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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 936 - (hide annotations)
Fri Nov 30 13:20:10 2012 UTC (12 years, 2 months ago) by mlimic
File size: 19780 byte(s)
Ajout d'envoi des messages "Decision de conformite effectue" et "Consultation ERP pour conformite"

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26