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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3216 - (hide annotations)
Wed Dec 17 11:44:45 2014 UTC (10 years, 1 month ago) by vpihour
File size: 52781 byte(s)
L'instruteur a maintenant la possibilité de "marquer comme lu" une consultation sur un dossier d'instruction clôturé.

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 nhaye 3023 "filename" => "getFichierFilename",
28 softime 2002 "dossier" => "getDossier",
29 softime 2016 "dossier_version" => "getDossierVersion",
30 softime 2025 "numDemandeAutor" => "getNumDemandeAutor",
31     "anneemoisDemandeAutor" => "getAnneemoisDemandeAutor",
32     "typeInstruction" => "getTypeInstruction",
33     "statutAutorisation" => "getStatutAutorisation",
34     "typeAutorisation" => "getTypeAutorisation",
35     "dateEvenementDocument" => "getDateEvenementDocument",
36 softime 2016 "groupeInstruction" => 'getGroupeInstruction',
37 softime 2025 "title" => 'getTitle',
38 softime 2002 ),
39 nhaye 1935 );
40    
41 fraynaud 20 function consultation($id,&$db,$debug) {
42     $this->constructeur($id,$db,$debug);
43     }// fin constructeur
44 fmichon 943
45     // {{{ Gestion de la confidentialité des données spécifiques
46    
47     /**
48     * Surcharge pour gérer les actions disponibles dans le portlet
49     */
50     function checkAccessibility() {
51     //
52     parent::checkAccessibility();
53     // Si l'utilisateur est un intructeur qui en correspond pas à la
54     // division du dossier
55     if ($this->f->isUserInstructeur()
56     && isset($this->f->om_utilisateur["division"])
57     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
58     //
59 vpihour 2104 $this->parameters["actions"]["modifier"] = NULL;
60     $this->parameters["actions"]["supprimer"] = NULL;
61     $this->actions_sup["finalisation"] = NULL;
62     $this->actions_sup["definalisation"] = NULL;
63     $this->actions_sup["lu"] = NULL;
64 fmichon 943 }
65     // Si une action 'lu' est présente et que le champ lu est à true
66     // on supprime l'action
67     if (isset($this->actions_sup["lu"])
68     && isset($this->val[array_search("lu", $this->champs)])
69     && $this->val[array_search("lu", $this->champs)]== "t") {
70     unset($this->actions_sup["lu"]);
71     }
72 vpihour 1974
73     //Si le document est déjà finalisé, le lien de l'édition est celui du stockage
74 vpihour 2603 $om_final_consultation = $this->getVal("om_final_consultation");
75     if ( $om_final_consultation== "t" ){
76    
77 vpihour 1974 //On affiche le bon lien pour l'édition
78     $this->actions_sup["pdfetat"]["lien"] = "../spg/file.php?id=";
79     $this->actions_sup["pdfetat"]["id"] =
80     "&amp;obj=consultation&amp;champ=om_fichier_consultation";
81 vpihour 2603 //On cache les liens d'action
82 vpihour 1986 $this->parameters["actions"]["modifier"] = NULL;
83     $this->parameters["actions"]["supprimer"] = NULL;
84 vpihour 2603 $this->actions_sup["finalisation"] = NULL;
85 vpihour 1974 }
86     //Si le document n'est pas finalisé, le lien de l'édition est le lien de
87     //génération à la volée
88 vpihour 2603 if ( $om_final_consultation!= "t" ){
89 vpihour 1974
90     //On affiche le bon lien pour l'édition
91     $this->actions_sup["pdfetat"]["lien"] = "../app/pdf_consultation.php?idx=";
92     $this->actions_sup["pdfetat"]["id"] = "&obj=consultation";
93 vpihour 2603 $this->actions_sup["definalisation"] = NULL;
94     if( $this->f->isUserInstructeur() ){
95     $this->parameters["actions"]["modifier"] = NULL;
96     }
97 vpihour 1974 }
98 vpihour 1978
99     $idxformulaire = $this->getParameter("idxformulaire");
100     $retourformulaire = $this->getParameter("retourformulaire");
101     //Si le dossier d'instruction auquel est rattachée la consultation est
102     //cloturé, on affiche pas les liens du portlet
103     if ( $idxformulaire != '' &&
104     (
105     $retourformulaire == 'dossier' ||
106     $retourformulaire == 'dossier_instruction' ||
107     $retourformulaire == 'dossier_instruction_mes_encours' ||
108     $retourformulaire == 'dossier_instruction_tous_encours' ||
109     $retourformulaire == 'dossier_instruction_mes_clotures' ||
110     $retourformulaire == 'dossier_instruction_tous_clotures'
111     )){
112    
113     //On récuppère le statut du dossier d'instruction
114 vpihour 2039 $statut = $this->f->getStatutDossier($idxformulaire);
115 vpihour 1978 if ( $this->f->isUserInstructeur() && $statut == "cloture" ){
116    
117     //On cache le lien de modification
118     $this->parameters["actions"]["modifier"] = NULL;
119     $this->parameters["actions"]["supprimer"] = NULL;
120     $this->actions_sup["finalisation"] = NULL;
121     $this->actions_sup["definalisation"] = NULL;
122 vpihour 3216
123     // On affiche l'action "marquer comme lu" uniquement si la
124     // consultation n'a pas été lue
125     if ($this->getVal("lu")== "t"){
126     $this->actions_sup["lu"] = NULL;
127     }
128 vpihour 1978 }
129     }
130 fmichon 943 }
131    
132     /**
133     * Cette methode est à surcharger elle permet de tester dans chaque classe
134     * des droits des droits spécifiques en fonction des données
135     */
136     function canAccess() {
137     // Si l'utilisateur est un utilisateur de service externe
138     // on vérifie qu'il peut accéder à la consultation
139 softime 2120 if ($this->f->isUserService()) {
140 fmichon 943 // On compare l'id du service de la consultation
141     // aux id des services de utilisateur connecté
142     foreach($this->f->om_utilisateur['service'] as $service) {
143     if($this->val[array_search("service",$this->champs)]===$service['service']) {
144     return true;
145     }
146     }
147 fmichon 1088 //
148     $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
149 fmichon 943 return false;
150     }
151     // Si l'utilisateur est un intructeur qui ne correspond pas à la
152     // division du dossier
153     if ($this->f->isUserInstructeur()
154     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
155     && $this->getParameter("maj") != 3) {
156     //
157 fmichon 1088 $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
158 fmichon 943 return false;
159     }
160 vpihour 1978
161     $retourformulaire = $this->getParameter("retourformulaire");
162     // Si l'utilisateur est un instructeur et que le dossier est cloturé
163     if ( $this->f->isUserInstructeur() &&
164 vpihour 2039 $this->f->getStatutDossier($this->getParameter("idxformulaire")) == "cloture" &&
165 vpihour 1978 (
166     $retourformulaire == 'dossier' ||
167     $retourformulaire == 'dossier_instruction' ||
168     $retourformulaire == 'dossier_instruction_mes_encours' ||
169     $retourformulaire == 'dossier_instruction_tous_encours' ||
170     $retourformulaire == 'dossier_instruction_mes_clotures' ||
171     $retourformulaire == 'dossier_instruction_tous_clotures'
172     ) &&
173     $this->getParameter("maj") != 3) {
174    
175     return false;
176     }
177 fmichon 943 //
178     return true;
179     }
180    
181     /**
182 fmichon 1908 * Cette variable permet de stocker le résultat de la méthode
183     * getDivisionFromDossier() afin de ne pas effectuer le recalcul à chacun de
184     * ces appels.
185     * @var string Code de la division du dossier en cours
186 fmichon 943 */
187 fmichon 1908 var $_division_from_dossier = NULL;
188    
189     /**
190     * Cette méthode permet de récupérer le code de division correspondant
191     * au dossier sur lequel on se trouve.
192     *
193     * @return string Code de la division du dossier en cours
194     */
195 fmichon 943 function getDivisionFromDossier() {
196 fmichon 1908
197     // Cette méthode peut être appelée plusieurs fois lors d'une requête.
198     // Pour éviter de refaire le traitement de recherche de la division
199     // alors on vérifie si nous ne l'avons pas déjà calculé.
200     if ($this->_division_from_dossier != NULL) {
201     // Logger
202     $this->addToLog("getDivisionFromDossier(): retour de la valeur déjà calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
203     // On retourne la valeur déjà calculée
204     return $this->_division_from_dossier;
205     }
206    
207     // Par défaut, on définit la valeur du dossier à NULL
208     $dossier = NULL;
209     // Test sur le mode et le contexte du formulaire
210     if ($this->getParameter("maj") == 0
211     && ($this->getParameter("retourformulaire") == "dossier"
212     || $this->getParameter("retourformulaire") == "dossier_instruction"
213     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
214     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
215     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
216     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
217     // Si on se trouve en mode AJOUT (seul mode où l'enregistrement
218     // n'existe pas en base de données) ET que nous nous trouvons
219     // dans le contexte d'un dossier d'instruction alors on récupère
220     // le numéro de dossier depuis le paramètre 'idxformulaire'
221     $dossier = $this->getParameter("idxformulaire");
222 fmichon 1088 } else {
223 fmichon 1908 // Sinon on récupère le numéro de dossier dans le champs dossier de
224     // l'enregistrement (en base de données)
225     $dossier = $this->getVal("dossier");
226 fmichon 943 }
227 fmichon 1088
228 fmichon 1908 // On appelle la méthode de la classe utils qui renvoi le code de la
229     // division d'un dossier, on la stocke pour ne pas refaire le calcul au
230     // prochain appel de cette méthode
231     $this->_division_from_dossier = $this->f->getDivisionFromDossier($dossier);
232     // Logger
233     $this->addToLog("getDivisionFromDossier(): retour de la valeur nouvellement calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
234     // On retourne la valeur retournée
235     return $this->_division_from_dossier;
236    
237 fmichon 943 }
238    
239     // }}}
240    
241 fraynaud 20 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
242 nhaye 1683 // ajout du retourformulaire aux attributs de l'objet
243     $this->retourformulaire = $retourformulaire;
244 fraynaud 20 if ($validation==0) {
245     if ($maj == 0){
246 nhaye 569 $form->setVal("dossier", $idxformulaire);
247     $form->setVal("date_envoi",date('d/m/Y'));
248 fraynaud 20 }
249 nhaye 587 if($maj == 1) {
250 nhaye 594 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
251     $this->f->isAccredited('consultation_retour_avis_service')) {
252     $form->setVal("date_retour",date('d/m/Y'));
253     }
254 nhaye 587 }
255 fraynaud 20 }
256     }
257 nhaye 587
258     function setVal(&$form, $maj, $validation, &$db) {
259     if($maj == 1) {
260     $form->setVal("date_retour",date('d/m/Y'));
261     }
262     }
263 fraynaud 20
264 nhaye 561 function setvalF($val) {
265 fmichon 1730 //
266 nhaye 561 parent::setValF($val);
267 fmichon 1730 //
268     if ($this->getParameter('maj') == 0) {
269     //
270     if (isset($this->valF["date_envoi"])) {
271     $this->valF["date_reception"] = $this->valF["date_envoi"];
272     }
273     //
274 fmichon 1172 $this->valF["lu"] = true;
275 nhaye 587 }
276 nhaye 598
277 nhaye 561 // Si un retour d'avis est modifie on passe "lu" a false
278 nhaye 598 if($this->getParameter('maj')==1 AND (
279     $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
280     $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
281     $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
282 nhaye 674 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
283 nhaye 598 ) {
284     $this->valF["lu"]=false;
285 nhaye 561 }
286 nhaye 675 }
287 fmichon 1730
288     function setLib(&$form, $maj) {
289     //
290     parent::setLib($form, $maj);
291     //
292     $form->setLib($this->clePrimaire, _("id"));
293     }
294    
295 fraynaud 20 function setType(&$form,$maj) {
296 fmichon 671 // Appel du parent
297 nhaye 459 parent::setType($form,$maj);
298 softime 2112 $form->setType('dossier', 'hidden');
299 fmichon 671 // MODE - AJOUTER
300     if ($maj == 0) {
301     // On cache alors tous les champs que nous ne voulons pas voir
302     // apparaître dans le formulaire d'ajout (principalement les
303     // informations sur le retour d'avis)
304 nmeucci 2857 $form->setType('date_retour', 'hiddendate');
305     $form->setType('date_reception', 'hiddendate');
306     $form->setType('date_limite', 'hiddendate');
307 fmichon 671 $form->setType('avis_consultation', 'hidden');
308     $form->setType('motivation', 'hidden');
309     $form->setType('fichier', 'hidden');
310     $form->setType('lu', 'hidden');
311     // On permet la modification de certains champs
312 softime 2112 $form->setType('dossier_libelle', 'hiddenstatic');
313 fmichon 671 $form->setType('service', 'select');
314     $form->setType('date_envoi', 'date2');
315     }
316     // MODE - MODIFIER
317     if ($maj == 1) {
318    
319     // On affiche en statique les informations qui ne sont plus
320     // modifiables
321 softime 2112 $form->setType('dossier_libelle', 'hiddenstatic');
322 fmichon 671 $form->setType('date_envoi', 'hiddenstaticdate');
323     $form->setType('date_limite', 'hiddenstaticdate');
324     $form->setType('service', 'selecthiddenstatic');
325    
326     // La date de réception ne peut être modifiée que par un
327     // utilisateur en ayant spécifiquement la permission
328     if($this->f->isAccredited('consultation_modifier_date_reception')) {
329     $form->setType('date_reception', 'date2');
330     } else {
331     $form->setType('date_reception', 'hiddenstaticdate');
332     }
333    
334     // Le marqueur lu/non lu ne peut être modifié que par un
335     // utilisateur en ayant spécifiquement la permission
336     if ($this->f->isAccredited('consultation_modifier_lu')) {
337     $form->setType('lu', 'checkbox');
338     } else {
339     $form->setType('lu', 'hidden');
340     }
341    
342     // Gestion du type du widget sur le champ fichier
343 nhaye 1683 if($this->getVal("fichier") == "" OR
344 fmichon 671 $this->f->isAccredited('consultation_modifier_fichier')) {
345     // Si il n'y a jamais eu de fichier enregistré ou que
346     // l'utilisateur a spécifiquement les droits pour modifier
347     // un fichier déjà enregistré alors on positionne un type
348     // de widget modifiable
349 nmeucci 2972 if ($this->retourformulaire == "demande_avis_encours"
350     || $this->retourformulaire == "dossier_qualifier"
351     || $this->retourformulaire == "dossier"
352     || $this->retourformulaire == "dossier_instruction"
353     || $this->retourformulaire == "dossier_instruction_mes_encours"
354     || $this->retourformulaire == "dossier_instruction_tous_encours"
355     || $this->retourformulaire == "dossier_instruction_mes_clotures"
356     || $this->retourformulaire == "dossier_instruction_tous_clotures") {
357 nhaye 1683 $form->setType('fichier', 'upload2');
358     } else {
359     $form->setType('fichier', 'upload');
360     }
361 fmichon 671 } else {
362     // Si non on affiche uniquement le nom du fichier
363 nhaye 1683 $form->setType('fichier', 'file');
364 fmichon 671 }
365    
366     // Modification layout : écran de retour d'avis permettant
367     // uniquement la saisie des trois champs : avis, motivation et fichier
368     if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
369    
370     // On cache alors tous les champs que nous ne voulons pas voir
371 softime 2112 $form->setType('dossier_libelle', 'hidden');
372 fmichon 671 $form->setType('service', 'hidden');
373 nmeucci 2857 $form->setType('date_envoi', 'hiddendate');
374     $form->setType('date_retour', 'hiddendate');
375     $form->setType('date_reception', 'hiddendate');
376     $form->setType('date_limite', 'hiddendate');
377 nhaye 561 $form->setType('lu', 'hidden');
378 fmichon 671
379 fraynaud 20 }
380 vpihour 1784
381 fraynaud 20 }
382 nhaye 1895 // Mode supprimer
383     if ($maj == 2) {
384     $form->setType('fichier', 'filestatic');
385     }
386 nhaye 674 // MODE - CONSULTER
387     if ( $maj == 3 ) {
388 nhaye 1683 $form->setType('fichier', 'file');
389 nhaye 674 }
390 fmichon 671 //// On cache la clé primaire
391     //$form->setType('consultation', 'hidden');
392 fmichon 1730 //
393     if ($this->getParameter("retourformulaire") == "dossier"
394     || $this->getParameter("retourformulaire") == "dossier_instruction"
395     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
396     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
397     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
398     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures") {
399     //
400 softime 2112 $form->setType('dossier_libelle', 'hidden');
401 fmichon 1730 }
402 vpihour 1784
403     $form->setType('code_barres', 'hidden');
404 vpihour 1899
405     //Cache les champs pour la finalisation
406     $form->setType('om_fichier_consultation', 'hidden');
407     $form->setType('om_final_consultation', 'hidden');
408 fraynaud 20 }
409    
410 fmichon 1170 // Cette méthode permet de calculer la date limite en fonction de la date
411     // de réception et du délai de consultation du service consulté
412     function calculDateLimite() {
413 fraynaud 20 // mise a jour instruction avec evenement [return delay]
414 fmichon 1170 if ($this->valF["date_reception"] != "") {
415     //
416     $sql = " select delai from ".DB_PREFIXE."service ";
417     $sql .= " where service='".$this->valF["service"]."' ";
418     //
419     $delai = $this->db->getOne($sql);
420     $this->addToLog("triggerajouter(): db->getone(\"".$sql."\")", VERBOSE_MODE);
421     //
422 softime 2771 $this->valF["date_limite"] = $this->f->mois_date($this->valF["date_reception"], $delai);
423 fmichon 1170 //
424 nhaye 532 $this->addToMessage(_("delai")." ".
425 fraynaud 41 _("retour")." ".$delai." "._("mois")." -> ".
426 fmichon 1170 _("retour")." ".date("d/m/Y", strtotime($this->valF["date_limite"])));
427 fraynaud 41 }
428 fraynaud 20 }
429 fmichon 1170
430     // TRIGGER AVANT MODIFICATION DE DONNEES
431     // trigger before modification data
432     function triggerajouter($id,&$db,$val,$DEBUG) {
433     //
434     $this->calculDateLimite();
435 vpihour 1784
436     // Identifiant du type de courrier
437     $idTypeCourrier = '12';
438     $idCourrier = str_pad($this->valF["consultation"], 10, "0", STR_PAD_LEFT);
439     // Code barres
440     $this->valF["code_barres"] = $idTypeCourrier . $idCourrier;
441 fmichon 1170 }
442    
443     //
444     function triggermodifier($id,&$db,$val,$DEBUG) {
445     //
446     $this->calculDateLimite();
447     }
448    
449     //
450 nhaye 532 function triggerajouterapres($id,&$db,$val,$DEBUG) {
451    
452     // Verification de la demande de notif par mail
453 fmichon 1168 $sql= "SELECT abrege, libelle, notification_email, email FROM ".DB_PREFIXE.
454 nhaye 532 "service WHERE service ='".$this->valF['service']."'";
455     $res=$db->query($sql);
456     $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
457     if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
458     if ($notif['notification_email']=='t') {
459    
460     // Recuperation des infos du dossier
461 softime 2081 $sql= "SELECT dossier, terrain_adresse_voie_numero, terrain_adresse_voie, terrain_adresse_code_postal, terrain_adresse_localite
462 nhaye 532 FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
463     $res=$db->query($sql);
464     $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
465    
466     // Definition des parametres d'envoi du mail
467     $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
468     $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
469 softime 2081 _("Il concerne le terrain situe a l'adresse :")." ".$dossier['terrain_adresse_voie_numero'].
470     " ".$dossier['terrain_adresse_voie']." ".$dossier['terrain_adresse_code_postal']." ".$dossier['terrain_adresse_localite']."<br/>".
471 fmichon 668 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
472 vpihour 3141 // On ajoute l'idx, s'il y a besoin
473     ((substr($this->f->getParameter('services_consultes_lien_interne'), -5)=="&idx=")?$this->valF['consultation']:"")."'>".
474 fmichon 668 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
475 vpihour 3141 // On ajoute l'idx, s'il y a besoin
476     ((substr($this->f->getParameter('services_consultes_lien_externe'), -5)=="&idx=")?$this->valF['consultation']:"")."'>".
477 nhaye 532 _("Lien externe (hors VDM)")."</a>";
478     // Envoi du mail avec message de retour
479 softime 2084 if($this->f->sendMail(iconv("UTF-8", "CP1252", $title), iconv("UTF-8", "CP1252", $corps), iconv("UTF-8", "CP1252", $notif['email']))) {
480 fmichon 1168 $this->addToMessage(_("Envoi d'un mail de notification au service")." \"(".$notif['abrege'].") ".$notif["libelle"]."\"");
481 nhaye 532 } else {
482     $this->addToMessage(_("L'envoi du mail de notification a echoue"));
483     }
484     }
485    
486 fmichon 1005
487     // verification si envoi vers ERP est active
488 vpihour 3126 if ($this->f->getParameter('option_erp') === 'true') {
489 fmichon 1005 // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
490     // deenvoie un
491     // message a ERP
492     $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
493     "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
494 nhaye 1140 $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
495     "dossier
496     INNER JOIN ".DB_PREFIXE."dossier_autorisation
497     ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
498     INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
499     ON dossier_autorisation.dossier_autorisation_type_detaille
500     = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
501     WHERE dossier = '" . $this->valF['dossier'] . "'");
502 fmichon 1005 if ($dossier_erp == 't'
503     && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
504     // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
505     if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
506     || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
507     $msgenque = new MessageEnqueuer();
508     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
509     $msgenque->setConsultationIdentifier($this->valF['consultation']);
510 vpihour 2842 $return = $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
511     //Si une erreur s'est produite on arrête le traitement et on
512     //retourne une erreur
513     if ($return !== 0){
514    
515     $this->addToMessage(_("Une erreur s'est produite lors de ".
516     "l'envoi du message au referentiel ERP. Merci de ".
517     "contacter votre administrateur"));
518     //On ne valide pas le formulaire
519 vpihour 2877 $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
520     $this->correct = false;
521     return false;
522 vpihour 2842 }
523     else {
524     $this->addToMessage(_("Le message a ete transmis au ".
525     "referentiel ERP."));
526     }
527 fmichon 1005 }
528    
529     // envoi du message "Consultation ERP pour conformite" en cas de creation de la
530     // consultation du service ERP Conformite
531     if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
532     $msgenque = new MessageEnqueuer();
533     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
534     $msgenque->setConsultationIdentifier($this->valF['consultation']);
535 vpihour 2842 $return = $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
536     //Si une erreur s'est produite on arrête le traitement et on
537     //retourne une erreur
538     if ($return !== 0){
539    
540     $this->addToMessage(_("Une erreur s'est produite lors de ".
541     "l'envoi du message au referentiel ERP. Merci de ".
542     "contacter votre administrateur"));
543     //On ne valide pas le formulaire
544 vpihour 2877 $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
545     $this->correct = false;
546     return false;
547 vpihour 2842 }
548     else {
549     $this->addToMessage(_("Le message a ete transmis au ".
550     "referentiel ERP."));
551     }
552 fmichon 1005 }
553 mlimic 936 }
554 vpihour 3126 } // fin de if($this->f->getParameter('option_erp') === 'true')
555 vpihour 1930
556     // Finalisation du document
557     $this->finaliserAjouter();
558 nhaye 532 }
559 mlimic 843
560 mlimic 936 /**
561     * Fait une requette sql pour extraire la valeur d'un champ, et retourne
562     * cette valeur
563     * @param string $sql La requete sql a executer
564     * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
565     * l'execution s'arrete.
566     */
567     function getFromDB($sql) {
568     //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
569     $res = $this->db->limitquery($sql, 0, 1);
570 vpihour 1777 $this->f->addToLog("getDossierERPSpecification(): db->limitquery(\"".
571 mlimic 936 str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
572     // Si une erreur survient on die
573     if (database::isError($res, true)) {
574     // Appel de la methode de recuperation des erreurs
575     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
576     }
577     // retourne la nature du dossier
578     while ($row =& $res->fetchRow()) {
579     return $row[0];
580     }
581     // la nature n'etait pas trouve, ce qui ne devrait pas se passer
582     return NULL;
583    
584     }
585    
586 fraynaud 20 // =============================================
587 vpihour 497 // Ajout du fielset
588     // Add fieldset
589     // =============================================
590 nhaye 569 function setLayout(&$form, $maj){
591 fmichon 671
592     // Modification layout : écran de retour d'avis permettant
593     // uniquement la saisie des trois champs : avis, motivation et fichier
594     if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
595    
596 nhaye 569 //Champs sur lequel s'ouvre le fieldset
597     $form->setBloc('dossier','D',"");
598     $form->setFieldset('dossier','D',_('Consultation'));
599    
600     //Champs sur lequel se ferme le fieldset
601     $form->setFieldset('date_envoi','F','');
602     $form->setBloc('date_envoi','F');
603 fmichon 671
604 nhaye 569 }
605 fmichon 671
606     // MODE - autre que AJOUTER alors on affiche un fieldset retour
607     // d'avis
608     if ($maj != 0) {
609    
610 nhaye 569 //Champs sur lequel s'ouvre le fieldset
611     $form->setBloc('date_reception','D',"");
612     $form->setFieldset('date_reception','D',_('Retour d\'avis'));
613 fmichon 671
614 nhaye 569 //Champs sur lequel se ferme le fieldset
615     $form->setFieldset('lu','F','');
616     $form->setBloc('lu','F');
617 fmichon 671
618 nhaye 569 }
619     }
620 nhaye 595
621     /** Surcharge de la methode retour afin de retourner sur la page de saisie de
622     * code barre si besoin
623     **/
624     function retour($premier = 0, $recherche = "", $tricol = "") {
625     $params ="obj=".get_class($this);
626     if($this->getParameter("retour")=="form") {
627     $params .= "&amp;idx=".$this->getParameter("idx");
628     $params .= "&amp;action=3";
629     }
630     $params .= "&amp;premier=".$this->getParameter("premier");
631     $params .= "&amp;tricol=".$this->getParameter("tricol");
632     $params .= "&amp;recherche=".$this->getParameter("recherche");
633     $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
634     $params .= "&amp;advs_id=".$this->getParameter("advs_id");
635     $params .= "&amp;valide=".$this->getParameter("valide");
636     echo "\n<a class=\"retour\" ";
637     echo "href=\"";
638     //
639    
640     if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
641     echo "form.php?".$params;
642 fmichon 1666 } elseif($this->getParameter("retour")=="suivi_retours_de_consultation") {
643     echo "../app/suivi_retours_de_consultation.php";
644 nhaye 595 } else {
645     echo "tab.php?".$params;
646     }
647     //
648     echo "\"";
649     echo ">";
650     //
651     echo _("Retour");
652     //
653     echo "</a>\n";
654     }
655 fmichon 938
656     /**
657 nhaye 802 * Surcharge du bouton retour pour popup
658     */
659     function retoursousformulaire($idxformulaire, $retourformulaire, $val,
660     $objsf, $premiersf, $tricolsf, $validation,
661     $idx, $maj, $retour) {
662     if($retourformulaire === "demande_avis_encours") {
663     echo "\n<a class=\"retour\" ";
664     echo "href=\"";
665     echo "#";
666     echo "\" ";
667     echo ">";
668     //
669     echo _("Retour");
670     //
671     echo "</a>\n";
672     } else {
673     parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
674     $objsf, $premiersf, $tricolsf, $validation,
675     $idx, $maj, $retour);
676     }
677     }
678 vpihour 1784
679 vpihour 1881 /**
680     * Ajout des contraintes spécifiques pour l'ajout d'un fichier en retour de
681     * consultation
682     */
683     function setSelect(&$form, $maj,&$db,$debug) {
684 fmichon 3172 if(file_exists ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc.php"))
685     include ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc.php");
686     elseif(file_exists ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc"))
687     include ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc");
688 atreal 2731
689     // avis_consultation
690     $this->init_select($form, $db, $maj, $debug, "avis_consultation",
691     $sql_avis_consultation, $sql_avis_consultation_by_id, true);
692    
693     // service
694     $this->init_select($form, $db, $maj, $debug, "service",
695     $sql_service, $sql_service_by_id, true);
696    
697 vpihour 1881 //Seulement dans le cas d'un retour d'avis
698     if($this->retourformulaire == "demande_avis_encours") {
699    
700     //Tableau des contraintes spécifiques
701     $params = array(
702     "constraint" => array(
703     "size_max" => 2,
704     "extension" => ".pdf"
705     ),
706     );
707    
708     $form->setSelect("fichier", $params);
709     }
710     }
711 vpihour 2603
712 vpihour 1930 /**
713     * Finalisation du document lors de l'ajout d'une consultation
714     */
715     function finaliserAjouter(){
716    
717     //Génération du PDF
718     $_GET['output'] = "string";
719     $_GET['obj'] = "consultation";
720     $_GET['idx'] = $this->valF[$this->clePrimaire];
721     $f = $this->f;
722     include '../app/pdf_consultation.php';
723    
724     //Métadonnées du document
725     $metadata = array(
726     'filename' => 'consultation_'.$idx.'.pdf',
727     'mimetype' => 'application/pdf',
728     'size' => strlen($pdf_output)
729     );
730    
731 nhaye 1935 // Récupération des métadonnées calculées après validation
732 nhaye 1938 $spe_metadata = $this->getMetadata("om_fichier_consultation");
733 nhaye 1935
734     $metadata = array_merge($metadata, $spe_metadata);
735    
736 vpihour 1930 //On ajoute le document et on récupère son uid
737     $uid = $this->f->storage->create($pdf_output, $metadata);
738    
739     //Mise à jour des données
740 vpihour 2789 if ( $uid != '' && $uid != 'OP_FAILURE' ){
741 vpihour 1930 // Logger
742     $this->addToLog("finaliserAjouter() - begin", EXTRA_VERBOSE_MODE);
743    
744     $valF = array(
745     "om_final_consultation"=> TRUE,
746     "om_fichier_consultation"=>$uid);
747    
748     // Execution de la requête de modification des donnees de l'attribut
749     // valF de l'objet dans l'attribut table de l'objet
750     $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
751     DB_AUTOQUERY_UPDATE, $this->getCle($idx));
752     $this->addToLog("finaliserAjouter() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($idx)."\")", VERBOSE_MODE);
753     // Si une erreur survient
754     if (database::isError($res)) {
755     // Appel de la methode de recuperation des erreurs
756     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
757     } else {
758     // Log
759     $this->addToLog(_("Requete executee"), VERBOSE_MODE);
760     // Log
761     $message = _("Enregistrement")."&nbsp;".$idx."&nbsp;";
762     $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
763     $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
764     $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
765     $this->addToLog($message, VERBOSE_MODE);
766     }
767     }
768     }
769 nhaye 1935
770 vpihour 2603 /**
771     * Finalisation des documents.
772     * @param string $champ champ du fichier à finaliser
773     * @param booleen $status permet de définir si on finalise ou définalise
774     * @param string $sousform permet de savoir si se trouve dans un sousformulaire (passé au javascript)
775     */
776     function finaliser($champ = '', $status, $sousform, $retourformulaire) {
777 nhaye 1935
778 vpihour 3027 // Recuperation de la valeur de la cle primaire de l'objet
779     if ($this->getVal($this->clePrimaire) != '') {
780     //
781     $id = $this->getVal($this->clePrimaire);
782     }
783     else {
784     //
785     $id=$this->id;
786     }
787    
788 vpihour 2603 // Si on finalise le document
789     if ($status == 1) {
790    
791     // Génération du PDF
792     $_GET['output'] = "string";
793     $f = $this->f;
794     include '../app/pdf_consultation.php';
795    
796     // Métadonnées du document
797     $metadata = array(
798     'filename' => 'consultation_'.$idx.'.pdf',
799     'mimetype' => 'application/pdf',
800     'size' => strlen($pdf_output)
801     );
802    
803     // Récupération des métadonnées calculées après validation
804     $spe_metadata = $this->getMetadata("om_fichier_consultation");
805    
806     $metadata = array_merge($metadata, $spe_metadata);
807    
808     // Si le document a déjà été finalisé
809     if ( $this->getVal("om_fichier_consultation") != '' ){
810    
811     // Met à jour le document mais pas son uid
812     $uid = $this->f->storage->update(
813     $this->getVal("om_fichier_consultation"), $pdf_output, $metadata);
814     }
815     // Sinon, ajoute le document et récupère son uid
816     else {
817    
818     // Stockage du PDF
819     $uid = $this->f->storage->create($pdf_output, $metadata);
820     }
821    
822     }
823     //
824     else {
825    
826     //Récupération de l'uid du document finalisé
827     $uid = $this->getVal("om_fichier_consultation");
828    
829     //On dé-finalise avant de finaliser
830     if ( $uid == '' || $uid == 'OP_FAILURE' ){
831 vpihour 3027 $this->addToLog(
832     _("Finalisation non enregistree")." - ".
833     _("id consultation")." = ".$id." - ".
834     _("uid fichier")." = ".$uid
835     );
836 vpihour 2603 return -1;
837     }
838     }
839    
840 vpihour 3027
841 vpihour 2603 //Mise à jour des données
842 vpihour 2789 if ($uid != '' && $uid != 'OP_FAILURE') {
843 vpihour 2603
844     // Logger
845     $this->addToLog("finaliser() - begin", EXTRA_VERBOSE_MODE);
846    
847     $actions = array();
848    
849     // Tableau contenant le lien vers le PDF et lien du portlet pour la
850     // mise à jour de l'interface
851     if ($status == 0) {
852    
853     // Lien pour ouvrir le PDF
854     $lien = '../app/pdf_consultation.php?idx='.$id;
855    
856     //
857     if ($this->f->isAccredited('consultation') ||
858     $this->f->isAccredited('consultation_modifier')) {
859    
860     $actions["modifier"] = ($sousform!='')?
861     '<li><a href="#" onclick="ajaxIt(\'consultation\',
862     \'../scr/sousform.php?obj=consultation&amp;action=1&amp;idx='.
863     $this->getVal($this->clePrimaire).
864     '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
865     $this->getVal("dossier").
866     '&amp;retour=form\');">
867     <span class="om-prev-icon om-icon-16 edit-16" title="'.
868     _('Modifier').'">'.
869     _('Modifier').
870     '</span></a></li>':
871     '<li>
872     <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
873     $this->getVal($this->clePrimaire).
874     '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
875     <span class="om-prev-icon om-icon-16 edit-16" title="'.
876     _('Modifier').'">'.
877     _('Modifier').
878     '</span></a></li>';
879     }
880    
881     //Si l'utilisateur a le droit de supprimer l'objet
882     if ( $this->f->isAccredited('consultation') ||
883     $this->f->isAccredited('consultation_supprimer') ){
884    
885     $actions["supprimer"] = ($sousform!='')?
886     '<li><a href="#" onclick="ajaxIt(\'consultation\',
887     \'../scr/sousform.php?obj=consultation&amp;action=2&amp;idx='.
888     $this->getVal($this->clePrimaire).
889     '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
890     $this->getVal("dossier").
891     '&amp;retour=form\');">
892     <span class="om-prev-icon om-icon-16 delete-16" title="'.
893     _('Supprimer').'">'.
894     _('Supprimer').
895     '</span></a></li>':
896     '<li>
897     <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
898     $this->getVal($this->clePrimaire).
899     '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
900     <span class="om-prev-icon om-icon-16 delete-16" title="'.
901     _('Supprimer').'">'.
902     _('Supprimer').
903     '</span></a></li>';
904     }
905     }
906     else {
907    
908     // Lien permettant d'afficher le PDF
909     $lien = '../spg/file.php?obj=consultation&'.
910     'champ=om_fichier_consultation&id='.$id;
911     }
912    
913     //
914     $retour = array(
915     "portlet"=> "<a href=\"#\" onclick=\"finalizeDocument(".
916     $id.", 'consultation', '".$sousform."', ".(($status==0)?1:0).")\">
917     <span class=\"om-prev-icon om-icon-16 om-icon-fix "
918     .(($status==1)?"de":"")."finalise\" title=\"".
919     (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."\">".
920     (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."</span>
921     </a>",
922     "pdf" => $lien,
923     "actions" => $actions
924     );
925    
926     foreach ($this->champs as $key => $value) {
927     //
928     $val[$value] = $this->val[$key];
929     }
930    
931     $this->setvalF($val);
932    
933     // Verification de la validite des donnees
934     $this->verifier($this->val, $this->db, DEBUG);
935     // Verification du verrou
936     $this->testverrou();
937     // Si les verifications precedentes sont correctes, on procede a
938     // la modification, sinon on ne fait rien et on retourne une erreur
939     if ($this->correct) {
940    
941     // Execution du trigger 'before' specifique au MODE 'update'
942     $this->triggermodifier( $id, $this->db, $this->val, DEBUG);
943    
944     //
945     $valF = '';
946     $valF["om_final_consultation"] = ($status==1)?TRUE:FALSE;
947     $valF["om_fichier_consultation"] = $uid;
948    
949     // Execution de la requête de modification des donnees de l'attribut
950     // valF de l'objet dans l'attribut table de l'objet
951     $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
952     DB_AUTOQUERY_UPDATE, $this->getCle($id));
953     $this->addToLog("finaliser() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($id)."\")", VERBOSE_MODE);
954    
955     // Si une erreur survient
956     if (database::isError($res)) {
957    
958     // Appel de la methode de recuperation des erreurs
959     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
960     } else {
961    
962     // Log
963     $this->addToLog(_("Requete executee"), VERBOSE_MODE);
964     // Log
965     $message = _("Enregistrement")."&nbsp;".$id."&nbsp;";
966     $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
967     $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
968     $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
969     $this->addToLog($message, VERBOSE_MODE);
970     // Mise en place du verrou pour ne pas finaliser plusieurs fois
971     // le meme document
972     $this->verrouille();
973     // Execution du trigger 'after' specifique au MODE 'update'
974     $this->triggermodifierapres($id, $this->db, $this->val, DEBUG);
975    
976     return $retour;
977     }
978     //
979     } else {
980    
981     // Message d'echec (saut d'une ligne supplementaire avant le
982     // message pour qu'il soit mis en evidence)
983 nhaye 3021 $this->addToLog(
984     _("Finalisation non enregistree")." - ".
985 vpihour 3027 _("id consultation")." = ".$id." - ".
986 nhaye 3021 _("uid fichier")." = ".$uid
987     );
988 vpihour 2603 return -1;
989     }
990     }
991     // Si le document n'a pas été stocké
992     else{
993 nhaye 3021 $this->addToLog(
994     _("Finalisation non enregistree")." - ".
995 vpihour 3027 _("id consultation")." = ".$id." - ".
996 nhaye 3021 _("uid fichier")." = ".$uid
997     );
998 vpihour 2603 return -1;
999     }
1000     }
1001    
1002 nhaye 3023 /**
1003     * Création du nom de fichier
1004     * @return string numéro de dossier d'instruction
1005     */
1006     protected function getFichierFilename() {
1007     return "consultation_avis_".$this->valF[$this->clePrimaire].".pdf";
1008     }
1009 vpihour 2603
1010 nhaye 1935 /**
1011     * Récupération du numéro de dossier d'instruction à ajouter aux métadonnées
1012 nhaye 1949 * @return string numéro de dossier d'instruction
1013 nhaye 1935 */
1014     protected function getDossier() {
1015     if(empty($this->specificMetadata)) {
1016     $this->getSpecificMetadata();
1017     }
1018     return $this->specificMetadata->dossier;
1019     }
1020     /**
1021 softime 2016 * Récupération la version du dossier d'instruction à ajouter aux métadonnées
1022     * @return int Version
1023     */
1024     protected function getDossierVersion() {
1025     if(empty($this->specificMetadata)) {
1026     $this->getSpecificMetadata();
1027     }
1028     return $this->specificMetadata->version;
1029     }
1030     /**
1031 nhaye 1935 * Récupération du numéro de dossier d'autorisation à ajouter aux métadonnées
1032 nhaye 1949 * @return string numéro de dossier d'autorisation
1033 nhaye 1935 */
1034 softime 2025 protected function getNumDemandeAutor() {
1035 nhaye 1935 if(empty($this->specificMetadata)) {
1036     $this->getSpecificMetadata();
1037     }
1038     return $this->specificMetadata->dossier_autorisation;
1039     }
1040     /**
1041     * Récupération de la date de demande initiale du dossier à ajouter aux métadonnées
1042 nhaye 1949 * @return date demande initiale
1043 nhaye 1935 */
1044 softime 2025 protected function getAnneemoisDemandeAutor() {
1045 nhaye 1935 if(empty($this->specificMetadata)) {
1046     $this->getSpecificMetadata();
1047     }
1048     return $this->specificMetadata->date_demande_initiale;
1049     }
1050     /**
1051     * Récupération du type de dossier d'instruction à ajouter aux métadonnées
1052 nhaye 1949 * @return string type de dossier d'instruction
1053 nhaye 1935 */
1054 softime 2025 protected function getTypeInstruction() {
1055 nhaye 1935 if(empty($this->specificMetadata)) {
1056     $this->getSpecificMetadata();
1057     }
1058     return $this->specificMetadata->dossier_instruction_type;
1059     }
1060     /**
1061     * Récupération du statut du dossier d'autorisation à ajouter aux métadonnées
1062 nhaye 1949 * @return string avis
1063 nhaye 1935 */
1064 softime 2025 protected function getStatutAutorisation() {
1065 nhaye 1935 if(empty($this->specificMetadata)) {
1066     $this->getSpecificMetadata();
1067     }
1068     return $this->specificMetadata->statut;
1069     }
1070     /**
1071     * Récupération du type de dossier d'autorisation à ajouter aux métadonnées
1072 nhaye 1949 * @return string type d'autorisation
1073 nhaye 1935 */
1074 softime 2025 protected function getTypeAutorisation() {
1075 nhaye 1935 if(empty($this->specificMetadata)) {
1076     $this->getSpecificMetadata();
1077     }
1078     return $this->specificMetadata->dossier_autorisation_type;
1079     }
1080     /**
1081     * Récupération de la date d'ajout de document à ajouter aux métadonnées
1082 nhaye 1949 * @return date de l'évènement
1083 nhaye 1935 */
1084 softime 2025 protected function getDateEvenementDocument() {
1085 softime 2046 return date("Y-m-d");
1086 nhaye 1935 }
1087     /**
1088     * Récupération du groupe d'instruction à ajouter aux métadonnées
1089     * @return string Groupe d'instruction
1090     */
1091     protected function getGroupeInstruction() {
1092     if(empty($this->specificMetadata)) {
1093     $this->getSpecificMetadata();
1094     }
1095     return $this->specificMetadata->groupe_instruction;
1096     }
1097 softime 2002 /**
1098     * Récupération du type de document à ajouter aux métadonnées
1099     * @return string Type de document
1100     */
1101 softime 2025 protected function getTitle() {
1102 softime 2002 if ($this->retourformulaire == "demande_avis_encours") {
1103     return 'Retour de consultation';
1104     } else {
1105     return 'Demande de consultation';
1106     }
1107     }
1108 nhaye 1935
1109     /**
1110     * Cette méthode permet de stocker en attribut toutes les métadonnées
1111     * nécessaire à l'ajout d'un document.
1112     */
1113     public function getSpecificMetadata() {
1114     if (isset($this->valF["dossier"]) AND $this->valF["dossier"] != "") {
1115     $dossier = $this->valF["dossier"];
1116     } else {
1117     $dossier = $this->getVal("dossier");
1118     }
1119     //Requête pour récupérer les informations essentiels sur le dossier d'instruction
1120     $sql = "SELECT dossier.dossier as dossier,
1121     dossier_autorisation.dossier_autorisation as dossier_autorisation,
1122     to_char(dossier.date_demande, 'YYYY/MM') as date_demande_initiale,
1123     dossier_instruction_type.code as dossier_instruction_type,
1124     etat_dossier_autorisation.libelle as statut,
1125     dossier_autorisation_type.code as dossier_autorisation_type,
1126     groupe.code as groupe_instruction
1127     FROM ".DB_PREFIXE."dossier
1128     LEFT JOIN ".DB_PREFIXE."dossier_instruction_type
1129     ON dossier.dossier_instruction_type = dossier_instruction_type.dossier_instruction_type
1130     LEFT JOIN ".DB_PREFIXE."dossier_autorisation
1131     ON dossier.dossier_autorisation = dossier_autorisation.dossier_autorisation
1132     LEFT JOIN ".DB_PREFIXE."etat_dossier_autorisation
1133     ON dossier_autorisation.etat_dossier_autorisation = etat_dossier_autorisation.etat_dossier_autorisation
1134     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
1135     ON dossier_autorisation.dossier_autorisation_type_detaille = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
1136     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type
1137     ON dossier_autorisation_type_detaille.dossier_autorisation_type = dossier_autorisation_type.dossier_autorisation_type
1138     LEFT JOIN ".DB_PREFIXE."groupe
1139     ON dossier_autorisation_type.groupe = groupe.groupe
1140     WHERE dossier.dossier = '".$dossier."'";
1141     $res = $this->db->query($sql);
1142     $this->f->addToLog("obj/document_numerise.class.php : db->query(".$sql.")", VERBOSE_MODE);
1143     if ( database::isError($res)){
1144     die();
1145     }
1146    
1147     //Le résultat est récupéré dans un objet
1148     $row =& $res->fetchRow(DB_FETCHMODE_OBJECT);
1149    
1150     //Si il y a un résultat
1151     if ($row !== null) {
1152 vpihour 2119
1153     //Génération du numéro de version
1154     $sql = "SELECT
1155     count(*)
1156     FROM
1157     ".DB_PREFIXE."dossier
1158     LEFT JOIN
1159     ".DB_PREFIXE."dossier_autorisation
1160     ON
1161     dossier_autorisation.dossier_autorisation = dossier.dossier_autorisation
1162     LEFT JOIN
1163     ".DB_PREFIXE."dossier_instruction_type
1164     ON
1165     dossier_instruction_type.dossier_instruction_type = dossier.dossier_instruction_type
1166     WHERE
1167 softime 2120 dossier_autorisation.dossier_autorisation = '".$row->dossier_autorisation."'
1168 vpihour 2119 AND
1169 softime 2120 dossier_instruction_type.code = '".$row->dossier_instruction_type."'";
1170     $row->version = $this->db->getOne($sql);
1171 vpihour 2119 $this->f->addToLog("getInfosForFoldername(): db->getOne(\"".$sql."\")", VERBOSE_MODE);
1172 softime 2120 if ( database::isError($row->version)){
1173     $this->f->addToError("", $row->version, $row->version);
1174 vpihour 2119 return false;
1175     }
1176    
1177     //Formatage du numéro de version
1178 softime 2120 $row->version = str_pad($row->version, 2, "0", STR_PAD_LEFT);
1179 nhaye 1935
1180     //Alors on créé l'objet dossier_instruction
1181     $this->specificMetadata = $row;
1182    
1183     }
1184     }
1185 softime 2112
1186 fraynaud 3 }// fin classe
1187 vpihour 2603 ?>

Properties

Name Value
svn:keywords Id

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26