SPIP-Contrib

SPIP-Contrib

عربي | Deutsch | English | Español | français | italiano | Nederlands

290 Plugins, 198 contribs sur SPIP-Zone, 97 visiteurs en ce moment

Accueil > Rédaction > Archives Rédaction > Filtres Mise en page pour avant SPIP 1.9 > Sommaire de l’article

Sommaire de l’article

12 mars 2003 – par Noplay – 43 commentaires

2 votes

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 :

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.

P.-S.

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

Dernière modification de cette page le 21 octobre 2005

Retour en haut de la page

Tout afficher

Vos commentaires

  • Le 9 juillet 2013 à 01:54, par formatec En réponse à : Sommaire de l’article

    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

  • Le 16 janvier 2012 à 15:00, par fwedboot En réponse à : Sommaire de l’article

    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

  • Le 21 avril 2010 à 16:58, par Spigushe En réponse à : Sommaire de l’article

    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

  • Le 12 juin 2006 à 13:19, par B.POIRAUD En réponse à : Sommaire de l’article

    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

    • Le 12 juin 2006 à 22:39, par B.POIRAUD En réponse à : Sommaire de l’article

      >>>>>>>>>>>>>>>>>>>>>>>>>>>>

      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

  • Le 1er janvier 2005 à 16:54, par fulvio En réponse à : > Appel conditionnel du sommaire

    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
    ?>
    • Le 22 janvier 2005 à 12:49, par paps En réponse à : > Appel conditionnel du sommaire

      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
    • Le 22 janvier 2005 à 13:33, par paps En réponse à : > Appel conditionnel du sommaire

      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.

    • Le 22 janvier 2005 à 13:36, par paps En réponse à : > Appel conditionnel du sommaire

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

    • Le 18 juillet 2005 à 16:17, par Pierre MULLER En réponse à : > Appel conditionnel du sommaire

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

    Répondre à ce message

  • Le 24 juin 2005 à 01:36, par fulvio En réponse à : > Sommaire de l’article

    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

  • Le 21 mars 2003 à 11:12, par ? En réponse à : > Sommaire de l’article

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

    Répondre à ce message

  • Le 21 avril 2005 à 09:33, par Bruno Mathieu En réponse à : > Sommaire de l’article et HTML Valide

    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.

    Répondre à ce message

  • Le 14 juillet 2004 à 19:43, par m. En réponse à : > [modification] titres dans l’article qui renvoient au sommaire

    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

  • Le 5 juin 2004 à 21:35, par DM En réponse à : > prob avec spip 1.7.2, sommaire s’affiche pas

    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.

    Répondre à ce message

Répondre à cet article

Qui êtes-vous ?
  • [Se connecter]

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 Les choses à faire avant de poser une question (Prolégomènes aux rapports de bugs. )
Ajouter un document

Retour en haut de la page

Ça discute par ici

  • Passer un site SPIP sous https://

    23 février 2017 – 39 commentaires

    Comment migrer simplement votre site SPIP de http:// vers https:// Le protocole https:// devient de plus en plus courant : C’est mieux pour la vie privée de tous La plupart des grands sites l’a déjà adopté Certains navigateurs commencent à afficher (...)

  • cipr : plugin « Prévisualisation étendue »

    22 septembre 2010 – 40 commentaires

    Ce plugin "cipr : Prévisualisation étendue" permet de naviguer sur le site en prévisualisation, entre articles et rubriques, sur la page d’accueil, etc. Ce plugin de prévisualisation étendue permet de : naviguer en prévisualisation entre articles et (...)

  • À propos des plugins actifs

    13 novembre 2010 – 25 commentaires

    À propos des plugins actifs affiche dans la partie publique de votre site la version de SPIP utilisée et la liste des Plugins activés avec affichage de l’icône, le nom, la version, l’état et une introduction de sa fonction. Si le Plugin n’a pas (...)

  • ScolaSPIP 4

    19 janvier 2016 – 362 commentaires

    ScolaSPIP est plugin-squelette responsive personnalisable pour sites Web d’établissements scolaires basé sur SPIPr Présentation de ScolaSPIP Ce plugin pour SPIP 3 est développé par la Dane de l’académie de Versailles pour les webmestres de cette (...)

  • Convertir un site SPIP 3 en utf-8 avec le plugin Grenier

    8 janvier 2014 – 23 commentaires

    SPIP 3 fonctionne nativement avec l’encodage universel unicode utf-8. Sur certains sites (par exemple sur une mise à jour), on peut avoir un site qui est resté en iso-latin ce qui n’est pas conseillé (source de bugs, d’incompatibilité, ...) . (...)