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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1949 - (hide annotations)
Wed May 29 15:42:34 2013 UTC (11 years, 8 months ago) by nhaye
File size: 33962 byte(s)
Ajout de commentaires

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 nhaye 1917 var $abstract_type = array(
10     "fichier" => "file",
11     );
12    
13 nhaye 1935 var $metadata = array(
14 nhaye 1938 "om_fichier_consultation" => array(
15 nhaye 1935 "dossier" => "getDossier",
16     "dossier_autorisation" => "getDossierAutorisation",
17     "date_demande_initiale" => "getDateDemandeInitiale",
18     "dossier_instruction_type" => "getDossierInstructionType",
19     "statut" => "getStatut",
20     "dossier_autorisation_type" => "getDossierAutorisationType",
21     "date_creation" => "getDateEvenement",
22     "groupe_instruction" => 'getGroupeInstruction',
23     ),
24     );
25    
26 fraynaud 20 function consultation($id,&$db,$debug) {
27     $this->constructeur($id,$db,$debug);
28     }// fin constructeur
29 fmichon 943
30     // {{{ Gestion de la confidentialité des données spécifiques
31    
32     /**
33     * Surcharge pour gérer les actions disponibles dans le portlet
34     */
35     function checkAccessibility() {
36     //
37     parent::checkAccessibility();
38     // Si l'utilisateur est un intructeur qui en correspond pas à la
39     // division du dossier
40     if ($this->f->isUserInstructeur()
41     && isset($this->f->om_utilisateur["division"])
42     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
43     //
44     $this->actions_sup = array();
45     $this->setParameter("actions", array());
46     }
47     // Si une action 'lu' est présente et que le champ lu est à true
48     // on supprime l'action
49     if (isset($this->actions_sup["lu"])
50     && isset($this->val[array_search("lu", $this->champs)])
51     && $this->val[array_search("lu", $this->champs)]== "t") {
52     unset($this->actions_sup["lu"]);
53     }
54     }
55    
56     /**
57     * Cette methode est à surcharger elle permet de tester dans chaque classe
58     * des droits des droits spécifiques en fonction des données
59     */
60     function canAccess() {
61     // Si l'utilisateur est un utilisateur de service externe
62     // on vérifie qu'il peut accéder à la consultation
63     if ($this->f->isUserServiceExt()) {
64     // On compare l'id du service de la consultation
65     // aux id des services de utilisateur connecté
66     foreach($this->f->om_utilisateur['service'] as $service) {
67     if($this->val[array_search("service",$this->champs)]===$service['service']) {
68     return true;
69     }
70     }
71 fmichon 1088 //
72     $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
73 fmichon 943 return false;
74     }
75     // Si l'utilisateur est un intructeur qui ne correspond pas à la
76     // division du dossier
77     if ($this->f->isUserInstructeur()
78     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
79     && $this->getParameter("maj") != 3) {
80     //
81 fmichon 1088 $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
82 fmichon 943 return false;
83     }
84     //
85     return true;
86     }
87    
88     /**
89 fmichon 1908 * Cette variable permet de stocker le résultat de la méthode
90     * getDivisionFromDossier() afin de ne pas effectuer le recalcul à chacun de
91     * ces appels.
92     * @var string Code de la division du dossier en cours
93 fmichon 943 */
94 fmichon 1908 var $_division_from_dossier = NULL;
95    
96     /**
97     * Cette méthode permet de récupérer le code de division correspondant
98     * au dossier sur lequel on se trouve.
99     *
100     * @return string Code de la division du dossier en cours
101     */
102 fmichon 943 function getDivisionFromDossier() {
103 fmichon 1908
104     // Cette méthode peut être appelée plusieurs fois lors d'une requête.
105     // Pour éviter de refaire le traitement de recherche de la division
106     // alors on vérifie si nous ne l'avons pas déjà calculé.
107     if ($this->_division_from_dossier != NULL) {
108     // Logger
109     $this->addToLog("getDivisionFromDossier(): retour de la valeur déjà calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
110     // On retourne la valeur déjà calculée
111     return $this->_division_from_dossier;
112     }
113    
114     // Par défaut, on définit la valeur du dossier à NULL
115     $dossier = NULL;
116     // Test sur le mode et le contexte du formulaire
117     if ($this->getParameter("maj") == 0
118     && ($this->getParameter("retourformulaire") == "dossier"
119     || $this->getParameter("retourformulaire") == "dossier_instruction"
120     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
121     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
122     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
123     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
124     // Si on se trouve en mode AJOUT (seul mode où l'enregistrement
125     // n'existe pas en base de données) ET que nous nous trouvons
126     // dans le contexte d'un dossier d'instruction alors on récupère
127     // le numéro de dossier depuis le paramètre 'idxformulaire'
128     $dossier = $this->getParameter("idxformulaire");
129 fmichon 1088 } else {
130 fmichon 1908 // Sinon on récupère le numéro de dossier dans le champs dossier de
131     // l'enregistrement (en base de données)
132     $dossier = $this->getVal("dossier");
133 fmichon 943 }
134 fmichon 1088
135 fmichon 1908 // On appelle la méthode de la classe utils qui renvoi le code de la
136     // division d'un dossier, on la stocke pour ne pas refaire le calcul au
137     // prochain appel de cette méthode
138     $this->_division_from_dossier = $this->f->getDivisionFromDossier($dossier);
139     // Logger
140     $this->addToLog("getDivisionFromDossier(): retour de la valeur nouvellement calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
141     // On retourne la valeur retournée
142     return $this->_division_from_dossier;
143    
144 fmichon 943 }
145    
146     // }}}
147    
148 fraynaud 20 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
149 nhaye 1683 // ajout du retourformulaire aux attributs de l'objet
150     $this->retourformulaire = $retourformulaire;
151 fraynaud 20 if ($validation==0) {
152     if ($maj == 0){
153 nhaye 569 $form->setVal("dossier", $idxformulaire);
154     $form->setVal("date_envoi",date('d/m/Y'));
155 fraynaud 20 }
156 nhaye 587 if($maj == 1) {
157 nhaye 594 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
158     $this->f->isAccredited('consultation_retour_avis_service')) {
159     $form->setVal("date_retour",date('d/m/Y'));
160     }
161 nhaye 587 }
162 fraynaud 20 }
163     }
164 nhaye 587
165     function setVal(&$form, $maj, $validation, &$db) {
166     if($maj == 1) {
167     $form->setVal("date_retour",date('d/m/Y'));
168     }
169     }
170 fraynaud 20
171 nhaye 561 function setvalF($val) {
172 fmichon 1730 //
173 nhaye 561 parent::setValF($val);
174 fmichon 1730 //
175     if ($this->getParameter('maj') == 0) {
176     //
177     if (isset($this->valF["date_envoi"])) {
178     $this->valF["date_reception"] = $this->valF["date_envoi"];
179     }
180     //
181 fmichon 1172 $this->valF["lu"] = true;
182 nhaye 587 }
183 nhaye 598
184 nhaye 561 // Si un retour d'avis est modifie on passe "lu" a false
185 nhaye 598 if($this->getParameter('maj')==1 AND (
186     $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
187     $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
188     $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
189 nhaye 674 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
190 nhaye 598 ) {
191     $this->valF["lu"]=false;
192 nhaye 561 }
193 nhaye 675 }
194 fmichon 1730
195     function setLib(&$form, $maj) {
196     //
197     parent::setLib($form, $maj);
198     //
199     $form->setLib($this->clePrimaire, _("id"));
200     }
201    
202 fraynaud 20 function setType(&$form,$maj) {
203 fmichon 671 // Appel du parent
204 nhaye 459 parent::setType($form,$maj);
205 fmichon 671 // MODE - AJOUTER
206     if ($maj == 0) {
207     // On cache alors tous les champs que nous ne voulons pas voir
208     // apparaître dans le formulaire d'ajout (principalement les
209     // informations sur le retour d'avis)
210     $form->setType('date_retour', 'hidden');
211     $form->setType('date_reception', 'hidden');
212     $form->setType('date_limite', 'hidden');
213     $form->setType('avis_consultation', 'hidden');
214     $form->setType('motivation', 'hidden');
215     $form->setType('fichier', 'hidden');
216     $form->setType('lu', 'hidden');
217     // On permet la modification de certains champs
218     $form->setType('dossier', 'hiddenstatic');
219     $form->setType('service', 'select');
220     $form->setType('date_envoi', 'date2');
221     }
222     // MODE - MODIFIER
223     if ($maj == 1) {
224    
225     // On affiche en statique les informations qui ne sont plus
226     // modifiables
227     $form->setType('dossier', 'hiddenstatic');
228     $form->setType('date_envoi', 'hiddenstaticdate');
229     $form->setType('date_limite', 'hiddenstaticdate');
230     $form->setType('service', 'selecthiddenstatic');
231    
232     // La date de réception ne peut être modifiée que par un
233     // utilisateur en ayant spécifiquement la permission
234     if($this->f->isAccredited('consultation_modifier_date_reception')) {
235     $form->setType('date_reception', 'date2');
236     } else {
237     $form->setType('date_reception', 'hiddenstaticdate');
238     }
239    
240     // Le marqueur lu/non lu ne peut être modifié que par un
241     // utilisateur en ayant spécifiquement la permission
242     if ($this->f->isAccredited('consultation_modifier_lu')) {
243     $form->setType('lu', 'checkbox');
244     } else {
245     $form->setType('lu', 'hidden');
246     }
247    
248     // Gestion du type du widget sur le champ fichier
249 nhaye 1683 if($this->getVal("fichier") == "" OR
250 fmichon 671 $this->f->isAccredited('consultation_modifier_fichier')) {
251     // Si il n'y a jamais eu de fichier enregistré ou que
252     // l'utilisateur a spécifiquement les droits pour modifier
253     // un fichier déjà enregistré alors on positionne un type
254     // de widget modifiable
255 nhaye 1683 if($this->retourformulaire == "demande_avis_encours") {
256     $form->setType('fichier', 'upload2');
257     } else {
258     $form->setType('fichier', 'upload');
259     }
260 fmichon 671 } else {
261     // Si non on affiche uniquement le nom du fichier
262 nhaye 1683 $form->setType('fichier', 'file');
263 fmichon 671 }
264    
265     // Modification layout : écran de retour d'avis permettant
266     // uniquement la saisie des trois champs : avis, motivation et fichier
267     if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
268    
269     // On cache alors tous les champs que nous ne voulons pas voir
270     $form->setType('dossier', 'hidden');
271     $form->setType('service', 'hidden');
272     $form->setType('date_envoi', 'hidden');
273     $form->setType('date_retour', 'hidden');
274     $form->setType('date_reception', 'hidden');
275 fraynaud 20 $form->setType('date_limite', 'hidden');
276 nhaye 561 $form->setType('lu', 'hidden');
277 fmichon 671
278 fraynaud 20 }
279 vpihour 1784
280 fraynaud 20 }
281 nhaye 1895 // Mode supprimer
282     if ($maj == 2) {
283     $form->setType('fichier', 'filestatic');
284     }
285 nhaye 674 // MODE - CONSULTER
286     if ( $maj == 3 ) {
287 nhaye 1683 $form->setType('fichier', 'file');
288 nhaye 674 }
289 fmichon 671 //// On cache la clé primaire
290     //$form->setType('consultation', 'hidden');
291 fmichon 1730 //
292     if ($this->getParameter("retourformulaire") == "dossier"
293     || $this->getParameter("retourformulaire") == "dossier_instruction"
294     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
295     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
296     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
297     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures") {
298     //
299     $form->setType('dossier', 'hidden');
300     }
301 vpihour 1784
302     $form->setType('code_barres', 'hidden');
303 vpihour 1899
304     //Cache les champs pour la finalisation
305     $form->setType('om_fichier_consultation', 'hidden');
306     $form->setType('om_final_consultation', 'hidden');
307 fraynaud 20 }
308    
309 fmichon 1170 // Cette méthode permet de calculer la date limite en fonction de la date
310     // de réception et du délai de consultation du service consulté
311     function calculDateLimite() {
312 fraynaud 20 // mise a jour instruction avec evenement [return delay]
313 fmichon 1170 if ($this->valF["date_reception"] != "") {
314     //
315     $sql = " select delai from ".DB_PREFIXE."service ";
316     $sql .= " where service='".$this->valF["service"]."' ";
317     //
318     $delai = $this->db->getOne($sql);
319     $this->addToLog("triggerajouter(): db->getone(\"".$sql."\")", VERBOSE_MODE);
320     //
321     $this->valF["date_limite"] = $this->moisdate($this->valF["date_reception"], $delai);
322     //
323 nhaye 532 $this->addToMessage(_("delai")." ".
324 fraynaud 41 _("retour")." ".$delai." "._("mois")." -> ".
325 fmichon 1170 _("retour")." ".date("d/m/Y", strtotime($this->valF["date_limite"])));
326 fraynaud 41 }
327 fraynaud 20 }
328 fmichon 1170
329     // TRIGGER AVANT MODIFICATION DE DONNEES
330     // trigger before modification data
331     function triggerajouter($id,&$db,$val,$DEBUG) {
332     //
333     $this->calculDateLimite();
334 vpihour 1784
335     // Identifiant du type de courrier
336     $idTypeCourrier = '12';
337     $idCourrier = str_pad($this->valF["consultation"], 10, "0", STR_PAD_LEFT);
338     // Code barres
339     $this->valF["code_barres"] = $idTypeCourrier . $idCourrier;
340 fmichon 1170 }
341    
342     //
343     function triggermodifier($id,&$db,$val,$DEBUG) {
344     //
345     $this->calculDateLimite();
346     }
347    
348     //
349 nhaye 532 function triggerajouterapres($id,&$db,$val,$DEBUG) {
350    
351     // Verification de la demande de notif par mail
352 fmichon 1168 $sql= "SELECT abrege, libelle, notification_email, email FROM ".DB_PREFIXE.
353 nhaye 532 "service WHERE service ='".$this->valF['service']."'";
354     $res=$db->query($sql);
355     $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
356     if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
357     if ($notif['notification_email']=='t') {
358    
359     // Recuperation des infos du dossier
360     $sql= "SELECT dossier, terrain_adresse, terrain_adresse_complement, terrain_cp, terrain_ville
361     FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
362     $res=$db->query($sql);
363     $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
364    
365     // Definition des parametres d'envoi du mail
366     $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
367     $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
368     _("Il concerne le terrain situe a l'adresse :")." ".utf8_decode($dossier['terrain_adresse']).
369     " ".utf8_decode($dossier['terrain_adresse_complement'])." ".utf8_decode($dossier['terrain_cp'])." ".$dossier['terrain_ville']."<br/>".
370 fmichon 668 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
371 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
372 fmichon 668 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
373 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
374     _("Lien externe (hors VDM)")."</a>";
375     // Envoi du mail avec message de retour
376     if($this->f->sendMail($title, $corps, $notif['email'])) {
377 fmichon 1168 $this->addToMessage(_("Envoi d'un mail de notification au service")." \"(".$notif['abrege'].") ".$notif["libelle"]."\"");
378 nhaye 532 } else {
379     $this->addToMessage(_("L'envoi du mail de notification a echoue"));
380     }
381     }
382    
383 fmichon 1005
384     // verification si envoi vers ERP est active
385     if ($this->f->getParameter('option_erp') != "") {
386     // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
387     // deenvoie un
388     // message a ERP
389     $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
390     "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
391 nhaye 1140 $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
392     "dossier
393     INNER JOIN ".DB_PREFIXE."dossier_autorisation
394     ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
395     INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
396     ON dossier_autorisation.dossier_autorisation_type_detaille
397     = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
398     WHERE dossier = '" . $this->valF['dossier'] . "'");
399 fmichon 1005 if ($dossier_erp == 't'
400     && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
401     // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
402     if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
403     || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
404     $msgenque = new MessageEnqueuer();
405     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
406     $msgenque->setConsultationIdentifier($this->valF['consultation']);
407     $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
408     }
409    
410     // envoi du message "Consultation ERP pour conformite" en cas de creation de la
411     // consultation du service ERP Conformite
412     if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
413     $msgenque = new MessageEnqueuer();
414     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
415     $msgenque->setConsultationIdentifier($this->valF['consultation']);
416     $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
417     }
418 mlimic 936 }
419 fmichon 1005 } // fin de if($this->f->getParameter('option_erp'))
420 vpihour 1930
421     // Finalisation du document
422     $this->finaliserAjouter();
423 nhaye 532 }
424 mlimic 843
425 mlimic 936 /**
426     * Fait une requette sql pour extraire la valeur d'un champ, et retourne
427     * cette valeur
428     * @param string $sql La requete sql a executer
429     * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
430     * l'execution s'arrete.
431     */
432     function getFromDB($sql) {
433     //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
434     $res = $this->db->limitquery($sql, 0, 1);
435 vpihour 1777 $this->f->addToLog("getDossierERPSpecification(): db->limitquery(\"".
436 mlimic 936 str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
437     // Si une erreur survient on die
438     if (database::isError($res, true)) {
439     // Appel de la methode de recuperation des erreurs
440     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
441     }
442     // retourne la nature du dossier
443     while ($row =& $res->fetchRow()) {
444     return $row[0];
445     }
446     // la nature n'etait pas trouve, ce qui ne devrait pas se passer
447     return NULL;
448    
449     }
450    
451 fraynaud 20 // =============================================
452     // calcul de date avec ajout de mois (delais)
453     // [add months (delay) and calculation final date]
454     // limite ? => voir fonction instruction
455     // =============================================
456     function moisdate($date,$delaimois) {
457     // rajout de mois à une date (moins de 12)
458     $temp = explode("-" , $date);
459     $jour = (int) $temp[2];
460     $mois = (int) $temp[1];
461     $annee = (int) $temp[0];
462     $mois=$mois+$delaimois;
463     // calcul mois annee
464     if($mois>12){
465     $mois=$mois-12;
466     $annee=$annee+1;
467     }
468     // Calcul du nombre de jours dans le mois sélectionné
469     switch($mois) {
470     case "2":
471     if ($annee % 4 == 0 && $annee % 100 != 0 || $annee % 400 == 0)
472     $jourmax = 29;
473     else
474     $jourmax = 28;
475     break;
476     case "4":
477     case "6":
478     case "9":
479     case "11":
480     $jourmax = 30;
481     break;
482     default:
483     $jourmax = 31;
484     }
485     if ($jour > $jourmax)
486     $jour = $jourmax;
487     return $annee."-".$mois."-".$jour ;
488     }
489 vpihour 497
490 nhaye 569 // =============================================
491 vpihour 497 // Ajout du fielset
492     // Add fieldset
493     // =============================================
494 nhaye 569 function setLayout(&$form, $maj){
495 fmichon 671
496     // Modification layout : écran de retour d'avis permettant
497     // uniquement la saisie des trois champs : avis, motivation et fichier
498     if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
499    
500 nhaye 569 //Champs sur lequel s'ouvre le fieldset
501     $form->setBloc('dossier','D',"");
502     $form->setFieldset('dossier','D',_('Consultation'));
503    
504     //Champs sur lequel se ferme le fieldset
505     $form->setFieldset('date_envoi','F','');
506     $form->setBloc('date_envoi','F');
507 fmichon 671
508 nhaye 569 }
509 fmichon 671
510     // MODE - autre que AJOUTER alors on affiche un fieldset retour
511     // d'avis
512     if ($maj != 0) {
513    
514 nhaye 569 //Champs sur lequel s'ouvre le fieldset
515     $form->setBloc('date_reception','D',"");
516     $form->setFieldset('date_reception','D',_('Retour d\'avis'));
517 fmichon 671
518 nhaye 569 //Champs sur lequel se ferme le fieldset
519     $form->setFieldset('lu','F','');
520     $form->setBloc('lu','F');
521 fmichon 671
522 nhaye 569 }
523     }
524 nhaye 595
525     /** Surcharge de la methode retour afin de retourner sur la page de saisie de
526     * code barre si besoin
527     **/
528     function retour($premier = 0, $recherche = "", $tricol = "") {
529     $params ="obj=".get_class($this);
530     if($this->getParameter("retour")=="form") {
531     $params .= "&amp;idx=".$this->getParameter("idx");
532     $params .= "&amp;action=3";
533     }
534     $params .= "&amp;premier=".$this->getParameter("premier");
535     $params .= "&amp;tricol=".$this->getParameter("tricol");
536     $params .= "&amp;recherche=".$this->getParameter("recherche");
537     $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
538     $params .= "&amp;advs_id=".$this->getParameter("advs_id");
539     $params .= "&amp;valide=".$this->getParameter("valide");
540     echo "\n<a class=\"retour\" ";
541     echo "href=\"";
542     //
543    
544     if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
545     echo "form.php?".$params;
546 fmichon 1666 } elseif($this->getParameter("retour")=="suivi_retours_de_consultation") {
547     echo "../app/suivi_retours_de_consultation.php";
548 nhaye 595 } else {
549     echo "tab.php?".$params;
550     }
551     //
552     echo "\"";
553     echo ">";
554     //
555     echo _("Retour");
556     //
557     echo "</a>\n";
558     }
559 fmichon 938
560     /**
561 nhaye 802 * Surcharge du bouton retour pour popup
562     */
563     function retoursousformulaire($idxformulaire, $retourformulaire, $val,
564     $objsf, $premiersf, $tricolsf, $validation,
565     $idx, $maj, $retour) {
566     if($retourformulaire === "demande_avis_encours") {
567     echo "\n<a class=\"retour\" ";
568     echo "href=\"";
569     echo "#";
570     echo "\" ";
571     echo ">";
572     //
573     echo _("Retour");
574     //
575     echo "</a>\n";
576     } else {
577     parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
578     $objsf, $premiersf, $tricolsf, $validation,
579     $idx, $maj, $retour);
580     }
581     }
582 vpihour 1784
583 vpihour 1881 /**
584     * Ajout des contraintes spécifiques pour l'ajout d'un fichier en retour de
585     * consultation
586     */
587     function setSelect(&$form, $maj,&$db,$debug) {
588     parent::setSelect($form, $maj,$db,$debug);
589    
590     //Seulement dans le cas d'un retour d'avis
591     if($this->retourformulaire == "demande_avis_encours") {
592    
593     //Tableau des contraintes spécifiques
594     $params = array(
595     "constraint" => array(
596     "size_max" => 2,
597     "extension" => ".pdf"
598     ),
599     );
600    
601     $form->setSelect("fichier", $params);
602     }
603     }
604 vpihour 1930
605     /**
606     * Finalisation du document lors de l'ajout d'une consultation
607     */
608     function finaliserAjouter(){
609    
610     //Génération du PDF
611     $_GET['output'] = "string";
612     $_GET['obj'] = "consultation";
613     $_GET['idx'] = $this->valF[$this->clePrimaire];
614     $f = $this->f;
615     include '../app/pdf_consultation.php';
616    
617     //Métadonnées du document
618     $metadata = array(
619     'filename' => 'consultation_'.$idx.'.pdf',
620     'mimetype' => 'application/pdf',
621     'size' => strlen($pdf_output)
622     );
623    
624 nhaye 1935 // Récupération des métadonnées calculées après validation
625 nhaye 1938 $spe_metadata = $this->getMetadata("om_fichier_consultation");
626 nhaye 1935
627     $metadata = array_merge($metadata, $spe_metadata);
628    
629 vpihour 1930 //On ajoute le document et on récupère son uid
630     $uid = $this->f->storage->create($pdf_output, $metadata);
631    
632     //Mise à jour des données
633     if ( $uid != '' ){
634     // Logger
635     $this->addToLog("finaliserAjouter() - begin", EXTRA_VERBOSE_MODE);
636    
637     $valF = array(
638     "om_final_consultation"=> TRUE,
639     "om_fichier_consultation"=>$uid);
640    
641     // Execution de la requête de modification des donnees de l'attribut
642     // valF de l'objet dans l'attribut table de l'objet
643     $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
644     DB_AUTOQUERY_UPDATE, $this->getCle($idx));
645     $this->addToLog("finaliserAjouter() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($idx)."\")", VERBOSE_MODE);
646     // Si une erreur survient
647     if (database::isError($res)) {
648     // Appel de la methode de recuperation des erreurs
649     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
650     } else {
651     // Log
652     $this->addToLog(_("Requete executee"), VERBOSE_MODE);
653     // Log
654     $message = _("Enregistrement")."&nbsp;".$idx."&nbsp;";
655     $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
656     $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
657     $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
658     $this->addToLog($message, VERBOSE_MODE);
659     }
660     }
661     }
662 nhaye 1935
663    
664     /**
665     * Récupération du numéro de dossier d'instruction à ajouter aux métadonnées
666 nhaye 1949 * @return string numéro de dossier d'instruction
667 nhaye 1935 */
668     protected function getDossier() {
669     if(empty($this->specificMetadata)) {
670     $this->getSpecificMetadata();
671     }
672     return $this->specificMetadata->dossier;
673     }
674     /**
675     * Récupération du numéro de dossier d'autorisation à ajouter aux métadonnées
676 nhaye 1949 * @return string numéro de dossier d'autorisation
677 nhaye 1935 */
678     protected function getDossierAutorisation() {
679     if(empty($this->specificMetadata)) {
680     $this->getSpecificMetadata();
681     }
682     return $this->specificMetadata->dossier_autorisation;
683     }
684     /**
685     * Récupération de la date de demande initiale du dossier à ajouter aux métadonnées
686 nhaye 1949 * @return date demande initiale
687 nhaye 1935 */
688     protected function getDateDemandeInitiale() {
689     if(empty($this->specificMetadata)) {
690     $this->getSpecificMetadata();
691     }
692     return $this->specificMetadata->date_demande_initiale;
693     }
694     /**
695     * Récupération du type de dossier d'instruction à ajouter aux métadonnées
696 nhaye 1949 * @return string type de dossier d'instruction
697 nhaye 1935 */
698     protected function getDossierInstructionType() {
699     if(empty($this->specificMetadata)) {
700     $this->getSpecificMetadata();
701     }
702     return $this->specificMetadata->dossier_instruction_type;
703     }
704     /**
705     * Récupération du statut du dossier d'autorisation à ajouter aux métadonnées
706 nhaye 1949 * @return string avis
707 nhaye 1935 */
708     protected function getStatut() {
709     if(empty($this->specificMetadata)) {
710     $this->getSpecificMetadata();
711     }
712     return $this->specificMetadata->statut;
713     }
714     /**
715     * Récupération du type de dossier d'autorisation à ajouter aux métadonnées
716 nhaye 1949 * @return string type d'autorisation
717 nhaye 1935 */
718     protected function getDossierAutorisationType() {
719     if(empty($this->specificMetadata)) {
720     $this->getSpecificMetadata();
721     }
722     return $this->specificMetadata->dossier_autorisation_type;
723     }
724     /**
725     * Récupération de la date d'ajout de document à ajouter aux métadonnées
726 nhaye 1949 * @return date de l'évènement
727 nhaye 1935 */
728     protected function getDateEvenement() {
729     return date("d/m/Y");
730     }
731     /**
732     * Récupération du groupe d'instruction à ajouter aux métadonnées
733     * @return string Groupe d'instruction
734     */
735     protected function getGroupeInstruction() {
736     if(empty($this->specificMetadata)) {
737     $this->getSpecificMetadata();
738     }
739     return $this->specificMetadata->groupe_instruction;
740     }
741    
742     /**
743     * Cette méthode permet de stocker en attribut toutes les métadonnées
744     * nécessaire à l'ajout d'un document.
745     */
746     public function getSpecificMetadata() {
747     if (isset($this->valF["dossier"]) AND $this->valF["dossier"] != "") {
748     $dossier = $this->valF["dossier"];
749     } else {
750     $dossier = $this->getVal("dossier");
751     }
752     //Requête pour récupérer les informations essentiels sur le dossier d'instruction
753     $sql = "SELECT dossier.dossier as dossier,
754     dossier_autorisation.dossier_autorisation as dossier_autorisation,
755     to_char(dossier.date_demande, 'YYYY/MM') as date_demande_initiale,
756     dossier_instruction_type.code as dossier_instruction_type,
757     etat_dossier_autorisation.libelle as statut,
758     dossier_autorisation_type.code as dossier_autorisation_type,
759     groupe.code as groupe_instruction
760     FROM ".DB_PREFIXE."dossier
761     LEFT JOIN ".DB_PREFIXE."dossier_instruction_type
762     ON dossier.dossier_instruction_type = dossier_instruction_type.dossier_instruction_type
763     LEFT JOIN ".DB_PREFIXE."dossier_autorisation
764     ON dossier.dossier_autorisation = dossier_autorisation.dossier_autorisation
765     LEFT JOIN ".DB_PREFIXE."etat_dossier_autorisation
766     ON dossier_autorisation.etat_dossier_autorisation = etat_dossier_autorisation.etat_dossier_autorisation
767     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
768     ON dossier_autorisation.dossier_autorisation_type_detaille = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
769     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type
770     ON dossier_autorisation_type_detaille.dossier_autorisation_type = dossier_autorisation_type.dossier_autorisation_type
771     LEFT JOIN ".DB_PREFIXE."groupe
772     ON dossier_autorisation_type.groupe = groupe.groupe
773     WHERE dossier.dossier = '".$dossier."'";
774     $res = $this->db->query($sql);
775     $this->f->addToLog("obj/document_numerise.class.php : db->query(".$sql.")", VERBOSE_MODE);
776     if ( database::isError($res)){
777     die();
778     }
779    
780     //Le résultat est récupéré dans un objet
781     $row =& $res->fetchRow(DB_FETCHMODE_OBJECT);
782    
783     //Si il y a un résultat
784     if ($row !== null) {
785    
786     //Alors on créé l'objet dossier_instruction
787     $this->specificMetadata = $row;
788    
789     }
790     }
791 fraynaud 3 }// fin classe
792 nhaye 509 ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26