/[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 497 by vpihour, Fri Oct 12 15:35:11 2012 UTC revision 843 by mlimic, Tue Nov 27 15:30:42 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          var $maj;  
9      function consultation($id,&$db,$debug) {      function consultation($id,&$db,$debug) {
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($val['avis_consultation']=='') $this->valF['avis_consultation']= null;  
     }  
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'));                  $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              }              }
                         else  
                                 if ( $maj == 1 )  
                                         $form->setVal("date_retour",date('d/m/Y'));  
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 setvalF($val) {
35            parent::setValF($val);
36            if($this->getParameter('maj')==0) {
37                $this->valF["date_reception"]=$this->valF["date_envoi"];
38            }
39    
40            // Si un retour d'avis est modifie on passe "lu" a false
41            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                $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
46            ) {
47                $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                }
80            }
81        }
82        
83      function setType(&$form,$maj) {      function setType(&$form,$maj) {
84            // Appel du parent
85          parent::setType($form,$maj);          parent::setType($form,$maj);
86          if ($maj < 2) { //ajouter et modifier [add and modify]          // MODE - AJOUTER
87              if($maj==0){ // add          if ($maj == 0) {
88                  $form->setType('date_envoi', 'date2');              // On cache alors tous les champs que nous ne voulons pas voir
89                  $form->setType('service', 'select');              // apparaître dans le formulaire d'ajout (principalement les
90                  $form->setType('date_limite', 'hidden');              // 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                    $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');                  $form->setType('date_retour', 'hidden');
151                  $form->setType('avis_consultation', 'hidden');                  $form->setType('date_reception', 'hidden');
152                                  $form->setType('motivation', 'hidden');                  $form->setType('date_limite', 'hidden');
153                                  $form->setType('fichier', 'hidden');                  $form->setType('lu', 'hidden');
154                                  $form->setType('lu', 'hidden');  
                                 $form->setType('date_reception', 'hidden');  
             }else{   // modify  
                 $form->setType('date_envoi', 'hiddenstaticdate');  
                                 $form->setType('date_limite', 'hiddenstaticdate');  
                 $form->setType('service', 'selectdisabled');  
                 $form->setType('date_retour', 'date2');  
                 $form->setType('avis_consultation', 'select');  
                                 $form->setType('motivation', 'textarea');  
                                 $form->setType('fichier', 'upload');  
155              }              }
156              $form->setType('consultation', 'hiddenstatic');  
             $form->setType('dossier', 'hiddenstatic');  
157          }          }
158                  else {          // MODE - CONSULTER
159              $form->setType('date_limite', 'hidden');          if ( $maj == 3 ) {
160              $form->setType('date_retour', 'hidden');              $form->setType('fichier', 'tmpUploadStatic');
161              $form->setType('avis_consultation', 'hidden');          }
162                          $form->setType('motivation', 'hidden');          //// On cache la clé primaire
163                          $form->setType('fichier', 'hidden');          //$form->setType('consultation', 'hidden');
                         $form->setType('lu', 'hidden');  
                         $form->setType('date_reception', '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 ".DB_PREFIXE."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;              $this->valF['lu'] = true;
178                                    }
179                          /*require("../php/phpmailer/class.phpmailer.php");          
180        }
181                          $mail = new PHPMailer();      
182                                function triggerajouterapres($id,&$db,$val,$DEBUG) {
183                          $mail->IsSMTP();                                      // set mailer to use SMTP          
184                          $mail->Host = "smtp.gmail.com";  // specify main and backup server          // Verification de la demande de notif par mail
185                          $mail->SMTPAuth = true;     // turn on SMTP authentication          $sql= "SELECT abrege, notification_email, email FROM ".DB_PREFIXE.
186                          $mail->Username = "";  // SMTP username                  "service WHERE service ='".$this->valF['service']."'";
187                          $mail->Password = ""; // SMTP password          $res=$db->query($sql);
188                                    $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
189                          $mail->From = "[email protected]";          if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
190                          $mail->FromName = "Mailer";          if ($notif['notification_email']=='t') {
191                          $mail->AddAddress("[email protected]", "Vi");              
192                          $mail->AddReplyTo("[email protected]", "Information");              // Recuperation des infos du dossier
193                                        $sql= "SELECT dossier, terrain_adresse, terrain_adresse_complement, terrain_cp, terrain_ville
194                          $mail->WordWrap = 50;                                 // set word wrap to 50 characters                      FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
195                          $mail->IsHTML(true);                                  // set email format to HTML              $res=$db->query($sql);
196                                        $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
197                          $mail->Subject = "Here is the subject";              
198                          $mail->Body    = "This is the HTML message body <b>in bold!</b>";              // Definition des parametres d'envoi du mail
199                          $mail->AltBody = "This is the body in plain text for non-HTML mail clients";              $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
200                                        $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
201                          if(!$mail->Send())              _("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                             echo "Message could not be sent. <p>";              _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
204                             echo "Mailer Error: " . $mail->ErrorInfo;              "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
205                             exit;              _("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                          echo "Message has been sent";*/              // 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 ou ERP Accessibilite envoie un
217            // message a ERP
218            if ($this->isDossierPC($this->valF['dossier']) == 'PC'
219                && ($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
220                || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
221                $msgenque = new MessageEnqueuer();
222                $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
223                $msgenque->setConsultationIdentifier($this->valF['consultation']);
224                $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
225          }          }
226            
227        }
228        
229        
230        function isDossierPC($dossier) {
231            $sql = "SELECT nature FROM dossier WHERE dossier = '" . $dossier . "'";
232            $res = $this->db->limitquery($sql, 0, 1);
233            $this->addToLog("isDossierPC(): db->limitquery(\"".str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
234            // Si une erreur survient on die
235            if (database::isError($res, true)) {
236                // Appel de la methode de recuperation des erreurs
237                $this->erreur_db($res->getDebugInfo(), $res->getMessage(), $tableSelect);
238            }
239            // retourne la nature du dossier
240            while ($row =& $res->fetchRow()) {
241                return $row[0];
242            }
243            // la nature n'etait pas trouve, ce qui ne devrait pas se passer
244            return NULL;
245      }      }
246    
247      // =============================================      // =============================================
# Line 150  class consultation extends consultation_ Line 283  class consultation extends consultation_
283          return $annee."-".$mois."-".$jour ;          return $annee."-".$mois."-".$jour ;
284      }      }
285    
286          // =============================================      // =============================================
287      // Ajout du fielset      // Ajout du fielset
288      // Add fieldset      // Add fieldset
289      // =============================================      // =============================================
290          function setLayout(&$form, $maj){      function setLayout(&$form, $maj){
291                  if ( $maj < 2 ) {  
292                          //Champs sur lequel s'ouvre le fieldset              // Modification layout : écran de retour d'avis permettant
293                          $form->setBloc('dossier','D',"");              // uniquement la saisie des trois champs : avis, motivation et fichier
294                          $form->setFieldset('dossier','D',_('Consultation'));              if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
295                            
296                          //Champs sur lequel se ferme le fieldset                  //Champs sur lequel s'ouvre le fieldset
297                          $form->setFieldset('date_envoi','F','');                  $form->setBloc('dossier','D',"");
298                          $form->setBloc('date_envoi','F');                  $form->setFieldset('dossier','D',_('Consultation'));
299                          if ( $maj == 1 ){      
300                                  //Champs sur lequel s'ouvre le fieldset                  //Champs sur lequel se ferme le fieldset
301                                  $form->setBloc('date_reception','D',"");                  $form->setFieldset('date_envoi','F','');
302                                  $form->setFieldset('date_reception','D',_('Retour d\'avis'));                  $form->setBloc('date_envoi','F');
303                    
304                                  //Champs sur lequel se ferme le fieldset              }
305                                  $form->setFieldset('lu','F','');              
306                                  $form->setBloc('lu','F');              // MODE - autre que AJOUTER alors on affiche un fieldset retour
307                          }              // d'avis
308                  }              if ($maj != 0) {
309                                            
310          }                  //Champs sur lequel s'ouvre le fieldset
311                            $form->setBloc('date_reception','D',"");
312          function setSelect(&$form, $maj,&$db,$debug) {                  $form->setFieldset('date_reception','D',_('Retour d\'avis'));
313          parent::setSelect($form, $maj,$db,$debug);      
314                  if(file_exists ("../sql/".$db->phptype."/".$this->table.".form.inc.php"))                  //Champs sur lequel se ferme le fieldset
315                  include ("../sql/".$db->phptype."/".$this->table.".form.inc.php");                  $form->setFieldset('lu','F','');
316          if($maj<2){                  $form->setBloc('lu','F');
317              $contenu=array();                  
318              $sql = " SELECT service, abrege, libelle FROM ".DB_PREFIXE."service";              }
319                          $res = $db->query($sql);      }
320                          if (database::isError($res))  
321                  die($res->getMessage());      /** Surcharge de la methode retour afin de retourner sur la page de saisie de
322                          $contenu[0][0]="";      * code barre si besoin
323                  $contenu[1][0]=_('choisir')." "._('service');      **/
324                          $k=1;      function retour($premier = 0, $recherche = "", $tricol = "") {
325                  while ($row=& $res->fetchRow()){          $params ="obj=".get_class($this);
326                      if($maj==0){ // ajouter          if($this->getParameter("retour")=="form") {
327                          $contenu[0][$k]=$row[0];              $params .= "&amp;idx=".$this->getParameter("idx");
328                          $contenu[1][$k]=$row[1]." ".$row[2];              $params .= "&amp;action=3";
329                          $k++;          }
330                      }else{          $params .= "&amp;premier=".$this->getParameter("premier");
331                          // select hiddenstatic          $params .= "&amp;tricol=".$this->getParameter("tricol");
332                          $contenu[0][$k]=$row[0];          $params .= "&amp;recherche=".$this->getParameter("recherche");
333                          $contenu[1][$k]=$row[1]." ".$row[2];          $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
334                          $k++;          $params .= "&amp;advs_id=".$this->getParameter("advs_id");
335                      }          $params .= "&amp;valide=".$this->getParameter("valide");
336                  }          echo "\n<a class=\"retour\" ";
337                  $form->setSelect("service",$contenu);          echo "href=\"";
338                  }          //
339          }  
340                    if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
341          //Formatage des intitulés des champs.              echo "form.php?".$params;
342          function setLib(&$form,$maj) {          } elseif($this->getParameter("retour")=="avis_code_barre") {
343          parent::setLib($form,$maj);              echo "../app/avis_code_barre.php";
344                  $form->setLib('date_reception','date de reception');          } else {
345                  $form->setLib('avis_consultation','avis');              echo "tab.php?".$params;
346                  $form->setLib('fichier','retour d\'avis');          }
347      }          //
348            echo "\"";
349            echo ">";
350            //
351            echo _("Retour");
352            //
353            echo "</a>\n";
354        }
355        
356        /**
357         * Méthode de verification d'accèssibilité de la consultation
358         * à l'utilisateur connecté
359         */
360        function canAccess() {
361            parent::canAccess();
362            if($this->f->isUserServiceExt()) {
363                // On compare l'id du service de la consultation
364                // aux id des services de utilisateur connecté
365                foreach($this->f->om_utilisateur['service'] as $service) {
366                    if($this->val[array_search("service",$this->champs)]===$service['service']) {
367                        return true;
368                    }
369                }
370                return false;
371            } else{
372                return true;
373            }
374        }
375    
376        /**
377         * Surcharge du bouton retour pour popup
378         */
379            function retoursousformulaire($idxformulaire, $retourformulaire, $val,
380                                      $objsf, $premiersf, $tricolsf, $validation,
381                                      $idx, $maj, $retour) {
382            if($retourformulaire === "demande_avis_encours") {
383                echo "\n<a class=\"retour\" ";
384                echo "href=\"";
385                echo "#";
386                echo  "\" ";
387                echo ">";
388                //
389                echo _("Retour");
390                //
391                echo "</a>\n";
392            } else {
393                parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
394                                      $objsf, $premiersf, $tricolsf, $validation,
395                                      $idx, $maj, $retour);
396            }
397        }
398  }// fin classe  }// fin classe
 ?>  
399    ?>

Legend:
Removed from v.497  
changed lines
  Added in v.843

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26