| 2 | ddelon | 1 | <?php
 | 
        
           |  |  | 2 |   | 
        
           |  |  | 3 | /*  +-----------------------------------------------------------------------+
 | 
        
           |  |  | 4 | *   |projet_derniers_telechargement.php			    	        			|
 | 
        
           |  |  | 5 | *   +-----------------------------------------------------------------------+
 | 
        
           |  |  | 6 | *   | Copyright (c) 2001 - 2005 Tela Botanica						        |
 | 
        
           |  |  | 7 | *   +-----------------------------------------------------------------------+
 | 
        
           |  |  | 8 | *   | Affiche les derniers fichiers uploader dans le module projet          |
 | 
        
           |  |  | 9 | *   +-----------------------------------------------------------------------+
 | 
        
           |  |  | 10 | *   | Auteur : Alexandre Granier <alexandre@tela-botanica.org> 		        |
 | 
        
           |  |  | 11 | *   +-----------------------------------------------------------------------+
 | 
        
           |  |  | 12 |   | 
        
           | 25 | alexandre_ | 13 | *   $Id: projet_derniers_telechargements.php,v 1.3 2005-10-06 08:23:48 alexandre_tb Exp $
 | 
        
           | 2 | ddelon | 14 | */
 | 
        
           |  |  | 15 |   | 
        
           | 25 | alexandre_ | 16 | // Cette application affiche les derniers  documents uploadé dans le module projet
 | 
        
           |  |  | 17 | // ainsi que tous les documents du module
 | 
        
           | 2 | ddelon | 18 |   | 
        
           |  |  | 19 | // ===========================================================
 | 
        
           |  |  | 20 | //                  Configuration
 | 
        
           |  |  | 21 | // ===========================================================
 | 
        
           |  |  | 22 |   | 
        
           |  |  | 23 |   | 
        
           | 25 | alexandre_ | 24 | // Le nombre à afficher
 | 
        
           | 2 | ddelon | 25 | define ("PROJET_TELECHARGEMENT_NOMBRE", 8) ;
 | 
        
           |  |  | 26 |   | 
        
           |  |  | 27 | //====================      Les labels      =======================================
 | 
        
           |  |  | 28 | define ("PROJET_TELECHARGEMENT_TITRE", "Page de téléchargements rapides") ;
 | 
        
           |  |  | 29 | define ("PROJET_TELECHARGEMENT_DERNIERS", "Derniers documents mis en ligne") ;
 | 
        
           |  |  | 30 | define ("PROJET_TELECHARGEMENT_TOUS", "Tous les documents, par projet") ;
 | 
        
           |  |  | 31 |   | 
        
           |  |  | 32 | //=============bibliothèques PEAR  ===================================
 | 
        
           |  |  | 33 | include_once 'HTML/Table.php' ;
 | 
        
           |  |  | 34 | include_once 'HTML/TreeMenu.php' ;
 | 
        
           |  |  | 35 |   | 
        
           |  |  | 36 | // ========== Bibliothèque Projet ====================================
 | 
        
           |  |  | 37 | include_once 'configuration/projet.config.inc.php' ;
 | 
        
           |  |  | 38 | include_once PROJET_CHEMIN_CLASSES.'projetControleur.class.php' ;
 | 
        
           |  |  | 39 | include_once PROJET_CHEMIN_CLASSES.'document.class.php' ;
 | 
        
           |  |  | 40 | include_once PROJET_CHEMIN_APPLI.'langues/pro_langue_fr.inc.php' ;
 | 
        
           |  |  | 41 |   | 
        
           |  |  | 42 |   | 
        
           |  |  | 43 | function afficherContenuCorps() {
 | 
        
           |  |  | 44 |     global $id_projet, $repcourant, $baseURL, $projet ;
 | 
        
           |  |  | 45 |     global $G_ftpHost,$G_ftpUser,$G_ftpPwd,$G_ftpLocal, $PHP_SELF;
 | 
        
           |  |  | 46 |   | 
        
           |  |  | 47 |     // à remplacer par un div pour genesia
 | 
        
           |  |  | 48 |     $res = "<h1>".PROJET_TELECHARGEMENT_TITRE."</h1>\n" ;
 | 
        
           |  |  | 49 |   | 
        
           |  |  | 50 |     $res .= "<h2>".PROJET_TELECHARGEMENT_DERNIERS."</h2>\n" ;
 | 
        
           |  |  | 51 |   | 
        
           |  |  | 52 |     $liste_documents = document::getDocumentsRecents( $nombre = 10, $GLOBALS['projet_db'], PROJET_CHEMIN_FICHIER,PROJET_CHEMIN_ICONES) ;
 | 
        
           |  |  | 53 |   | 
        
           |  |  | 54 |     include_once PROJET_CHEMIN_CLASSES.'HTML_Liste.class.php' ;
 | 
        
           |  |  | 55 |     include_once PROJET_CHEMIN_CLASSES.'HTML_listeDocuments.class.php' ;
 | 
        
           |  |  | 56 |     $vue_liste_document = new HTML_listeDocuments($GLOBALS['url'], false, '', $GLOBALS['projet_auth']) ;
 | 
        
           |  |  | 57 |     $vue_liste_document->setCheminIcones(PROJET_CHEMIN_ICONES) ;
 | 
        
           |  |  | 58 |     $entete_liste = array (PROJET_FICHIERS_NOM, PROJET_FICHIERS_TAILLE, PROJET_FICHIERS_PAR, PROJET_FICHIERS_CREE_LE) ;
 | 
        
           |  |  | 59 |     if (!isset($droits)) $droits = PROJET_DROIT_AUCUN ;
 | 
        
           |  |  | 60 |   | 
        
           |  |  | 61 |     $vue_liste_document->construitEntete($entete_liste) ;
 | 
        
           |  |  | 62 |     $vue_liste_document->construitListe ($liste_documents, $droits, 'ignore_repertoire', $GLOBALS['projet_db']) ;
 | 
        
           |  |  | 63 |     $res .= $vue_liste_document->toHTML() ;
 | 
        
           |  |  | 64 |   | 
        
           |  |  | 65 |     $res .= "<h2>".PROJET_TELECHARGEMENT_TOUS."</h2>\n" ;
 | 
        
           |  |  | 66 |   | 
        
           |  |  | 67 |     // Création de l'objet TreeMenu
 | 
        
           |  |  | 68 |     GEN_stockerFichierScript(1, "api/TreeMenu/TreeMenu.js") ;
 | 
        
           |  |  | 69 |   | 
        
           |  |  | 70 |     // Les noms des fichiers graphiques
 | 
        
           |  |  | 71 |     $icon         = 'folder.gif';
 | 
        
           |  |  | 72 |     $expandedIcon = 'folder-expanded.gif';
 | 
        
           |  |  | 73 |   | 
        
           |  |  | 74 |     $i = 0 ;
 | 
        
           |  |  | 75 |     // Requete sur les projets
 | 
        
           |  |  | 76 |     $requete = "SELECT p_titre, p_id FROM projet ORDER BY p_titre" ;
 | 
        
           |  |  | 77 |     $resultat = $GLOBALS['projet_db']->query ($requete) or die ("Echec <br />".mysql_error()."<br />$requete") ;
 | 
        
           |  |  | 78 |   | 
        
           |  |  | 79 |     $menu = new HTML_TreeMenu() ;
 | 
        
           |  |  | 80 |     $node = new HTML_TreeNode(array('text' => "Les projets de Tela Botanica", 'link' => "", 'icon' => $icon, 'expandedIcon' => $expandedIcon));
 | 
        
           |  |  | 81 |   | 
        
           |  |  | 82 |     while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 83 |         $titre = $ligne->p_titre ;
 | 
        
           |  |  | 84 |         $node_1[$i] = &$node->addItem (new HTML_TreeNode(array('text' => $titre, 'link' => "", 'icon' => $icon, 'expandedIcon' => $expandedIcon)));
 | 
        
           |  |  | 85 |         projet_fichiers (&$node_1[$i], $ligne->p_id) ;
 | 
        
           |  |  | 86 |         $i++ ;
 | 
        
           |  |  | 87 |     }
 | 
        
           |  |  | 88 |     $menu->addItem($node);
 | 
        
           |  |  | 89 |     $treeMenu = &new HTML_TreeMenu_DHTML($menu, array('images' => 'api/TreeMenu/images', 'defaultClass' => 'text'));
 | 
        
           |  |  | 90 |     $res .= "<p>".$treeMenu->toHTML()."</p>\n" ;
 | 
        
           |  |  | 91 |   | 
        
           |  |  | 92 |     return $res ;
 | 
        
           |  |  | 93 | }
 | 
        
           |  |  | 94 |   | 
        
           |  |  | 95 | /** fonction projet_fichiers() - Remplie un noeud avec les fichiers et répertoires
 | 
        
           |  |  | 96 | *
 | 
        
           |  |  | 97 | * Le noeud est passé en référence. Ainsi, cette fonction ne retourne rien mais modifie le tableau des
 | 
        
           |  |  | 98 | * noeuds passé en référence.
 | 
        
           |  |  | 99 | *
 | 
        
           |  |  | 100 | * return  void
 | 
        
           |  |  | 101 | */
 | 
        
           |  |  | 102 |   | 
        
           |  |  | 103 | function projet_fichiers ($noeud, $id_rep, $pere = 0)
 | 
        
           |  |  | 104 | {
 | 
        
           |  |  | 105 |     //Récupération de l'identifiant du répertoire courant
 | 
        
           |  |  | 106 |   | 
        
           |  |  | 107 |     //La fonction est appelé récursivement quand $pere ne vaut pas null
 | 
        
           |  |  | 108 |     //$id_rep prend donc la valeur de $pere transmise par l'appel précédent de la fonction.
 | 
        
           |  |  | 109 |   | 
        
           |  |  | 110 |     // Les noms des fichiers graphiques
 | 
        
           |  |  | 111 |     $icon = 'folder.gif';
 | 
        
           |  |  | 112 |     $expandedIcon = 'folder-expanded.gif';
 | 
        
           |  |  | 113 |   | 
        
           |  |  | 114 |     //Requête pour récupérer les noms des répertoires contenus dans le répertoire courant ($id_rep)
 | 
        
           |  |  | 115 |     $queryRep =    ' SELECT projet_documents.*'.
 | 
        
           |  |  | 116 |                             ' FROM projet_documents'.
 | 
        
           |  |  | 117 |                             ' WHERE projet_documents.pd_pere = '.$pere.
 | 
        
           |  |  | 118 |                             ' AND projet_documents.pd_visibilite = "public" and pd_ce_projet='.$id_rep.' and pd_ce_type=0'.
 | 
        
           |  |  | 119 |                             ' ORDER BY projet_documents.pd_nom ASC' ;
 | 
        
           |  |  | 120 |   | 
        
           |  |  | 121 |     $resultRep = $GLOBALS['projet_db']->query($queryRep) ;
 | 
        
           |  |  | 122 |     if (DB::isError ($resultRep)) {
 | 
        
           |  |  | 123 |         die ('Echec de la requete : '.$queryRep.'<br />'.$resultRep->getMessage()) ;
 | 
        
           |  |  | 124 |     }
 | 
        
           |  |  | 125 |   | 
        
           |  |  | 126 |     //Stockage des informations sur les répertoires contenu dans le répertoire courant pour affichage dans un arbre.
 | 
        
           |  |  | 127 |     //Et appel récursif de la fonction pour examiner le contenu de chaque répertoire du répertoire courant.
 | 
        
           |  |  | 128 |     if ( $resultRep->numRows() != 0 ) {
 | 
        
           |  |  | 129 |         while ( $ligneRep = $resultRep->fetchRow(DB_FETCHMODE_OBJECT) ) {
 | 
        
           |  |  | 130 |             //Stockage des informations sur le répertoire courant
 | 
        
           |  |  | 131 |             $noeud1_1 = &$noeud->addItem(new HTML_TreeNode(
 | 
        
           |  |  | 132 |                                                         array(
 | 
        
           |  |  | 133 |                                                             'text' => trim ($ligneRep->pd_nom),
 | 
        
           |  |  | 134 |                                                             'link' => "", 'icon' => $icon,
 | 
        
           |  |  | 135 |                                                             'expandedIcon' => $expandedIcon ) ) );
 | 
        
           |  |  | 136 |             //Appel récursif de fonction courante
 | 
        
           |  |  | 137 |             projet_fichiers (&$noeud1_1, $id_rep, $ligneRep->pd_id) ;
 | 
        
           |  |  | 138 |         }
 | 
        
           |  |  | 139 |     }
 | 
        
           |  |  | 140 |   | 
        
           |  |  | 141 |     // Requête pour récupérer les fichiers du répertoire courant ($id_rep) et leurs informations
 | 
        
           |  |  | 142 |     $requete_fichiers = 'SELECT projet_documents.*, gen_type_de_fichier.gtf_type_icone'.
 | 
        
           |  |  | 143 |                                     ' FROM projet_documents, gen_type_de_fichier'.
 | 
        
           |  |  | 144 |                                     ' WHERE projet_documents.pd_ce_type= gen_type_de_fichier.gtf_id_type'.
 | 
        
           |  |  | 145 |                                     ' AND projet_documents.pd_visibilite= "public" ' ;
 | 
        
           |  |  | 146 |     if ($pere == 0) {
 | 
        
           |  |  | 147 |         $requete_fichiers .= ' AND projet_documents.pd_ce_projet= '.$id_rep.' and pd_pere=0 and pd_ce_type <> 0' ;
 | 
        
           |  |  | 148 |     } else {
 | 
        
           |  |  | 149 |         $requete_fichiers .= ' AND projet_documents.pd_pere= '.$pere.' and pd_ce_type<>0' ;
 | 
        
           |  |  | 150 |     }
 | 
        
           |  |  | 151 |     $requete_fichiers .= ' ORDER BY projet_documents.pd_nom ASC' ;
 | 
        
           |  |  | 152 |   | 
        
           |  |  | 153 |     $resultat_fichiers = $GLOBALS['projet_db']->query($requete_fichiers) ;
 | 
        
           |  |  | 154 |     if (DB::isError ($resultat_fichiers)) {
 | 
        
           |  |  | 155 |         die ('Echec de la requete : '.$requete.'<br />'.$resultat_fichiers->getMessage()) ;
 | 
        
           |  |  | 156 |     }
 | 
        
           |  |  | 157 |   | 
        
           |  |  | 158 |     //Stockage des informations sur les fichiers du répertoires courant pour affichage dans un arbre
 | 
        
           |  |  | 159 |     if ( $resultat_fichiers->numRows() != 0 ) {
 | 
        
           |  |  | 160 |         while ( $ligne_fichiers = $resultat_fichiers->fetchRow(DB_FETCHMODE_OBJECT) ) {
 | 
        
           |  |  | 161 |             //Ajout de slash devant les caractères spéciaux et suppression des caractères invisibles en début et fin des noms de fichier.
 | 
        
           |  |  | 162 |             $lien = trim( $ligne_fichiers->pd_nom  );
 | 
        
           |  |  | 163 |             $noeud_1_2 = &$noeud->addItem (new HTML_TreeNode (
 | 
        
           |  |  | 164 |                                                             array (
 | 
        
           |  |  | 165 |                                                                 "text" => $lien,
 | 
        
           |  |  | 166 |                                                                 "link" => PROJET_CHEMIN_FICHIER.$ligne_fichiers->pd_lien,
 | 
        
           |  |  | 167 |                                                                 'icon' => $ligne_fichiers->gtf_type_icone,
 | 
        
           |  |  | 168 |                                                                 "linkTarget" => "_blank" ))) ;
 | 
        
           |  |  | 169 |         }
 | 
        
           |  |  | 170 |     }
 | 
        
           |  |  | 171 | }
 | 
        
           |  |  | 172 |   | 
        
           | 25 | alexandre_ | 173 | /* +--Fin du code ----------------------------------------------------------------------------------------+
 | 
        
           |  |  | 174 | *
 | 
        
           |  |  | 175 | * $Log: not supported by cvs2svn $
 | 
        
           |  |  | 176 | *
 | 
        
           |  |  | 177 | *
 | 
        
           |  |  | 178 | * +-- Fin du code ----------------------------------------------------------------------------------------+
 | 
        
           |  |  | 179 | */
 | 
        
           |  |  | 180 |   | 
        
           | 2 | ddelon | 181 | ?>
 |