Subversion Repositories Applications.papyrus

Rev

Rev 754 | Rev 1028 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 754 Rev 832
1
<?php
1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
3
// +------------------------------------------------------------------------------------------------------+
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
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                                  |
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                            |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
21
// +------------------------------------------------------------------------------------------------------+
22
// CVS : $Id: selecteur_sites.php,v 1.8 2006-03-02 10:49:49 ddelon Exp $
22
// CVS : $Id: selecteur_sites.php,v 1.9 2006-04-28 12:41:49 florian Exp $
23
/**
23
/**
24
* Applette : selecteur sites
24
* Applette : selecteur sites
25
*
25
*
26
* Génère un formulaire contenant un menu déroulant permettant de choisir un site parmis les disponibles.
26
* Génère un formulaire contenant un menu déroulant permettant de choisir un site parmis les disponibles.
27
* Nécessite :
27
* Nécessite :
28
* - Constantes et globales de Papyrus.
28
* - Constantes et globales de Papyrus.
29
* - Base de données de Papyrus
29
* - Base de données de Papyrus
30
* - Pear Net_URL
30
* - Pear Net_URL
31
* - Pear DB
31
* - Pear DB
32
* - API Débogage 1.0
32
* - API Débogage 1.0
33
* Le nom de l'applette est "SELECTEUR_SITES" pour afficher un formulaire HTML et "SELECTEUR_SITES_XHTML" 
33
* Le nom de l'applette est "SELECTEUR_SITES" pour afficher un formulaire HTML et "SELECTEUR_SITES_XHTML" 
34
* pour afficher un formulaire XHTML strict.
34
* pour afficher un formulaire XHTML strict.
35
*
35
*
36
*@package Applette
36
*@package Applette
37
*@subpackage Selecteur_sites
37
*@subpackage Selecteur_sites
38
//Auteur original :
38
//Auteur original :
39
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
39
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
40
//Autres auteurs :
40
//Autres auteurs :
41
*@author        Aucun
41
*@author        Aucun
42
*@copyright     Tela-Botanica 2000-2004
42
*@copyright     Tela-Botanica 2000-2004
43
*@version       $Revision: 1.8 $ $Date: 2006-03-02 10:49:49 $
43
*@version       $Revision: 1.9 $ $Date: 2006-04-28 12:41:49 $
44
// +------------------------------------------------------------------------------------------------------+
44
// +------------------------------------------------------------------------------------------------------+
45
*/
45
*/
46
 
46
 
47
// +------------------------------------------------------------------------------------------------------+
47
// +------------------------------------------------------------------------------------------------------+
48
// |                                            ENTÊTE du PROGRAMME                                       |
48
// |                                            ENTÊTE du PROGRAMME                                       |
49
// +------------------------------------------------------------------------------------------------------+
49
// +------------------------------------------------------------------------------------------------------+
50
$_GEN_commun['info_applette_nom_fonction'] = 'afficherSelecteurSite';
50
$_GEN_commun['info_applette_nom_fonction'] = 'afficherSelecteurSite';
51
$_GEN_commun['info_applette_balise'] = 'SELECTEUR_SITES_?(XHTML)?_?(SANS_(?:\d+_?)+)?';
51
$_GEN_commun['info_applette_balise'] = 'SELECTEUR_SITES_?(XHTML)?_?(SANS_(?:\d+_?)+)?';
52
 
52
 
53
 
53
 
54
/** Inclusion du fichier de configuration de cette applette.*/
54
/** Inclusion du fichier de configuration de cette applette.*/
55
require_once GEN_CHEMIN_APPLETTE.'selecteur_sites/configuration/sesi_config.inc.php';
55
require_once GEN_CHEMIN_APPLETTE.'selecteur_sites/configuration/sesi_config.inc.php';
56
 
56
 
57
// Inclusion des fichiers de traduction de l'applette.
57
// Inclusion des fichiers de traduction de l'applette.
58
if (file_exists(SESI_CHEMIN_LANGUE.'sesi_langue_'.$_GEN_commun['i18n'].'.inc.php')) {
58
if (file_exists(SESI_CHEMIN_LANGUE.'sesi_langue_'.$_GEN_commun['i18n'].'.inc.php')) {
59
    /** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
59
    /** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
60
    require_once SESI_CHEMIN_LANGUE.'sesi_langue_'.$_GEN_commun['i18n'].'.inc.php';
60
    require_once SESI_CHEMIN_LANGUE.'sesi_langue_'.$_GEN_commun['i18n'].'.inc.php';
61
} else {
61
} else {
62
    /** Inclusion du fichier de traduction par défaut.*/
62
    /** Inclusion du fichier de traduction par défaut.*/
63
    require_once SESI_CHEMIN_LANGUE.'sesi_langue_'.SESI_I18N_DEFAUT.'.inc.php';
63
    require_once SESI_CHEMIN_LANGUE.'sesi_langue_'.SESI_I18N_DEFAUT.'.inc.php';
64
}
64
}
65
 
65
 
66
// +------------------------------------------------------------------------------------------------------+
66
// +------------------------------------------------------------------------------------------------------+
67
// |                                            CORPS du PROGRAMME                                        |
67
// |                                            CORPS du PROGRAMME                                        |
68
// +------------------------------------------------------------------------------------------------------+
68
// +------------------------------------------------------------------------------------------------------+
69
 
69
 
70
// +------------------------------------------------------------------------------------------------------+
70
// +------------------------------------------------------------------------------------------------------+
71
// |                                           LISTE de FONCTIONS                                         |
71
// |                                           LISTE de FONCTIONS                                         |
72
// +------------------------------------------------------------------------------------------------------+
72
// +------------------------------------------------------------------------------------------------------+
73
/** Fonnction GEN_afficherContenuApplette() - Fournit un formulaire de sélection des sites.
73
/** Fonnction GEN_afficherContenuApplette() - Fournit un formulaire de sélection des sites.
74
*
74
*
75
* Renvoie un formulaire permettant de passer de site en site pour une langue donnée.
75
* Renvoie un formulaire permettant de passer de site en site pour une langue donnée.
76
* Le formulaire affiche les noms des sites en fonctions de la langue passée dans l'url.
76
* Le formulaire affiche les noms des sites en fonctions de la langue passée dans l'url.
77
* Necessite l'utilisation de Pear Net_URL par le programme appelant cette fonction.
77
* Necessite l'utilisation de Pear Net_URL par le programme appelant cette fonction.
78
*
78
*
79
* @param  array  tableau d'éventuel arguments présent dans la balise transmis à la fonction. 
79
* @param  array  tableau d'éventuel arguments présent dans la balise transmis à la fonction. 
80
* @param  array  tableau global de Papyrus.
80
* @param  array  tableau global de Papyrus.
81
* @return   string  formulaire XHTML contenant les sites disponibles.
81
* @return   string  formulaire XHTML contenant les sites disponibles.
82
*/
82
*/
83
function afficherSelecteurSite($tab_applette_arguments, $_GEN_commun)
83
function afficherSelecteurSite($tab_applette_arguments, $_GEN_commun)
84
{
84
{
85
    // Initialisation de variable de configuration.
85
    // Initialisation de variable de configuration.
86
    $liste_type_site = '102, 103';// Les id des types des sites pouvant apparaître dans le sélecteur
86
    $liste_type_site = '102, 103';// Les id des types des sites pouvant apparaître dans le sélecteur
87
    $objet_pear_db = $_GEN_commun['pear_db'];//objet Pear créé par DB contenant la connexion à la base de données.
87
    $objet_pear_db = $_GEN_commun['pear_db'];//objet Pear créé par DB contenant la connexion à la base de données.
88
    $code_site = $_GEN_commun['url_site'];//identifiant du site courant.
88
    $code_site = $_GEN_commun['url_site'];//identifiant du site courant.
89
    $id_langue = $_GEN_commun['i18n'];//identifiant de la langue choisie
89
    $id_langue = $_GEN_commun['i18n'];//identifiant de la langue choisie
90
    $url_base = PAP_URL;
90
    $url_base = PAP_URL;
91
    $url_cle_site = GEN_URL_CLE_SITE;
91
    $url_cle_site = GEN_URL_CLE_SITE;
92
    $url_cle_i18n = GEN_URL_CLE_I18N;
92
    $url_cle_i18n = GEN_URL_CLE_I18N;
93
    $url_id_type_site = GEN_URL_ID_TYPE_SITE;
93
    $url_id_type_site = GEN_URL_ID_TYPE_SITE;
94
    
94
    
95
    
95
    
96
    $indent_origine = 12;// Indentation de départ en nombre d'espace
96
    $indent_origine = 12;// Indentation de départ en nombre d'espace
97
    $indent_pas     = 4;// Pas d'indentation en nombre d'espace
97
    $indent_pas     = 4;// Pas d'indentation en nombre d'espace
98
    
98
    
99
    // Récupérations des arguments passés dans la balise.
99
    // Récupérations des arguments passés dans la balise.
100
    // Nous vérifions si on veut du XHTML strict ou pas
100
    // Nous vérifions si on veut du XHTML strict ou pas
101
    $bln_xhtml_strict = 0;
101
    $bln_xhtml_strict = 0;
102
    if (isset($tab_applette_arguments[2]) && $tab_applette_arguments[2] == 'XHTML') {
102
    if (isset($tab_applette_arguments[2]) && $tab_applette_arguments[2] == 'XHTML') {
103
        $bln_xhtml_strict = 1;
103
        $bln_xhtml_strict = 1;
104
    }
104
    }
105
    // Nous vérifions s'il y a des sites que nous ne voulons pas afficher:
105
    // Nous vérifions s'il y a des sites que nous ne voulons pas afficher:
106
    $morceau_requete_id_suppr = '';
106
    $morceau_requete_id_suppr = '';
-
 
107
    $tab_id_suppr_groupe='';
107
    if (isset($tab_applette_arguments[3]) && ereg('SANS_(.+)', $tab_applette_arguments[3], $tab_id_suppr_groupe)) {
108
    if (isset($tab_applette_arguments[3]) && ereg('SANS_(.+)', $tab_applette_arguments[3], $tab_id_suppr_groupe)) {
108
        if (preg_match('/^\d+$/', $tab_id_suppr_groupe[1])) {
109
        if (preg_match('/^\d+$/', $tab_id_suppr_groupe[1])) {
109
            $liste_id_suppr = $tab_id_suppr_groupe[1];
110
            $liste_id_suppr = $tab_id_suppr_groupe[1];
110
        } else if (preg_match('/^\d+(?:_\d+)+$/', $tab_id_suppr_groupe[1])) {
111
        } else if (preg_match('/^\d+(?:_\d+)+$/', $tab_id_suppr_groupe[1])) {
111
            $liste_id_suppr = preg_replace('/_/', ', ', $tab_id_suppr_groupe[1]);
112
            $liste_id_suppr = preg_replace('/_/', ', ', $tab_id_suppr_groupe[1]);
112
        } else {
113
        } else {
113
            $liste_id_suppr = '0';
114
            $liste_id_suppr = '0';
114
        }
115
        }
115
        $morceau_requete_id_suppr = 'AND gs_id_site NOT IN ('.$liste_id_suppr.') ';
116
        $morceau_requete_id_suppr = 'AND gs_id_site NOT IN ('.$liste_id_suppr.') ';
116
    }
117
    }
117
    
118
    
118
    // Recherche de tous les sites  langue en cours
119
    // Recherche de tous les sites  langue en cours
119
    
120
    
120
    // On recherche l'ensemble des site en excluant le site admin ? (administration de Papyrus).
121
    // On recherche l'ensemble des site en excluant le site admin ? (administration de Papyrus).
121
 
122
 
122
	if (isset($id_langue) && ($id_langue!='')) {
123
	if (isset($id_langue) && ($id_langue!='')) {
123
		$langue_test=$id_langue;
124
		$langue_test=$id_langue;
124
	} else {
125
	} else {
125
		$langue_test=GEN_I18N_ID_DEFAUT;
126
		$langue_test=GEN_I18N_ID_DEFAUT;
126
	}
127
	}
127
    
128
    
128
    $requete =  'SELECT gs_id_site, gs_code_num, gs_code_alpha, gs_nom, gs_ce_i18n '.
129
    $requete =  'SELECT gs_id_site, gs_code_num, gs_code_alpha, gs_nom, gs_ce_i18n '.
129
                'FROM gen_site, gen_site_relation '.
130
                'FROM gen_site, gen_site_relation '.
130
                'WHERE gsr_id_site_01 = gsr_id_site_02 '.
131
                'WHERE gsr_id_site_01 = gsr_id_site_02 '.
131
                'AND gs_id_site = gsr_id_site_01 '.
132
                'AND gs_id_site = gsr_id_site_01 '.
132
                'AND gsr_id_valeur IN ('.$liste_type_site.') '.
133
                'AND gsr_id_valeur IN ('.$liste_type_site.') '.
133
                'AND gs_ce_i18n = "'.$langue_test.'" '.
134
                'AND gs_ce_i18n = "'.$langue_test.'" '.
134
                $morceau_requete_id_suppr.// Liste des sites ne devant pas figurer
135
                $morceau_requete_id_suppr.// Liste des sites ne devant pas figurer
135
                'ORDER BY gs_code_num ASC';// 102 = site "principal" et 103 = site "externe"
136
                'ORDER BY gs_code_num ASC';// 102 = site "principal" et 103 = site "externe"
136
                
137
                
137
    $resultat = $objet_pear_db->query($requete);
138
    $resultat = $objet_pear_db->query($requete);
138
    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
139
    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
139
    
140
    
140
    $liste_site=array();
141
    $liste_site=array();
141
    
142
    
142
    while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
143
    while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
143
    	         // Si le site trouvé est une traduction vers la langue principale, on ne le selectionne pas
144
    	         // Si le site trouvé est une traduction vers la langue principale, on ne le selectionne pas
144
    			if ($langue_test == GEN_I18N_ID_DEFAUT) {
145
    			if ($langue_test == GEN_I18N_ID_DEFAUT) {
145
    		  		$requete_est_traduction =   'SELECT gsr_id_site_01 '.
146
    		  		$requete_est_traduction =   'SELECT gsr_id_site_01 '.
146
	                       'FROM  gen_site_relation '.
147
	                       'FROM  gen_site_relation '.
147
	                       'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_02 ' .
148
	                       'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_02 ' .
148
	                  	   'AND  gsr_id_site_01 <> gsr_id_site_02 ' .
149
	                  	   'AND  gsr_id_site_01 <> gsr_id_site_02 ' .
149
	                       'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
150
	                       'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
150
	                                
151
	                                
151
		            $resultat_est_traduction = $objet_pear_db->query($requete_est_traduction);
152
		            $resultat_est_traduction = $objet_pear_db->query($requete_est_traduction);
152
		            (DB::isError($resultat_est_traduction))
153
		            (DB::isError($resultat_est_traduction))
153
		                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_est_traduction->getMessage(), $requete_est_traduction))
154
		                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_est_traduction->getMessage(), $requete_est_traduction))
154
		                : '';
155
		                : '';
155
		                
156
		                
156
		   			if ( $resultat_est_traduction->numRows() == 0 ) {
157
		   			if ( $resultat_est_traduction->numRows() == 0 ) {
157
	    	 			$liste_site[]=$ligne;
158
	    	 			$liste_site[]=$ligne;
158
		            }
159
		            }
159
    			}
160
    			}
160
    			else {
161
    			else {
161
    				$liste_site[]=$ligne;
162
    				$liste_site[]=$ligne;
162
    			}
163
    			}
163
    }
164
    }
164
    
165
    
165
    $resultat->free();
166
    $resultat->free();
166
    
167
    
167
 
168
 
168
    // Si la langue en cours n'est pas la langue par défaut, recherche des sites ayant comme langue
169
    // Si la langue en cours n'est pas la langue par défaut, recherche des sites ayant comme langue
169
    // la langue par defaut et non traduits dans la langue en cours.
170
    // la langue par defaut et non traduits dans la langue en cours.
170
  	
171
  	
171
 
172
 
172
    // On recherche l'ensemble des site en excluant le site admin (administration de Papyrus).
173
    // On recherche l'ensemble des site en excluant le site admin (administration de Papyrus).
173
 
174
 
174
	if ($langue_test != GEN_I18N_ID_DEFAUT) {
175
	if ($langue_test != GEN_I18N_ID_DEFAUT) {
175
    
176
    
176
    
177
    
177
    // Site ayant commme langue, la langue par defaut 
178
    // Site ayant commme langue, la langue par defaut 
178
	    $requete =  'SELECT gs_id_site, gs_code_num, gs_code_alpha, gs_nom, gs_ce_i18n '.
179
	    $requete =  'SELECT gs_id_site, gs_code_num, gs_code_alpha, gs_nom, gs_ce_i18n '.
179
	                'FROM gen_site, gen_site_relation '.
180
	                'FROM gen_site, gen_site_relation '.
180
	                'WHERE gsr_id_site_01 = gsr_id_site_02 '.
181
	                'WHERE gsr_id_site_01 = gsr_id_site_02 '.
181
	                'AND gs_id_site = gsr_id_site_01 '.
182
	                'AND gs_id_site = gsr_id_site_01 '.
182
	                'AND gsr_id_valeur IN ('.$liste_type_site.') '.
183
	                'AND gsr_id_valeur IN ('.$liste_type_site.') '.
183
	                'AND gs_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" '.
184
	                'AND gs_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" '.
184
	                $morceau_requete_id_suppr.// Liste des sites ne devant pas figurer
185
	                $morceau_requete_id_suppr.// Liste des sites ne devant pas figurer
185
	                'ORDER BY gs_code_num ASC';// 102 = site "principal" et 103 = site "externe"
186
	                'ORDER BY gs_code_num ASC';// 102 = site "principal" et 103 = site "externe"
186
	                
187
	                
187
	    $resultat = $objet_pear_db->query($requete);
188
	    $resultat = $objet_pear_db->query($requete);
188
	    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
189
	    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
189
	    
190
	    
190
	    // Est il traduit ? Non, alors affichage 
191
	    // Est il traduit ? Non, alors affichage 
191
	    
192
	    
192
	    while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
193
	    while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
193
	    	
194
	    	
194
				if (isset($id_langue) && ($id_langue!='')) {
195
				if (isset($id_langue) && ($id_langue!='')) {
195
					$langue_test=$id_langue;
196
					$langue_test=$id_langue;
196
				} else {
197
				} else {
197
					$langue_test=GEN_I18N_ID_DEFAUT;
198
					$langue_test=GEN_I18N_ID_DEFAUT;
198
				}
199
				}
199
			    
200
			    
200
	    				$requete_est_traduction =   'SELECT gsr_id_site_01 '.
201
	    				$requete_est_traduction =   'SELECT gsr_id_site_01 '.
201
	                                'FROM  gen_site_relation '.
202
	                                'FROM  gen_site_relation '.
202
	                                'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_02 ' .
203
	                                'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_02 ' .
203
	                                'AND  gsr_id_site_01 <> gsr_id_site_02 ' .
204
	                                'AND  gsr_id_site_01 <> gsr_id_site_02 ' .
204
	                                'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
205
	                                'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
205
	                                
206
	                                
206
	                                
207
	                                
207
	            $resultat_est_traduction = $objet_pear_db->query($requete_est_traduction);
208
	            $resultat_est_traduction = $objet_pear_db->query($requete_est_traduction);
208
	            (DB::isError($resultat_est_traduction))
209
	            (DB::isError($resultat_est_traduction))
209
	                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_est_traduction->getMessage(), $requete_est_traduction))
210
	                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_est_traduction->getMessage(), $requete_est_traduction))
210
	                : '';
211
	                : '';
211
	                
212
	                
212
	            if ( $resultat_est_traduction->numRows() == 0 ) {
213
	            if ( $resultat_est_traduction->numRows() == 0 ) {
213
	    
214
	    
214
			    
215
			    
215
			    	
216
			    	
216
		    		$requete_traduction =   'SELECT gsr_id_site_01 '.
217
		    		$requete_traduction =   'SELECT gsr_id_site_01 '.
217
		                                    'FROM  gen_site_relation, gen_site '.
218
		                                    'FROM  gen_site_relation, gen_site '.
218
		                                    'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_01 ' .
219
		                                    'WHERE '.$ligne['gs_id_site'].' = gsr_id_site_01 ' .
219
		                                    'AND gsr_id_site_02 = gs_id_site '.
220
		                                    'AND gsr_id_site_02 = gs_id_site '.
220
		                                    'AND gs_ce_i18n = "'.$langue_test.'" '.
221
		                                    'AND gs_ce_i18n = "'.$langue_test.'" '.
221
		                                    'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
222
		                                    'AND gsr_id_valeur = 1 ';// 1 = "avoir traduction"
222
		                                    
223
		                                    
223
		            $resultat_traduction = $objet_pear_db->query($requete_traduction);
224
		            $resultat_traduction = $objet_pear_db->query($requete_traduction);
224
		            (DB::isError($resultat_traduction))
225
		            (DB::isError($resultat_traduction))
225
		                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_traduction->getMessage(), $requete_traduction))
226
		                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_traduction->getMessage(), $requete_traduction))
226
		                : '';
227
		                : '';
227
		                
228
		                
228
		            if ( $resultat_traduction->numRows() == 0 ) {
229
		            if ( $resultat_traduction->numRows() == 0 ) {
229
		            	$liste_site []=$ligne;
230
		            	$liste_site []=$ligne;
230
		            }
231
		            }
231
		            
232
		            
232
		            $resultat_traduction->free();
233
		            $resultat_traduction->free();
233
	            }
234
	            }
234
		    
235
		    
235
	    }
236
	    }
236
	    $resultat->free();
237
	    $resultat->free();
237
	}
238
	}
238
   
239
   
239
        
240
        
240
    if (count($liste_site) == 0 ) {
241
    if (count($liste_site) == 0 ) {
241
        $retour =  str_repeat(' ', $indent_origine + ($indent_pas * 0)).
242
        $retour =  str_repeat(' ', $indent_origine + ($indent_pas * 0)).
242
                '<!-- '.SESI_LG_ETIQUETTE_VALIDER.' -->';
243
                '<!-- '.SESI_LG_ETIQUETTE_VALIDER.' -->';
243
    } else {
244
    } else {
244
        // Préparation de l'url de retour du formulaire
245
        // Préparation de l'url de retour du formulaire
245
        $objet_pear_url = & new Net_URL($url_base);
246
        $objet_pear_url = & new Net_URL($url_base);
246
 
247
 
247
        // Préparation du code du sites
248
        // Préparation du code du sites
248
        $champs_code_site = ($url_id_type_site == 'int') ? 'gs_code_num' : 'gs_code_alpha';
249
        $champs_code_site = ($url_id_type_site == 'int') ? 'gs_code_num' : 'gs_code_alpha';
249
        
250
        
250
        // Préparation du formulaire
251
        // Préparation du formulaire
251
        $retour = str_repeat(' ', $indent_origine + ($indent_pas * 0)).
252
        $retour = str_repeat(' ', $indent_origine + ($indent_pas * 0)).
252
                '<form id="sesi_selecteur" ';
253
                '<form id="sesi_selecteur" ';
253
        // Test sur XHTML strict
254
        // Test sur XHTML strict
254
        if ($bln_xhtml_strict == 0) {
255
        if ($bln_xhtml_strict == 0) {
255
            $retour .= 'name="sesi_selecteur" ';
256
            $retour .= 'name="sesi_selecteur" ';
256
        }
257
        }
257
        $retour .= 'action="'.$objet_pear_url->getURL().'" method="get">'."\n";
258
        $retour .= 'action="'.$objet_pear_url->getURL().'" method="get">'."\n";
258
        
259
        
259
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
260
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
260
                '<fieldset>'."\n";
261
                '<fieldset>'."\n";
261
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
262
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
262
                '<legend>'.SESI_LG_LEGENDE.'</legend>'."\n";
263
                '<legend>'.SESI_LG_LEGENDE.'</legend>'."\n";
263
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
264
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
264
                '<select id="sesi_'.$url_cle_site.'" name="'.$url_cle_site.'" onchange="javascript:this.form.submit();">'."\n";
265
                '<select id="sesi_'.$url_cle_site.'" name="'.$url_cle_site.'" onchange="javascript:this.form.submit();">'."\n";
265
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 3)).
266
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 3)).
266
                '<option value="'.$code_site.'" selected="selected">'.SESI_LG_DEFAUT.'</option>'."\n";
267
                '<option value="'.$code_site.'" selected="selected">'.SESI_LG_DEFAUT.'</option>'."\n";
267
        foreach ($liste_site as $ligne ) {
268
        foreach ($liste_site as $ligne ) {
268
            // Initialisation des variables
269
            // Initialisation des variables
269
            $nom = $ligne['gs_nom'];
270
            $nom = $ligne['gs_nom'];
270
            $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 3)).
271
            $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 3)).
271
                    '<option value="'.$ligne[$champs_code_site].'">'.$nom.'</option>'."\n";
272
                    '<option value="'.$ligne[$champs_code_site].'">'.$nom.'</option>'."\n";
272
        }
273
        }
273
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
274
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
274
                '</select>'."\n";
275
                '</select>'."\n";
275
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
276
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 2)).
276
                '<input id="sesi_ok" name="sesi_ok" type="submit" value="'.SESI_LG__VALIDER.'"/>'."\n";
277
                '<input id="sesi_ok" name="sesi_ok" type="submit" value="'.SESI_LG__VALIDER.'"/>'."\n";
277
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
278
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
278
                '</fieldset>'."\n";
279
                '</fieldset>'."\n";
279
        if ($langue_test != GEN_I18N_ID_DEFAUT) {
280
        if ($langue_test != GEN_I18N_ID_DEFAUT) {
280
	        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
281
	        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 1)).
281
					 '<input name="'.$url_cle_i18n.'" type="hidden" value="'.$id_langue.'"/>'."\n";
282
					 '<input name="'.$url_cle_i18n.'" type="hidden" value="'.$id_langue.'"/>'."\n";
282
        }
283
        }
283
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 0)).
284
        $retour .= str_repeat(' ', $indent_origine + ($indent_pas * 0)).
284
        '</form>'."\n";
285
        '</form>'."\n";
285
        
286
        
286
                
287
                
287
    }
288
    }
288
    
289
    
289
    return $retour;
290
    return $retour;
290
}
291
}
291
 
292
 
292
// +------------------------------------------------------------------------------------------------------+
293
// +------------------------------------------------------------------------------------------------------+
293
// |                                            PIED du PROGRAMME                                         |
294
// |                                            PIED du PROGRAMME                                         |
294
// +------------------------------------------------------------------------------------------------------+
295
// +------------------------------------------------------------------------------------------------------+
295
 
296
 
296
 
297
 
297
 
298
 
298
/* +--Fin du code ----------------------------------------------------------------------------------------+
299
/* +--Fin du code ----------------------------------------------------------------------------------------+
299
*
300
*
300
* $Log: not supported by cvs2svn $
301
* $Log: not supported by cvs2svn $
-
 
302
* Revision 1.8  2006/03/02 10:49:49  ddelon
-
 
303
* Fusion branche multilinguisme dans branche principale
-
 
304
*
301
* Revision 1.7.2.4  2006/02/28 14:02:07  ddelon
305
* Revision 1.7.2.4  2006/02/28 14:02:07  ddelon
302
* Finition multilinguisme
306
* Finition multilinguisme
303
*
307
*
304
* Revision 1.7.2.3  2006/01/19 21:26:20  ddelon
308
* Revision 1.7.2.3  2006/01/19 21:26:20  ddelon
305
* Multilinguisme site + bug ftp
309
* Multilinguisme site + bug ftp
306
*
310
*
307
* Revision 1.7.2.2  2005/12/20 14:40:24  ddelon
311
* Revision 1.7.2.2  2005/12/20 14:40:24  ddelon
308
* Fusion Head vers Livraison
312
* Fusion Head vers Livraison
309
*
313
*
310
* Revision 1.7.2.1  2005/12/07 19:46:14  ddelon
314
* Revision 1.7.2.1  2005/12/07 19:46:14  ddelon
311
* Merge + navi sites
315
* Merge + navi sites
312
*
316
*
313
* Revision 1.7  2005/05/25 12:53:00  jpm
317
* Revision 1.7  2005/05/25 12:53:00  jpm
314
* Changement et ajout d'attributs id.
318
* Changement et ajout d'attributs id.
315
*
319
*
316
* Revision 1.6  2005/05/23 09:31:43  jpm
320
* Revision 1.6  2005/05/23 09:31:43  jpm
317
* Ajout d'une majuscule à un txt.
321
* Ajout d'une majuscule à un txt.
318
*
322
*
319
* Revision 1.5  2004/10/26 18:42:02  jpm
323
* Revision 1.5  2004/10/26 18:42:02  jpm
320
* Possibilité d'externaliser l'applette.
324
* Possibilité d'externaliser l'applette.
321
* Gestion des sites externes.
325
* Gestion des sites externes.
322
*
326
*
323
* Revision 1.4  2004/09/15 09:32:01  jpm
327
* Revision 1.4  2004/09/15 09:32:01  jpm
324
* Mise en conformité avec le standard XHTML Strict.
328
* Mise en conformité avec le standard XHTML Strict.
325
*
329
*
326
* Revision 1.3  2004/07/06 17:07:16  jpm
330
* Revision 1.3  2004/07/06 17:07:16  jpm
327
* Modification de la documentation pour une mailleur analyse par PhpDocumentor.
331
* Modification de la documentation pour une mailleur analyse par PhpDocumentor.
328
*
332
*
329
* Revision 1.2  2004/06/21 07:37:50  alex
333
* Revision 1.2  2004/06/21 07:37:50  alex
330
* Modification d'un label
334
* Modification d'un label
331
*
335
*
332
* Revision 1.1  2004/06/15 15:05:47  jpm
336
* Revision 1.1  2004/06/15 15:05:47  jpm
333
* Changement de nom et d'arborescence de Genesia en Papyrus.
337
* Changement de nom et d'arborescence de Genesia en Papyrus.
334
*
338
*
335
* Revision 1.5  2004/05/05 08:27:12  jpm
339
* Revision 1.5  2004/05/05 08:27:12  jpm
336
* Ajout du paramétrage de l'indentation et l'utilisation de variable pour contenir les textes de l'appli.
340
* Ajout du paramétrage de l'indentation et l'utilisation de variable pour contenir les textes de l'appli.
337
*
341
*
338
* Revision 1.4  2004/05/05 06:44:28  jpm
342
* Revision 1.4  2004/05/05 06:44:28  jpm
339
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
343
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
340
*
344
*
341
* Revision 1.3  2004/05/03 11:19:10  jpm
345
* Revision 1.3  2004/05/03 11:19:10  jpm
342
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
346
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
343
*
347
*
344
* Revision 1.2  2004/05/01 16:13:11  jpm
348
* Revision 1.2  2004/05/01 16:13:11  jpm
345
* Ajout du nom de la balise de l'applette dans le code de l'applette.
349
* Ajout du nom de la balise de l'applette dans le code de l'applette.
346
*
350
*
347
* Revision 1.1  2004/05/01 10:30:59  jpm
351
* Revision 1.1  2004/05/01 10:30:59  jpm
348
* Ajout de l'applette selecteur de sites.
352
* Ajout de l'applette selecteur de sites.
349
*
353
*
350
*
354
*
351
* +-- Fin du code ----------------------------------------------------------------------------------------+
355
* +-- Fin du code ----------------------------------------------------------------------------------------+
352
*/
356
*/
353
?>
357
?>