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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2104 - (hide annotations)
Thu Jul 18 14:55:14 2013 UTC (11 years, 6 months ago) by vpihour
File size: 38940 byte(s)
Les instructeurs peuvent visualiser les éditions des événements d'instruction d'un dossier d'une autre division

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26