Subversion Repositories Applications.papyrus

Rev

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

Rev 1498 Rev 2002
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: afficheur.php,v 1.14 2007-06-26 15:38:39 jp_milcent Exp $
22
// CVS : $Id: afficheur.php,v 1.14 2007-06-26 15:38:39 jp_milcent Exp $
23
/**
23
/**
24
* Application réalisant l'affichage du contenu stocké dans Papyrus.
24
* Application réalisant l'affichage du contenu stocké dans Papyrus.
25
*
25
*
26
* Récupère le dernier contenu lié à un menu et le retourne.
26
* Récupère le dernier contenu lié à un menu et le retourne.
27
*
27
*
28
*@package Afficheur
28
*@package Afficheur
29
//Auteur original :
29
//Auteur original :
30
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
30
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
31
//Autres auteurs :
31
//Autres auteurs :
32
*@author        Alexandre GRANIER <alexandrel@tela-botanica.org>
32
*@author        Alexandre GRANIER <alexandrel@tela-botanica.org>
33
*@copyright     Tela-Botanica 2000-2004
33
*@copyright     Tela-Botanica 2000-2004
34
*@version       $Revision: 1.14 $ $Date: 2007-06-26 15:38:39 $
34
*@version       $Revision: 1.14 $ $Date: 2007-06-26 15:38:39 $
35
// +------------------------------------------------------------------------------------------------------+
35
// +------------------------------------------------------------------------------------------------------+
36
*/
36
*/
37
 
37
 
38
// +------------------------------------------------------------------------------------------------------+
38
// +------------------------------------------------------------------------------------------------------+
39
// |                                            ENTÊTE du PROGRAMME                                       |
39
// |                                            ENTÊTE du PROGRAMME                                       |
40
// +------------------------------------------------------------------------------------------------------+
40
// +------------------------------------------------------------------------------------------------------+
41
/** Inclusion du fichier de configuration de cette application.*/
41
/** Inclusion du fichier de configuration de cette application.*/
42
require_once GEN_CHEMIN_PAP.'applications/afficheur/configuration/affi_configuration.inc.php';
42
require_once GEN_CHEMIN_PAP.'applications/afficheur/configuration/affi_configuration.inc.php';
43
// Inclusion de la bibliothèque PEAR Text_Wiki réalisées par Papyrus.
43
// Inclusion de la bibliothèque PEAR Text_Wiki réalisées par Papyrus.
44
 
44
 
45
// +------------------------------------------------------------------------------------------------------+
45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            CORPS du PROGRAMME                                        |
46
// |                                            CORPS du PROGRAMME                                        |
47
// +------------------------------------------------------------------------------------------------------+
47
// +------------------------------------------------------------------------------------------------------+
48
/** Fonction afficherContenuTete() - Fonction appelé par le gestionnaire Papyrus.
48
/** Fonction afficherContenuTete() - Fonction appelé par le gestionnaire Papyrus.
49
*
49
*
50
* Elle retourne l'entête de l'application..
50
* Elle retourne l'entête de l'application..
51
*
51
*
52
* @return  string  du code XHTML correspondant à la zone d'entête de l'application.
52
* @return  string  du code XHTML correspondant à la zone d'entête de l'application.
53
*/
53
*/
54
function afficherContenuTete()
54
function afficherContenuTete()
55
{
55
{
56
    return '';
56
    return '';
57
}
57
}
58
 
58
 
59
function afficherContenuCorps() {
59
function afficherContenuCorps() {
60
	$retour = '';
60
	$retour = '';
61
    $db = $GLOBALS['_AFFICHEUR']['objet_pear_db'];
61
    $db = $GLOBALS['_AFFICHEUR']['objet_pear_db'];
62
	$id_or = GEN_rechercheMenuCode($db, GEN_rechercheMenuIdentifiant($db, $GLOBALS['_AFFICHEUR']['menu_courant_id']));
62
	$id_or = GEN_rechercheMenuCode($db, GEN_rechercheMenuIdentifiant($db, $GLOBALS['_AFFICHEUR']['menu_courant_id']));
63
 
63
 
64
    $ligne_contenu = GEN_rechercheContenu($db, $id_or);
64
    $ligne_contenu = GEN_rechercheContenu($db, $id_or);
65
	        
65
	        
66
	$contenu = $ligne_contenu->gmc_contenu;
66
	$contenu = $ligne_contenu->gmc_contenu;
67
	
67
	
68
	// Inclusion de la bibliothèque Text_Wiki_Papyrus effectuées par Papyrus précédement
68
	// Inclusion de la bibliothèque Text_Wiki_Papyrus effectuées par Papyrus précédement
69
	// Les actions Text_Wiki_Papyrus sont gérées par Papyrus
69
	// Les actions Text_Wiki_Papyrus sont gérées par Papyrus
70
	
70
	
71
	// Nous regardons si nous avons à faire à un texte sous format Wikini ou XHTML
71
	// Nous regardons si nous avons à faire à un texte sous format Wikini ou XHTML
72
	if (($ligne_contenu->gmc_ce_type_contenu == 1)||(substr($ligne_contenu->gmc_ce_type_contenu,-1)== 1)) {
72
	if (($ligne_contenu->gmc_ce_type_contenu == 1)||(substr($ligne_contenu->gmc_ce_type_contenu,-1)== 1)) {
73
	    $retour = $contenu;
73
	    $retour = $contenu;
74
	} elseif (($ligne_contenu->gmc_ce_type_contenu == 2) || (substr($ligne_contenu->gmc_ce_type_contenu,-1)== 2)){
74
	} elseif (($ligne_contenu->gmc_ce_type_contenu == 2) || (substr($ligne_contenu->gmc_ce_type_contenu,-1)== 2)){
75
	    include_once AFFI_CHEMIN_BIBLIOTHEQUE_API.'text/wiki_wikini/Wikini.class.php';
75
	    include_once AFFI_CHEMIN_BIBLIOTHEQUE_API.'text/wiki_wikini/Wikini.class.php';
76
	    // Création d'un objet Text_Wikini :
76
	    // Création d'un objet Text_Wikini :
77
	    $wikini =& new Text_Wikini();
77
	    $wikini =& new Text_Wikini();
78
	    // Pour éviter de remplacer les caractères spéciaux du XHTML:
78
	    // Pour éviter de remplacer les caractères spéciaux du XHTML:
79
	    $wikini->setFormatConf('Xhtml', 'translate', false);
79
	    $wikini->setFormatConf('Xhtml', 'translate', false);
80
	    // Configuration de la règle Freelink :
80
	    // Configuration de la règle Freelink :
81
	    $wikini->setRenderConf('Xhtml', 'freelink', 'pages', null);
81
	    $wikini->setRenderConf('Xhtml', 'freelink', 'pages', null);
82
	    $wikini->setRenderConf('Xhtml', 'freelink', 'view_url', AFFI_URL_PAPYRUS);
82
	    $wikini->setRenderConf('Xhtml', 'freelink', 'view_url', AFFI_URL_PAPYRUS);
83
	    // Configuration de la règle Interwiki :
83
	    // Configuration de la règle Interwiki :
84
	    $wikini->setRenderConf('Xhtml', 'interwiki', 'sites', $GLOBALS['_AFFICHEUR']['interwiki_sites']);
84
	    $wikini->setRenderConf('Xhtml', 'interwiki', 'sites', $GLOBALS['_AFFICHEUR']['interwiki_sites']);
85
	    // Application des règles de Wikini :
85
	    // Application des règles de Wikini :
86
	    $retour = $wikini->transform($contenu, 'Xhtml');
86
	    $retour = $wikini->transform($contenu, 'Xhtml');
87
	}
87
	}
-
 
88
  
-
 
89
	// +---------------------------------------------------------------------------------------------------------------+
-
 
90
	// Nous regardons si nous voulons surligner ou pas des mots
-
 
91
	if (isset($_GET['var_recherche'])) {
-
 
92
		$tab_mots = explode(' ', rawurldecode($_GET['var_recherche']));
-
 
93
		foreach ($tab_mots as $mot) {
-
 
94
			if (strlen($mot) >= 2) {
-
 
95
				$regexp = '/(>[^<]*)('.$mot.'\b)/Uis';
-
 
96
				$retour = preg_replace($regexp, '$1<span class="surlignage">$2</span>', $retour);
-
 
97
			}
-
 
98
		}
-
 
99
	}
88
  
100
	
89
    //----------------------------------------------------------------------------
101
    //----------------------------------------------------------------------------
90
    // Renvoie du contenu de la page
102
    // Renvoie du contenu de la page
91
    return $retour;
103
    return $retour;
92
}
104
}
93
	
105
	
94
 
106
 
95
 
107
 
96
/** Fonction afficherContenuCorps() - Fonction appelé par le gestionnaire Papyrus.
108
/** Fonction afficherContenuCorps() - Fonction appelé par le gestionnaire Papyrus.
97
*
109
*
98
* Elle retourne le contenu stocké dans Papyrus pour le menu courant demandé.
110
* Elle retourne le contenu stocké dans Papyrus pour le menu courant demandé.
99
*
111
*
100
* @return  string  du code XHTML correspondant au contenu du menu demandé.
112
* @return  string  du code XHTML correspondant au contenu du menu demandé.
101
*/
113
*/
102
function afficherContenuCorpsOld()
114
function afficherContenuCorpsOld()
103
{
115
{
104
    //----------------------------------------------------------------------------
116
    //----------------------------------------------------------------------------
105
    // Initialisation des variable
117
    // Initialisation des variable
106
    $retour = '';
118
    $retour = '';
107
    
119
    
108
    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
120
    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
109
    
121
    
110
    if (isset($id_langue) && ($id_langue!='')) {
122
    if (isset($id_langue) && ($id_langue!='')) {
111
		$langue_test=$id_langue;
123
		$langue_test=$id_langue;
112
	} else {
124
	} else {
113
		$langue_test=GEN_I18N_ID_DEFAUT;
125
		$langue_test=GEN_I18N_ID_DEFAUT;
114
	}
126
	}
115
 
127
 
116
	//-------------------------------------------------------------------------------------------------------------------
128
	//-------------------------------------------------------------------------------------------------------------------
117
        // Récupération des informations du contenu concerné.
129
        // Récupération des informations du contenu concerné.
118
     $ligne_menu = GEN_lireInfoMenu($GLOBALS['_AFFICHEUR']['objet_pear_db'], $GLOBALS['_AFFICHEUR']['menu_courant_id'], DB_FETCHMODE_ASSOC);
130
     $ligne_menu = GEN_lireInfoMenu($GLOBALS['_AFFICHEUR']['objet_pear_db'], $GLOBALS['_AFFICHEUR']['menu_courant_id'], DB_FETCHMODE_ASSOC);
119
        
131
        
120
        
132
        
121
     if ($ligne_menu == false) {
133
     if ($ligne_menu == false) {
122
            die('ERREUR Papyrus Administrateur de Menus: impossible de lire les infos du menu.<br />'.
134
            die('ERREUR Papyrus Administrateur de Menus: impossible de lire les infos du menu.<br />'.
123
                'Idenitifiant du menu n° : '. $GLOBALS['_AFFICHEUR']['objet_pear_db'] .'<br />'.
135
                'Idenitifiant du menu n° : '. $GLOBALS['_AFFICHEUR']['objet_pear_db'] .'<br />'.
124
                'Ligne n° : '. __LINE__ .'<br />'.
136
                'Ligne n° : '. __LINE__ .'<br />'.
125
                'Fichier n° : '. __FILE__ .'<br />');
137
                'Fichier n° : '. __FILE__ .'<br />');
126
     }
138
     }
127
        
139
        
128
 
140
 
129
    // Comment ca marche ?
141
    // Comment ca marche ?
130
    // Historiquement, le code menu est associé au contenu
142
    // Historiquement, le code menu est associé au contenu
131
    // Depuis le passage au multilinguisme : ce comportement est conservé mais :
143
    // Depuis le passage au multilinguisme : ce comportement est conservé mais :
132
    // Tout nouveau contenu, contient également l'information code gm_id_menu, enfoui dans le 
144
    // Tout nouveau contenu, contient également l'information code gm_id_menu, enfoui dans le 
133
    // type contenu.
145
    // type contenu.
134
    
146
    
135
    // Récupération identifiant du menu en cours 
147
    // Récupération identifiant du menu en cours 
136
    
148
    
137
    $requete =  'SELECT gm_id_menu, gm_code_num   '.
149
    $requete =  'SELECT gm_id_menu, gm_code_num   '.
138
                'FROM gen_menu  '.
150
                'FROM gen_menu  '.
139
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
151
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
140
                'AND gm_ce_i18n = "'.$langue_test.'" ';
152
                'AND gm_ce_i18n = "'.$langue_test.'" ';
141
 
153
 
142
	$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
154
	$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
143
	
155
	
144
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
156
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
145
	if ( $resultat->numRows() > 0 ) {
157
	if ( $resultat->numRows() > 0 ) {
146
	
158
	
147
			$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
159
			$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
148
	}
160
	}
149
	else {
161
	else {
150
	
162
	
151
	// Recherche defaut :
163
	// Recherche defaut :
152
 
164
 
153
	$requete =  'SELECT gm_id_menu, gm_code_num   '.
165
	$requete =  'SELECT gm_id_menu, gm_code_num   '.
154
                'FROM gen_menu  '.
166
                'FROM gen_menu  '.
155
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' ';
167
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' ';
156
                'AND gm_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" ';
168
                'AND gm_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" ';
157
 
169
 
158
		$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
170
		$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
159
 
171
 
160
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
172
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
161
		
173
		
162
		$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
174
		$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
163
		
175
		
164
			if ($langue_test!=GEN_I18N_ID_DEFAUT) {
176
			if ($langue_test!=GEN_I18N_ID_DEFAUT) {
165
		
177
		
166
			    $requete_defaut =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
178
			    $requete_defaut =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
167
	                            	'FROM  gen_menu_relation '.
179
	                            	'FROM  gen_menu_relation '.
168
	                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
180
	                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
169
	                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
181
	                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
170
				$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
182
				$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
171
				(DB::isError($resultat_defaut))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut))
183
				(DB::isError($resultat_defaut))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut))
172
				: '';
184
				: '';
173
				if ($resultat_defaut->numRows() > 0) {
185
				if ($resultat_defaut->numRows() > 0) {
174
						$ligne=$resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
186
						$ligne=$resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
175
				}
187
				}
176
			}
188
			}
177
		}  
189
		}  
178
 
190
 
179
	// Cas historique : ce menu n'a jamais été traduit.
191
	// Cas historique : ce menu n'a jamais été traduit.
180
	$requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
192
	$requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
181
	                'FROM gen_menu_contenu  '.
193
	                'FROM gen_menu_contenu  '.
182
	                'WHERE gmc_ce_menu = '.$ligne->gm_id_menu.' '.
194
	                'WHERE gmc_ce_menu = '.$ligne->gm_id_menu.' '.
183
	                'AND gmc_ce_type_contenu in (1,2) '.
195
	                'AND gmc_ce_type_contenu in (1,2) '.
184
	                'AND gmc_bool_dernier = 1';
196
	                'AND gmc_bool_dernier = 1';
185
	
197
	
186
	$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
198
	$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
187
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
199
	(DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
188
	
200
	
189
	
201
	
190
	// Rien trouvé ? : Migration multilinguisme ou pas encore de contenu 
202
	// Rien trouvé ? : Migration multilinguisme ou pas encore de contenu 
191
	
203
	
192
	if ( $resultat->numRows() == 0 ) {
204
	if ( $resultat->numRows() == 0 ) {
193
	
205
	
194
		
206
		
195
	    // Migration multilinguisme 
207
	    // Migration multilinguisme 
196
	     
208
	     
197
	    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
209
	    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
198
	                'FROM gen_menu_contenu  '.
210
	                'FROM gen_menu_contenu  '.
199
	                'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
211
	                'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
200
	                'AND truncate((gmc_ce_type_contenu/10),0) = '. $ligne->gm_id_menu . ' '.
212
	                'AND truncate((gmc_ce_type_contenu/10),0) = '. $ligne->gm_id_menu . ' '.
201
	                'AND gmc_bool_dernier = 1';
213
	                'AND gmc_bool_dernier = 1';
202
	    
214
	    
203
	    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
215
	    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
204
	    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
216
	    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
205
	
217
	
206
		// Pas de contenu, tentative de recuperation du contenu se 
218
		// Pas de contenu, tentative de recuperation du contenu se 
207
			
219
			
208
		if ( $resultat->numRows() == 0 ) {
220
		if ( $resultat->numRows() == 0 ) {
209
			
221
			
210
					
222
					
211
	
223
	
212
						    $requete =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
224
						    $requete =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
213
				                            	'FROM  gen_menu_relation '.
225
				                            	'FROM  gen_menu_relation '.
214
				                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
226
				                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
215
				                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
227
				                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
216
				                            	
228
				                            	
217
							$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
229
							$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
218
							
230
							
219
				                            	
231
				                            	
220
							(DB::isError($resultat))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete))
232
							(DB::isError($resultat))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete))
221
							: '';
233
							: '';
222
 
234
 
223
						
235
						
224
					    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
236
					    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
225
		                'FROM gen_menu_contenu, gen_menu_relation '.
237
		                'FROM gen_menu_contenu, gen_menu_relation '.
226
		                'WHERE truncate((gmc_ce_type_contenu/10),0) = gmr_id_menu_01 '.
238
		                'WHERE truncate((gmc_ce_type_contenu/10),0) = gmr_id_menu_01 '.
227
		                'AND '.$ligne->gm_id_menu.' = gmr_id_menu_02 '.
239
		                'AND '.$ligne->gm_id_menu.' = gmr_id_menu_02 '.
228
		                'AND gmr_id_valeur = 2 '.
240
		                'AND gmr_id_valeur = 2 '.
229
		                'AND gmc_bool_dernier = 1';
241
		                'AND gmc_bool_dernier = 1';
230
 
242
 
231
					    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
243
					    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
232
					    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
244
					    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
233
 
245
 
234
/*   
246
/*   
235
	
247
	
236
						    $requete =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
248
						    $requete =   'SELECT gmr_id_menu_02 as gm_id_menu , ' . $ligne->gm_code_num . ' as gm_code_num '.
237
				                            	'FROM  gen_menu_relation '.
249
				                            	'FROM  gen_menu_relation '.
238
				                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
250
				                            	'WHERE '.$ligne->gm_id_menu. ' = gmr_id_menu_01 ' .
239
				                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
251
				                            	'AND  gmr_id_valeur  = 105 ';// 105 Traduction par defaut
240
				                            	
252
				                            	
241
							$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
253
							$resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
242
							print_r ($requete);
254
							print_r ($requete);
243
							
255
							
244
				                            	
256
				                            	
245
							(DB::isError($resultat))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete))
257
							(DB::isError($resultat))             ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete))
246
							: '';
258
							: '';
247
*/
259
*/
248
									
260
									
249
				}
261
				}
250
				// Toujours rien ?
262
				// Toujours rien ?
251
					
263
					
252
				if ( $resultat->numRows() == 0 ) {
264
				if ( $resultat->numRows() == 0 ) {
253
					
265
					
254
						$requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
266
						$requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
255
	                	'FROM gen_menu_contenu  '.
267
	                	'FROM gen_menu_contenu  '.
256
	                	'WHERE gmc_ce_menu = '.$ligne->gm_code_num.' '.
268
	                	'WHERE gmc_ce_menu = '.$ligne->gm_code_num.' '.
257
	                	'AND gmc_ce_type_contenu in (1,2) '.
269
	                	'AND gmc_ce_type_contenu in (1,2) '.
258
	                	'AND gmc_bool_dernier = 1';
270
	                	'AND gmc_bool_dernier = 1';
259
					                
271
					                
260
					                
272
					                
261
					    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
273
					    $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
262
					    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
274
					    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
263
	    
275
	    
264
									
276
									
265
				}
277
				}
266
				
278
				
267
		}
279
		}
268
			
280
			
269
		 $ligne_contenu = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
281
		 $ligne_contenu = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
270
	    
282
	    
271
	        
283
	        
272
	$contenu = $ligne_contenu->gmc_contenu;
284
	$contenu = $ligne_contenu->gmc_contenu;
273
	
285
	
274
	    // Inclusion de la bibliothèque Text_Wiki_Papyrus effectuées par Papyrus précédement
286
	    // Inclusion de la bibliothèque Text_Wiki_Papyrus effectuées par Papyrus précédement
275
	    // Les actions Text_Wiki_Papyrus sont gérées par Papyrus
287
	    // Les actions Text_Wiki_Papyrus sont gérées par Papyrus
276
	    
288
	    
277
	    // Nous regardons si nous avons à faire à un texte sous format Wikini ou XHTML
289
	    // Nous regardons si nous avons à faire à un texte sous format Wikini ou XHTML
278
	    if (($ligne_contenu->gmc_ce_type_contenu == 1)||(substr($ligne_contenu->gmc_ce_type_contenu,-1)== 1)) {
290
	    if (($ligne_contenu->gmc_ce_type_contenu == 1)||(substr($ligne_contenu->gmc_ce_type_contenu,-1)== 1)) {
279
	        $retour = $contenu;
291
	        $retour = $contenu;
280
	    } elseif (($ligne_contenu->gmc_ce_type_contenu == 2) || (substr($ligne_contenu->gmc_ce_type_contenu,-1)== 2)){
292
	    } elseif (($ligne_contenu->gmc_ce_type_contenu == 2) || (substr($ligne_contenu->gmc_ce_type_contenu,-1)== 2)){
281
	        include_once AFFI_CHEMIN_BIBLIOTHEQUE_API.'text/wiki_wikini/Wikini.class.php';
293
	        include_once AFFI_CHEMIN_BIBLIOTHEQUE_API.'text/wiki_wikini/Wikini.class.php';
282
	        // Création d'un objet Text_Wikini :
294
	        // Création d'un objet Text_Wikini :
283
	        $wikini =& new Text_Wikini();
295
	        $wikini =& new Text_Wikini();
284
	        // Pour éviter de remplacer les caractères spéciaux du XHTML:
296
	        // Pour éviter de remplacer les caractères spéciaux du XHTML:
285
	        $wikini->setFormatConf('Xhtml', 'translate', false);
297
	        $wikini->setFormatConf('Xhtml', 'translate', false);
286
	        // Configuration de la règle Freelink :
298
	        // Configuration de la règle Freelink :
287
	        $wikini->setRenderConf('Xhtml', 'freelink', 'pages', null);
299
	        $wikini->setRenderConf('Xhtml', 'freelink', 'pages', null);
288
	        $wikini->setRenderConf('Xhtml', 'freelink', 'view_url', AFFI_URL_PAPYRUS);
300
	        $wikini->setRenderConf('Xhtml', 'freelink', 'view_url', AFFI_URL_PAPYRUS);
289
	        // Configuration de la règle Interwiki :
301
	        // Configuration de la règle Interwiki :
290
	        $wikini->setRenderConf('Xhtml', 'interwiki', 'sites', $GLOBALS['_AFFICHEUR']['interwiki_sites']);
302
	        $wikini->setRenderConf('Xhtml', 'interwiki', 'sites', $GLOBALS['_AFFICHEUR']['interwiki_sites']);
291
	        // Application des règles de Wikini :
303
	        // Application des règles de Wikini :
292
	        $retour = $wikini->transform($contenu, 'Xhtml');
304
	        $retour = $wikini->transform($contenu, 'Xhtml');
293
	    }
305
	    }
294
 
306
 
295
	// +---------------------------------------------------------------------------------------------------------------+
307
	// +---------------------------------------------------------------------------------------------------------------+
296
	// Nous regardons si nous voulons surligner ou pas des mots
308
	// Nous regardons si nous voulons surligner ou pas des mots
297
	if (isset($_GET['var_recherche'])) {
309
	if (isset($_GET['var_recherche'])) {
298
		$tab_mots = explode(' ', rawurldecode($_GET['var_recherche']));
310
		$tab_mots = explode(' ', rawurldecode($_GET['var_recherche']));
299
		foreach ($tab_mots as $mot) {
311
		foreach ($tab_mots as $mot) {
300
			if (strlen($mot) >= 2) {
312
			if (strlen($mot) >= 2) {
301
				$regexp = '/(>[^<]*)('.$mot.'\b)/Uis';
313
				$regexp = '/(>[^<]*)('.$mot.'\b)/Uis';
302
				$retour = preg_replace($regexp, '$1<span class="surlignage">$2</span>', $retour);
314
				$retour = preg_replace($regexp, '$1<span class="surlignage">$2</span>', $retour);
303
			}
315
			}
304
		}
316
		}
305
	}
317
	}
306
 
318
 
307
    //----------------------------------------------------------------------------
319
    //----------------------------------------------------------------------------
308
    // Renvoie du contenu de la page
320
    // Renvoie du contenu de la page
309
    return $retour;
321
    return $retour;
310
}
322
}
311
// +------------------------------------------------------------------------------------------------------+
323
// +------------------------------------------------------------------------------------------------------+
312
// |                                           LISTE de FONCTIONS                                         |
324
// |                                           LISTE de FONCTIONS                                         |
313
// +------------------------------------------------------------------------------------------------------+
325
// +------------------------------------------------------------------------------------------------------+
314
 
326
 
315
 
327
 
316
 
328
 
317
// +------------------------------------------------------------------------------------------------------+
329
// +------------------------------------------------------------------------------------------------------+
318
// |                                            PIED du PROGRAMME                                         |
330
// |                                            PIED du PROGRAMME                                         |
319
// +------------------------------------------------------------------------------------------------------+
331
// +------------------------------------------------------------------------------------------------------+
320
 
332
 
321
 
333
 
322
 
334
 
323
/* +--Fin du code ----------------------------------------------------------------------------------------+
335
/* +--Fin du code ----------------------------------------------------------------------------------------+
324
*
336
*
325
* $Log: not supported by cvs2svn $
337
* $Log: not supported by cvs2svn $
326
* Revision 1.13  2006-11-21 18:52:20  jp_milcent
338
* Revision 1.13  2006-11-21 18:52:20  jp_milcent
327
* Ajout de la possibilité de surligner des mots.
339
* Ajout de la possibilité de surligner des mots.
328
*
340
*
329
* Revision 1.12  2006/11/21 15:50:05  jp_milcent
341
* Revision 1.12  2006/11/21 15:50:05  jp_milcent
330
* Ajout du surlignage des mots passé dans la query string via la variable var_recherche.
342
* Ajout du surlignage des mots passé dans la query string via la variable var_recherche.
331
*
343
*
332
* Revision 1.11  2006/10/16 15:49:07  ddelon
344
* Revision 1.11  2006/10/16 15:49:07  ddelon
333
* Refactorisation code mulitlinguisme et gestion menu invisibles
345
* Refactorisation code mulitlinguisme et gestion menu invisibles
334
*
346
*
335
* Revision 1.10  2006/06/29 15:12:26  ddelon
347
* Revision 1.10  2006/06/29 15:12:26  ddelon
336
* Multilinguisme : contenu par defaut
348
* Multilinguisme : contenu par defaut
337
*
349
*
338
* Revision 1.9  2006/03/27 10:50:24  ddelon
350
* Revision 1.9  2006/03/27 10:50:24  ddelon
339
* Still some pb
351
* Still some pb
340
*
352
*
341
* Revision 1.7  2006/03/13 21:00:20  ddelon
353
* Revision 1.7  2006/03/13 21:00:20  ddelon
342
* Suppression messages d'erreur multilinguisme
354
* Suppression messages d'erreur multilinguisme
343
*
355
*
344
* Revision 1.6  2006/03/02 10:49:49  ddelon
356
* Revision 1.6  2006/03/02 10:49:49  ddelon
345
* Fusion branche multilinguisme dans branche principale
357
* Fusion branche multilinguisme dans branche principale
346
*
358
*
347
* Revision 1.5.2.3  2006/03/02 00:22:23  ddelon
359
* Revision 1.5.2.3  2006/03/02 00:22:23  ddelon
348
* bug afficheur multilinguisme
360
* bug afficheur multilinguisme
349
*
361
*
350
* Revision 1.5.2.2  2006/03/01 23:51:07  ddelon
362
* Revision 1.5.2.2  2006/03/01 23:51:07  ddelon
351
* bug afficheur multilinguisme
363
* bug afficheur multilinguisme
352
*
364
*
353
* Revision 1.5.2.1  2006/02/28 14:02:11  ddelon
365
* Revision 1.5.2.1  2006/02/28 14:02:11  ddelon
354
* Finition multilinguisme
366
* Finition multilinguisme
355
*
367
*
356
* Revision 1.5  2005/04/21 16:46:17  jpm
368
* Revision 1.5  2005/04/21 16:46:17  jpm
357
* Gestion via Papyrus du XHTML.
369
* Gestion via Papyrus du XHTML.
358
*
370
*
359
* Revision 1.4  2005/02/22 18:25:13  jpm
371
* Revision 1.4  2005/02/22 18:25:13  jpm
360
* Déplacement d'un message d'alerte en cas d'erreur sql.
372
* Déplacement d'un message d'alerte en cas d'erreur sql.
361
*
373
*
362
* Revision 1.3  2004/12/07 12:24:30  jpm
374
* Revision 1.3  2004/12/07 12:24:30  jpm
363
* Changement chemin d'accés à l'api Text/Wiki...
375
* Changement chemin d'accés à l'api Text/Wiki...
364
*
376
*
365
* Revision 1.2  2004/11/26 13:10:05  jpm
377
* Revision 1.2  2004/11/26 13:10:05  jpm
366
* Utilisation des actions Papyrus et implémentation de la syntaxe Wikini.
378
* Utilisation des actions Papyrus et implémentation de la syntaxe Wikini.
367
*
379
*
368
* Revision 1.1  2004/06/16 14:35:26  jpm
380
* Revision 1.1  2004/06/16 14:35:26  jpm
369
* Changement de nom de Génésia en Papyrus.
381
* Changement de nom de Génésia en Papyrus.
370
* Changement de l'arborescence.
382
* Changement de l'arborescence.
371
*
383
*
372
* Revision 1.12  2004/05/05 11:35:12  jpm
384
* Revision 1.12  2004/05/05 11:35:12  jpm
373
* Amélioration de la gestion de l'internationalisation.
385
* Amélioration de la gestion de l'internationalisation.
374
*
386
*
375
* Revision 1.11  2004/05/05 06:45:40  jpm
387
* Revision 1.11  2004/05/05 06:45:40  jpm
376
* Suppression de l'appel de la fonction générant le "vous êtes ici" dans la fonction affichant l'entête de l'application.
388
* Suppression de l'appel de la fonction générant le "vous êtes ici" dans la fonction affichant l'entête de l'application.
377
*
389
*
378
* Revision 1.10  2004/05/04 16:28:22  jpm
390
* Revision 1.10  2004/05/04 16:28:22  jpm
379
* Réduction de code pour la fonction afficherContenuTete().
391
* Réduction de code pour la fonction afficherContenuTete().
380
*
392
*
381
*
393
*
382
* +-- Fin du code ----------------------------------------------------------------------------------------+
394
* +-- Fin du code ----------------------------------------------------------------------------------------+
383
*/
395
*/
384
?>
396
?>