Rev 264 | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php/*trail.php : Permet d'afficher des liens "Page Suivante" "Sommaire" "Page Precedente" dans une pageCopyright 2003 Eric FELDSTEINThis program is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2 of the License, or(at your option) any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA*//** Cette action permet de lier des pages entre elle via une page contenant la liste* ordonnées de ces pages. L'action affiche des liens de navigation permettant de* passer à la page suivante ou précédente ou de revenir au sommaire.** @param toc string nom de la page contenant la liste ordonnée des pages à liées entre elles*//* La page sommaire doit contenir une liste de pages. Le premier mot de chaque élémentde la liste doit être le nom d'une page du wiki, donc un mot wiki ou un lien forceexemple de page sommaire:===Sommaire===IntroductionAuProjet : présentation du projet.[[AnalyseProjet Analyse]] : analyse des besoins-BesoinDesUtilisateurs-ContraintesTechniquesOutilsEtNormesTexte texte texte texte texte texte texte texte texte textetexte texte texte texte texte texte texte texte texte texte textetexte texte texte texte texte texte texte texte texte texte texte texte*///echo $this->Format("===Action Trail===");$sommaire = $this->GetParameter("toc");if (!$sommaire) {echo $this->Format("//Indiquez le nom de la page sommaire, paramètre 'toc'//.");}else{//chargement de la page sommaire$tocPage = $this->LoadPage($sommaire);//analyse de la page sommaire pour récupérer la liste des pages//recuperation de la listeif (preg_match_all("/\n[\t ]+(.*)/",$tocPage["body"],$tocListe)){//analyse de chaque ligne de la liste pour recupérer la page cible$currentPageIndex = NULL;foreach ($tocListe[1] as $line){//suppression d'un signe de liste eventuel$line = trim(preg_replace("/^([A-Za-z0-9]+\)|-)/","",$line));//recuperation du 1er mot$line = preg_replace("/^(\[\[.*\]\]|[A-Za-z0-9]+)\s*(.*)$/","$1",$line);//ajout a la liste des pages si le 1er mot est un lien force ou un mot wikiif (preg_match("/\[\[.*\]\]/",$line,$match)|$this->IsWikiName($line)){$pages[] = $line;//regarde si la page ajoute a la liste est la page couranteif (strcasecmp($this->GetPageTag(),$line)==0){$currentPageIndex = count($pages)-1;}else { //traite le cas des lien forceif (preg_match("/\[\[(.*:)?".$this->GetPageTag()."(\s.*)?\]\]$/",$line)) {$currentPageIndex = count($pages)-1;}}}}//foreach}//ecriture des liens Page Précedente/sommaire/page suivanteif ($currentPageIndex>0) {$PrevPage = $pages[$currentPageIndex-1];$btnPrev = "<span class=\"trail_button\">".$this->Format("<< $PrevPage")."</span>";}else{$btnPrev = " ";}$btnTOC = "<span class=\"trail_button\">".$this->Format($sommaire)."</span>";if ($currentPageIndex < (count($pages)-1)){$NextPage = $pages[$currentPageIndex+1];$btnNext = "<span class=\"trail_button\">".$this->Format("$NextPage >>")."</span>";}else{$btnNext = " ";}echo "<table class=\"trail_table\" width=\"100%\" border=\"0\" cellspacing=\"0\" cellpadding=\"5\">\n";echo " <tr>\n";echo " <td align=\"left\" width=\"35%\">$btnPrev</td>\n";echo " <td align=\"center\">$btnTOC</td>\n";echo " <td align=\"right\" width=\"35%\">$btnNext</td>\n";echo " </tr>\n";echo "</table>\n";}?>