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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 41 by fraynaud, Fri Jul 22 16:30:22 2011 UTC revision 938 by fmichon, Fri Nov 30 13:37:57 2012 UTC
# Line 2  Line 2 
2  //$Id$  //$Id$
3  //gen openMairie le 10/02/2011 20:32  //gen openMairie le 10/02/2011 20:32
4  require_once ("../gen/obj/consultation.class.php");  require_once ("../gen/obj/consultation.class.php");
5    require_once("../services/outgoing/messageenqueuer.php");
6    
7  class consultation extends consultation_gen {  class consultation extends consultation_gen {
8    
# Line 9  class consultation extends consultation_ Line 10  class consultation extends consultation_
10          $this->constructeur($id,$db,$debug);          $this->constructeur($id,$db,$debug);
11      }// fin constructeur      }// fin constructeur
12            
     function setValFAjout($val){  
         $this->valF['service'] = $val['service'];  
     }  
   
     function setvalF($val){  
         parent::setvalF($val);        
         // cles secondaires numerique (contrainte integrite  pgsql)  
         if(!is_numeric($val['avis'])) $this->valF['avis']= null;  
     }  
   
     function verifier(){  
         $this->correct=True;  
         $imgv="";  
         $f="&nbsp!    ";  
         $imgv="<img src='../img/punaise.png' style='vertical-align:middle' hspace='2' border='0'>";  
         if ($this->valF['service']==""){  
            $this->correct=false;  
            $this->msg= $this->msg.$imgv." "._("service")." ".  
            _("obligatoire").$f;  
         }  
         if ($this->valF['dossier']==""){  
            $this->correct=false;  
            $this->msg= $this->msg.$imgv." "._("dossier")." ".  
            _("obligatoire").$f;  
         }  
         if ($this->valF['date_envoi']==""){  
            $this->correct=false;  
            $this->msg= $this->msg.$imgv." "._("date_envoi")." ".  
            _("obligatoire").$f;  
         }  
     }  
   
13      function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){      function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
14          if ($validation==0) {          if ($validation==0) {
15              if ($maj == 0){              if ($maj == 0){
16                $form->setVal("dossier", $idxformulaire);                  $form->setVal("dossier", $idxformulaire);
17                    $form->setVal("date_envoi",date('d/m/Y'));
18                }
19                if($maj == 1) {
20                    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              }              }
25          }          }
26      }      }
27        
28        function setVal(&$form, $maj, $validation, &$db) {
29            if($maj == 1) {
30                 $form->setVal("date_retour",date('d/m/Y'));
31            }
32        }
33    
34      function setType(&$form,$maj) {      function setvalF($val) {
35          if ($maj < 2) { //ajouter et modifier [add and modify]          parent::setValF($val);
36              if($maj==0){ // add          if($this->getParameter('maj')==0) {
37                  $form->setType('date_envoi', 'date2');              $this->valF["date_reception"]=$this->valF["date_envoi"];
38                  $form->setType('service', 'select');          }
39                  $form->setType('date_limite', 'hidden');  
40                  $form->setType('date_retour', 'hidden');          // Si un retour d'avis est modifie on passe "lu" a false
41                  $form->setType('avis', 'hidden');          if($this->getParameter('maj')==1 AND (
42              }else{   // modify              $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
43                  $form->setType('date_envoi', 'hiddenstaticdate');              $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
44                  $form->setType('service', 'selectdisabled');              $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
45                  $form->setType('date_limite', 'date2');              $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
46                  $form->setType('date_retour', 'date2');          ) {
47                  $form->setType('avis', 'select');              $this->valF["lu"]=false;
48            }
49        }
50        
51        function verifier($val, &$db, $DEBUG) {
52            parent::verifier($val, $db, $DEBUG);
53            // Si le fichier envoye est different de l'existant
54            if (isset($this->val[array_search("fichier",$this->champs)])
55                && $this->val[array_search("fichier",$this->champs)] != $val["fichier"]
56                && $this->valF['fichier']!="") {
57                // 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                        unlink("../tmp/".$this->valF['fichier']);
70                        $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                        $this->correct = false;
75                        $this->addToMessage($res);
76                        unlink("../tmp/".$this->valF['fichier']);
77                        $this->valF['fichier']=$this->val[array_search("fichier",$this->champs)];
78                    }
79              }              }
             $form->setType('consultation', 'hiddenstatic');  
             $form->setType('dossier', 'hiddenstatic');  
         }else{ // supprimer  
             $form->setType('consultation', 'hiddenstatic');  
             $form->setType('dossier', 'hiddenstatic');  
80          }          }
81      }      }
82        
83        function setType(&$form,$maj) {
84            // Appel du parent
85            parent::setType($form,$maj);
86            // 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      function setTaille(&$form,$maj){              // On affiche en statique les informations qui ne sont plus
107          $form->setTaille('consultation', 8);              // modifiables
108          $form->setTaille('dossier', 12);              $form->setType('dossier', 'hiddenstatic');
109          $form->setTaille('service', 5);              $form->setType('date_envoi', 'hiddenstaticdate');
110          $form->setTaille('date_envoi', 12);              $form->setType('date_limite', 'hiddenstaticdate');
111          $form->setTaille('date_retour', 12);              $form->setType('service', 'selecthiddenstatic');
112          $form->setTaille('avis', 2);              
113          $form->setTaille('date_limite', 12);              // 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      function setMax(&$form,$maj){                  $form->setType('date_reception', 'date2');
117          $form->setMax('consultation', 8);              } else {
118          $form->setMax('dossier', 12);                  $form->setType('date_reception', 'hiddenstaticdate');
119          $form->setMax('service', 5);              }
         $form->setMax('date_envoi', 12);  
         $form->setMax('date_retour', 12);  
         $form->setMax('avis', 2);  
         $form->setMax('date_limite', 12);  
     }  
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                    $form->setType('fichier', 'tmpUploadStatic');
140                }
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                    $form->setType('date_limite', 'hidden');
153                    $form->setType('lu', 'hidden');
154    
155                }
156    
157            }
158            // MODE - CONSULTER
159            if ( $maj == 3 ) {
160                $form->setType('fichier', 'tmpUploadStatic');
161            }
162            //// On cache la clé primaire
163            //$form->setType('consultation', 'hidden');
164        }
165    
166      // TRIGGER AVANT MODIFICATION DE DONNEES      // TRIGGER AVANT MODIFICATION DE DONNEES
167      // trigger before modification data      // trigger before modification data
168      function triggerajouter($id,&$db,$val,$DEBUG) {      function triggerajouter($id,&$db,$val,$DEBUG) {
169          // mise a jour instruction avec evenement [return delay]          // mise a jour instruction avec evenement [return delay]
170          if (!$this->valF['date_envoi']==""){          if ($this->valF['date_envoi']!=""){
171              $sql= "select delai from service where service ='".$this->valF['service']."'";              $sql= "select delai from ".DB_PREFIXE."service where service ='".$this->valF['service']."'";
172              $delai = $db->getOne($sql);              $delai = $db->getOne($sql);
173              $this->valF['date_limite'] =  $this->moisdate($this->valF['date_envoi'],$delai);              $this->valF['date_limite'] =  $this->moisdate($this->valF['date_envoi'],$delai);
174              $this->msg=$this->msg."<br>"._("delai")." ".              $this->addToMessage(_("delai")." ".
175                 _("retour")." ".$delai." "._("mois")." -> ".                 _("retour")." ".$delai." "._("mois")." -> ".
176                 _("retour")." ".$this->valF['date_limite']."<br>";                 _("retour")." ".$this->valF['date_limite']."<br>");
177                $this->valF['lu'] = true;
178            }
179            
180        }
181        
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                _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
204                "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
205                _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
206                "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            // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
217            // deenvoie un
218            // message a ERP
219            $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            if ($dossier_erp == 't'
224                && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
225                // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
226                if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
227                    || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
228                    $msgenque = new MessageEnqueuer();
229                    $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
230                    $msgenque->setConsultationIdentifier($this->valF['consultation']);
231                    $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
232                }
233                
234                // envoi du message "Consultation ERP pour conformite" en cas de creation de la
235                // consultation du service ERP Conformite
236                if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
237                    $msgenque = new MessageEnqueuer();
238                    $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
239                    $msgenque->setConsultationIdentifier($this->valF['consultation']);
240                    $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);                
241                }
242            }
243            
244        }
245        
246        /**
247         * Fait une requette sql pour extraire la valeur d'un champ, et retourne
248         * cette valeur
249         * @param string $sql La requete sql a executer
250         * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
251         * l'execution s'arrete.
252         */
253        function getFromDB($sql) {
254            //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
255            $res = $this->db->limitquery($sql, 0, 1);
256            $this->addToLog("getDossierERPSpecification(): db->limitquery(\"".
257                            str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
258            // Si une erreur survient on die
259            if (database::isError($res, true)) {
260                // Appel de la methode de recuperation des erreurs
261                $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
262            }
263            // retourne la nature du dossier
264            while ($row =& $res->fetchRow()) {
265                return $row[0];
266          }          }
267            // la nature n'etait pas trouve, ce qui ne devrait pas se passer
268            return NULL;
269    
270        }
271    
272        
273        /**
274         * Returne la nature du dossier auquel la consultation appartient.
275         * @param string $dossier L'identifiant du dossier
276         * @return La nature du dossier si elle existe, sinon NULL. En cas
277         * d'erreur de la BD, l'execution se termine.
278         */
279        function getDossierNature($dossier) {
280            $sql = "SELECT nature FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
281            $res = $this->db->limitquery($sql, 0, 1);
282            $this->addToLog("getDossierNature(): db->limitquery(\"".str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
283            // Si une erreur survient on die
284            if (database::isError($res, true)) {
285                // Appel de la methode de recuperation des erreurs
286                $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'dossier');
287            }
288            // retourne la nature du dossier
289            while ($row =& $res->fetchRow()) {
290                return $row[0];
291            }
292            // la nature n'etait pas trouve, ce qui ne devrait pas se passer
293            return NULL;
294      }      }
295    
296      // =============================================      // =============================================
# Line 146  class consultation extends consultation_ Line 332  class consultation extends consultation_
332          return $annee."-".$mois."-".$jour ;          return $annee."-".$mois."-".$jour ;
333      }      }
334    
335        // =============================================
336        // Ajout du fielset
337        // Add fieldset
338        // =============================================
339        function setLayout(&$form, $maj){
340    
341                // Modification layout : écran de retour d'avis permettant
342                // uniquement la saisie des trois champs : avis, motivation et fichier
343                if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
344                    
345                    //Champs sur lequel s'ouvre le fieldset
346                    $form->setBloc('dossier','D',"");
347                    $form->setFieldset('dossier','D',_('Consultation'));
348        
349                    //Champs sur lequel se ferme le fieldset
350                    $form->setFieldset('date_envoi','F','');
351                    $form->setBloc('date_envoi','F');
352    
353                }
354                
355                // MODE - autre que AJOUTER alors on affiche un fieldset retour
356                // d'avis
357                if ($maj != 0) {
358                    
359                    //Champs sur lequel s'ouvre le fieldset
360                    $form->setBloc('date_reception','D',"");
361                    $form->setFieldset('date_reception','D',_('Retour d\'avis'));
362        
363                    //Champs sur lequel se ferme le fieldset
364                    $form->setFieldset('lu','F','');
365                    $form->setBloc('lu','F');
366                    
367                }
368        }
369    
370        /** Surcharge de la methode retour afin de retourner sur la page de saisie de
371        * code barre si besoin
372        **/
373        function retour($premier = 0, $recherche = "", $tricol = "") {
374            $params ="obj=".get_class($this);
375            if($this->getParameter("retour")=="form") {
376                $params .= "&amp;idx=".$this->getParameter("idx");
377                $params .= "&amp;action=3";
378            }
379            $params .= "&amp;premier=".$this->getParameter("premier");
380            $params .= "&amp;tricol=".$this->getParameter("tricol");
381            $params .= "&amp;recherche=".$this->getParameter("recherche");
382            $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
383            $params .= "&amp;advs_id=".$this->getParameter("advs_id");
384            $params .= "&amp;valide=".$this->getParameter("valide");
385            echo "\n<a class=\"retour\" ";
386            echo "href=\"";
387            //
388    
389            if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
390                echo "form.php?".$params;
391            } elseif($this->getParameter("retour")=="avis_code_barre") {
392                echo "../app/avis_code_barre.php";
393            } else {
394                echo "tab.php?".$params;
395            }
396            //
397            echo "\"";
398            echo ">";
399            //
400            echo _("Retour");
401            //
402            echo "</a>\n";
403        }
404        
405        /**
406         * Surcharge pour gérer les actions disponibles dans le portlet
407         */
408        function checkAccessibility() {
409            //
410            if (isset($this->actions_sup["lu"]) && $this->val[10] == "t") {
411                unset($this->actions_sup["lu"]);
412            }
413            //
414            parent::checkAccessibility();
415        }
416    
417        /**
418         * Méthode de verification d'accèssibilité de la consultation
419         * à l'utilisateur connecté
420         */
421        function canAccess() {
422            parent::canAccess();
423            if($this->f->isUserServiceExt()) {
424                // On compare l'id du service de la consultation
425                // aux id des services de utilisateur connecté
426                foreach($this->f->om_utilisateur['service'] as $service) {
427                    if($this->val[array_search("service",$this->champs)]===$service['service']) {
428                        return true;
429                    }
430                }
431                return false;
432            } else{
433                return true;
434            }
435        }
436    
437        /**
438         * Surcharge du bouton retour pour popup
439         */
440            function retoursousformulaire($idxformulaire, $retourformulaire, $val,
441                                      $objsf, $premiersf, $tricolsf, $validation,
442                                      $idx, $maj, $retour) {
443            if($retourformulaire === "demande_avis_encours") {
444                echo "\n<a class=\"retour\" ";
445                echo "href=\"";
446                echo "#";
447                echo  "\" ";
448                echo ">";
449                //
450                echo _("Retour");
451                //
452                echo "</a>\n";
453            } else {
454                parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
455                                      $objsf, $premiersf, $tricolsf, $validation,
456                                      $idx, $maj, $retour);
457            }
458        }
459  }// fin classe  }// fin classe
 ?>  
460    ?>

Legend:
Removed from v.41  
changed lines
  Added in v.938

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26