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

Discussion

19 discussions

  • 1

    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;
    }

    Répondre à ce 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 :)

    Répondre à ce 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é.

    Répondre à ce 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

    Répondre à ce 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>

    Répondre à ce 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

    Répondre à ce message

  • 2

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

    Répondre à ce 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 » !!

    Répondre à ce 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;
    }

    Répondre à ce 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...

    Répondre à ce message

Ajouter un commentaire

Qui êtes-vous ?

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom

Dernière modification de cette page le 21 octobre 2005