Subversion Repositories Applications.bazar

Rev

Rev 79 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
5 florian 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
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                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
80 alexandre_ 22
// CVS : $Id: bazar.fonct.formulaire.php,v 1.15 2006-01-23 16:57:03 alexandre_tb Exp $
5 florian 23
/**
45 florian 24
* Formulaire
5 florian 25
*
26
* Les fonctions de mise en page des formulaire
27
*
28
*@package bazar
29
//Auteur original :
30
*@author        Florian SCHMITT <florian@ecole-et-nature.org>
31
//Autres auteurs :
32
*@author        Aleandre GRANIER <alexandre@tela-botanica.org>
33
*@copyright     Tela-Botanica 2000-2004
80 alexandre_ 34
*@version       $Revision: 1.15 $ $Date: 2006-01-23 16:57:03 $
5 florian 35
// +------------------------------------------------------------------------------------------------------+
36
*/
37
 
45 florian 38
require_once 'bazar.fonct.formulaire.controles.php';
39
 
5 florian 40
//-------------------FONCTIONS DE MISE EN PAGE DES FORMULAIRES
41
 
42
/** liste() - Ajoute un élément de type liste au formulaire
43
*
44
* @param    mixed   L'objet QuickForm du formulaire
68 florian 45
* @param    int     identifiant de la liste sur bazar_liste
5 florian 46
* @param    string  label à afficher dans le 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
49
* @param    string  valeur par défaut du formulaire
50
* @param    string  table source pour les valeurs de la liste
51
* @param    string  ce champs est il obligatoire? (required)
52
* @return   void
53
*/
68 florian 54
function liste(&$formtemplate, $id_liste , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
79 florian 55
	$requete = 'SELECT * FROM bazar_liste_valeurs WHERE blv_ce_liste='.$id_liste.' AND blv_ce_i18n="'.$GLOBALS['_BAZAR_']['langue'].'"';
5 florian 56
	$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;
57
	if (DB::isError ($resultat)) {
62 alexandre_ 58
		die ($resultat->getMessage().$resultat->getDebugInfo()) ;
5 florian 59
	}
60
	while ($ligne = $resultat->fetchRow()) {
68 florian 61
		$select[$ligne[1]] = $ligne[2] ;
5 florian 62
	}
63
	$option=array('style'=>'width: '.$limite1.'px;');
57 florian 64
	require_once 'HTML/QuickForm/select.php';
68 florian 65
	$select= new HTML_QuickForm_select('liste'.$id_liste, constant($label), $select, $option);
5 florian 66
	$select->setSize($limite2);
67
	$select->setMultiple(0);
45 florian 68
	$select->setSelected($defaut);
5 florian 69
	$formtemplate->addElement($select) ;
47 florian 70
	if (isset($obligatoire)and($obligatoire==1)) {
68 florian 71
		$formtemplate->addRule('liste'.$id_liste, BAZ_CHOISIR_OBLIGATOIRE.' '.constant($label) , 'nonzero', '', 'client') ;
72
		$formtemplate->addRule('liste'.$id_liste, constant($label.'_REQUIS'), 'required', '', 'client') ;}
5 florian 73
}
74
 
75
 
54 florian 76
/** checkbox() - Ajoute un élément de type checkbox au formulaire
77
*
78
* @param    mixed   L'objet QuickForm du formulaire
68 florian 79
* @param    int     identifiant de la liste sur bazar_liste
54 florian 80
* @param    string  label à afficher dans le formulaire
81
* @param    string  première restriction de la taille des champs du formulaire
82
* @param    string  deuxième restriction de la taille des champs du formulaire
83
* @param    string  valeur par défaut du formulaire
84
* @param    string  table source pour les valeurs de la liste
85
* @param    string  ce champs est il obligatoire? (required)
86
* @return   void
87
*/
68 florian 88
function checkbox(&$formtemplate, $id_liste , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
79 florian 89
	$requete = 'SELECT * FROM bazar_liste_valeurs WHERE blv_ce_liste='.$id_liste.' AND blv_ce_i18n="'.$GLOBALS['_BAZAR_']['langue'].'"';
54 florian 90
	$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;
91
	if (DB::isError ($resultat)) {
80 alexandre_ 92
		die ($resultat->getMessage().$resultat->getDebugInfo()) ;
79 florian 93
	}
94
	require_once 'HTML/QuickForm/checkbox.php' ;
54 florian 95
	$i=0;
79 florian 96
	if (isset($defaut)) $tab=split(', ', $defaut);
54 florian 97
	while ($ligne = $resultat->fetchRow()) {
98
		if ($i==0) $labelchkbox=constant($label) ; else $labelchkbox='&nbsp;' ;
79 florian 99
		$checkbox[$i]= & HTML_Quickform::createElement('checkbox', $ligne[1], $labelchkbox, $ligne[2],
67 alexandre_ 100
						array ('style'=>'display:inline;margin-left:2px;')) ;
79 florian 101
		foreach ($tab as $val) {
102
            if ($ligne[1]==$val) $checkbox[$i]->setChecked(1);
103
        }
54 florian 104
		$i++;
105
	}
68 florian 106
	$formtemplate->addGroup($checkbox, 'checkbox'.$id_liste, constant($label), '<br />'."\n");
79 florian 107
	if (isset($obligatoire)and($obligatoire==1)) {
108
		//TODO: marches pas...
109
		$formtemplate->addGroupRule('checkbox'.$id_liste, constant($label.'_REQUIS'), 'required', null, 1, 'client');
110
	}
54 florian 111
}
112
 
113
 
5 florian 114
/** listedatedeb() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de début
115
*
116
* @param    mixed   L'objet QuickForm du formulaire
117
* @param    string  nom de la table dans la base de donnée
118
* @param    string  label à afficher dans le formulaire
119
* @param    string  première restriction de la taille des champs du formulaire
120
* @param    string  deuxième restriction de la taille des champs du formulaire
121
* @param    string  valeur par défaut du formulaire
122
* @param    string  table source pour les valeurs de la date
123
* @param    string  ce champs est il obligatoire? (required)
124
* @return   void
125
*/
126
function listedatedeb(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
127
	$optiondate=array('language' => BAZ_LANGUE_PAR_DEFAUT,'minYear' => date('Y'),'maxYear'=> (date('Y')+10), 'format' => 'd m Y');
128
	$formtemplate->addElement('date', $nom_bdd, constant($label), $optiondate) ;
79 florian 129
	//gestion des valeurs par défaut (date du jour)
130
	if (isset($defaut)) $formtemplate->setDefaults(array($nom_bdd => $defaut));
131
	else {
132
		$defauts=array($nom_bdd => array ('d'=>date('d'), 'm'=>date('m'), 'Y'=>date('Y')));
133
		$formtemplate->setDefaults($defauts);
134
	}
5 florian 135
	//gestion du champs obligatoire
136
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
137
}
138
 
139
/** listedatefin() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de fin
140
*
141
* @param    mixed   L'objet QuickForm du formulaire
142
* @param    string  nom de la table dans la base de donnée
143
* @param    string  label à afficher dans le formulaire
144
* @param    string  première restriction de la taille des champs du formulaire
145
* @param    string  deuxième restriction de la taille des champs du formulaire
146
* @param    string  valeur par défaut du formulaire
147
* @param    string  table source pour les valeurs de la date
148
* @param    string  ce champs est il obligatoire? (required)
149
* @return   void
150
*/
151
function listedatefin(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
152
	listedatedeb($formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire);
153
}
154
 
155
 
156
/** texte() - Ajoute un élément de type texte au formulaire
157
*
158
* @param    mixed   L'objet QuickForm du formulaire
159
* @param    string  nom de la table dans la base de donnée
160
* @param    string  label à afficher dans le formulaire
161
* @param    string  première restriction de la taille des champs du formulaire
162
* @param    string  deuxième restriction de la taille des champs du formulaire
163
* @param    string  valeur par défaut du formulaire
164
* @param    string  table source pour les valeurs du texte (inutile)
165
* @param    string  ce champs est il obligatoire? (required)
166
* @return   void
167
*/
168
function texte(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
169
	$option=array('size'=>$limite1,'maxlength'=>$limite2);
170
	$formtemplate->addElement('text', $nom_bdd, constant($label), $option) ;
171
	//gestion des valeurs par défaut
172
	$defauts=array($nom_bdd=>$defaut);
173
	$formtemplate->setDefaults($defauts);
41 alexandre_ 174
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
5 florian 175
	//gestion du champs obligatoire
176
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
177
}
178
 
179
 
180
/** textelong() - Ajoute un élément de type textearea au formulaire
181
*
182
* @param    mixed   L'objet QuickForm du formulaire
183
* @param    string  nom de la table dans la base de donnée
184
* @param    string  label à afficher dans le formulaire
185
* @param    string  taille des colonnes de l'élément
186
* @param    string  taille des lignes de l'élément
187
* @param    string  valeur par défaut du formulaire
188
* @param    string  table source pour les valeurs du texte (inutile)
189
* @param    string  ce champs est il obligatoire? (required)
190
* @return   void
191
*/
192
function textelong(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
54 florian 193
	$formtexte= new HTML_QuickForm_textarea($nom_bdd, constant($label), array('style'=>'white-space: normal;'));
5 florian 194
	$formtexte->setCols($limite1);
195
	$formtexte->setRows($limite2);
196
	$formtemplate->addElement($formtexte) ;
197
	//gestion des valeurs par défaut
198
	$defauts=array($nom_bdd=>$defaut);
199
	$formtemplate->setDefaults($defauts);
41 alexandre_ 200
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
5 florian 201
	//gestion du champs obligatoire
202
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
203
}
204
 
205
 
206
/** labelhtml() - Ajoute un élément de type textearea au formulaire
207
*
208
* @param    mixed   L'objet QuickForm du formulaire
209
* @param    string  nom de la table dans la base de donnée (pas utilisé)
210
* @param    string  label à afficher dans le formulaire
211
* @param    string  taille des colonnes de l'élément (pas utilisé)
212
* @param    string  taille des lignes de l'élément (pas utilisé)
213
* @param    string  valeur par défaut du formulaire (pas utilisé)
214
* @param    string  table source pour les valeurs du texte (pas utilisé)
215
* @param    string  ce champs est il obligatoire? (required) (pas utilisé)
216
* @return   void
217
*/
218
function labelhtml(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
57 florian 219
	require_once 'HTML/QuickForm/html.php';
68 florian 220
	$formhtml= new HTML_QuickForm_html('<tr>'."\n".'<td colspan="2">'."\n".constant($label)."\n".'</td>'."\n".'</tr>'."\n");
5 florian 221
	$formtemplate->addElement($formhtml) ;
222
}
223
 
224
/* +--Fin du code ----------------------------------------------------------------------------------------+
225
*
41 alexandre_ 226
* $Log: not supported by cvs2svn $
80 alexandre_ 227
* Revision 1.14  2006/01/19 17:42:11  florian
228
* ajout des cases à cocher pré-cochées pour les maj
229
*
79 florian 230
* Revision 1.13  2006/01/13 14:12:51  florian
231
* utilisation des temlates dans la table bazar_nature
232
*
68 florian 233
* Revision 1.12  2006/01/05 16:28:24  alexandre_tb
234
* prise en chage des checkbox, reste la mise à jour à gérer
235
*
67 alexandre_ 236
* Revision 1.11  2006/01/02 13:24:07  alexandre_tb
237
* correction de bug d'un mauvais retour en erreur
238
*
62 alexandre_ 239
* Revision 1.10  2005/12/01 16:05:41  florian
240
* changement des chemins pour appli Pear
241
*
57 florian 242
* Revision 1.9  2005/11/24 16:17:13  florian
243
* corrections bugs, ajout des cases à cocher
244
*
54 florian 245
* Revision 1.8  2005/11/18 16:03:23  florian
246
* correction bug html entites
247
*
53 florian 248
* Revision 1.7  2005/11/07 17:51:06  florian
249
* correction bug liste
250
*
47 florian 251
* Revision 1.6  2005/11/07 17:30:36  florian
252
* ajout controle sur les listes pour la saisie
253
*
46 florian 254
* Revision 1.5  2005/11/07 17:05:45  florian
255
* amélioration validation conditions de saisie, ajout des règles spécifiques de saisie des formulaires
256
*
45 florian 257
* Revision 1.4  2005/10/25 13:53:02  alexandre_tb
258
* ajout d'un filtre dans les formulaire texte et textelong
259
*
41 alexandre_ 260
* Revision 1.3  2005/07/21 19:03:12  florian
261
* nouveautés bazar: templates fiches, correction de bugs, ...
262
*
5 florian 263
* Revision 1.1.1.1  2005/02/17 18:05:11  florian
264
* Import initial de Bazar
265
*
266
* Revision 1.1.1.1  2005/02/17 11:09:50  florian
267
* Import initial
268
*
269
* Revision 1.1.1.1  2005/02/16 18:06:35  florian
270
* import de la nouvelle version
271
*
272
* Revision 1.4  2004/07/08 11:17:59  alex
273
* ajout de commentaires et d'entete
274
*
275
*
276
* +-- Fin du code ----------------------------------------------------------------------------------------+
277
*/
278
?>