1,5 → 1,4 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
19,8 → 18,6 |
// | 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: inscription.class.php,v 1.3 2005/05/13 13:48:38 alex Exp $ |
// CVS : $Id: inscription.class.php,v 1.3 2005/05/13 13:48:38 alex Exp $ |
/** |
* Fonctions du module inscription |
* |
30,10 → 27,9 |
//Auteur original : |
*@author Alexandre Granier <alexandre@tela-botanica.org> |
//Autres auteurs : |
*@author Aucun |
*@author Jean-Pascal MILCENT <jpm@tela-botanica.org> |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.3 $ $Date: 2005/05/13 13:48:38 $ |
*@version $Revision: 1.3 $ $Date: 2005/05/13 13:48:38 $ |
*@version $Id: inscription.class.php,v 1.3 2005/05/13 13:48:38 alex Exp $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
|
41,9 → 37,6 |
// | ENTETE du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
|
require_once 'HTML/QuickForm.php' ; |
require_once 'HTML/QuickForm/checkbox.php' ; |
require_once 'HTML/QuickForm/password.php' ; |
|
// +------------------------------------------------------------------------------------------------------+ |
// | LISTE de FONCTIONS | |
51,7 → 44,7 |
|
class HTML_formulaireInscription extends HTML_Quickform { |
|
|
var $mode_ajout = true; |
/** |
* Constructeur |
* |
64,7 → 57,6 |
* @return void |
* @access public |
*/ |
|
function HTML_forumlaireInscription ( $formName, $method = "post", $action, $target = "_self", $attributes, $trackSubmit = false ) { |
HTML_Quickform::HTML_Quickform($formName, $method, $action, $target, $attributes, $trackSubmit) ; |
} |
75,8 → 67,7 |
* @return void |
* @access public |
*/ |
function construitFormulaire($url, $liste_pays) |
{ |
function construitFormulaire($url, $liste_pays) { |
$squelette =& $this->defaultRenderer(); |
$squelette->setFormTemplate("\n".'<form{attributes}>'."\n".'{content}'."\n".'</form>'."\n"); |
|
104,7 → 95,7 |
$squelette->setRequiredNoteTemplate("\n".'<p>'."\n".'<span class="symbole_obligatoire">*</span> {requiredNote}'."\n".'</p>'."\n"); |
|
$fieldset_debut = '<fieldset>'."\n". |
'<legend>'.INS_AJOUT_MEMBRE.'</legend>'."\n". |
'<legend>'.(($this->mode_ajout) ? INS_AJOUT_MEMBRE : INS_MODIF_MEMBRE).'</legend>'."\n". |
'<ul>'."\n"; |
$this->addElement('html', $fieldset_debut); |
$this->addElement ('text', 'email', INS_EMAIL) ; |
123,10 → 114,6 |
$this->addRule ('nom', INS_NOM_REQUIS, 'required', '', 'client') ; |
$this->addRule ('prenom', INS_PRENOM_REQUIS, 'required', '', 'client') ; |
|
/* On enlève le champs non wiki, on va le générer |
$this->addElement ('text', 'nomwiki', INS_NOM_WIKI) ; |
$this->addRule ('nomwiki', INS_MAUVAIS_NOM_WIKI, 'regex', '/^[A-Z][a-z]+[A-Z,0-9][A-Z,a-z,0-9]*$/', 'client') ; |
*/ |
$this->addElement ('text', 'adresse_1', INS_ADRESSE_1) ; |
$this->addElement ('text', 'adresse_2', INS_ADRESSE_2) ; |
$this->addElement ('text', 'region', INS_REGION) ; |
136,17 → 123,15 |
$this->addRule ('cp', INS_CODE_POSTAL_REQUIS, 'required', '', 'client') ; |
$this->addRule ('ville', INS_VILLE_REQUIS, 'required', '', 'client') ; |
|
// L'élément pays est construit à partir de la table gen_COUNTRY |
|
// $this->addElement ('select', 'pays', INS_PAYS, $liste_pays) ; |
|
|
// L'élément pays est construit à partir de la table des pays |
$s =& $this->createElement('select','pays',INS_PAYS); |
$s->loadArray($liste_pays,'fr'); |
$this->addElement($s); |
|
if (INS_UTILISE_LISTE) { |
$element_lettre = &new HTML_QuickForm_checkbox ('lettre', '', INS_LETTRE) ; |
$this->addElement($element_lettre) ; |
} |
|
$this->addElement ('text', 'site', INS_SITE_INTERNET) ; |
|
171,7 → 156,7 |
$this->addElement('html', $fieldset_debut); |
|
// requete pour trouver les niveaux en botanique |
$requete = "select * from annuaire_LABEL_NIV" ; |
$requete = 'SELECT * FROM annuaire_LABEL_NIV'; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError($resultat)) { |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
184,7 → 169,6 |
'</fieldset>'."\n"; |
$this->addElement('html', $fieldset_fin); |
|
|
// L'activité professionnelle |
$fieldset_debut = '<fieldset>'."\n". |
'<legend>'.INS_ACTIVITE_PROFESSIONNELLE.'</legend>'."\n". |
192,8 → 176,8 |
$this->addElement('html', $fieldset_debut); |
|
|
// requete pour trouver les niveaux en botanique |
$requete = "select * from annuaire_LABEL_ACT" ; |
// Requete pour trouver les niveaux en botanique |
$requete = 'SELECT * FROM annuaire_LABEL_ACT'; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError($resultat)) { |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
212,8 → 196,8 |
'<ul>'."\n"; |
$this->addElement('html', $fieldset_debut); |
|
// requete pour trouver les niveaux en botanique |
$requete = "select * from annuaire_LABEL_ASS" ; |
// Requete pour trouver les niveaux en botanique |
$requete = 'SELECT * FROM annuaire_LABEL_ASS'; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError($resultat)) { |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
247,12 → 231,13 |
'</fieldset>'."\n"; |
$this->addElement('html', $fieldset_fin); |
|
|
if (!$this->mode_ajout) { |
$this->addElement ('link', 'annuler', '', preg_replace ('/&/', '&', $GLOBALS['ins_url']->getURL()), INS_ANNULER) ; |
} |
$this->addElement ('submit', 'valider', INS_VALIDER) ; |
|
$this->setRequiredNote(INS_NOTE_REQUIS) ; |
} // end of member function construitFormulaire |
} |
|
/** Modifie le formulaire pour l'adapter au cas des structures |
* |
260,9 → 245,7 |
* @return void |
* @access public |
*/ |
function formulaireStructure() |
{ |
|
function formulaireStructure() { |
$this->removeElement('email', false) ; |
$mail = & HTML_QuickForm::createElement ('text', 'email', INS_MAIL_STRUCTURE) ; |
$this->insertElementBefore ($mail, 'mot_de_passe') ; |
282,14 → 265,10 |
* @return string |
* @access public |
*/ |
function toHTML( ) |
{ |
function toHTML( ) { |
$res = HTML_QuickForm::toHTML() ; |
return $res ; |
} // end of member function toHTML |
|
|
|
} |
|
class ListeDePays extends PEAR{ |
301,20 → 280,19 |
* @param DB Un objet PEAR::DB |
* @return |
*/ |
|
function ListeDePays (&$objetDB) { |
$this->_db = $objetDB ; |
$requete = "show tables" ; |
$requete = 'SHOW TABLES'; |
$resultat = $objetDB->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
} |
while ($ligne = $resultat->fetchRow()) { |
if ($ligne[0] == 'gen_COUNTRY') { |
if ($ligne[0] == INS_TABLE_PAYS) { |
return ; |
} |
} |
return $this->raiseError ('La table gen_COUNTRY n\'est pas présente dans la base de donnée !') ; |
return $this->raiseError('La table '.INS_TABLE_PAYS.' n\'est pas présente dans la base de donnée !') ; |
} |
|
/** Renvoie la liste des pays traduite |
322,12 → 300,14 |
* @param string une chaine de type i18n ou une chaine code iso langue (fr_FR ou fr ou FR) |
* @return un tableau contenant en clé, le code iso du pays, en majuscule et en valeur le nom du pays traduit |
*/ |
|
function getListePays ($i18n) { |
if (strlen($i18n) == 2) { |
$i18n = strtolower($i18n)."-".strtoupper($i18n) ; |
$i18n = strtolower($i18n).'-'.strtoupper($i18n) ; |
} |
$requete = "select GC_ID, GC_NAME from gen_COUNTRY where GC_LOCALE='fr' order by GC_NAME" ; |
$requete = 'SELECT '.INS_CHAMPS_ID_PAYS.', '.INS_CHAMPS_LABEL_PAYS.' '. |
'FROM '.INS_TABLE_PAYS.' '. |
'WHERE '.INS_CHAMPS_PAYS_LG.' = "fr" '. |
'ORDER BY '.INS_CHAMPS_LABEL_PAYS.' '; |
$resultat = $this->_db->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
336,8 → 316,8 |
return $this->raiseError('Le code fourni ne correspond à aucun pays ou n\'est pas dans la table!') ; |
} |
$retour = array() ; |
while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) { |
$retour[$ligne->GC_ID] = $ligne->GC_NAME; |
while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) { |
$retour[$ligne[INS_CHAMPS_ID_PAYS]] = $ligne[INS_CHAMPS_LABEL_PAYS]; |
} |
return $retour ; |
} |