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