Sommaire de l’article

Cette modification permet d’afficher le sommaire de son article généré dynamiquement à partir du texte de l’article.

Ce filtre permet d’afficher le sommaire de son article généré dynamiquement à partir du texte de l’article. Vous pouvez naviguer dans l’article en cliquant sur les titres du sommaire.

Démo

Tous ce qui se trouve entre {{{ et }}} est considéré comme un titre à ajouter au sommaire de l’article.

Installation

dans mes_fonctions.php3 ajoutez:

/*
 *   +----------------------------------+
 *    Nom du Filtre : Sommaire de l'article                                               
 *   +----------------------------------+
 *    Date : dimanche 9 février 2003
 *    Auteur :  Noplay (noplay@altern.org)                                      
 *   +-------------------------------------+
 *    Fonctions de ce filtre :
 *      Cette modification permet d'afficher le sommaire de son article 
 *      généré dynamiquement à partir du texte de l'article. Vous pouvez naviguer 
 *      dans l'article en cliquant sur les titres du sommaire. 
 *
 *      Tous ce qui ce trouve entre {{{ et }}} est considéré comme un titre à ajouter au sommaire de l'article.
 *   +-------------------------------------+ 
 *   
 * Pour toute suggestion, remarque, proposition d'ajout
 * reportez-vous au forum de l'article :
 * http://www.uzine.net/spip_contrib/article.php3?id_article=76
*/
function sommaire_article($texte)
{
	
	preg_match_all("|\{\{\{(.*)\}\}\}|U", $texte, $regs);
	
	$texte="";
	
	$nb=1;
	
	for($j=0;$j<count($regs[1]);$j++)
	{
    	$texte=$texte."<a href=\"#sommaire_".$nb."\">".$regs[1][$j]."</a><br>";
		$nb++;
    }
	return $texte;
}

function sommaire_ancre($texte)
{
	$texte = preg_replace("|\{\{\{(.*)\}\}\}|U","<a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a>", $texte);
	
	$array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $texte);
	$res =count($array);
	$i =1;
	$texte=$array[0];
	while($i<$res)
	{
		$texte=$texte.$i.$array[$i];
		$i++;
	}
	
	return $texte;
}
//Fin filtre sommaire de l'article

et dans votre squelette vous ajoutez:
-  [(#TEXTE*|sommaire_article|propre)] pour afficher le sommaire de l’article
-  [(#TEXTE*|sommaire_ancre|propre)] pour afficher l’article.

Attention : ce filtre utilise la fonction preg_match_all qui necessite une version de PHP3 superieure a PHP 3.0.9

updated on 21 October 2005

Discussion

19 discussions

  • 1
    formatec

    Ce script me serait bien utile, mais je ne parviens pas à reprendre deux fois la variable #NB_TITRE_DE_MON_ARTICLE# il passe à la suivante dans l’array et me retourne donc:

    <div id="sommaire_1"><a name="sommaire_2">

    $i++

    <div id="sommaire_3"><a name="sommaire_4">

    hors j’aimerais qu’il me retourne

    <div id="sommaire_1"><a name="sommaire_1">

    $i++

    <div id="sommaire_2"><a name="sommaire_2">

    auriez-vous une solution?
    d’avance merci

    function sommaire_ancre($texte)
    {
            $texte = preg_replace("|\{\{\{(.*)\}\}\}|U","<div id=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\"><a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a></div>", $texte);
            
            $array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $texte);
            $res =count($array);
            $i =1;
            $texte=$array[0];
            while($i<$res)
            {
                    $texte=$texte.$i.$array[$i];
                    $i++;
            }
            
            return $texte;
    }

    Reply to this message

  • Bonjour,

    Au cas où, pour ceux qui utilise ce script avec Enluminures typographiques V3 , en configuration par défaut qui met des

    pour les intertitres de niveau 2, j’ai changé l’expression régulière pour qu’elle
    ne considère pas les titres avec 2 * au début:

    |{{{([^**].*)}}}

    au lieu de

    |{{{(.*)}}}
    En espérant que ça en dépanne 2/3 :)

    Reply to this message

  • 1
    Spigushe

    Il me semble bien que je sois arrivé trop tard, mais bon.
    Quel est le fichier “article.htm” à modifier ?
    Est-ce celui de /squelettes-dist ? celui de /prive/contenu ? celui de prive/info ? celui de /priver/editer ?

    En fin bref, je suis paumé.

    Reply to this message

  • 1

    Excusez-moi d’arriver longtemps après la fin d ela bagarre !

    Vous écrivez ceci :
    et dans votre squelette vous ajoutez :

    * [(#TEXTE*|sommaire_article|propre)] pour afficher le sommaire de l’article
    * [(#TEXTE*|sommaire_ancre|propre)] pour afficher l’article.

    mais moi je ne sais pas : dans quel fichier du squelette il faut mettre ça ?
    Peut-on le mettre n’importe où ?
    Est-ce que ça remplace quelque chose existant ?

    Merci d’avance !

    b_poiraud

    • >>>>>>>>>>>>>>>>>>>>>>>>>>>>

      B.Poiraud répond ........... Youpi !!

      Merci, j’ai trouvé
      après de multiples manipulations.
      Voici, pour d’autres,novices comme moi, ce que ça donne :

      Dans article.html j'avais ceci :
      [<div class="chapo">#DEBUT_SURLIGNE(#CHAPO)#FIN_SURLIGNE</div>]
      [<div class="texte">#DEBUT_SURLIGNE(#TEXTE|couleur)#FIN_SURLIGNE</div>]
      [<div class="ps">#DEBUT_SURLIGNE(#PS)#FIN_SURLIGNE</div>]
      [<div class="notes">#DEBUT_SURLIGNE(#NOTES)#FIN_SURLIGNE</div>]
       
      J'ai remplacé la deuxième ligne par ceci :
      [<div class="texte">(#TEXTE*|sommaire_article|propre)</div>] 
      [<div class="texte">(#TEXTE*|sommaire_ancre|propre)</div>]
       
      Cela me fait donc ceci :
      [<div class="chapo">#DEBUT_SURLIGNE(#CHAPO)#FIN_SURLIGNE</div>]
      [<div class="texte">(#TEXTE*|sommaire_article|propre)</div>] 
      [<div class="texte">(#TEXTE*|sommaire_ancre|propre)</div>]
      [<div class="ps">#DEBUT_SURLIGNE(#PS)#FIN_SURLIGNE</div>]
      [<div class="notes">#DEBUT_SURLIGNE(#NOTES)#FIN_SURLIGNE</div>]

      et, compte-tenu de ce que j’ai mis dans mes_fonctions .... CA MARCHE !
      Et c’est bien commode ce sommaire automatique :!

      Mais, encore deux questions

      1) j’aurais voulu que les lignes du sommaire soient bleues. J’ai essayé plein de choses, ça ne va pas.

      2) j’avais fixé une couleur violette à h3 . Et, depuis que j’ai mis le sommaire automatique ... ya plus de violet.

      Une idée ? deux zidées ?

      Merci à Jacques J et à tous

    Reply to this message

  • 4

    Super contrib! Merci noplay. Toutefois il implique que tous les articles qui ont du texte entre les 3 accolades {{{ ajoute automatiquement le menu.
    J’avais donc besoin d’afficher le sommaire que sur certains articles.

    J’ai donc créé une boucle qui me permette d’afficher le sommaire uniquement lorsque le mot clé “ancres-texte” est attaché à l’article :

    <BOUCLE_ancres(MOTS){id_article}{titre = ancres-texte}>
    [(#TEXTE*|sommaire_article|propre)]
    <hr>
    <br><br>
    </BOUCLE_ancres>
    
    [(#TEXTE*|sommaire_ancre|propre)] 
    ...

    Malheureusement, et ne sais pas pourquoi, ca ne marche pas ! :-(
    J’ai tout essayé mais impossible de faire apparaitre/disparaitre le menu avec l’utilisation de mots clés.

    Je propose donc une solution plus ou moins sympas.
    La solution et bien en effet c’est sebold qui l’a donnée ci-dessous et que je remercie infiniment, avec la possibilité d’utiliser ses propres tags et ne pas lier le sommaire aux 3 accolades.

    Cela m’a permis de créer des tags personnalisés. Tant qu’ils ne sont pas utilisés le menu n’apparait pas! J’ai donc créé des tags personnalisés <anc></anc>.

    J’ai utilisé ma boucle “Mots” avec le mot clé “ancres-texte” pour afficher la décoration du sommaire.

    Résultat dans le squelette de l’article :

    <!-- affichage du sommaire si tag "anc" utilisé -->
    [(#TEXTE*|sommaire_article{"<anc>","</anc>"}|propre)]
    
    <!-- boucle affichant la décoration et espace pour le sommaire -->
    <BOUCLE_ancres(MOTS){id_article}{titre = ancres-texte}>
    <hr>
    <br><br>
    </BOUCLE_ancres>
    
    <!-- texte de l'article -->
    [(#TEXTE*|liens_ouvrants{"<anc>","</anc>"}|sommaire_ancre|propre)]

    Ainsi, le tag anc active le sommaire et le mot clé “ancres-texte” rattaché à l’article me permet de “décorer” l’article. Si l’article n’utilise pas les tag “anc” et n’a pas le mot clé attaché, il se présentera comme un article normal.

    J’ai également profité de la contribution de ovto pour faire des liens de retour au sommaire sur les titres en adaptant le script pour mes_fonctions en conséquence:

    /*
     *   +----------------------------------+
     *    Nom du Filtre : Sommaire de l'article                                               
     *   +----------------------------------+
     *    Date : dimanche 9 février 2003
     *    Auteur :  Noplay (noplay@altern.org)                                      
     *   +-------------------------------------+
     *    Fonctions de ce filtre :
     *      Cette modification permet d'afficher le sommaire de son article 
     *      généré dynamiquement à partir du texte de l'article. Vous pouvez naviguer 
     *      dans l'article en cliquant sur les titres du sommaire. 
     *
     *      Tous ce qui ce trouve entre {{{ et }}} est considéré comme un titre à ajouter au sommaire de l'article.
     *   +-------------------------------------+ 
     *   
     * Pour toute suggestion, remarque, proposition d'ajout
     * reportez-vous au forum de l'article :
     * http://www.uzine.net/spip_contrib/article.php3?id_article=76
    */
    function sommaire_article($texte, $beginPattern="\{\{\{", $endPattern="\}\}\}"){
     $pattern = "|" . $beginPattern . "(.*)" . $endPattern . "|U";
            preg_match_all($pattern, $texte, $regs);
            $texte="";
            $nb=1;
            for($j=0;$j<count($regs[1]);$j++){
               $texte=$texte."<BR>&nbsp;&nbsp;&nbsp;<li><a name=\"so_".$nb."\" a href=\"#sommaire_".$nb."\">".$regs[1][$j]."</a></li>";
                    $nb++;
       }
            return $texte;
    }
    
    function sommaire_ancre($texte, $beginPattern="\{\{\{", $endPattern="\}\}\}"){
     $pattern = "|" . $beginPattern . "(.*)" . $endPattern . "|U";
            $texte = preg_replace($pattern, "<a href=\"#so_#NB_TITRE_DE_MON_ARTICLE_renvoi#\" name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a>", $texte);
           
            $array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $texte);
            $res =count($array);
            $i =1;
            $texte=$array[0];
            while($i<$res){
                    $texte=$texte.$i.$array[$i];
                    $i++;
            }
            $array = explode("#NB_TITRE_DE_MON_ARTICLE_renvoi#" , $texte);
            $res =count($array);
            $i =1;
            $texte=$array[0];
            while($i<$res)
            {
                    $texte=$texte.$i.$array[$i];
                    $i++;
            }
            
            return $texte;
    }
    
    //Fin filtre sommaire de l'article
    ?>
    • Je sais pas pourquoi ta fonction ne marche pas chez moi mais j’ai mis ca à la place et tout fonctionne, le sommaire et les liens pour retourner au sommaire.

      /*
       *   +----------------------------------+
       *    Nom du Filtre : Sommaire de l'article                                               
       *   +----------------------------------+
       *    Date : dimanche 9 février 2003
       *    Auteur :  Noplay (noplay@altern.org)                                      
       *   +-------------------------------------+
       *    Fonctions de ce filtre :
       *      Cette modification permet d'afficher le sommaire de son article 
       *      généré dynamiquement à partir du texte de l'article. Vous pouvez naviguer 
       *      dans l'article en cliquant sur les titres du sommaire. 
       *
       *      Tous ce qui ce trouve entre {{{ et }}} est considéré comme un titre à ajouter au sommaire de l'article.
       *   +-------------------------------------+ 
       *   
       * Pour toute suggestion, remarque, proposition d'ajout
       * reportez-vous au forum de l'article :
       * http://www.uzine.net/spip_contrib/article.php3?id_article=76
      */
      function sommaire_article($texte)
      {
              
              preg_match_all("|\{\{\{(.*)\}\}\}|U", $texte, $regs);
              
              $texte="";
              
              $nb=1;
              
              for($j=0;$j<count($regs[1]);$j++)
              {
                  $texte=$texte."<a name=\"so_".$nb."\" href=\"#sommaire_".$nb."\">".$regs[1][$j]."</a><br>";
                      $nb++;
          }
              return $texte;
      }
      
      function sommaire_ancre($texte)
      {
              $texte = preg_replace("|\{\{\{(.*)\}\}\}|U","<a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\" href=\"#so_#NB_TITRE_DE_MON_ARTICLE_renvoi#\">$0</a>", $texte);
              
              $array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $texte);
              $res =count($array);
              $i =1;
              $texte=$array[0];
              while($i<$res)
              {
                      $texte=$texte.$i.$array[$i];
                      $i++;
              }
      
              $array = explode("#NB_TITRE_DE_MON_ARTICLE_renvoi#" , $texte);
              $res =count($array);
              $i =1;
              $texte=$array[0];
              while($i<$res)
              {
                      $texte=$texte.$i.$array[$i];
                      $i++;
              }
              
              return $texte;
      }
      //Fin filtre sommaire de l'article
    • Pour compléter et faire réellement fonctionner le mot clé conditionnel ancres-texte tout en se débarassant de ces affreuses balises <anc></anc> voici la comment est rédigé mon corps d’article :

      <B_ancres>
              <!-- affichage du sommaire si tag "anc" utilisé -->
              [(#TEXTE*|sommaire_article|propre)]
      
              <!-- boucle affichant la décoration et espace pour le sommaire -->
              <BOUCLE_ancres(MOTS){id_article}{titre = ancres-texte}>
              <hr>
              <br><br>
              </BOUCLE_ancres>
      
              <!-- texte de l'article -->
              [(#TEXTE*|liens_ouvrants|sommaire_ancre|propre|justifier)]
      </B_ancres>
              [(#TEXTE|liens_ouvrants|justifier)] 
      <//B_ancres>

      -  un article avec le mot clé : http://legoux.org/article139.html
      -  un article sans : http://legoux.org/article139.html

      no problemo

      Patrice.

    • oups... l’article avec c’est celui là : http://legoux.org/article118.html

    • Pierre MULLER

      Avec une boucle ARTICLES au lieu de MOTS, cela marche.

      <BOUCLE_sommaire(ARTICLES){id_article}{titre_mot = avec-sommaire}>
      [(#TEXTE*|sommaire_article|propre|liens_ouvrants)
      <hr>
      ]
      </BOUCLE_sommaire>

    Reply to this message

  • Ca semblera tout bête mais le lien qui se crèe est http://www.monsite.com/#sommaire_1 mais il manque devant l’article! (ca devrait être http://www.monsite.com/article.php3?id_article=76#sommaire_1)

    Ainsi ca me mène au sommaire....

    Une idée où j’ai fait faux?
    Sinon faudrait que devant p>

    merci pour votre aide

    Reply to this message

  • 2

    Comment je fais pour imprimer un article sur le site contrib.
    ou est l’icon imprimer ?

    Reply to this message

  • 1
    Bruno Mathieu

    Bonjour, j’ai remplacé

    $texte = preg_replace("|\{\{\{(.*)\}\}\}|U","<a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a>", $texte);

    par

    $texte = preg_replace("|\{\{\{(.*)\}\}\}|U","{{{<a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$1</a>}}}", $texte);

    sinon, le validateur html du w3c pour un doctype
    HTML 4.01 Transitional me répond que la page est invalide car si j’ai bien compris, on ne peut pas mettre un H3 dans un A.

    Autrement, c’est vraiment bien utile comme filtre. Merci.

    PS: j’utilise la version de SPIP 1.7.2.

    • atchoum

      Ah merci de la contrib et de sa correction pour les éléments “h3” et “a href”!!

    Reply to this message

  • j’ai un peu modifié les filtres et on revient au sommaire en cliquant les titres :

    function sommaire_article($texte)
    {
            
            preg_match_all("|\{\{\{(.*)\}\}\}|U", $texte, $regs);
            
            $texte="";
            
            $nb=1;
            
            for($j=0;$j<count($regs[1]);$j++)
            {
                $texte=$texte."<a name=\"so_".$nb."\" href=\"#sommaire_".$nb."\">".$regs[1][$j]."</a><br>";
                    $nb++;
        }
            return $texte;
    }
    
    function sommaire_ancre($texte)
    {
            $texte = preg_replace("|\{\{\{(.*)\}\}\}|U","<a href=\"#so_#NB_TITRE_DE_MON_ARTICLE_renvoi#\" name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a>", $texte);
            
            $array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $texte);
            $res =count($array);
            $i =1;
            $texte=$array[0];
            while($i<$res)
            {
                    $texte=$texte.$i.$array[$i];
                    $i++;
            }
    
            $array = explode("#NB_TITRE_DE_MON_ARTICLE_renvoi#" , $texte);
            $res =count($array);
            $i =1;
            $texte=$array[0];
            while($i<$res)
            {
                    $texte=$texte.$i.$array[$i];
                    $i++;
            }
            
            return $texte;
    }

    Reply to this message

  • 4

    Le filtre sommaire ne fonctionne pas en ligne (alors que ça marche en local avec easy php). Bizarre...

    Mon hébergeur est Ouvaton, et d’après ce que j’ai vu ils ont une version de php suffisante.

    • Il t’affiche aucun message d’erreur?

    • Non, y a aucun messages d’erreur. Le texte s’affiche en mode normal, comme si y avait pas le filtre.
      Pourtant, le ficbier mes_options est bien en ligne.

    • C’est bizarre surtout que sa marche en local.

    • Ca y est, le sommaire avec ancres s’affiche et fonctionne à présent... Allez savoir pourquoi, pourtant je n’ai rien changé...
      En revanche, le moteur de recherche en ligne toujours pas, mais ça c’est une autre histoire...

    Reply to this message

Comment on this article

Who are you?
  • [Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom