Subversion Repositories Applications.bazar

Rev

Rev 5 | 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
// +------------------------------------------------------------------------------------------------------+
41 alexandre_ 22
// CVS : $Id: bazar.fonct.formulaire.php,v 1.4 2005-10-25 13:53:02 alexandre_tb Exp $
5 florian 23
/**
24
* Inscription
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
41 alexandre_ 34
*@version       $Revision: 1.4 $ $Date: 2005-10-25 13:53:02 $
5 florian 35
// +------------------------------------------------------------------------------------------------------+
36
*/
37
 
38
//-------------------FONCTIONS DE MISE EN PAGE DES FORMULAIRES
39
 
40
/** liste() - Ajoute un élément de type liste au formulaire
41
*
42
* @param    mixed   L'objet QuickForm du formulaire
43
* @param    string  nom du champs dans la table bazar_fiche dans la base de donnée
44
* @param    string  label à afficher dans le formulaire
45
* @param    string  première restriction de la taille des champs du formulaire
46
* @param    string  deuxième restriction de la taille des champs du formulaire
47
* @param    string  valeur par défaut du formulaire
48
* @param    string  table source pour les valeurs de la liste
49
* @param    string  ce champs est il obligatoire? (required)
50
* @return   void
51
*/
52
function liste(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
53
	$requete = 'select * from '.$source;
54
	$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;
55
	if (DB::isError ($resultat)) {
56
		die ($GLOBALS['_BAZAR_']['db']->getMessage().$GLOBALS['_BAZAR_']['db']->getDebugInfo()) ;
57
	}
58
	while ($ligne = $resultat->fetchRow()) {
59
		$select[$ligne[0]] = $ligne[1] ;
60
	}
61
	$option=array('style'=>'width: '.$limite1.'px;');
62
	require_once 'HTML/QuickForm/select.php';
63
	$select= new HTML_QuickForm_select($nom_bdd, constant($label), $select, $option);
64
	$select->setSize($limite2);
65
	$select->setMultiple(0);
66
	$formtemplate->addElement($select) ;
67
	//gestion des valeurs par défaut
68
	$defauts=array($nom_bdd=>$defaut);
69
	$formtemplate->setDefaults($defauts);
70
	//gestion du champs obligatoire
71
	$formtemplate->addRule('titre', BAZ_TITRE_REQUIS, 'required', '', 'client') ;
72
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
73
}
74
 
75
 
76
/** listedatedeb() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de début
77
*
78
* @param    mixed   L'objet QuickForm du formulaire
79
* @param    string  nom de la table dans la base de donnée
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 date
85
* @param    string  ce champs est il obligatoire? (required)
86
* @return   void
87
*/
88
function listedatedeb(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
89
	$optiondate=array('language' => BAZ_LANGUE_PAR_DEFAUT,'minYear' => date('Y'),'maxYear'=> (date('Y')+10), 'format' => 'd m Y');
90
	$formtemplate->addElement('date', $nom_bdd, constant($label), $optiondate) ;
91
	//gestion des valeurs par défaut (date du jour)
92
	$defauts=array($nom_bdd => array ('d'=>date('d'), 'm'=>date('m'), 'Y'=>date('Y')));
93
	$formtemplate->setDefaults($defauts);
94
	//gestion du champs obligatoire
95
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
96
}
97
 
98
/** listedatefin() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de fin
99
*
100
* @param    mixed   L'objet QuickForm du formulaire
101
* @param    string  nom de la table dans la base de donnée
102
* @param    string  label à afficher dans le formulaire
103
* @param    string  première restriction de la taille des champs du formulaire
104
* @param    string  deuxième restriction de la taille des champs du formulaire
105
* @param    string  valeur par défaut du formulaire
106
* @param    string  table source pour les valeurs de la date
107
* @param    string  ce champs est il obligatoire? (required)
108
* @return   void
109
*/
110
function listedatefin(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
111
	listedatedeb($formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire);
112
}
113
 
114
 
115
/** texte() - Ajoute un élément de type texte au formulaire
116
*
117
* @param    mixed   L'objet QuickForm du formulaire
118
* @param    string  nom de la table dans la base de donnée
119
* @param    string  label à afficher dans le formulaire
120
* @param    string  première restriction de la taille des champs du formulaire
121
* @param    string  deuxième restriction de la taille des champs du formulaire
122
* @param    string  valeur par défaut du formulaire
123
* @param    string  table source pour les valeurs du texte (inutile)
124
* @param    string  ce champs est il obligatoire? (required)
125
* @return   void
126
*/
127
function texte(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
128
	$option=array('size'=>$limite1,'maxlength'=>$limite2);
129
	$formtemplate->addElement('text', $nom_bdd, constant($label), $option) ;
130
	//gestion des valeurs par défaut
131
	$defauts=array($nom_bdd=>$defaut);
132
	$formtemplate->setDefaults($defauts);
41 alexandre_ 133
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
5 florian 134
	//gestion du champs obligatoire
135
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
136
}
137
 
138
 
139
/** textelong() - Ajoute un élément de type textearea au formulaire
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  taille des colonnes de l'élément
145
* @param    string  taille des lignes de l'élément
146
* @param    string  valeur par défaut du formulaire
147
* @param    string  table source pour les valeurs du texte (inutile)
148
* @param    string  ce champs est il obligatoire? (required)
149
* @return   void
150
*/
151
function textelong(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
152
	$formtexte= new HTML_QuickForm_textarea($nom_bdd, constant($label));
153
	$formtexte->setCols($limite1);
154
	$formtexte->setRows($limite2);
155
	$formtexte->setWrap('HARD');
156
	$formtemplate->addElement($formtexte) ;
157
	//gestion des valeurs par défaut
158
	$defauts=array($nom_bdd=>$defaut);
159
	$formtemplate->setDefaults($defauts);
41 alexandre_ 160
	$formtemplate->applyFilter($nom_bdd, 'addslashes') ;
5 florian 161
	//gestion du champs obligatoire
162
	if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}
163
}
164
 
165
 
166
/** labelhtml() - Ajoute un élément de type textearea au formulaire
167
*
168
* @param    mixed   L'objet QuickForm du formulaire
169
* @param    string  nom de la table dans la base de donnée (pas utilisé)
170
* @param    string  label à afficher dans le formulaire
171
* @param    string  taille des colonnes de l'élément (pas utilisé)
172
* @param    string  taille des lignes de l'élément (pas utilisé)
173
* @param    string  valeur par défaut du formulaire (pas utilisé)
174
* @param    string  table source pour les valeurs du texte (pas utilisé)
175
* @param    string  ce champs est il obligatoire? (required) (pas utilisé)
176
* @return   void
177
*/
178
function labelhtml(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {
179
	require_once 'HTML/QuickForm/html.php';
180
	$formhtml= new HTML_QuickForm_html(constant($label));
181
	$formtemplate->addElement($formhtml) ;
182
}
183
 
184
/* +--Fin du code ----------------------------------------------------------------------------------------+
185
*
41 alexandre_ 186
* $Log: not supported by cvs2svn $
187
* Revision 1.3  2005/07/21 19:03:12  florian
188
* nouveautés bazar: templates fiches, correction de bugs, ...
189
*
5 florian 190
* Revision 1.1.1.1  2005/02/17 18:05:11  florian
191
* Import initial de Bazar
192
*
193
* Revision 1.1.1.1  2005/02/17 11:09:50  florian
194
* Import initial
195
*
196
* Revision 1.1.1.1  2005/02/16 18:06:35  florian
197
* import de la nouvelle version
198
*
199
* Revision 1.4  2004/07/08 11:17:59  alex
200
* ajout de commentaires et d'entete
201
*
202
*
203
* +-- Fin du code ----------------------------------------------------------------------------------------+
204
*/
205
?>