Subversion Repositories Applications.papyrus

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1107 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
// +------------------------------------------------------------------------------------------------------+
22
// CVS : $Id$
23
/**
24
*
25
*@package bottin
26
//Auteur original :
27
*@author        Florian Schmitt <florian@ecole-et-nature.org>
1421 alexandre_ 28
*@author		Alexandre Granier <alexandre@tela-botanica.org>
1107 florian 29
//Autres auteurs :
1421 alexandre_ 30
*@copyright     Tela-Botanica 2000-2007
1107 florian 31
*@version       $Revision$ $Date$
32
// +------------------------------------------------------------------------------------------------------+
33
*/
34
// +------------------------------------------------------------------------------------------------------+
35
// |                                            ENTETE du PROGRAMME                                       |
36
// +------------------------------------------------------------------------------------------------------+
1467 alexandre_ 37
include_once 'configuration/bottin.config.inc.php';
38
include_once INS_CHEMIN_APPLI.'langues/bottin.admin.langue_fr.php';
1107 florian 39
 
40
 
41
// +------------------------------------------------------------------------------------------------------+
42
// |                                                 CLASSE                                               |
43
// +------------------------------------------------------------------------------------------------------+
1400 alexandre_ 44
 
45
 
1107 florian 46
class Inscription_Admin {
47
    var $objet_pear_auth;
48
    var $objet_pear_db;
49
    var $objet_pear_url;
50
    var $sortie_xhtml;
51
 
52
    /** Fonction redigerContenu() - Affiche le formulaire de r?action
53
    *
54
    *
55
    *   @return  string  Le HTML
56
    */
57
    function afficherContenuCorps()
58
    {
59
        /** Inclusion du fichier de configuration de cette application.*/
60
        require_once PAP_CHEMIN_RACINE.'client/bottin/configuration/bottin.config.inc.php';
61
        //require_once INS_CHEMIN_APPLI.'configuration/cartographie.config.inc.php';
62
        require_once PAP_CHEMIN_API_PEAR.'HTML/QuickForm.php' ;
63
 
64
        //-------------------------------------------------------------------------------------------------------------------
65
        // Initialisation des attributs
66
        $this->objet_pear_auth = $GLOBALS['_GEN_commun']['pear_auth'];
67
        $this->objet_pear_db = $GLOBALS['ins_db'];
68
        $this->objet_pear_url = $GLOBALS['_GEN_commun']['url'];
69
        $this->sortie_xhtml = '<h1>'.INS_CONFIG_INSCRIPTION.'</h1><br />'."\n";
70
 
71
        //-------------------------------------------------------------------------------------------------------------------
72
        // Gestion des boutons de l'interface
73
        if (isset($_POST['afficheur_annuler'])) {
74
            return false;
1421 alexandre_ 75
        }
1107 florian 76
 
1421 alexandre_ 77
 
1107 florian 78
        $requete = 'SELECT gm_application_arguments FROM gen_menu WHERE gm_id_menu='.$_GET['adme_menu_id'];
79
        $resultat = $this->objet_pear_db->query($requete) ;
80
        if (DB::isError($resultat)) {
1400 alexandre_ 81
        	return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
1107 florian 82
        }
83
        $valeurs_par_defaut = array();
1400 alexandre_ 84
        if ($resultat->numRows()>0) {
1107 florian 85
        	while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
86
        		$arguments = explode(' ', $ligne->gm_application_arguments);
87
 				for ($i = 0; $i < count($arguments); $i++) {
88
 					$attr = explode('=', $arguments[$i]);
89
 					if ($attr[0] != '') {
90
 						$info_application->$attr[0] = (isset($attr[1]) ? $attr[1] : '');
91
 					}
92
 			   	}
93
 			}
94
        	//valeurs par defaut enregistrees dans la table
1400 alexandre_ 95
        	if (isset ($info_application->type_annuaire))$valeurs_par_defaut['type_annuaire']=$info_application->type_annuaire;
1107 florian 96
        } else {
97
        	//valeurs par defaut pour afficher une carto des structures
1400 alexandre_ 98
        	$valeurs_par_defaut['type_annuaire']=0;
1107 florian 99
        }
100
 
1421 alexandre_ 101
        //-------------------------------------------------------------------------------------------------------------
102
        // Si le formulaire vient d etre poste, on met a jour la table inscription_configuration
103
 
104
        if (isset($_POST['enregistrer_quitter'])) {
1467 alexandre_ 105
        	if (isset ($_POST['id_inscription'])) {
106
	        	$req = 'update inscription_configuration set '.
107
	        			'ic_nom_inscription="'.$_POST['ic_nom_inscription'].'", '.
108
	        			'ic_url_bazar="'.$_POST['ic_url_bazar'].'", '.
109
	        			(isset ($_POST['ic_inscription_modere']) ? 'ic_inscription_modere="'.$_POST['ic_inscription_modere'].'", ':'ic_inscription_modere=0, ').
110
	        			'ic_mail_moderateur="'.$_POST['ic_mail_moderateur'].'", '.
111
	        			'ic_from_mail_confirmation="'.$_POST['ic_from_mail_confirmation'].'", '.
112
	        			'ic_utilise_nom_wiki="'.$_POST['ic_utilise_nom_wiki'].'", '.
113
	        			(isset ($_POST['ic_genere_nom_wiki']) ? 'ic_genere_nom_wiki="'.$_POST['ic_genere_nom_wiki'].'", ':'').
114
	        			(isset ($_POST['ic_utilise_reecriture_url']) ? 'ic_utilise_reecriture_url="'.$_POST['ic_utilise_reecriture_url'].'", ':'').
115
	        			'ic_url_prefixe="'.$_POST['ic_url_prefixe'].'", '.
116
	        			(isset ($_POST['ic_mail_valide_inscription']) ? 'ic_mail_valide_inscription="'.$_POST['ic_mail_valide_inscription'].'", ':'').
117
	        			'ic_mail_inscription_news="'.$_POST['ic_mail_inscription_news'].'", '.
118
	        			'ic_mail_admin_apres_inscription="'.$_POST['ic_mail_admin_apres_inscription'].'"'.
119
	        			' where ic_id_inscription="'.$_GET['id_inscription'].'"';
120
 
1486 alexandre_ 121
	        	$res = $GLOBALS['ins_db']->query($req);$this->sortie_xhtml .= $req;
122
	        	if (DB::isError($res)) $this->sortie_xhtml .= $res->getMessage().'<br />'.$res->getDebugInfo();
1421 alexandre_ 123
        	}
1467 alexandre_ 124
        	if (isset($_POST['id_template'])) {
125
        		$req = 'update inscription_template set ' .
126
        				'it_nom_template="'.$_POST['it_nom_template'].'",' .
127
        				'it_template="'.$_POST['it_template'].'" ' .
1573 alexandre_ 128
        				'where it_id_template="'.$_REQUEST['id_template'].'"'.
129
        				' and it_ce_inscription="'.$_REQUEST['id_inscription'].'"';
130
 
131
 
132
 
1467 alexandre_ 133
        		$GLOBALS['ins_db']->query($req);
134
        	}
1421 alexandre_ 135
        }
136
 
137
 
1400 alexandre_ 138
        // Requete pour recuperer les valeurs de la table inscription_config
1426 alexandre_ 139
        $requete = 'select * from inscription_configuration order by ic_id_inscription';
1467 alexandre_ 140
        $resultat = $GLOBALS['ins_db']->query($requete) ;
1400 alexandre_ 141
        if (DB::isError($resultat)) {
142
        	return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
143
        }
1421 alexandre_ 144
        if ($resultat->numRows() == 0) {
1400 alexandre_ 145
        	return 'La table inscription_configuration est vide. Il faut qu\'elle contienne au moins une ligne';
146
        }
1467 alexandre_ 147
 
148
        $GLOBALS['ins_url']->addQueryString('adme_site_id', $_GET['adme_site_id']);
149
        $GLOBALS['ins_url']->addQueryString('adme_menu_id', $_GET['adme_menu_id']);
150
        $GLOBALS['ins_url']->addQueryString('adme_action', 'administrer');
151
 
152
        // Affichage des inscriptions disponible
153
        $this->sortie_xhtml .= '<ul>';
1426 alexandre_ 154
        while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
1467 alexandre_ 155
        	$GLOBALS['ins_url']->addQueryString('id_inscription', $ligne['ic_id_inscription']);
156
        	$this->sortie_xhtml .= '<li><a href="'.$GLOBALS['ins_url']->getURL().'">'.$ligne['ic_nom_inscription'];
157
        	$this->sortie_xhtml .= '</a></li>';
158
        }
159
        $this->sortie_xhtml .= '</ul>';
160
 
161
        if (isset ($_GET['id_inscription'])) {
162
        	$requete = 'select * from inscription_configuration where ic_id_inscription="'.$_GET['id_inscription'].'"';
163
        	$resultat = $GLOBALS['ins_db']->query($requete) ;
164
	        if (DB::isError($resultat)) {
165
	        	return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
166
	        }
167
	        if ($resultat->numRows() == 0) {
168
        		return 'La table inscription_configuration est vide. Il faut qu\'elle contienne au moins une ligne';
169
        	}
170
        	$ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC);
171
        	$this->sortie_xhtml .= '<h2>'.$ligne['ic_nom_inscription'].'</h2>';
172
 
1426 alexandre_ 173
	        //-------------------------------------------------------------------------------------------------------------
174
	        // Gestion du formulaire
1467 alexandre_ 175
 
1426 alexandre_ 176
	        $GLOBALS['ins_url']->addQueryString('id_inscription', $ligne['ic_id_inscription']);
1467 alexandre_ 177
	        $form = &new HTML_QuickForm('form_param_inscription', 'post', str_replace('&amp;', '&', $GLOBALS['ins_url']->getUrl()));
178
	        $squelette =& $form->defaultRenderer();
1426 alexandre_ 179
	        $squelette->setFormTemplate("\n".'<form {attributes}>'."\n".'{content}'."\n".'</form>'."\n");
180
	        $squelette->setElementTemplate( '<p>'."\n".
181
	                                        '<label style="width:100px;padding:5px;text-align:right;">{label}'.
182
	                                        '<!-- BEGIN required --><span class="symbole_obligatoire">*</span><!-- END required -->'."\n".
183
	                                        '<!-- BEGIN error --><span class="erreur">{error}</span><!-- END error -->'."\n".
184
											' : </label>'."\n".'{element}'."\n".
185
											'</p>'."\n" );
1467 alexandre_ 186
 
187
	        $form->addElement('text', 'ic_nom_inscription', INS_NOM_INSCRIPTION);
188
	        $form->addElement('checkbox', 'ic_inscription_modere', INS_INSCRIPTION_MODERE);
189
	        $form->addElement('textarea', 'ic_mail_moderateur', INS_MAILS_MODERATEURS, array('cols' => 30, 'rows' => 4));
190
	        $form->addElement('checkbox', 'ic_mail_valide_inscription', INS_INSCRIPTION_VERIFICATION_EMAIL);
191
	        $form->addElement('textarea', 'ic_mail_admin_apres_inscription', INS_MAILS_ADMIN, array('cols' => 30, 'rows' => 4));
192
	        $form->addElement('text', 'ic_from_mail_confirmation', INS_FROM_MAIL_CONFIRMATION, array('size' => '50'));
193
 
194
	        $form->addElement('checkbox', 'ic_utilise_nom_wiki', INS_CHAMPS_WIKI);
195
	        $form->addElement('checkbox', 'ic_genere_nom_wiki', INS_GENERE_NOM_WIKI);
196
	        $form->addElement('checkbox', 'ic_utilise_reecriture_url', INS_REECRITURE_URL);
197
	        $form->addElement('text', 'ic_url_prefixe', INS_PREFIXE_URL);
198
	        $form->addElement('text', 'ic_mail_inscription_news', INS_MAIL_INSCRIPTION_NEWS, array('size' => '50'));
1426 alexandre_ 199
 
1467 alexandre_ 200
	        $form->addElement('text', 'ic_url_bazar', INS_URL_BAZAR);
201
	        $form->addElement('hidden', 'id_inscription', $_GET['id_inscription']);
202
	        $form->addElement('submit', 'enregistrer_quitter', INS_ENREGISTRER_ET_QUITTER);
203
	        $form->addElement('button', 'afficheur_annuler', INS_ANNULER);
1426 alexandre_ 204
 
1467 alexandre_ 205
	        $form->setDefaults($ligne);
206
	        $this->sortie_xhtml .= $form->toHTML()."\n";
207
	        $this->sortie_xhtml .= '<hr /><br />';
208
 
209
	        // recuperation des templates
210
	        $requete = 'select * from inscription_template where it_ce_inscription="'.$_GET['id_inscription'].'"';
211
	        $resultat = $GLOBALS['ins_db']->query($requete) ;
212
	        if (DB::isError($resultat)) {
213
	        	return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
214
	        }
215
	        if ($resultat->numRows() == 0) {
216
        		$this->sortie_xhtml .= 'La table inscription_template est vide. Ca n\'est pas normal';
217
        	}
218
        	$this->sortie_xhtml .= '<ul>';
219
        	while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
220
        		$GLOBALS['ins_url']->addQueryString('id_template', $ligne['it_id_template']);
221
        		$this->sortie_xhtml .= '<li><a href="'.$GLOBALS['ins_url']->getURL().'">'.$ligne['it_nom_template'].'</a></li>'."\n";
222
        	}
223
        	$this->sortie_xhtml .= '</ul>';
224
        	// Si un template a ete clique, on affiche le formulaire
225
        	if (isset ($_GET['id_template'])) {
226
        		$requete = 'select * from inscription_template where it_id_template="'.$_GET['id_template'].'"';
227
        		if (isset ($GLOBALS['langue'])) $requete .= ' and it_i18n="'.$GLOBALS['langue'].'"';
228
        		$requete .= ' and it_ce_inscription="'.$_GET['id_inscription'].'"';
229
	        	$resultat = $GLOBALS['ins_db']->query($requete) ;
230
		        if (DB::isError($resultat)) {
231
		        	return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
232
		        }
233
		        if ($resultat->numRows() == 0) {
234
	        		return 'Pas de template avec ce numero.';
235
	        	}
236
	        	$ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC);
237
	        	$this->sortie_xhtml .= '<h2>'.$ligne['it_nom_template'].'</h2>';
238
 
239
		        //-------------------------------------------------------------------------------------------------------------
240
		        // Gestion du formulaire
241
 
242
		        $GLOBALS['ins_url']->addQueryString('id_template', $ligne['it_id_template']);
243
		        $form = &new HTML_QuickForm('form_inscription_template', 'post', str_replace('&amp;', '&', $GLOBALS['ins_url']->getUrl()));
244
		        $form->addElement('text', 'it_nom_template', INS_NOM_MODELE, array ('size' => 40));
245
 
246
		        // Recherche des langues
247
 
248
		        $form->addElement('textarea', 'it_template', INS_CONTENU_MODELE, array('cols' => 80, 'rows' => 12));
249
 
250
		        require_once PAP_CHEMIN_API_PEAR.'I18Nv2/Language.php';
251
		        $lang = & new I18Nv2_Language('fr', 'iso-8859-1');
252
 
253
 
254
		        // Les langues utilisees dans le site sont gen_i18n_langue
255
		        $requete_langue = 'select * from gen_i18n_langue';
256
		        $resultat_langue = $GLOBALS ['ins_db']->query($requete_langue);
257
		        while ($ligne_langue = $resultat_langue->fetchRow(DB_FETCHMODE_OBJECT)) {
258
		        	$langues[$ligne_langue->gil_id_langue] = $ligne_langue->gil_nom;
259
		        }
260
 
261
		        $form->addElement('html', '<tr><td>'.INS_LANGUE.' : '.$lang->getName($ligne_langue->it_i18n).'</td></tr>');
262
		        $form->addElement('hidden', 'id_template', $ligne['it_id_template']);
263
		        $form->addElement('submit', 'enregistrer_quitter', INS_ENREGISTRER_ET_QUITTER);
264
		        $form->addElement('button', 'afficheur_annuler', INS_ANNULER);
265
		        $form->setDefaults($ligne);
266
		        $this->sortie_xhtml .= $form->toHTML()."\n";
267
		        $this->sortie_xhtml .= '<hr /><br />';
268
        	}
269
 
1426 alexandre_ 270
        }
1107 florian 271
        return $this->sortie_xhtml;
272
    }
273
 
274
}// Fin de la classe
275
 
276
// +------------------------------------------------------------------------------------------------------+
277
// |                                            PIED du PROGRAMME                                         |
278
// +------------------------------------------------------------------------------------------------------+
279
?>