Subversion Repositories Applications.papyrus

Rev

Rev 793 | Rev 1033 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
// +------------------------------------------------------------------------------------------------------+
// | PHP version 4.1                                                                                      |
// +------------------------------------------------------------------------------------------------------+
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
// +------------------------------------------------------------------------------------------------------+
// | This library is free software; you can redistribute it and/or                                        |
// | modify it under the terms of the GNU Lesser General Public                                           |
// | License as published by the Free Software Foundation; either                                         |
// | version 2.1 of the License, or (at your option) any later version.                                   |
// |                                                                                                      |
// | This library is distributed in the hope that it will be useful,                                      |
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
// | Lesser General Public License for more details.                                                      |
// |                                                                                                      |
// | You should have received a copy of the GNU Lesser General Public                                     |
// | License along with this library; if not, write to the Free Software                                  |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
// +------------------------------------------------------------------------------------------------------+
// CVS : $Id: afficheur.php,v 1.9 2006-03-27 10:50:24 ddelon Exp $
/**
* Application réalisant l'affichage du contenu stocké dans Papyrus.
*
* Récupère le dernier contenu lié à un menu et le retourne.
*
*@package Afficheur
//Auteur original :
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
//Autres auteurs :
*@author        Alexandre GRANIER <alexandrel@tela-botanica.org>
*@copyright     Tela-Botanica 2000-2004
*@version       $Revision: 1.9 $ $Date: 2006-03-27 10:50:24 $
// +------------------------------------------------------------------------------------------------------+
*/

// +------------------------------------------------------------------------------------------------------+
// |                                            ENTÊTE du PROGRAMME                                       |
// +------------------------------------------------------------------------------------------------------+
/** Inclusion du fichier de configuration de cette application.*/
require_once GEN_CHEMIN_PAP.'applications/afficheur/configuration/affi_configuration.inc.php';
// Inclusion de la bibliothèque PEAR Text_Wiki réalisées par Papyrus.

// +------------------------------------------------------------------------------------------------------+
// |                                            CORPS du PROGRAMME                                        |
// +------------------------------------------------------------------------------------------------------+
/** Fonction afficherContenuTete() - Fonction appelé par le gestionnaire Papyrus.
*
* Elle retourne l'entête de l'application..
*
* @return  string  du code XHTML correspondant à la zone d'entête de l'application.
*/
function afficherContenuTete()
{
    return '';
}

/** Fonction afficherContenuCorps() - Fonction appelé par le gestionnaire Papyrus.
*
* Elle retourne le contenu stocké dans Papyrus pour le menu courant demandé.
*
* @return  string  du code XHTML correspondant au contenu du menu demandé.
*/
function afficherContenuCorps()
{
    //----------------------------------------------------------------------------
    // Initialisation des variable
    $retour = '';
    
    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
    
    if (isset($id_langue) && ($id_langue!='')) {
                $langue_test=$id_langue;
        } else {
                $langue_test=GEN_I18N_ID_DEFAUT;
        }

        //-------------------------------------------------------------------------------------------------------------------
        // Récupération des informations du contenu concerné.
     $ligne_menu = GEN_lireInfoMenu($GLOBALS['_AFFICHEUR']['objet_pear_db'], $GLOBALS['_AFFICHEUR']['menu_courant_id'], DB_FETCHMODE_ASSOC);
        
        
     if ($ligne_menu == false) {
            die('ERREUR Papyrus Administrateur de Menus: impossible de lire les infos du menu.<br />'.
                'Idenitifiant du menu n° : '. $GLOBALS['_AFFICHEUR']['objet_pear_db'] .'<br />'.
                'Ligne n° : '. __LINE__ .'<br />'.
                'Fichier n° : '. __FILE__ .'<br />');
     }
        

    // Comment ca marche ?
    // Historiquement, le code menu est associé au contenu
    // Depuis le passage au multilinguisme : ce comportement est conservé mais :
    // Tout nouveau contenu, contient également l'information code gm_id_menu, enfoui dans le 
    // type contenu.
    
    // Récupération identifiant du menu en cours 
    
    $requete =  'SELECT gm_id_menu, gm_code_num   '.
                'FROM gen_menu  '.
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
                'AND gm_ce_i18n = "'.$langue_test.'" ';

        $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
        
        (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';

        if ( $resultat->numRows() > 0 ) {
        
                        $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
        }
        else {
        
        $requete =  'SELECT gm_id_menu, gm_code_num   '.
                'FROM gen_menu  '.
                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' ';

                $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);

        (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
                
                $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
        }  

        // Cas historique :
        
        $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
                        'FROM gen_menu_contenu  '.
                        'WHERE gmc_ce_menu = '.$ligne->gm_id_menu.' '.
                        'AND gmc_ce_type_contenu in (1,2) '.
                        'AND gmc_bool_dernier = 1';
        
        $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
        (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
        
        
        // Rien trouvé ? : Migration multilinguisme ou pas encore de contenu 
        
        if ( $resultat->numRows() == 0 ) {
        
                
            // Multilinguisme :
             
            $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
                        'FROM gen_menu_contenu  '.
                        'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
                        'AND truncate((gmc_ce_type_contenu/10),0) = '. $ligne->gm_id_menu . ' '.
                        'AND gmc_bool_dernier = 1';
            
            $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
            (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
        
                // Pas de contenu, tentative de recuperation contenu initial
                        
                if ( $resultat->numRows() == 0 ) {
                                        
                                            $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
                                                        'FROM gen_menu_contenu, gen_menu_relation '.
                                                        'WHERE truncate((gmc_ce_type_contenu/10),0) = gmr_id_menu_01 '.
                                                        'AND '.$ligne->gm_id_menu.' = gmr_id_menu_02 '.
                                                        'AND gmr_id_valeur = 2 '.
                                                        'AND gmc_bool_dernier = 1';

                                            $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
                                            (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
            
                                                                        
                                }
                                // Toujours rien ?
                                        
                                if ( $resultat->numRows() == 0 ) {
                                        
                                                $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu '.
                                'FROM gen_menu_contenu  '.
                                'WHERE gmc_ce_menu = '.$ligne->gm_code_num.' '.
                                'AND gmc_ce_type_contenu in (1,2) '.
                                'AND gmc_bool_dernier = 1';
                                                        
                                                        
                                            $resultat = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete);
                                            (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
            
                                                                        
                                }
                                
                }
                        
                 $ligne_contenu = $resultat->fetchRow(DB_FETCHMODE_OBJECT);
            
                
        $contenu = $ligne_contenu->gmc_contenu;
        
            // Inclusion de la bibliothèque Text_Wiki_Papyrus effectuées par Papyrus précédement
            // Les actions Text_Wiki_Papyrus sont gérées par Papyrus
            
            // Nous regardons si nous avons à faire à un texte sous format Wikini ou XHTML
            if (($ligne_contenu->gmc_ce_type_contenu == 1)||(substr($ligne_contenu->gmc_ce_type_contenu,-1)== 1)) {
                $retour = $contenu;
            } elseif (($ligne_contenu->gmc_ce_type_contenu == 2) || (substr($ligne_contenu->gmc_ce_type_contenu,-1)== 2)){
                include_once AFFI_CHEMIN_BIBLIOTHEQUE_API.'text/wiki_wikini/Wikini.class.php';
                // Création d'un objet Text_Wikini :
                $wikini =& new Text_Wikini();
                // Pour éviter de remplacer les caractères spéciaux du XHTML:
                $wikini->setFormatConf('Xhtml', 'translate', false);
                // Configuration de la règle Freelink :
                $wikini->setRenderConf('Xhtml', 'freelink', 'pages', null);
                $wikini->setRenderConf('Xhtml', 'freelink', 'view_url', AFFI_URL_PAPYRUS);
                // Configuration de la règle Interwiki :
                $wikini->setRenderConf('Xhtml', 'interwiki', 'sites', $GLOBALS['_AFFICHEUR']['interwiki_sites']);
                // Application des règles de Wikini :
                $retour = $wikini->transform($contenu, 'Xhtml');
            }

  
    //----------------------------------------------------------------------------
    // Renvoie du contenu de la page
    return $retour;
}
// +------------------------------------------------------------------------------------------------------+
// |                                           LISTE de FONCTIONS                                         |
// +------------------------------------------------------------------------------------------------------+



// +------------------------------------------------------------------------------------------------------+
// |                                            PIED du PROGRAMME                                         |
// +------------------------------------------------------------------------------------------------------+



/* +--Fin du code ----------------------------------------------------------------------------------------+
*
* $Log: not supported by cvs2svn $
* Revision 1.7  2006/03/13 21:00:20  ddelon
* Suppression messages d'erreur multilinguisme
*
* Revision 1.6  2006/03/02 10:49:49  ddelon
* Fusion branche multilinguisme dans branche principale
*
* Revision 1.5.2.3  2006/03/02 00:22:23  ddelon
* bug afficheur multilinguisme
*
* Revision 1.5.2.2  2006/03/01 23:51:07  ddelon
* bug afficheur multilinguisme
*
* Revision 1.5.2.1  2006/02/28 14:02:11  ddelon
* Finition multilinguisme
*
* Revision 1.5  2005/04/21 16:46:17  jpm
* Gestion via Papyrus du XHTML.
*
* Revision 1.4  2005/02/22 18:25:13  jpm
* Déplacement d'un message d'alerte en cas d'erreur sql.
*
* Revision 1.3  2004/12/07 12:24:30  jpm
* Changement chemin d'accés à l'api Text/Wiki...
*
* Revision 1.2  2004/11/26 13:10:05  jpm
* Utilisation des actions Papyrus et implémentation de la syntaxe Wikini.
*
* Revision 1.1  2004/06/16 14:35:26  jpm
* Changement de nom de Génésia en Papyrus.
* Changement de l'arborescence.
*
* Revision 1.12  2004/05/05 11:35:12  jpm
* Amélioration de la gestion de l'internationalisation.
*
* Revision 1.11  2004/05/05 06:45:40  jpm
* Suppression de l'appel de la fonction générant le "vous êtes ici" dans la fonction affichant l'entête de l'application.
*
* Revision 1.10  2004/05/04 16:28:22  jpm
* Réduction de code pour la fonction afficherContenuTete().
*
*
* +-- Fin du code ----------------------------------------------------------------------------------------+
*/
?>