Subversion Repositories Applications.bazar

Rev

Rev 45 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 45 Rev 46
1
<?php
1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
3
// +------------------------------------------------------------------------------------------------------+
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
19
// | License along with this library; if not, write to the Free Software                                  |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
21
// +------------------------------------------------------------------------------------------------------+
22
// CVS : $Id: bazar.fonct.formulaire.php,v 1.5 2005-11-07 17:05:45 florian Exp $
22
// CVS : $Id: bazar.fonct.formulaire.php,v 1.6 2005-11-07 17:30:36 florian Exp $
23
/**
23
/**
24
* Formulaire
24
* Formulaire
25
*
25
*
26
* Les fonctions de mise en page des formulaire
26
* Les fonctions de mise en page des formulaire
27
*
27
*
28
*@package bazar
28
*@package bazar
29
//Auteur original :
29
//Auteur original :
30
*@author        Florian SCHMITT <florian@ecole-et-nature.org>
30
*@author        Florian SCHMITT <florian@ecole-et-nature.org>
31
//Autres auteurs :
31
//Autres auteurs :
32
*@author        Aleandre GRANIER <alexandre@tela-botanica.org>
32
*@author        Aleandre GRANIER <alexandre@tela-botanica.org>
33
*@copyright     Tela-Botanica 2000-2004
33
*@copyright     Tela-Botanica 2000-2004
34
*@version       $Revision: 1.5 $ $Date: 2005-11-07 17:05:45 $
34
*@version       $Revision: 1.6 $ $Date: 2005-11-07 17:30:36 $
35
// +------------------------------------------------------------------------------------------------------+
35
// +------------------------------------------------------------------------------------------------------+
36
*/
36
*/
37
 
37
 
38
require_once 'bazar.fonct.formulaire.controles.php';
38
require_once 'bazar.fonct.formulaire.controles.php';
39
 
39
 
40
//-------------------FONCTIONS DE MISE EN PAGE DES FORMULAIRES
40
//-------------------FONCTIONS DE MISE EN PAGE DES FORMULAIRES
41
 
41
 
42
/** liste() - Ajoute un élément de type liste au formulaire
42
/** liste() - Ajoute un élément de type liste au formulaire
43
*
43
*
44
* @param    mixed   L'objet QuickForm du formulaire
44
* @param    mixed   L'objet QuickForm du formulaire
45
* @param    string  nom du champs dans la table bazar_fiche dans la base de donnée
45
* @param    string  nom du champs dans la table bazar_fiche dans la base de donnée
46
* @param    string  label à afficher dans le formulaire
46
* @param    string  label à afficher dans le formulaire
47
* @param    string  première restriction de la taille des champs du formulaire
47
* @param    string  première restriction de la taille des champs du formulaire
48
* @param    string  deuxième restriction de la taille des champs du formulaire
48
* @param    string  deuxième restriction de la taille des champs du formulaire
49
* @param    string  valeur par défaut du formulaire
49
* @param    string  valeur par défaut du formulaire
50
* @param    string  table source pour les valeurs de la liste
50
* @param    string  table source pour les valeurs de la liste
51
* @param    string  ce champs est il obligatoire? (required)
51
* @param    string  ce champs est il obligatoire? (required)
52
* @return   void
52
* @return   void
53
*/
53
*/
54
function liste(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
54
function liste(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
55
	$requete = 'select * from '.$source;
55
	$requete = 'select * from '.$source;
56
	$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;
56
	$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;
57
	if (DB::isError ($resultat)) {
57
	if (DB::isError ($resultat)) {
58
		die ($GLOBALS['_BAZAR_']['db']->getMessage().$GLOBALS['_BAZAR_']['db']->getDebugInfo()) ;
58
		die ($GLOBALS['_BAZAR_']['db']->getMessage().$GLOBALS['_BAZAR_']['db']->getDebugInfo()) ;
59
	}
59
	}
60
	while ($ligne = $resultat->fetchRow()) {
60
	while ($ligne = $resultat->fetchRow()) {
61
		$select[$ligne[0]] = $ligne[1] ;
61
		$select[$ligne[0]] = $ligne[1] ;
62
	}
62
	}
63
	$option=array('style'=>'width: '.$limite1.'px;');
63
	$option=array('style'=>'width: '.$limite1.'px;');
64
	require_once 'HTML/QuickForm/select.php';
64
	require_once 'HTML/QuickForm/select.php';
65
	$select= new HTML_QuickForm_select($nom_bdd, constant($label), $select, $option);
65
	$select= new HTML_QuickForm_select($nom_bdd, constant($label), $select, $option);
66
	$select->setSize($limite2); 
66
	$select->setSize($limite2); 
67
	$select->setMultiple(0);
67
	$select->setMultiple(0);
68
	$select->setSelected($defaut);
68
	$select->setSelected($defaut);
69
	$formtemplate->addElement($select) ;
69
	$formtemplate->addElement($select) ;
70
	
70
	
71
	//gestion des champs obligatoire
71
	//gestion des champs obligatoire
72
	$formtemplate->registerRule('saisir_liste','function','liste_choisir');
72
	//$formtemplate->registerRule('saisir_liste','function','liste_choisir');
73
	$formtemplate->addRule($nom_bdd, BAZ_CHOISIR_OBLIGATOIRE, 'saisir_liste');
73
	//$formtemplate->addRule($nom_bdd, BAZ_CHOISIR_OBLIGATOIRE , 'saisir_liste');
74
	print_r($formtemplate->getRegisteredRules());
74
	$formtemplate->addRule($nom_bdd, BAZ_CHOISIR_OBLIGATOIRE.' '.constant($label) , 'nonzero', '', 'client') ;
75
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
75
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
76
}
76
}
77
 
77
 
78
 
78
 
79
/** listedatedeb() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de début
79
/** listedatedeb() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de début
80
*
80
*
81
* @param    mixed   L'objet QuickForm du formulaire
81
* @param    mixed   L'objet QuickForm du formulaire
82
* @param    string  nom de la table dans la base de donnée
82
* @param    string  nom de la table dans la base de donnée
83
* @param    string  label à afficher dans le formulaire
83
* @param    string  label à afficher dans le formulaire
84
* @param    string  première restriction de la taille des champs du formulaire
84
* @param    string  première restriction de la taille des champs du formulaire
85
* @param    string  deuxième restriction de la taille des champs du formulaire
85
* @param    string  deuxième restriction de la taille des champs du formulaire
86
* @param    string  valeur par défaut du formulaire
86
* @param    string  valeur par défaut du formulaire
87
* @param    string  table source pour les valeurs de la date
87
* @param    string  table source pour les valeurs de la date
88
* @param    string  ce champs est il obligatoire? (required)
88
* @param    string  ce champs est il obligatoire? (required)
89
* @return   void
89
* @return   void
90
*/
90
*/
91
function listedatedeb(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
91
function listedatedeb(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
92
	$optiondate=array('language' => BAZ_LANGUE_PAR_DEFAUT,'minYear' => date('Y'),'maxYear'=> (date('Y')+10), 'format' => 'd m Y');
92
	$optiondate=array('language' => BAZ_LANGUE_PAR_DEFAUT,'minYear' => date('Y'),'maxYear'=> (date('Y')+10), 'format' => 'd m Y');
93
	$formtemplate->addElement('date', $nom_bdd, constant($label), $optiondate) ;
93
	$formtemplate->addElement('date', $nom_bdd, constant($label), $optiondate) ;
94
	//gestion des valeurs par défaut (date du jour)
94
	//gestion des valeurs par défaut (date du jour)
95
	$defauts=array($nom_bdd => array ('d'=>date('d'), 'm'=>date('m'), 'Y'=>date('Y')));
95
	$defauts=array($nom_bdd => array ('d'=>date('d'), 'm'=>date('m'), 'Y'=>date('Y')));
96
	$formtemplate->setDefaults($defauts);
96
	$formtemplate->setDefaults($defauts);
97
	//gestion du champs obligatoire
97
	//gestion du champs obligatoire
98
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
98
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
99
}
99
}
100
 
100
 
101
/** listedatefin() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de fin
101
/** listedatefin() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de fin
102
*
102
*
103
* @param    mixed   L'objet QuickForm du formulaire
103
* @param    mixed   L'objet QuickForm du formulaire
104
* @param    string  nom de la table dans la base de donnée
104
* @param    string  nom de la table dans la base de donnée
105
* @param    string  label à afficher dans le formulaire
105
* @param    string  label à afficher dans le formulaire
106
* @param    string  première restriction de la taille des champs du formulaire
106
* @param    string  première restriction de la taille des champs du formulaire
107
* @param    string  deuxième restriction de la taille des champs du formulaire
107
* @param    string  deuxième restriction de la taille des champs du formulaire
108
* @param    string  valeur par défaut du formulaire
108
* @param    string  valeur par défaut du formulaire
109
* @param    string  table source pour les valeurs de la date
109
* @param    string  table source pour les valeurs de la date
110
* @param    string  ce champs est il obligatoire? (required)
110
* @param    string  ce champs est il obligatoire? (required)
111
* @return   void
111
* @return   void
112
*/
112
*/
113
function listedatefin(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
113
function listedatefin(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
114
	listedatedeb($formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire);
114
	listedatedeb($formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire);
115
}
115
}
116
 
116
 
117
 
117
 
118
/** texte() - Ajoute un élément de type texte au formulaire
118
/** texte() - Ajoute un élément de type texte au formulaire
119
*
119
*
120
* @param    mixed   L'objet QuickForm du formulaire
120
* @param    mixed   L'objet QuickForm du formulaire
121
* @param    string  nom de la table dans la base de donnée
121
* @param    string  nom de la table dans la base de donnée
122
* @param    string  label à afficher dans le formulaire
122
* @param    string  label à afficher dans le formulaire
123
* @param    string  première restriction de la taille des champs du formulaire
123
* @param    string  première restriction de la taille des champs du formulaire
124
* @param    string  deuxième restriction de la taille des champs du formulaire
124
* @param    string  deuxième restriction de la taille des champs du formulaire
125
* @param    string  valeur par défaut du formulaire
125
* @param    string  valeur par défaut du formulaire
126
* @param    string  table source pour les valeurs du texte (inutile)
126
* @param    string  table source pour les valeurs du texte (inutile)
127
* @param    string  ce champs est il obligatoire? (required)
127
* @param    string  ce champs est il obligatoire? (required)
128
* @return   void
128
* @return   void
129
*/
129
*/
130
function texte(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
130
function texte(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
131
	$option=array('size'=>$limite1,'maxlength'=>$limite2);
131
	$option=array('size'=>$limite1,'maxlength'=>$limite2);
132
	$formtemplate->addElement('text', $nom_bdd, constant($label), $option) ;
132
	$formtemplate->addElement('text', $nom_bdd, constant($label), $option) ;
133
	//gestion des valeurs par défaut
133
	//gestion des valeurs par défaut
134
	$defauts=array($nom_bdd=>$defaut);
134
	$defauts=array($nom_bdd=>$defaut);
135
	$formtemplate->setDefaults($defauts);
135
	$formtemplate->setDefaults($defauts);
136
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
136
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
137
	//gestion du champs obligatoire
137
	//gestion du champs obligatoire
138
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
138
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
139
}
139
}
140
 
140
 
141
 
141
 
142
/** textelong() - Ajoute un élément de type textearea au formulaire
142
/** textelong() - Ajoute un élément de type textearea au formulaire
143
*
143
*
144
* @param    mixed   L'objet QuickForm du formulaire
144
* @param    mixed   L'objet QuickForm du formulaire
145
* @param    string  nom de la table dans la base de donnée
145
* @param    string  nom de la table dans la base de donnée
146
* @param    string  label à afficher dans le formulaire
146
* @param    string  label à afficher dans le formulaire
147
* @param    string  taille des colonnes de l'élément
147
* @param    string  taille des colonnes de l'élément
148
* @param    string  taille des lignes de l'élément
148
* @param    string  taille des lignes de l'élément
149
* @param    string  valeur par défaut du formulaire
149
* @param    string  valeur par défaut du formulaire
150
* @param    string  table source pour les valeurs du texte (inutile)
150
* @param    string  table source pour les valeurs du texte (inutile)
151
* @param    string  ce champs est il obligatoire? (required)
151
* @param    string  ce champs est il obligatoire? (required)
152
* @return   void
152
* @return   void
153
*/
153
*/
154
function textelong(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
154
function textelong(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
155
	$formtexte= new HTML_QuickForm_textarea($nom_bdd, constant($label));
155
	$formtexte= new HTML_QuickForm_textarea($nom_bdd, constant($label));
156
	$formtexte->setCols($limite1);
156
	$formtexte->setCols($limite1);
157
	$formtexte->setRows($limite2);
157
	$formtexte->setRows($limite2);
158
	$formtexte->setWrap('HARD');
158
	$formtexte->setWrap('HARD');
159
	$formtemplate->addElement($formtexte) ;
159
	$formtemplate->addElement($formtexte) ;
160
	//gestion des valeurs par défaut
160
	//gestion des valeurs par défaut
161
	$defauts=array($nom_bdd=>$defaut);
161
	$defauts=array($nom_bdd=>$defaut);
162
	$formtemplate->setDefaults($defauts);
162
	$formtemplate->setDefaults($defauts);
163
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
163
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
164
	//gestion du champs obligatoire
164
	//gestion du champs obligatoire
165
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
165
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
166
}
166
}
167
 
167
 
168
 
168
 
169
/** labelhtml() - Ajoute un élément de type textearea au formulaire
169
/** labelhtml() - Ajoute un élément de type textearea au formulaire
170
*
170
*
171
* @param    mixed   L'objet QuickForm du formulaire
171
* @param    mixed   L'objet QuickForm du formulaire
172
* @param    string  nom de la table dans la base de donnée (pas utilisé)
172
* @param    string  nom de la table dans la base de donnée (pas utilisé)
173
* @param    string  label à afficher dans le formulaire
173
* @param    string  label à afficher dans le formulaire
174
* @param    string  taille des colonnes de l'élément (pas utilisé)
174
* @param    string  taille des colonnes de l'élément (pas utilisé)
175
* @param    string  taille des lignes de l'élément (pas utilisé)
175
* @param    string  taille des lignes de l'élément (pas utilisé)
176
* @param    string  valeur par défaut du formulaire (pas utilisé)
176
* @param    string  valeur par défaut du formulaire (pas utilisé)
177
* @param    string  table source pour les valeurs du texte (pas utilisé)
177
* @param    string  table source pour les valeurs du texte (pas utilisé)
178
* @param    string  ce champs est il obligatoire? (required) (pas utilisé)
178
* @param    string  ce champs est il obligatoire? (required) (pas utilisé)
179
* @return   void
179
* @return   void
180
*/
180
*/
181
function labelhtml(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
181
function labelhtml(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
182
	require_once 'HTML/QuickForm/html.php';
182
	require_once 'HTML/QuickForm/html.php';
183
	$formhtml= new HTML_QuickForm_html(constant($label));
183
	$formhtml= new HTML_QuickForm_html(constant($label));
184
	$formtemplate->addElement($formhtml) ;
184
	$formtemplate->addElement($formhtml) ;
185
}
185
}
186
 
186
 
187
/* +--Fin du code ----------------------------------------------------------------------------------------+
187
/* +--Fin du code ----------------------------------------------------------------------------------------+
188
*
188
*
189
* $Log: not supported by cvs2svn $
189
* $Log: not supported by cvs2svn $
-
 
190
* Revision 1.5  2005/11/07 17:05:45  florian
-
 
191
* amélioration validation conditions de saisie, ajout des règles spécifiques de saisie des formulaires
-
 
192
*
190
* Revision 1.4  2005/10/25 13:53:02  alexandre_tb
193
* Revision 1.4  2005/10/25 13:53:02  alexandre_tb
191
* ajout d'un filtre dans les formulaire texte et textelong
194
* ajout d'un filtre dans les formulaire texte et textelong
192
*
195
*
193
* Revision 1.3  2005/07/21 19:03:12  florian
196
* Revision 1.3  2005/07/21 19:03:12  florian
194
* nouveautés bazar: templates fiches, correction de bugs, ...
197
* nouveautés bazar: templates fiches, correction de bugs, ...
195
*
198
*
196
* Revision 1.1.1.1  2005/02/17 18:05:11  florian
199
* Revision 1.1.1.1  2005/02/17 18:05:11  florian
197
* Import initial de Bazar
200
* Import initial de Bazar
198
*
201
*
199
* Revision 1.1.1.1  2005/02/17 11:09:50  florian
202
* Revision 1.1.1.1  2005/02/17 11:09:50  florian
200
* Import initial
203
* Import initial
201
*
204
*
202
* Revision 1.1.1.1  2005/02/16 18:06:35  florian
205
* Revision 1.1.1.1  2005/02/16 18:06:35  florian
203
* import de la nouvelle version
206
* import de la nouvelle version
204
*
207
*
205
* Revision 1.4  2004/07/08 11:17:59  alex
208
* Revision 1.4  2004/07/08 11:17:59  alex
206
* ajout de commentaires et d'entete
209
* ajout de commentaires et d'entete
207
*
210
*
208
*
211
*
209
* +-- Fin du code ----------------------------------------------------------------------------------------+
212
* +-- Fin du code ----------------------------------------------------------------------------------------+
210
*/
213
*/
211
?>
214
?>