/[openfoncier]/branches/3.2.0-ax/obj/consultation.class.php
ViewVC logotype

Annotation of /branches/3.2.0-ax/obj/consultation.class.php

Parent Directory Parent Directory | Revision Log Revision Log


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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26