Subversion Repositories Applications.papyrus

Rev

Rev 52 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
151 jpm 1
    <?php
4 jpm 2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
151 jpm 22
// CVS : $Id: menu.php,v 1.8 2004-11-10 18:59:21 jpm Exp $
4 jpm 23
/**
24
* Applette : menu
25
*
26
* Génère une liste de listes comportant tous les niveaux des menus "classiques" d'un site.
27
* Nécessite :
28
* - Variable de Papyrus.
29
* - Base de données de Papyrus
30
* - Pear DB
31
* - Pear Net_URL
32
* - API Débogage 1.0
33
*
34
*@package Applette
35
*@subpackage Menu
36
//Auteur original :
37
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
38
//Autres auteurs :
39
*@author        Aucun
40
*@copyright     Tela-Botanica 2000-2004
151 jpm 41
*@version       $Revision: 1.8 $ $Date: 2004-11-10 18:59:21 $
4 jpm 42
// +------------------------------------------------------------------------------------------------------+
43
*/
44
 
45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            ENTÊTE du PROGRAMME                                       |
33 alex 47
// +------------------------------------------------------------------------------------------------------+
48
 
151 jpm 49
require_once 'papyrus/bibliotheque/fonctions/pap_menu.fonct.php';
33 alex 50
 
4 jpm 51
$_GEN_commun['info_applette_nom_fonction'] = 'afficherMenuNiveauMultiple';
151 jpm 52
$_GEN_commun['info_applette_balise'] = 'PAPYRUS_MENU_?(?:(|CLASSIQUE|COMMUN)_([0-9])_([0-9])|(UNIQUE)_([0-9]))';
4 jpm 53
 
54
// +------------------------------------------------------------------------------------------------------+
55
// |                                            CORPS du PROGRAMME                                        |
56
// +------------------------------------------------------------------------------------------------------+
57
 
58
 
59
// +------------------------------------------------------------------------------------------------------+
60
// |                                           LISTE de FONCTIONS                                         |
61
// +------------------------------------------------------------------------------------------------------+
62
/** Fonction GEN_afficherMenuNiveauMultiple() - Retourne la liste des listes de menus.
63
*
64
* Cette fonction retourne ne fait qu'encapsuler une fonction récursive
65
* retournant les listes de menus de l'arborescence d'un site dans une
66
* langue donnée.
67
*
68
* @param  array contient les arguments de la fonction en 1 le niveau de départ et en 2 le niveau d'arrivée (profondeur max demandée).
69
* @param  array  tableau global de Papyrus.
70
* @return string HTML la liste des listes de menus.
71
*/
72
function afficherMenuNiveauMultiple($tab_applette_arguments, $_GEN_commun)
73
{
74
    // Initialisation de variable.
75
    $objet_pear_db = $_GEN_commun['pear_db'];
76
    $id_site = $_GEN_commun['info_site']->gs_id_site;
77
    $id_menu = $_GEN_commun['info_menu']->gm_id_menu;
78
    $id_langue = $_GEN_commun['i18n'];
79
    $i18n_url = '';// Evite d'écrire l'i18n dans l'url demandée.
80
    if (!empty($_GEN_commun['url_i18n'])) {
81
        // L'écriture de l'i18n dans les urls des menus est demandée.
82
        $i18n_url = $_GEN_commun['url_i18n'];
83
    }
84
    $indent_origine = 12;// Indentation de départ en nombre d'espace
85
    $indent_pas     = 4;// Pas d'indentation en nombre d'espace
86
 
87
    // Récupérations des arguments passés dans la balise.
151 jpm 88
    // Pour les menus CLASSIQUE et COMMUN
89
    $balise           = $tab_applette_arguments[1];
90
    $menu_type        = $tab_applette_arguments[2];
91
    $niveau_depart    = $tab_applette_arguments[3];
92
    $profondeur       = $tab_applette_arguments[4];
93
    // Pour les menus UNIQUE
94
    if (isset($tab_applette_arguments[5])) {
95
        $menu_type = $tab_applette_arguments[5];
96
    }
97
    if (isset($tab_applette_arguments[6])) {
98
        $niveau_depart   = $tab_applette_arguments[6];
99
    }
100
 
101
    // Gestion du type de menu
102
    switch ($menu_type) {
103
        case '' :
104
            $menu_type = 'classique';
105
        break;
106
        case 'CLASSIQUE' :
107
            $menu_type = 'classique';
108
        break;
109
        case 'COMMUN' :
110
            $menu_type = 'commun';
111
        break;
112
        case 'UNIQUE' :
113
            $menu_type = 'unique';
114
        break;
115
        default:
116
            $menu_type = 'classique';
117
    }
4 jpm 118
 
119
    //Construction du menu
151 jpm 120
    $xhtml_menu = afficherListeNiveauMultiple($objet_pear_db, $id_site, $id_langue, $i18n_url ,$niveau_depart, $profondeur, 0, 1, $menu_type, $indent_origine, $indent_pas, $_GEN_commun);
4 jpm 121
 
122
    //Si nous avons un
123
    if (! empty($xhtml_menu)) {
41 jpm 124
        $retour = $xhtml_menu;
4 jpm 125
    } else {
151 jpm 126
        $retour = '<!-- '.$balise.' : aucun menu trouvé ! -->';
4 jpm 127
    }
41 jpm 128
    return $retour;
4 jpm 129
}
130
 
131
/** Fonction afficherListeNiveauMultiple() - Affiche une arborescence des menu classiques d'un site.
132
*
133
* Créé et retourne une liste pour chaque niveau de menu classique trouvé dans l'arborescence
134
* des menus d'un site dans une langue donnée.
135
* C'est une fonction récursive.
136
*
137
* @param  mixed   objet Pear DB de connexion à la base de données.
138
* @param  integer identifiant d'un site.
139
* @param  integer identifiant de la langue demandée.
140
* @param  integer niveau de départ.
141
* @param  integer niveau d'arrivée (profondeur max demandée).
142
* @param  integer identifiant d'un menu pére.
143
* @return  string  les listes de menus au format XHTML.
144
*/
151 jpm 145
function afficherListeNiveauMultiple($objet_pear_db, $id_site, $id_langue, $i18n_url, $niveau_depart, $profondeur, $id_pere_menu_a_deployer, $position, $menu_type, $indent_origine = 12, $indent_pas = 4, $_GEN_commun)
4 jpm 146
{
147
    // Initialisation des variables
148
    static $niveau_actuel = 1;
41 jpm 149
    $retour = '';
151 jpm 150
    if ($menu_type == 'unique') {
151
        $retour .= afficherEntreeListeMenu( $objet_pear_db, $niveau_depart, $i18n_url,
152
                                            $niveau_actuel, 1, $position, $menu_type, $indent_origine, $indent_pas, $_GEN_commun);
153
    } else {
154
        // On affiche un menu que si $profondeur <= $niveau_actuel <= $depart
155
        if ($niveau_actuel > $profondeur) {
156
            return null;
157
        }
4 jpm 158
        if ($niveau_actuel >= $niveau_depart && $niveau_actuel <= $profondeur) {
151 jpm 159
            $retour .=   str_repeat(' ', $indent_origine + ($indent_pas * $position)).
160
                        '<ul id="groupe_menu_'.$menu_type.'_'.$id_pere_menu_a_deployer.'" class="menu_'.$menu_type.'_'.'n'.$niveau_actuel.'">'."\n";
161
        }
162
 
163
        $requete =  'SELECT gm_id_menu, GMR01.gmr_ordre '.
164
                    'FROM gen_menu, gen_menu_relation AS GMR01, gen_menu_relation AS GMR02 '.
165
                    'WHERE GMR01.gmr_id_menu_02 = '.$id_pere_menu_a_deployer.' '.
166
                    'AND GMR01.gmr_id_menu_01 = gm_id_menu '.
167
                    'AND GMR01.gmr_id_valeur = 1 '.// 1 = "avoir père"
168
                    'AND GMR02.gmr_id_menu_02 = gm_id_menu '.
169
                    'AND GMR02.gmr_id_menu_01 = GMR02.gmr_id_menu_02 ';
170
 
171
        if ($menu_type == 'classique') {
172
            $requete .= 'AND gm_ce_site = '.$id_site.' '.
173
                        'AND GMR02.gmr_id_valeur = 100 '.// 100 = type "menu classique"
174
                        'ORDER BY GMR01.gmr_ordre ASC';
175
        } else if ($menu_type == 'commun') {
176
            $requete .= 'AND gm_ce_site = 0 '.
177
                        'AND GMR02.gmr_id_valeur = 102 '.// 102 = type "menu commun"
178
                        'ORDER BY GMR01.gmr_ordre ASC';
179
        }
180
        //$GLOBALS['_GEN_commun']['debogage_info'] .=$requete;
181
        $resultat = $objet_pear_db->query($requete);
182
        (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
183
 
184
        while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
185
            // On commence par regarder si le menu existe dans la langue demandée
186
            if ($niveau_actuel >= $niveau_depart && $niveau_actuel <= $profondeur) {
187
                $requete_i18n = 'SELECT gm_id_menu '.
188
                                'FROM gen_menu, gen_menu_relation '.
189
                                'WHERE gmr_id_menu_01 = '.$ligne->gm_id_menu.' '.
190
                                'AND gmr_id_menu_02 = gm_id_menu '.
191
                                'AND gmr_id_valeur = 2 '.// 2 = "avoir traduction"
192
                                'AND gm_ce_i18n = "'.$id_langue.'"';
193
 
194
                $resultat_i18n = $objet_pear_db->query($requete_i18n);
195
                (DB::isError($resultat_i18n)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_i18n->getMessage(), $requete_i18n)) : '';
196
 
197
                // Récupération de l'id du menu à afficher
198
                if ($resultat_i18n->numRows() != 0) {
199
                    $id_menu_i18n = $resultat_i18n->fetchRow(DB_FETCHMODE_OBJECT);
200
                    $id_menu_inf = $id_menu_i18n->gm_id_menu;
201
                    $resultat_i18n->free();
202
                } else {
203
                    $id_menu_inf = $ligne->gm_id_menu;
204
                }
205
                $id_menu_selectionne = '';
206
                if (isset($GLOBALS['_GEN_commun']['info_menu']->gm_id_menu)) {
207
                    $id_menu_selectionne = $GLOBALS['_GEN_commun']['info_menu']->gm_id_menu;
208
                }
209
                // On vérifie si le menu est le menu sélectionné
210
                if (!empty($id_menu_selectionne) && (GEN_etreAncetre($id_menu_inf, $id_menu_selectionne) || $id_menu_inf == $id_menu_selectionne) ) {
211
                    $classe = 'menu_actif';
212
                } else {
213
                    $classe = 'menu_inactif';
214
                }
215
 
216
                // Affichage du menu
217
                $retour .=   str_repeat(' ', $indent_origine + ($indent_pas * ($position + 1))).
218
                            '<li id="menu_'.$menu_type.'_'.$id_menu_inf.'" class="'.$classe.'">'."\n";
219
                $retour .= afficherEntreeListeMenu( $objet_pear_db, $id_menu_inf, $i18n_url, $niveau_actuel,
220
                                                    $ligne->gmr_ordre, $position, $menu_type, $indent_origine, $indent_pas, $_GEN_commun);
221
            }
222
            // Pour chaque menu on regarde s'il y a des fils. Si oui, on les déploie.
223
            $requete_fils = 'SELECT gm_id_menu '.
224
                            'FROM gen_menu, gen_menu_relation AS GMR01, gen_menu_relation AS GMR02 '.
225
                            'WHERE GMR01.gmr_id_menu_02 = '.$ligne->gm_id_menu.' '.
226
                            'AND GMR01.gmr_id_menu_01 = gm_id_menu '.
227
                            'AND GMR01.gmr_id_valeur = 1 '.// 1 = "avoir père"
228
                            'AND GMR02.gmr_id_menu_02 = gm_id_menu '.
229
                            'AND GMR02.gmr_id_menu_01 = GMR02.gmr_id_menu_02 '.
230
                            'AND GMR02.gmr_id_valeur = 100 '.// 100 = type "menu classique"
231
                            'ORDER BY GMR01.gmr_ordre ASC '.
232
                            'LIMIT 0,1';
41 jpm 233
 
151 jpm 234
            $resultat_fils = $objet_pear_db->query($requete_fils);
235
            (DB::isError($resultat_fils))
236
                ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_fils->getMessage(), $requete_fils))
237
                : '';
41 jpm 238
 
151 jpm 239
            if ($resultat_fils->numRows() != 0 && $ligne->gm_id_menu == $GLOBALS['_GEN_commun']['info_menu']->gm_id_menu
240
                || GEN_etreAncetre($ligne->gm_id_menu, $GLOBALS['_GEN_commun']['info_menu']->gm_id_menu)) {
241
 
242
                $niveau_actuel++;
243
                $retour .= afficherListeNiveauMultiple($objet_pear_db, $id_site, $id_langue, $i18n_url, $niveau_depart, $profondeur, $ligne->gm_id_menu, ($position + 2), $menu_type, null, null, $_GEN_commun);
244
                // On ramène $niveau_actuel un cran plus bas
245
                $niveau_actuel--;
246
                $retour .= str_repeat(' ', $indent_origine + ($indent_pas * ($position + 1))).'</li>'."\n";
41 jpm 247
            } else {
151 jpm 248
                $retour .= str_repeat(' ', $indent_origine + ($indent_pas * ($position + 1))).'</li>'."\n";
41 jpm 249
            }
4 jpm 250
 
151 jpm 251
            $resultat_fils->free();
4 jpm 252
        }
151 jpm 253
        $resultat->free();
254
        if ($niveau_actuel >= $niveau_depart && $niveau_actuel <= $profondeur) {
255
            $retour .= str_repeat(' ', $indent_origine + ($indent_pas * $position)).'</ul>'."\n";
256
        }
4 jpm 257
    }
41 jpm 258
    return $retour;
4 jpm 259
}
260
 
261
/** Fonction afficherEntreeListeMenu() - Contruit une entrée dans une liste du menu d'un site.
262
*
151 jpm 263
* Cette fonction retourne une entrée dans la liste du menu d'un site (<a></a>).
4 jpm 264
* Le menu est un lien.
265
* Necessite l'utilisation de Pear Net_URL par le programme appelant cette fonction.
266
*
267
* @param  mixed   objet Pear DB de connexion à la base de données.
268
* @param  integer niveau du menu.
269
* @param  integer ordre du menu dans le niveau.
270
* @return  string  liste représentant le menu duHTML
271
*/
151 jpm 272
function afficherEntreeListeMenu($db, $id_menu, $i18n_url, $niveau, $ordre, $position, $menu_type, $indent_origine = 12, $indent_pas = 4, $_GEN_commun)
4 jpm 273
{
274
    // Préparation des noms des champs des codes pour le site et le menu
275
    $champs_code_site = (GEN_URL_ID_TYPE_SITE == 'int') ? 'gs_code_num' : 'gs_code_alpha';
276
    $champs_code_menu = (GEN_URL_ID_TYPE_MENU == 'int') ? 'gm_code_num' : 'gm_code_alpha';
277
 
278
    // Récupération du nom de l'entrée du menu à afficher
151 jpm 279
    $requete =  'SELECT '.$champs_code_menu.', '.
280
                'gm_nom, gm_description_resume, gm_raccourci_clavier, gm_ce_i18n, gm_ce_site '.
281
                'FROM gen_menu '.
282
                'WHERE gm_id_menu = '.$id_menu.' ';
4 jpm 283
 
151 jpm 284
    $resultat = $db->query($requete);
285
    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
4 jpm 286
 
151 jpm 287
    $ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC);
288
    $resultat->free();
289
    // Nous vérifions si nous avons à faire à un menu commun ou pas
290
    if ($ligne['gm_ce_site'] != 0) {
291
        // Récupération des infos sur le site
292
        $requete_site = 'SELECT '.$champs_code_site.' '.
293
                        'FROM gen_site '.
294
                        'WHERE gs_id_site = '.$ligne['gm_ce_site'].' ';
295
 
296
        $resultat_site = $db->query($requete_site);
297
        (DB::isError($resultat_site)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_site->getMessage(), $requete_site)) : '';
298
 
299
        $ligne_site = $resultat_site->fetchRow(DB_FETCHMODE_ASSOC);
300
        $resultat_site->free();
301
    } else {
302
        // Menu commun
303
        $ligne_site[$champs_code_site] = $_GEN_commun['info_site']->$champs_code_site;
304
    }
4 jpm 305
    // Préparation d'une entrée dans la liste du menu
306
    $menu_nom = htmlentities($ligne['gm_nom']);
307
    $menu_texte_title = htmlentities($ligne['gm_description_resume']);
308
    // Préparation de l'url de l'entrée
309
    $objet_pear_url = & new Net_URL('http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF']);
151 jpm 310
    $objet_pear_url->addQueryString(GEN_URL_CLE_SITE, $ligne_site[$champs_code_site]);
4 jpm 311
    $objet_pear_url->addQueryString(GEN_URL_CLE_MENU, $ligne[$champs_code_menu]);
312
    if (!empty($i18n_url)) {
313
        $objet_pear_url->addQueryString(GEN_URL_CLE_I18N, $i18n_url);
314
    }
151 jpm 315
    $url = $objet_pear_url->getURL();
4 jpm 316
 
39 jpm 317
    //Création d'une entrée dans la liste du menu
151 jpm 318
    $espaces = str_repeat(' ', $indent_origine + ($indent_pas * ($position + 2)));
319
    $retour  = $espaces.'<a href="'.$url.'" title="'.$menu_texte_title.'">'.$menu_nom.'</a>'."\n";
39 jpm 320
    return $retour;
321
}
4 jpm 322
 
323
// +------------------------------------------------------------------------------------------------------+
324
// |                                            PIED du PROGRAMME                                         |
325
// +------------------------------------------------------------------------------------------------------+
326
 
327
 
328
/* +--Fin du code ----------------------------------------------------------------------------------------+
329
*
330
* $Log: not supported by cvs2svn $
151 jpm 331
* Revision 1.7  2004/09/23 14:31:40  jpm
332
* Correction bogue sur le menu actif.
333
*
52 jpm 334
* Revision 1.6  2004/09/23 10:47:16  jpm
335
* Amélioration de la gestion du menu actif en fonction du menu demandé dans l'url.
336
*
48 jpm 337
* Revision 1.5  2004/09/15 09:32:21  jpm
338
* Mise en conformité avec le standard XHTML Strict.
339
* Amélioration de la gestion de l'indentation.
340
*
41 jpm 341
* Revision 1.4  2004/09/13 18:02:34  jpm
342
* Changement de nom de m_select en menu_actif et de m_non_select en menu_inactif.
343
* Amélioration du rendu du code html.
344
*
39 jpm 345
* Revision 1.3  2004/07/23 11:21:25  alex
346
* suppression du javascript.
347
*
33 alex 348
* Revision 1.2  2004/06/25 08:32:02  alex
349
* modification des styles
350
*
19 alex 351
* Revision 1.1  2004/06/15 15:04:14  jpm
352
* Changement de nom et d'arborescence de Genesia en Papyrus.
353
*
4 jpm 354
* Revision 1.10  2004/05/05 14:33:04  jpm
355
* Gestion de l'indication de langue dans l'url.
356
* Utile que si on veut forcer la langue.
357
*
358
* Revision 1.8  2004/05/05 06:44:19  jpm
359
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
360
*
361
* Revision 1.7  2004/05/04 14:19:37  jpm
362
* Mise entre guillemet simple d'un texte.
363
*
364
* Revision 1.6  2004/05/03 14:11:01  jpm
365
* Intégration du fichier bibliothèquie de fonctions sur gen_menu provenant de la bibliothèque de Génésia INUTILE!
366
*
367
* Revision 1.5  2004/05/03 14:09:32  jpm
368
* Intégration du fichier bibliothèquie de fonctions sur gen_menu provenant de la bibliothèque de Génésia.
369
*
370
* Revision 1.4  2004/05/03 11:19:00  jpm
371
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
372
*
373
* Revision 1.3  2004/05/03 08:52:44  jpm
374
* Modification pour intégrer les sous listes (ul) de menus à l'intèrieur de l'entrée (li) du menu supérieur.
375
*
376
* Revision 1.2  2004/05/01 17:22:23  jpm
377
* Changement de nom de l'applette dans les commentaires.
378
*
379
* Revision 1.1  2004/05/01 16:12:39  jpm
380
* Ajout de l'applette gérant les menus multi niveaux ou niveau unique.
381
*
382
*
383
* +-- Fin du code ----------------------------------------------------------------------------------------+
384
*/
385
?>