Rev 82 | Blame | Last modification | View Log | RSS feed
<?php/*vim: set expandtab tabstop=4 shiftwidth=4: */// +------------------------------------------------------------------------------------------------------+// | PHP version 4.1 |// +------------------------------------------------------------------------------------------------------+// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org) |// +------------------------------------------------------------------------------------------------------+// | This library is free software; you can redistribute it and/or |// | modify it under the terms of the GNU Lesser General Public |// | License as published by the Free Software Foundation; either |// | version 2.1 of the License, or (at your option) any later version. |// | |// | This library is distributed in the hope that it will be useful, |// | but WITHOUT ANY WARRANTY; without even the implied warranty of |// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |// | Lesser General Public License for more details. |// | |// | You should have received a copy of the GNU Lesser General Public |// | License along with this library; if not, write to the Free Software |// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |// +------------------------------------------------------------------------------------------------------+// CVS : $Id: bazar.fonct.formulaire.php,v 1.17 2006-01-30 10:27:03 florian Exp $/*** Formulaire** Les fonctions de mise en page des formulaire**@package bazar//Auteur original :*@author Florian SCHMITT <florian@ecole-et-nature.org>//Autres auteurs :*@author Aleandre GRANIER <alexandre@tela-botanica.org>*@copyright Tela-Botanica 2000-2004*@version $Revision: 1.17 $ $Date: 2006-01-30 10:27:03 $// +------------------------------------------------------------------------------------------------------+*/require_once 'bazar.fonct.formulaire.controles.php';//-------------------FONCTIONS DE MISE EN PAGE DES FORMULAIRES/** liste() - Ajoute un élément de type liste au formulaire** @param mixed L'objet QuickForm du formulaire* @param int identifiant de la liste sur bazar_liste* @param string label à afficher dans le formulaire* @param string première restriction de la taille des champs du formulaire* @param string deuxième restriction de la taille des champs du formulaire* @param string valeur par défaut du formulaire* @param string table source pour les valeurs de la liste* @param string ce champs est il obligatoire? (required)* @return void*/function liste(&$formtemplate, $id_liste , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$requete = 'SELECT * FROM bazar_liste_valeurs WHERE blv_ce_liste='.$id_liste.' AND blv_ce_i18n="'.$GLOBALS['_BAZAR_']['langue'].'"';$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;if (DB::isError ($resultat)) {die ($resultat->getMessage().$resultat->getDebugInfo()) ;}while ($ligne = $resultat->fetchRow()) {$select[$ligne[1]] = $ligne[2] ;}$option=array('style'=>'width: '.$limite1.'px;');require_once 'HTML/QuickForm/select.php';$select= new HTML_QuickForm_select('liste'.$id_liste, constant($label), $select, $option);$select->setSize($limite2);$select->setMultiple(0);$select->setSelected($defaut);$formtemplate->addElement($select) ;if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule('liste'.$id_liste, BAZ_CHOISIR_OBLIGATOIRE.' '.constant($label) , 'nonzero', '', 'client') ;$formtemplate->addRule('liste'.$id_liste, constant($label.'_REQUIS'), 'required', '', 'client') ;}}/** checkbox() - Ajoute un élément de type checkbox au formulaire** @param mixed L'objet QuickForm du formulaire* @param int identifiant de la liste sur bazar_liste* @param string label à afficher dans le formulaire* @param string première restriction de la taille des champs du formulaire* @param string deuxième restriction de la taille des champs du formulaire* @param string valeur par défaut du formulaire* @param string table source pour les valeurs de la liste* @param string ce champs est il obligatoire? (required)* @return void*/function checkbox(&$formtemplate, $id_liste , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$requete = 'SELECT * FROM bazar_liste_valeurs WHERE blv_ce_liste='.$id_liste.' AND blv_ce_i18n="'.$GLOBALS['_BAZAR_']['langue'].'"';$resultat = & $GLOBALS['_BAZAR_']['db'] -> query($requete) ;if (DB::isError ($resultat)) {die ($resultat->getMessage().$resultat->getDebugInfo()) ;}require_once 'HTML/QuickForm/checkbox.php' ;$i=0;if (isset($defaut)) $tab=split(', ', $defaut);while ($ligne = $resultat->fetchRow()) {if ($i==0) $labelchkbox=constant($label) ; else $labelchkbox=' ' ;$checkbox[$i]= & HTML_Quickform::createElement('checkbox', $ligne[1], $labelchkbox, $ligne[2],array ('style'=>'display:inline;margin-left:2px;')) ;foreach ($tab as $val) {if ($ligne[1]==$val) $checkbox[$i]->setChecked(1);}$i++;}$formtemplate->addGroup($checkbox, 'checkbox'.$id_liste, constant($label), '<br />'."\n");if (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addGroupRule('checkbox'.$id_liste, constant($label.'_REQUIS'), 'required', null, 1, 'client');}}/** listedatedeb() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de début** @param mixed L'objet QuickForm du formulaire* @param string nom de la table dans la base de donnée* @param string label à afficher dans le formulaire* @param string première restriction de la taille des champs du formulaire* @param string deuxième restriction de la taille des champs du formulaire* @param string valeur par défaut du formulaire* @param string table source pour les valeurs de la date* @param string ce champs est il obligatoire? (required)* @return void*/function listedatedeb(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$optiondate = array('language' => BAZ_LANGUE_PAR_DEFAUT,'minYear' => date('Y'),'maxYear'=> (date('Y')+10),'format' => 'd m Y','addEmptyOption' => true,);$formtemplate->addElement('date', $nom_bdd, constant($label), $optiondate) ;//gestion des valeurs par défaut (date du jour)if (isset($defaut)) $formtemplate->setDefaults(array($nom_bdd => $defaut));else {$defauts=array($nom_bdd => array ('d'=>date('d'), 'm'=>date('m'), 'Y'=>date('Y')));$formtemplate->setDefaults($defauts);}//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}}/** listedatefin() - Ajoute un élément de type date sous forme de liste au formulaire pour designer une date de fin** @param mixed L'objet QuickForm du formulaire* @param string nom de la table dans la base de donnée* @param string label à afficher dans le formulaire* @param string première restriction de la taille des champs du formulaire* @param string deuxième restriction de la taille des champs du formulaire* @param string valeur par défaut du formulaire* @param string table source pour les valeurs de la date* @param string ce champs est il obligatoire? (required)* @return void*/function listedatefin(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {listedatedeb($formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire);}/** texte() - Ajoute un élément de type texte au formulaire** @param mixed L'objet QuickForm du formulaire* @param string nom de la table dans la base de donnée* @param string label à afficher dans le formulaire* @param string première restriction de la taille des champs du formulaire* @param string deuxième restriction de la taille des champs du formulaire* @param string valeur par défaut du formulaire* @param string table source pour les valeurs du texte (inutile)* @param string ce champs est il obligatoire? (required)* @return void*/function texte(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$option=array('size'=>$limite1,'maxlength'=>$limite2);$formtemplate->addElement('text', $nom_bdd, constant($label), $option) ;//gestion des valeurs par défaut$defauts=array($nom_bdd=>$defaut);$formtemplate->setDefaults($defauts);$formtemplate->applyFilter($nom_bdd, 'addslashes') ;//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}}/** textelong() - Ajoute un élément de type textearea au formulaire** @param mixed L'objet QuickForm du formulaire* @param string nom de la table dans la base de donnée* @param string label à afficher dans le formulaire* @param string taille des colonnes de l'élément* @param string taille des lignes de l'élément* @param string valeur par défaut du formulaire* @param string table source pour les valeurs du texte (inutile)* @param string ce champs est il obligatoire? (required)* @return void*/function textelong(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$formtexte= new HTML_QuickForm_textarea($nom_bdd, constant($label), array('style'=>'white-space: normal;'));$formtexte->setCols($limite1);$formtexte->setRows($limite2);$formtemplate->addElement($formtexte) ;//gestion des valeurs par défaut$defauts=array($nom_bdd=>$defaut);$formtemplate->setDefaults($defauts);$formtemplate->applyFilter($nom_bdd, 'addslashes') ;//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule($nom_bdd, constant($label.'_REQUIS'), 'required', '', 'client') ;}}/** url() - Ajoute un élément de type url internet au formulaire** @param mixed L'objet QuickForm du formulaire* @param string numero du champs input du formulaire (pour le différencier d'autres champs du meme type dans ce formulaire)* @param string label à afficher dans le formulaire* @param string taille des colonnes de l'élément* @param string taille des lignes de l'élément* @param string valeur par défaut du formulaire* @param string table source pour les valeurs du texte (inutile)* @param string ce champs est il obligatoire? (required)* @return void*/function url(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$html.='<tr>'."\n".'<td colspan="2">'."\n".'<h4>'.$label.'</h4>'."\n".'</td>'."\n".'</tr>'."\n";$formtemplate->addElement('html', $html) ;$formtemplate->addElement('text', 'url_lien'.$nom_bdd, BAZ_URL_LIEN) ;$formtemplate->addElement('text', 'url_texte'.$nom_bdd, BAZ_URL_TEXTE) ;//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule('url_lien'.$nom_bdd, BAZ_URL_LIEN_REQUIS, 'required', '', 'client') ;$formtemplate->addRule('url_texte'.$nom_bdd, BAZ_URL_TEXTE_REQUIS, 'required', '', 'client') ;}}/** fichier() - Ajoute un élément de type fichier au formulaire** @param mixed L'objet QuickForm du formulaire* @param string numero du champs input du formulaire (pour le différencier d'autres champs du meme type dans ce formulaire)* @param string label à afficher dans le formulaire* @param string taille des colonnes de l'élément* @param string taille des lignes de l'élément* @param string valeur par défaut du formulaire* @param string table source pour les valeurs du texte (inutile)* @param string ce champs est il obligatoire? (required)* @return void*/function fichier(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$html.='<tr>'."\n".'<td colspan="2">'."\n".'<h4>'.$label.'</h4>'."\n".'</td>'."\n".'</tr>'."\n";$formtemplate->addElement('html', $html) ;$formtemplate->addElement('text', 'texte_fichier'.$nom_bdd, BAZ_FICHIER_DESCRIPTION) ;$formtemplate->addElement('file', 'fichier'.$nom_bdd, BAZ_FICHIER_JOINT) ;$formtemplate->addRule('image', BAZ_IMAGE_VALIDE_REQUIS, '', '', 'client') ; //a completer pour checker l'image$formtemplate->setMaxFileSize($limite1);//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule('texte_fichier'.$nom_bdd, BAZ_FICHIER_LABEL_REQUIS, 'required', '', 'client') ;$formtemplate->addRule('fichier'.$nom_bdd, BAZ_FICHIER_JOINT_REQUIS, 'required', '', 'client') ;}}/** image() - Ajoute un élément de type image au formulaire** @param mixed L'objet QuickForm du formulaire* @param string numero du champs input du formulaire (pour le différencier d'autres champs du meme type dans ce formulaire)* @param string label à afficher dans le formulaire* @param string taille maximum du fichier colonnes de l'élément* @param string taille des lignes de l'élément* @param string valeur par défaut du formulaire* @param string table source pour les valeurs du texte (inutile)* @param string ce champs est il obligatoire? (required)* @return void*/function image(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {$html.='<tr>'."\n".'<td colspan="2">'."\n".'<h4>'.$label.'</h4>'."\n".'</td>'."\n".'</tr>'."\n";$formtemplate->addElement('html', $html) ;$formtemplate->addElement('file', 'image'.$nom_bdd, BAZ_IMAGE) ;//TODO: controler si c'est une image$formtemplate->setMaxFileSize($limite1);//gestion du champs obligatoireif (isset($obligatoire)and($obligatoire==1)) {$formtemplate->addRule('image'.$nom_bdd, BAZ_IMAGE_VALIDE_REQUIS, 'required', '', 'client') ;}}/** labelhtml() - Ajoute un élément de type textearea au formulaire** @param mixed L'objet QuickForm du formulaire* @param string nom de la table dans la base de donnée (pas utilisé)* @param string label à afficher dans le formulaire* @param string taille des colonnes de l'élément (pas utilisé)* @param string taille des lignes de l'élément (pas utilisé)* @param string valeur par défaut du formulaire (pas utilisé)* @param string table source pour les valeurs du texte (pas utilisé)* @param string ce champs est il obligatoire? (required) (pas utilisé)* @return void*/function labelhtml(&$formtemplate, $nom_bdd , $label, $limite1, $limite2, $defaut, $source, $obligatoire) {require_once 'HTML/QuickForm/html.php';$formhtml= new HTML_QuickForm_html('<tr>'."\n".'<td colspan="2">'."\n".constant($label)."\n".'</td>'."\n".'</tr>'."\n");$formtemplate->addElement($formhtml) ;}/* +--Fin du code ----------------------------------------------------------------------------------------+** $Log: not supported by cvs2svn $* Revision 1.16 2006/01/24 14:11:44 alexandre_tb* ajout du paramètre emptyOptionValue dans les champs de date** Revision 1.15 2006/01/23 16:57:03 alexandre_tb* correction d'un notice** Revision 1.14 2006/01/19 17:42:11 florian* ajout des cases à cocher pré-cochées pour les maj** Revision 1.13 2006/01/13 14:12:51 florian* utilisation des temlates dans la table bazar_nature** Revision 1.12 2006/01/05 16:28:24 alexandre_tb* prise en chage des checkbox, reste la mise à jour à gérer** Revision 1.11 2006/01/02 13:24:07 alexandre_tb* correction de bug d'un mauvais retour en erreur** Revision 1.10 2005/12/01 16:05:41 florian* changement des chemins pour appli Pear** Revision 1.9 2005/11/24 16:17:13 florian* corrections bugs, ajout des cases à cocher** Revision 1.8 2005/11/18 16:03:23 florian* correction bug html entites** Revision 1.7 2005/11/07 17:51:06 florian* correction bug liste** Revision 1.6 2005/11/07 17:30:36 florian* ajout controle sur les listes pour la saisie** Revision 1.5 2005/11/07 17:05:45 florian* amélioration validation conditions de saisie, ajout des règles spécifiques de saisie des formulaires** Revision 1.4 2005/10/25 13:53:02 alexandre_tb* ajout d'un filtre dans les formulaire texte et textelong** Revision 1.3 2005/07/21 19:03:12 florian* nouveautés bazar: templates fiches, correction de bugs, ...** Revision 1.1.1.1 2005/02/17 18:05:11 florian* Import initial de Bazar** Revision 1.1.1.1 2005/02/17 11:09:50 florian* Import initial** Revision 1.1.1.1 2005/02/16 18:06:35 florian* import de la nouvelle version** Revision 1.4 2004/07/08 11:17:59 alex* ajout de commentaires et d'entete*** +-- Fin du code ----------------------------------------------------------------------------------------+*/?>