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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1540 - (hide annotations)
Thu Mar 21 06:50:50 2013 UTC (11 years, 10 months ago) by fmichon
File size: 17262 byte(s)
Nettoyage de la classe instruction + Ajout d'un select multiple pour sélectionner les états depuis le formulaire de l'événement

1 fraynaud 3 <?php
2 fmichon 1540 /**
3     *
4     *
5     * @package openfoncier
6     * @version SVN : $Id$
7     */
8 fraynaud 3
9 fmichon 1540 //
10     require_once "../gen/obj/evenement.class.php";
11    
12 fraynaud 3 class evenement extends evenement_gen {
13    
14 fmichon 1540 function evenement($id, &$db, $debug) {
15     $this->constructeur($id, $db, $debug);
16     }
17 fraynaud 3
18 fmichon 1540 function setType(&$form, $maj) {
19     //
20     parent::setType($form, $maj);
21     // MODE AJOUTER et MODE MODIFIER
22     if ($maj == 0 || $maj == 1) {
23     //
24 fraynaud 7 $form->setType('accord_tacite', 'select');
25     $form->setType('delai_notification', 'select');
26     $form->setType('delai', 'select');
27     $form->setType('lettretype', 'select');
28 nhaye 433 $form->setType('consultation', 'checkbox');
29 vpihour 1133 $form->setType('dossier_instruction_type','select_multiple');
30 fmichon 1503 $form->setType('type','select');
31 fmichon 1540 $form->setType('etats_depuis_lequel_l_evenement_est_disponible','select_multiple');
32 fraynaud 7 }
33 fmichon 1540 // MODE SUPPRIMER et MODE CONSULTER
34     if ($maj == 2 || $maj == 3) {
35     //
36 vpihour 1133 $form->setType('dossier_instruction_type','select_multiple_static');
37 fmichon 1540 $form->setType('etats_depuis_lequel_l_evenement_est_disponible','select_multiple_static');
38     }
39 fraynaud 7 }
40 atreal 312
41 fmichon 1540 function setSelect(&$form, $maj, $db, $debug) {
42     //
43     parent::setSelect($form, $maj, $db, $debug);
44     //
45     if(file_exists ("../sql/".$db->phptype."/".$this->table.".form.inc.php")) {
46     include ("../sql/".$db->phptype."/".$this->table.".form.inc.php");
47     }
48     //
49 atreal 312 if($maj<2){
50     // lettretype
51 vpihour 1133
52 atreal 312 $contenu=array();
53     $res = $db->query($sql_om_lettretype);
54     if (database::isError($res))
55     die($res->getMessage().$sql_om_lettretype);
56     else{
57     if ($debug == 1)
58     echo " la requete ".$sql_om_lettretype." est executee<br>";
59     $contenu[0][0]='';
60     $contenu[1][0]=_('choisir')."&nbsp;"._('lettretype');
61     $k=1;
62     while ($row=& $res->fetchRow()){
63     $contenu[0][$k]=$row[0];
64     $contenu[1][$k]=$row[1];
65     $k++;
66     }
67     $form->setSelect('lettretype',$contenu);
68     }// fin error db
69 fraynaud 7 }
70     // accord_tacite
71     $contenu=array();
72     $contenu[0]=array('Non','Oui');
73     $contenu[1]=array($this->lang('Non'),$this->lang('Oui'));
74     $form->setSelect("accord_tacite",$contenu);
75     // delai_notification
76     $contenu=array();
77     $contenu[0]=array('0','1');
78     $contenu[1]=array('sans','1 '.$this->lang("mois"));
79     $form->setSelect("delai_notification",$contenu);
80     // delai
81     $contenu=array();
82     $contenu[0]=array('0','1','2','3','4','5','6','7','8','9','10','11','12','18','24');
83     $contenu[1]=array('sans',
84     '1 '._("mois"),
85     '2 '._("mois"),
86     '3 '._("mois"),
87     '4 '._("mois"),
88     '5 '._("mois"),
89     '6 '._("mois"),
90     '7 '._("mois"),
91     '8 '._("mois"),
92     '9 '._("mois"),
93     '10 '._("mois"),
94     '11 '._("mois"),
95     '12 '._("mois"),
96     '18 '._("mois"),
97     '24 '._("mois")
98 atreal 312 );
99 fraynaud 7 $form->setSelect("delai",$contenu);
100 fmichon 1503
101     // type de l'événement
102     $contenu=array();
103     $contenu[0]=array('', 'arrete', 'incompletude', 'majoration_delai', );
104     $contenu[1]=array(_('choisir type'), _('arrete'), _('incompletude'), _('majoration_delai'),);
105     $form->setSelect("type",$contenu);
106    
107 vpihour 1133 // dossier_instruction_type
108     $this->init_select($form, $db, $maj, $debug, "dossier_instruction_type",
109 fmichon 1540 $sql_dossier_instruction_type, $sql_dossier_instruction_type_by_id, false, true);
110     // dossier_instruction_type
111     $this->init_select($form, $db, $maj, $debug, "etats_depuis_lequel_l_evenement_est_disponible",
112     $sql_etats_depuis_lequel_l_evenement_est_disponible, $sql_etats_depuis_lequel_l_evenement_est_disponible_by_id, false, true);
113 fraynaud 7 }
114 fmichon 1540
115 vpihour 1133 function setTaille(&$form, $maj) {
116 fmichon 1540 //
117 vpihour 1133 parent::setTaille($form, $maj);
118 fmichon 1540 //
119     $form->setTaille("dossier_instruction_type", 10);
120     $form->setTaille("etats_depuis_lequel_l_evenement_est_disponible", 10);
121 vpihour 1133 }
122 fmichon 1540
123 vpihour 1133 function setMax(&$form, $maj) {
124 fmichon 1540 //
125 vpihour 1133 parent::setMax($form, $maj);
126 fmichon 1540 //
127 vpihour 1133 $form->setMax("dossier_instruction_type", 5);
128 fmichon 1540 $form->setMax("etats_depuis_lequel_l_evenement_est_disponible", 5);
129 vpihour 1133 }
130 fraynaud 7
131 fmichon 1540 function setLib(&$form, $maj) {
132     //
133     parent::setLib($form, $maj);
134     //
135     $form->setLib("dossier_instruction_type", _("type(s) de DI concerne(s)"));
136     $form->setLib("etats_depuis_lequel_l_evenement_est_disponible", _("etat(s) source(s)"));
137     }
138    
139 vpihour 1133 //Ajoute autant de lien_dossier_instruction_type_evenement que de dossier_instruction_type
140     function triggerajouterapres($id,&$db,$val,$DEBUG) {
141 fmichon 1540 //
142 vpihour 1133 parent::triggerajouterapres($id,$db,$val,$DEBUG);
143 atreal 312
144 fmichon 1540 /**
145     * LIEN ETAT
146     */
147     // Récupération des données du select multiple
148     $etats_depuis_lequel_l_evenement_est_disponible = $this->getPostedValues('etats_depuis_lequel_l_evenement_est_disponible');
149     // Ne traite les données que s'il y en a et qu'elles sont correctes
150     if (is_array($etats_depuis_lequel_l_evenement_est_disponible)
151     && count($etats_depuis_lequel_l_evenement_est_disponible) > 0 ){
152     // Initialisation
153     $nb_liens_etat = 0;
154     // Boucle sur la liste des états sélectionnés
155     foreach ($etats_depuis_lequel_l_evenement_est_disponible as $value) {
156     // Test si la valeur par défaut est sélectionnée
157     if ($value != "") {
158     //
159     $donnees = array(
160     'evenement' => $this->valF['evenement'],
161     'etat' => $value
162     );
163     // On ajoute l'enregistrement
164     $this->ajouter_lien_etat_evenement($donnees);
165     // On compte le nombre d'éléments ajoutés
166     $nb_liens_etat++;
167     }
168     }
169     // Message de confirmation
170     if ($nb_liens_etat > 0) {
171     if ($nb_liens_etat == 1 ){
172     $this->addToMessage(_("Creation de ").$nb_liens_etat._(" nouvelle liaison realisee avec succes."));
173     } else{
174     $this->addToMessage(_("Creation de ").$nb_liens_etat._(" nouvelles liaisons realisees avec succes."));
175     }
176     }
177     }
178    
179     /**
180     * LIEN DI TYPE
181     */
182 vpihour 1133 //Récupère les données du select multiple
183     $dossier_instruction_type = $this->getPostedValues('dossier_instruction_type');
184     //Ne traite les données que s'il y en a et qu'elles sont correctes
185     if ( is_array($dossier_instruction_type) && count($dossier_instruction_type) > 0 ){
186    
187     $nb_tr = 0;
188 vpihour 1134 /* Va créer autant de lien_dossier_instruction_type_evenement
189     * que de dossier_instruction_type choisis */
190 vpihour 1133 foreach( $dossier_instruction_type as $value ){
191    
192     //Test si la valeur par défaut est sélectionnée
193     if ( $value != "" ) {
194    
195     //Données
196     $donnees = array(
197     'evenement' => $this->valF['evenement'],
198     'dossier_instruction_type' => $value
199     );
200    
201 vpihour 1134 //Ajoute un nouveau lien_dossier_instruction_type_evenement
202     $this->addLienDossierInstructionType($donnees, $db, $DEBUG);
203 vpihour 1133
204     $nb_tr++;
205     }
206     }
207    
208     //Message de confirmation de création de(s) lien_dossier_instruction_type_evenement(s).
209     if ( $nb_tr > 0 ){
210    
211     if ( $nb_tr == 1 ){
212    
213 vpihour 1173 $this->addToMessage(_("Creation de ").$nb_tr._(" nouvelle liaison
214 vpihour 1135 realisee avec succes."));
215 vpihour 1133 }
216     else{
217    
218 vpihour 1173 $this->addToMessage(_("Creation de ").$nb_tr._(" nouvelles liaisions
219 vpihour 1135 realisee avec succes."));
220 vpihour 1133 }
221     }
222     }
223    
224     }
225    
226     //Fonction générique permettant de récupérer les données d'un champ postées
227     function getPostedValues($champ) {
228    
229     // Récupération des demandeurs dans POST
230     if (isset($_POST[$champ]) ) {
231    
232     return $_POST[$champ];
233     }
234     }
235    
236     //Modification des liens
237     function triggerModifierApres($id, &$db, $val, $DEBUG){
238 fmichon 1540 //
239 vpihour 1133 parent::triggerModifierApres($id, $db, $val, $DEBUG);
240 fmichon 1540
241     /**
242     * LIEN ETAT
243     */
244     // Suppression de tous les liens de la table transition (table lien
245     // entre etat et evenement)
246     $this->supprimer_liens_etat_evenement($this->valF['evenement']);
247     // Récupération des données du select multiple
248     $etats_depuis_lequel_l_evenement_est_disponible = $this->getPostedValues('etats_depuis_lequel_l_evenement_est_disponible');
249     // Ne traite les données que s'il y en a et qu'elles sont correctes
250     if (is_array($etats_depuis_lequel_l_evenement_est_disponible)
251     && count($etats_depuis_lequel_l_evenement_est_disponible) > 0 ){
252     // Initialisation
253     $nb_liens_etat = 0;
254     // Boucle sur la liste des états sélectionnés
255     foreach ($etats_depuis_lequel_l_evenement_est_disponible as $value) {
256     // Test si la valeur par défaut est sélectionnée
257     if ($value != "") {
258     //
259     $donnees = array(
260     'evenement' => $this->valF['evenement'],
261     'etat' => $value
262     );
263     // On ajoute l'enregistrement
264     $this->ajouter_lien_etat_evenement($donnees);
265     // On compte le nombre d'éléments ajoutés
266     $nb_liens_etat++;
267     }
268     }
269     // Message de confirmation
270     if ($nb_liens_etat > 0) {
271     $this->addToMessage(_("Mise a jour des liaisons realisee avec succes."));
272     }
273     }
274    
275     /**
276     * LIEN DI TYPE
277     */
278 vpihour 1133 //Supprime toutes les liaisions liées à l'événement
279     $this->deleteAllLienDossierInstructionTypeEvenementEvenement($this->valF['evenement'], $db, $DEBUG);
280    
281     //Récupère les données du select multiple
282     $dossier_instruction_type = $this->getPostedValues('dossier_instruction_type');
283    
284     //Ne traite les données que s'il y en a et qu'elles sont correctes
285     if ( is_array($dossier_instruction_type) && count($dossier_instruction_type) > 0 ){
286    
287     $nb_tr = 0;
288     //Va créer autant de lien_dossier_instruction_type_evenement que de dossier_instruction_type choisis
289     foreach( $dossier_instruction_type as $value ){
290    
291     //Test si la valeur par défaut est sélectionnée
292     if ( $value != "" ) {
293    
294     //Données
295     $donnees = array(
296     'evenement' => $this->valF['evenement'],
297     'dossier_instruction_type' => $value
298     );
299    
300 vpihour 1134 //Ajoute un nouveau lien_dossier_instruction_type_evenement
301     $this->addLienDossierInstructionType($donnees, $db, $DEBUG);
302 vpihour 1133
303     $nb_tr++;
304     }
305     }
306    
307 vpihour 1134 //Message de confirmation de création de(s) lien_dossier_instruction_type_evenement.
308 vpihour 1133 if ( $nb_tr > 0 ){
309    
310 fmichon 1159 $this->addToMessage(_("Mise a jour des liaisons realisee avec succes."));
311 vpihour 1133 }
312     }
313     }
314    
315 fmichon 1540 /**
316     * Ajout d'un lien dans la table transition (table lien entre etat et
317     * evenement)
318     */
319     function ajouter_lien_etat_evenement($data) {
320     //
321     require_once '../obj/transition.class.php';
322     $lien_etat_evenement = new transition("]", $this->db, false);
323     // ???
324     $lien_etat_evenement->valF = "";
325     $val['transition'] = NULL;
326     //
327     if (is_array($data)) {
328     foreach ($data as $key => $value) {
329     $val[$key]=$value;
330     }
331     }
332     //
333     $lien_etat_evenement->ajouter($val, $this->db, false);
334     }
335    
336     /**
337     * Suppression de tous les liens de la table transition (table lien entre
338     * etat etevenement)
339     */
340     function supprimer_liens_etat_evenement($id) {
341     // Suppression de tous les enregistrements correspondants à l'id de
342     // l'événement
343     $sql = "DELETE
344     FROM ".DB_PREFIXE."transition
345     WHERE evenement=".$id;
346     $res = $this->db->query($sql);
347     $this->f->addToLog("supprimer_liens_etat_evenement(): db->query(\"".$sql."\");", VERBOSE_MODE);
348     $this->f->isDatabaseError();
349     }
350    
351 vpihour 1133 //Ajoute un nouveau lien_dossier_instruction_type_evenement
352     // $data array de données
353 vpihour 1134 function addLienDossierInstructionType($data, $db, $DEBUG){
354 vpihour 1133
355     require_once '../obj/lien_dossier_instruction_type_evenement.class.php';
356    
357     $lien_dossier_instruction_type_evenement = new lien_dossier_instruction_type_evenement("]",$db,$DEBUG);
358     $lien_dossier_instruction_type_evenement->valF = "";
359    
360     //Données
361     $vallien_dossier_instruction_type_evenement['lien_dossier_instruction_type_evenement']=NULL;
362    
363     if ( is_array($data) ){
364    
365     foreach ($data as $key => $value) {
366    
367     $vallien_dossier_instruction_type_evenement[$key]=$value;
368     }
369     }
370    
371     $lien_dossier_instruction_type_evenement->ajouter($vallien_dossier_instruction_type_evenement, $db, $DEBUG);
372     }
373    
374     //Supprime toutes les lien_dossier_instruction_type_evenement liées à un événement
375     function deleteAllLienDossierInstructionTypeEvenementEvenement($id, $db, $DEBUG){
376    
377     //Création de la requête
378     $sql = "DELETE FROM
379     ".DB_PREFIXE."lien_dossier_instruction_type_evenement
380     WHERE
381     evenement = $id";
382    
383     //Exécution de la requête
384     $res = $db->query($sql);
385    
386     //Ajout au log
387     $this->f->addToLog("deleteAllLienDossierInstructionTypeEvenementEvenement(): db->query(\"".$sql."\");", VERBOSE_MODE);
388     $this->f->isDatabaseError();
389     }
390    
391     function triggersupprimer($id, &$db, $val, $DEBUG){
392 fmichon 1540 // Suppression de tous les liens de la table transition (table lien
393     // entre etat et evenement)
394     $this->supprimer_liens_etat_evenement($id);
395 vpihour 1134 //Supprime toutes les lien_dossier_instruction_type_evenement liées à l'evenement
396 vpihour 1133 $this->deleteAllLienDossierInstructionTypeEvenementEvenement($id, $db, $DEBUG);
397     }
398    
399     /* Surcharge de la fonction cleSecondaire pour qu'elle ne vérifie pas le lien avec
400 fmichon 1540 * lien_dossier_instruction_type_evenement qui sera supprimé juste après ni avec la table transition*/
401 vpihour 1133 function cleSecondaire($id, &$db = NULL, $val = array(), $DEBUG = false) {
402    
403     // Verification de la cle secondaire : bible
404     $this->rechercheTable($db, "bible", "evenement", $id);
405     // Verification de la cle secondaire : demande_type
406     $this->rechercheTable($db, "demande_type", "evenement", $id);
407     // Verification de la cle secondaire : evenement
408     $this->rechercheTable($db, "evenement", "evenement_retour_ar", $id);
409     // Verification de la cle secondaire : evenement
410     $this->rechercheTable($db, "evenement", "evenement_suivant_tacite", $id);
411     // Verification de la cle secondaire : instruction
412     $this->rechercheTable($db, "instruction", "evenement", $id);
413     // Verification de la cle secondaire : lien_evenement_dossier_autorisation_type
414     $this->rechercheTable($db, "lien_evenement_dossier_autorisation_type", "evenement", $id);
415 fmichon 1540 //// Verification de la cle secondaire : transition
416     //$this->rechercheTable($db, "transition", "evenement", $id);
417 vpihour 1133 }
418    
419 vpihour 1134 //Affichage des dossier_instruction_type anciennement liés
420 vpihour 1133 function setVal(&$form, $maj, $validation, &$db) {
421    
422     parent::setVal($form, $maj, $validation, $db);
423    
424     if($maj == 2 && $validation == 1 ) {
425     $form->setVal("dossier_instruction_type",$this->val[count($this->val)-1]);
426     }
427     }
428    
429 fraynaud 3 }// fin classe
430     ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26