/[openfoncier]/trunk/obj/consultation.class.php
ViewVC logotype

Annotation of /trunk/obj/consultation.class.php

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1164 - (hide annotations)
Mon Jan 7 19:33:46 2013 UTC (12 years ago) by fmichon
File size: 23443 byte(s)
Changement du format de la date pour un affichage plus lisible

1 fraynaud 3 <?php
2     //$Id$
3     //gen openMairie le 10/02/2011 20:32
4     require_once ("../gen/obj/consultation.class.php");
5 mlimic 843 require_once("../services/outgoing/messageenqueuer.php");
6 fraynaud 3
7     class consultation extends consultation_gen {
8 nhaye 601
9 fraynaud 20 function consultation($id,&$db,$debug) {
10     $this->constructeur($id,$db,$debug);
11     }// fin constructeur
12 fmichon 943
13     // {{{ Gestion de la confidentialité des données spécifiques
14    
15     /**
16     * Surcharge pour gérer les actions disponibles dans le portlet
17     */
18     function checkAccessibility() {
19     //
20     parent::checkAccessibility();
21     // Si l'utilisateur est un intructeur qui en correspond pas à la
22     // division du dossier
23     if ($this->f->isUserInstructeur()
24     && isset($this->f->om_utilisateur["division"])
25     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
26     //
27     $this->actions_sup = array();
28     $this->setParameter("actions", array());
29     }
30     // Si une action 'lu' est présente et que le champ lu est à true
31     // on supprime l'action
32     if (isset($this->actions_sup["lu"])
33     && isset($this->val[array_search("lu", $this->champs)])
34     && $this->val[array_search("lu", $this->champs)]== "t") {
35     unset($this->actions_sup["lu"]);
36     }
37     }
38    
39     /**
40     * Cette methode est à surcharger elle permet de tester dans chaque classe
41     * des droits des droits spécifiques en fonction des données
42     */
43     function canAccess() {
44     // Si l'utilisateur est un utilisateur de service externe
45     // on vérifie qu'il peut accéder à la consultation
46     if ($this->f->isUserServiceExt()) {
47     // On compare l'id du service de la consultation
48     // aux id des services de utilisateur connecté
49     foreach($this->f->om_utilisateur['service'] as $service) {
50     if($this->val[array_search("service",$this->champs)]===$service['service']) {
51     return true;
52     }
53     }
54 fmichon 1088 //
55     $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
56 fmichon 943 return false;
57     }
58     // Si l'utilisateur est un intructeur qui ne correspond pas à la
59     // division du dossier
60     if ($this->f->isUserInstructeur()
61     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
62     && $this->getParameter("maj") != 3) {
63     //
64 fmichon 1088 $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
65 fmichon 943 return false;
66     }
67     //
68     return true;
69     }
70    
71     /**
72     * Cette méthode permet de récupérer la division d'un dossier
73     */
74     function getDivisionFromDossier() {
75 fmichon 1088 // Si on se trouve en mode MODIFIER ou SUPPRIMER ou CONSULTER alors on
76     // récupère le numéro de dossier dans la consultation et on en retourne
77     // sa division
78     if ($this->getParameter("maj") == 1 || $this->getParameter("maj") == 2
79     || $this->getParameter("maj") == 3) {
80     //
81     if (!isset($this->val[array_search("dossier", $this->champs)])) {
82     return NULL;
83     }
84     //
85     $sql = "select division from ".DB_PREFIXE."dossier ";
86     $sql .= " where dossier='".$this->val[array_search("dossier", $this->champs)]."'";
87     //
88     $division = $this->db->getOne($sql);
89     $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
90     database::isError($division);
91     //
92     return $division;
93     } elseif ($this->getParameter("maj") == 0
94     && ($this->getParameter("retourformulaire") == "dossier"
95     || $this->getParameter("retourformulaire") == "dossier_instruction"
96     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
97     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
98     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
99     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
100     // Si on se trouve en mode AJOUTER et en sous formulaire alors on
101     // récupère le numéro de dossier dans les paramètres de sous
102     // formulaires et on en retourne sa division
103     $sql = "select division from ".DB_PREFIXE."dossier ";
104     $sql .= " where dossier='".$this->getParameter("idxformulaire")."'";
105     //
106     $division = $this->db->getOne($sql);
107     $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
108     database::isError($division);
109     //
110     return $division;
111     } else {
112 fmichon 943 return NULL;
113     }
114 fmichon 1088
115 fmichon 943 }
116    
117     // }}}
118    
119 fraynaud 20 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
120     if ($validation==0) {
121     if ($maj == 0){
122 nhaye 569 $form->setVal("dossier", $idxformulaire);
123     $form->setVal("date_envoi",date('d/m/Y'));
124 fraynaud 20 }
125 nhaye 587 if($maj == 1) {
126 nhaye 594 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
127     $this->f->isAccredited('consultation_retour_avis_service')) {
128     $form->setVal("date_retour",date('d/m/Y'));
129     }
130 nhaye 587 }
131 fraynaud 20 }
132     }
133 nhaye 587
134     function setVal(&$form, $maj, $validation, &$db) {
135     if($maj == 1) {
136     $form->setVal("date_retour",date('d/m/Y'));
137     }
138     }
139 fraynaud 20
140 nhaye 561 function setvalF($val) {
141     parent::setValF($val);
142 nhaye 598 if($this->getParameter('maj')==0) {
143 nhaye 587 $this->valF["date_reception"]=$this->valF["date_envoi"];
144     }
145 nhaye 598
146 nhaye 561 // Si un retour d'avis est modifie on passe "lu" a false
147 nhaye 598 if($this->getParameter('maj')==1 AND (
148     $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
149     $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
150     $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
151 nhaye 674 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
152 nhaye 598 ) {
153     $this->valF["lu"]=false;
154 nhaye 561 }
155 nhaye 675 }
156    
157     function verifier($val, &$db, $DEBUG) {
158     parent::verifier($val, $db, $DEBUG);
159 nhaye 638 // Si le fichier envoye est different de l'existant
160 fmichon 665 if (isset($this->val[array_search("fichier",$this->champs)])
161     && $this->val[array_search("fichier",$this->champs)] != $val["fichier"]
162     && $this->valF['fichier']!="") {
163 nhaye 638 // Si le fichier existe dans tmp
164     if(file_exists("../tmp/".$this->valF['fichier'])) {
165     $contents=file_get_contents("../tmp/".$this->valF['fichier']);
166     // On essaye de l'enregistrer
167     $res = $this->f->storeDecisionFile($contents, $this->valF['fichier'],
168     $this->valF['dossier'],
169     'consultation_'.$this->valF['consultation']."_");
170     // Si l'enregistrement s'est bien deroule
171     // on supprime le fichier dans tmp
172     // on met a jour valF avec le nouveau nom du fichier
173     if($res===true){
174     $this->addToMessage(_("Sauvegarde du fichier reussi"));
175 nhaye 637 unlink("../tmp/".$this->valF['fichier']);
176 nhaye 638 $this->valF['fichier']='consultation_'.$this->valF['consultation']."_".$this->valF['fichier'];
177     // Sinon on supprime le fichier dans tmp
178     // on reinitialise le nom du fichier a l'ancienne valeur
179     } else {
180 nhaye 675 $this->correct = false;
181 nhaye 638 $this->addToMessage($res);
182     unlink("../tmp/".$this->valF['fichier']);
183     $this->valF['fichier']=$this->val[array_search("fichier",$this->champs)];
184 nhaye 637 }
185     }
186     }
187 nhaye 561 }
188    
189 fraynaud 20 function setType(&$form,$maj) {
190 fmichon 671 // Appel du parent
191 nhaye 459 parent::setType($form,$maj);
192 fmichon 671 // MODE - AJOUTER
193     if ($maj == 0) {
194     // On cache alors tous les champs que nous ne voulons pas voir
195     // apparaître dans le formulaire d'ajout (principalement les
196     // informations sur le retour d'avis)
197     $form->setType('date_retour', 'hidden');
198     $form->setType('date_reception', 'hidden');
199     $form->setType('date_limite', 'hidden');
200     $form->setType('avis_consultation', 'hidden');
201     $form->setType('motivation', 'hidden');
202     $form->setType('fichier', 'hidden');
203     $form->setType('lu', 'hidden');
204     // On permet la modification de certains champs
205     $form->setType('dossier', 'hiddenstatic');
206     $form->setType('service', 'select');
207     $form->setType('date_envoi', 'date2');
208     }
209     // MODE - MODIFIER
210     if ($maj == 1) {
211    
212     // On affiche en statique les informations qui ne sont plus
213     // modifiables
214     $form->setType('dossier', 'hiddenstatic');
215     $form->setType('date_envoi', 'hiddenstaticdate');
216     $form->setType('date_limite', 'hiddenstaticdate');
217     $form->setType('service', 'selecthiddenstatic');
218    
219     // La date de réception ne peut être modifiée que par un
220     // utilisateur en ayant spécifiquement la permission
221     if($this->f->isAccredited('consultation_modifier_date_reception')) {
222     $form->setType('date_reception', 'date2');
223     } else {
224     $form->setType('date_reception', 'hiddenstaticdate');
225     }
226    
227     // Le marqueur lu/non lu ne peut être modifié que par un
228     // utilisateur en ayant spécifiquement la permission
229     if ($this->f->isAccredited('consultation_modifier_lu')) {
230     $form->setType('lu', 'checkbox');
231     } else {
232     $form->setType('lu', 'hidden');
233     }
234    
235     // Gestion du type du widget sur le champ fichier
236     if($this->val[array_search("fichier",$this->champs)]=="" OR
237     $this->f->isAccredited('consultation_modifier_fichier')) {
238     // Si il n'y a jamais eu de fichier enregistré ou que
239     // l'utilisateur a spécifiquement les droits pour modifier
240     // un fichier déjà enregistré alors on positionne un type
241     // de widget modifiable
242     $form->setType('fichier', 'tmpUpload');
243     } else {
244     // Si non on affiche uniquement le nom du fichier
245 nhaye 674 $form->setType('fichier', 'tmpUploadStatic');
246 fmichon 671 }
247    
248     // Modification layout : écran de retour d'avis permettant
249     // uniquement la saisie des trois champs : avis, motivation et fichier
250     if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
251    
252     // On cache alors tous les champs que nous ne voulons pas voir
253     $form->setType('dossier', 'hidden');
254     $form->setType('service', 'hidden');
255     $form->setType('date_envoi', 'hidden');
256     $form->setType('date_retour', 'hidden');
257     $form->setType('date_reception', 'hidden');
258 fraynaud 20 $form->setType('date_limite', 'hidden');
259 nhaye 561 $form->setType('lu', 'hidden');
260 fmichon 671
261 fraynaud 20 }
262 fmichon 671
263 fraynaud 20 }
264 nhaye 674 // MODE - CONSULTER
265     if ( $maj == 3 ) {
266     $form->setType('fichier', 'tmpUploadStatic');
267     }
268 fmichon 671 //// On cache la clé primaire
269     //$form->setType('consultation', 'hidden');
270 fraynaud 20 }
271    
272     // TRIGGER AVANT MODIFICATION DE DONNEES
273     // trigger before modification data
274     function triggerajouter($id,&$db,$val,$DEBUG) {
275     // mise a jour instruction avec evenement [return delay]
276 nhaye 532 if ($this->valF['date_envoi']!=""){
277 fraynaud 242 $sql= "select delai from ".DB_PREFIXE."service where service ='".$this->valF['service']."'";
278 fraynaud 41 $delai = $db->getOne($sql);
279     $this->valF['date_limite'] = $this->moisdate($this->valF['date_envoi'],$delai);
280 nhaye 532 $this->addToMessage(_("delai")." ".
281 fraynaud 41 _("retour")." ".$delai." "._("mois")." -> ".
282 fmichon 1164 _("retour")." ".date("d/m/Y", strtotime($this->valF['date_limite']))."<br>");
283 nhaye 532 $this->valF['lu'] = true;
284 fraynaud 41 }
285 nhaye 532
286 fraynaud 20 }
287 nhaye 532
288     function triggerajouterapres($id,&$db,$val,$DEBUG) {
289    
290     // Verification de la demande de notif par mail
291     $sql= "SELECT abrege, notification_email, email FROM ".DB_PREFIXE.
292     "service WHERE service ='".$this->valF['service']."'";
293     $res=$db->query($sql);
294     $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
295     if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
296     if ($notif['notification_email']=='t') {
297    
298     // Recuperation des infos du dossier
299     $sql= "SELECT dossier, terrain_adresse, terrain_adresse_complement, terrain_cp, terrain_ville
300     FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
301     $res=$db->query($sql);
302     $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
303    
304     // Definition des parametres d'envoi du mail
305     $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
306     $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
307     _("Il concerne le terrain situe a l'adresse :")." ".utf8_decode($dossier['terrain_adresse']).
308     " ".utf8_decode($dossier['terrain_adresse_complement'])." ".utf8_decode($dossier['terrain_cp'])." ".$dossier['terrain_ville']."<br/>".
309 fmichon 668 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
310 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
311 fmichon 668 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
312 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
313     _("Lien externe (hors VDM)")."</a>";
314     // Envoi du mail avec message de retour
315     if($this->f->sendMail($title, $corps, $notif['email'])) {
316     $this->addToMessage(_("Envoi d'un mail de notification au service")." ".$notif['abrege']);
317     } else {
318     $this->addToMessage(_("L'envoi du mail de notification a echoue"));
319     }
320     }
321    
322 fmichon 1005
323     // verification si envoi vers ERP est active
324     if ($this->f->getParameter('option_erp') != "") {
325     // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
326     // deenvoie un
327     // message a ERP
328     $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
329     "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
330 nhaye 1140 $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
331     "dossier
332     INNER JOIN ".DB_PREFIXE."dossier_autorisation
333     ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
334     INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
335     ON dossier_autorisation.dossier_autorisation_type_detaille
336     = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
337     WHERE dossier = '" . $this->valF['dossier'] . "'");
338 fmichon 1005 if ($dossier_erp == 't'
339     && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
340     // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
341     if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
342     || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
343     $msgenque = new MessageEnqueuer();
344     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
345     $msgenque->setConsultationIdentifier($this->valF['consultation']);
346     $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
347     }
348    
349     // envoi du message "Consultation ERP pour conformite" en cas de creation de la
350     // consultation du service ERP Conformite
351     if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
352     $msgenque = new MessageEnqueuer();
353     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
354     $msgenque->setConsultationIdentifier($this->valF['consultation']);
355     $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
356     }
357 mlimic 936 }
358 fmichon 1005 } // fin de if($this->f->getParameter('option_erp'))
359 nhaye 532 }
360 mlimic 843
361 mlimic 936 /**
362     * Fait une requette sql pour extraire la valeur d'un champ, et retourne
363     * cette valeur
364     * @param string $sql La requete sql a executer
365     * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
366     * l'execution s'arrete.
367     */
368     function getFromDB($sql) {
369     //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
370     $res = $this->db->limitquery($sql, 0, 1);
371     $this->addToLog("getDossierERPSpecification(): db->limitquery(\"".
372     str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
373     // Si une erreur survient on die
374     if (database::isError($res, true)) {
375     // Appel de la methode de recuperation des erreurs
376     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
377     }
378     // retourne la nature du dossier
379     while ($row =& $res->fetchRow()) {
380     return $row[0];
381     }
382     // la nature n'etait pas trouve, ce qui ne devrait pas se passer
383     return NULL;
384    
385     }
386    
387 fraynaud 20 // =============================================
388     // calcul de date avec ajout de mois (delais)
389     // [add months (delay) and calculation final date]
390     // limite ? => voir fonction instruction
391     // =============================================
392     function moisdate($date,$delaimois) {
393     // rajout de mois à une date (moins de 12)
394     $temp = explode("-" , $date);
395     $jour = (int) $temp[2];
396     $mois = (int) $temp[1];
397     $annee = (int) $temp[0];
398     $mois=$mois+$delaimois;
399     // calcul mois annee
400     if($mois>12){
401     $mois=$mois-12;
402     $annee=$annee+1;
403     }
404     // Calcul du nombre de jours dans le mois sélectionné
405     switch($mois) {
406     case "2":
407     if ($annee % 4 == 0 && $annee % 100 != 0 || $annee % 400 == 0)
408     $jourmax = 29;
409     else
410     $jourmax = 28;
411     break;
412     case "4":
413     case "6":
414     case "9":
415     case "11":
416     $jourmax = 30;
417     break;
418     default:
419     $jourmax = 31;
420     }
421     if ($jour > $jourmax)
422     $jour = $jourmax;
423     return $annee."-".$mois."-".$jour ;
424     }
425 vpihour 497
426 nhaye 569 // =============================================
427 vpihour 497 // Ajout du fielset
428     // Add fieldset
429     // =============================================
430 nhaye 569 function setLayout(&$form, $maj){
431 fmichon 671
432     // Modification layout : écran de retour d'avis permettant
433     // uniquement la saisie des trois champs : avis, motivation et fichier
434     if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
435    
436 nhaye 569 //Champs sur lequel s'ouvre le fieldset
437     $form->setBloc('dossier','D',"");
438     $form->setFieldset('dossier','D',_('Consultation'));
439    
440     //Champs sur lequel se ferme le fieldset
441     $form->setFieldset('date_envoi','F','');
442     $form->setBloc('date_envoi','F');
443 fmichon 671
444 nhaye 569 }
445 fmichon 671
446     // MODE - autre que AJOUTER alors on affiche un fieldset retour
447     // d'avis
448     if ($maj != 0) {
449    
450 nhaye 569 //Champs sur lequel s'ouvre le fieldset
451     $form->setBloc('date_reception','D',"");
452     $form->setFieldset('date_reception','D',_('Retour d\'avis'));
453 fmichon 671
454 nhaye 569 //Champs sur lequel se ferme le fieldset
455     $form->setFieldset('lu','F','');
456     $form->setBloc('lu','F');
457 fmichon 671
458 nhaye 569 }
459     }
460 nhaye 595
461     /** Surcharge de la methode retour afin de retourner sur la page de saisie de
462     * code barre si besoin
463     **/
464     function retour($premier = 0, $recherche = "", $tricol = "") {
465     $params ="obj=".get_class($this);
466     if($this->getParameter("retour")=="form") {
467     $params .= "&amp;idx=".$this->getParameter("idx");
468     $params .= "&amp;action=3";
469     }
470     $params .= "&amp;premier=".$this->getParameter("premier");
471     $params .= "&amp;tricol=".$this->getParameter("tricol");
472     $params .= "&amp;recherche=".$this->getParameter("recherche");
473     $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
474     $params .= "&amp;advs_id=".$this->getParameter("advs_id");
475     $params .= "&amp;valide=".$this->getParameter("valide");
476     echo "\n<a class=\"retour\" ";
477     echo "href=\"";
478     //
479    
480     if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
481     echo "form.php?".$params;
482     } elseif($this->getParameter("retour")=="avis_code_barre") {
483     echo "../app/avis_code_barre.php";
484     } else {
485     echo "tab.php?".$params;
486     }
487     //
488     echo "\"";
489     echo ">";
490     //
491     echo _("Retour");
492     //
493     echo "</a>\n";
494     }
495 fmichon 938
496     /**
497 nhaye 802 * Surcharge du bouton retour pour popup
498     */
499     function retoursousformulaire($idxformulaire, $retourformulaire, $val,
500     $objsf, $premiersf, $tricolsf, $validation,
501     $idx, $maj, $retour) {
502     if($retourformulaire === "demande_avis_encours") {
503     echo "\n<a class=\"retour\" ";
504     echo "href=\"";
505     echo "#";
506     echo "\" ";
507     echo ">";
508     //
509     echo _("Retour");
510     //
511     echo "</a>\n";
512     } else {
513     parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
514     $objsf, $premiersf, $tricolsf, $validation,
515     $idx, $maj, $retour);
516     }
517     }
518 fraynaud 3 }// fin classe
519 nhaye 509 ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26