SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Rédaction > Archives Rédaction > Filtres Mise en page pour avant Spip 1.9

Découper un article en plusieurs pages et lui ajouter un sommaire

mardi 24 juin 2003, par Aurélien PIERARD, Noplay. Dernier ajout mercredi 6 octobre 2004


Ce filtre est une mise à jour des filtres de noplay "Sommaire de l’article" et de "gpl" "Découper un article en plusieurs pages".


Ce script contient deux filtres :

  • Un filtre pour afficher le sommaire
  • Un filtre pour découper l’article

Pour installer ces filtres, il faut ajouter ces deux fonctions dans le fichier mes_fonctions.php3.

Afficher le sommaire

Découper l’article

Utilisation :

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

- [(#TEXTE*|decouper_en_page|propre|justifier)] pour afficher l’article.

Notez bien l’astérisque après #TEXTE ! Cette astérisque permet de désactiver les traitements par défaut de Spip sur le champ #TEXTE : c’est nécessaire ici parce que je veux traiter cinq traits d’union consécutifs qui sont transformés en <hr> normalement.

- Rédigez vos articles en utilisant cinq traits d’union consécutifs à l’endroit qui doit recevoir la coupure.

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

À noter Pour obtenir une ligne horizontale, la documentation de Spip stipule qu’une succession de quatre traits d’union ou plus est nécessaire. Avec ce filtre, c’est différent : quatre traits d’union provoque une ligne horizontale, cinq provoquent un saut de page. J’ai choisi ceci pour permettre d’avoir, dans l’hypothèse d’un autre squelette avec #TEXTE et non #TEXTE*, une ligne horizontale qui signale le découpage en pages.

Remarques :

Pour intégrer quelques choses uniquement à la dernière page (par exemple le forum de l’article ou le PS) tapez dans votre squellette :

P.-S.

- Attention : ce filtre utilise la fonction preg_match_all qui necessite une version de PHP3 superieure a PHP 3.0.9
- #NOTES fonctionne avec ce filtre. (La numérotation recommence à chaque nouvelle page)

Documents joints

  • Script complet Script complet (texte - 5 ko)

    Script complet contenant les filtres :
    - Découper par pages
    - Afficher le sommaire de l’article


Répondre à cet article

  • Bonjour,

    existe t il une version de ce filtre compatible avec spip 1.9 car ca ne marche plus au niveau des pages ? par contre aucun problème pour le sommaire

    merci

    Répondre à ce message

    Retour au début des forums

  • ID_ARTICLE manquant

    31 mars 2006 20:12, par philooo

    pour que ca marche sur ma 1.8.2

    j’ai du faire un appel dans mon squelette comme ceci :

    [(#TEXTE|decouper_en_pages{#ID_ARTICLE}]

    Ensuiote j’ai du injecter dans la focntion l’id_Article :

    function decouper_en_pages($texte,$id_article) {

    Ensuite changer la definition de la variable uri_art :

           $uri_art = generer_url_article($id_article);

    apres ca tout marche nickel :)

    exemple : http://www.topspeed.com/car_news/au...

    Voir en ligne : Fast cars

    Répondre à ce message

    Retour au début des forums

  • J’utilise ce filtre un peu modifié pour la mise en page avec spip 1.8.2-d (standart). Un exemple du rendu est visible sur http://www.gigean-village.com/artic...).

    Je rencontre cependant un problème de taille, je suis obligé de désactiver le système de cache des articles en affectant le délais de rafraichissement à 0.
    Cela n’est pas viable sur un site important.

    J’ai cherché partout où le bas blessait sans rien trouver. Une piste serait la bienvenue...

    Répondre à ce message

    • Après mult galéres et un echauffement du bulbe intempestif, je crois avoir trouvé la solution.
      Alors accrochez vous ! Cela vient du système de cache de spip. Si j’ai tout bien compris, spip ne cache qu’une page pour une url du type quelque-chose.php3?parametre1=x&parametre2=y. En fait, il prend le premier paramètre (dans le cas de ce filtre, article.php3?id_article=x), et n’interprete pas les suivants (dans le cas de ce filtre, la transmission des pages suivantes|precedentes de la forme artsuite=x).
      Pour le forcer a prendre en compte ces variables et generer une page de cache pour chaque page découpée de l’article, il faut forcer spip a prendre en compte ces variables.
      Admettons que le squelette de la page contenant l’article découpé s’appelle inc-article.html et qu’il est appelé dans le squelette article.html par la commande .
      Il faut modifier ce fichier inc-article.php3 pour que spip prenne en compte la variable $artsuite. Pour cela on ajoute sous la ligne
      $delais = 2 * 3600 ;
      et avant la ligne
      include (inc-public.php3) ;
      la ligne magique :
      $contexte_inclus[artsuite’]=$_GET[artsuite’] ;
      Et voilà le travail !
      Faites moi savoir si vous rencontrez des erreurs avec cette méthode.

      Répondre à ce message

    Retour au début des forums

  • et les documents joints ?

    2 novembre 2005 20:02, par matthieu

    Bonjour,

    je rencontre un petit pb : en utilisant ce filtre (au demeurant très pratique et fort bien fait), les documents qui sont inclus dans le corp du texte réaparaissent une seconde fois comme documents joints... et ça m’ennuie un peu :-)

    ex : http://www.issyescalade.info/article.php?id_article=24&artsuite=0#sommaire_3

    y’a-t-il un moyen de contrer ce pb ?

    Merci d’avance,

    Matthieu

    Répondre à ce message

    Retour au début des forums

  • Ce filtre est-il compatible avec la version spip 1.8.2d ?

    Répondre à ce message

    Retour au début des forums

  • une petite URL, pour voir un exemple ?

    Répondre à ce message

    • Ici : http://www.trainduvivarais.org/arti... par exemple...

      J’ai adopté de filtre qui me donne entière satisfaction à ce jour !

      JC

      Voir en ligne : http://www.trainduvivarais.org/arti...

      Répondre à ce message

      • Merci pour l’url, mais je ne vois pas bien ou se situe ton sommaire

        Répondre à ce message

        • bonjour à tous, j’ai le meme problème, je n’arrive pas à écrire la commande dans le fichier .htaccess pour rediriger correctement ce qui fait que l’on rivent toujours sur la première page du sommaire. Quelqu’un a t il une idée ? Merci à tous les géniaux inventeurs qui travaillent ici. ALexis

          Voir en ligne : Les béatitudes au Liban

          Répondre à ce message

          • maintenant cela marche du tonère... y ’a qu’a voir... http://www.bealiban.com/article7.html j’ai été obligé de modifier le code dans mes_fonctions.php pour coder autrement les url, pour ceux qui veulent avoir le code écrivez moi.

            Voir en ligne : voyez plutot...

            Répondre à ce message

            • Et pourquoi ne pas proposer ta modification directement sur Spip-Contrib ;)

              Répondre à ce message

              • J’aimerais bien savoir moi aussi comment tu as fait, j’ai le même problème que indiqué plus haut, je n’ai que la première page qui est traitée pour récupérer les titres à intégrer dans le sommaire, pourrais-tu partager avec nous ton savoir-faire ?

                Répondre à ce message

              • Avec retard... !! voici donc le code qui permet d’utiliser l’url rewriteing et la contrib. En fait il faut réécrire la ligne qui fabrique le lien qui envoie vers les pages de la table des matières. Il faut aussi écrire une ligne dans le htaccess.

                Voilà le fitre...

                function decouper_en_page($texte) {
                       global $artsuite, $var_recherche, $num_pages;
                               
                       if (empty($artsuite)) $artsuite = 0;
                       
                                // on divise la page (séparateur : "-----")        
                       $page = split('-----', $texte);
                       // Nombre total de pages
                       $num_pages = count($page);

                       // Si une seule page ou numéro illégal, alors retourner tout le texte.
                       // Cas spécial : si var_recherche positionné, tout renvoyer pour permettre à la surbrillance de fonctionner correctement.
                       if ($num_pages == 1 || !empty($var_recherche) || $artsuite < 0 || $artsuite > $num_pages) {
                                        // On place les ancres sur les intertitres
                                        $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;
                       }

                       $p_prec = $artsuite - 1;
                       $p_suiv = $artsuite + 1;
                                $var=($GLOBALS['id_article']);
                      // $uri_art = generer_url_article($GLOBALS['id_article']);
                      // $uri_art .= strpos($uri_art, '?') ? '&' : '?';
                                $uri_art = 'articles'.$var;

                                // On place les ancres sur les intertitres
                                $page[$artsuite] = preg_replace("|\{\{\{(.*)\}\}\}|U","<a name=\"sommaire_#NB_TITRE_DE_MON_ARTICLE#\">$0</a>", $page[$artsuite]);
                                $array = explode("#NB_TITRE_DE_MON_ARTICLE#" , $page[$artsuite]);
                                $res =count($array);
                                $i =1;
                                $page[$artsuite]=$array[0];
                                while($i<$res){
                                        $page[$artsuite]=$page[$artsuite].$i.$array[$i];
                                        $i++;
                                }
                                // Pagination
                            switch (TRUE) {
                                        case ($artsuite == 0):
                                                $precedent = "";
                                                $suivant = "<a href='" . $uri_art . "-" . $p_suiv . ".html   '>&gt;&gt;</a>";
                                                break;
                                        case ($artsuite == ($num_pages-1)):
                                                $precedent = "<a href='" . $uri_art . "-" . $p_prec . ".html  '>&lt;&lt;</a>";
                                                $suivant = "";
                                                break;
                                        default:
                                                $precedent = "<a href='" . $uri_art . "-" . $p_prec . ".html '>&lt;&lt;</a>";
                                                $suivant = "<a href='" . $uri_art . "-" . $p_suiv . ".html '>&gt;&gt;</a>";
                                                break;
                       }
                   
                       for ($i = 0; $i < $num_pages; $i++) {
                                        $j = $i;
                                        if ($i == $artsuite) {
                                                $milieu .= " <strong>" . ++$j . "</strong> ";
                           }
                                        else {

                                                //$milieu .= " <a href='" . $uri_art . "artsuite=$i'>" . ++$j . "</a> ";
                                                $milieu .= " <a href='" . $uri_art ."-". $i.".html'>" . ++$j . "</a> ";                               

                                        }
                       }

                       // Ici, on peut personnaliser la présentation
                       $resultat .= $page[$artsuite];
                               
                       $resultat .= "<p class='tm'><center>Pages : $precedent $milieu $suivant</center></p>";
                       return $resultat;
                }
                // FIN du Filtre decouper_en_page

                Et mon fichier htaccess

                RewriteRule ^rubrique([0-9]+).html$   /rubrique.php3?id_rubrique=$1
                RewriteRule ^article([0-9]+).html$    /article.php3?id_article=$1
                RewriteRule ^breve([0-9]+).html$     /breve.php3?id_breve=$1
                RewriteRule ^secteur([0-9]+).html$    /secteur.php3?id_rubrique=$1
                RewriteRule ^articles([0-9]+)-([0-9]+).html$   /article.php3?id_article=$1&artsuite=$2
                RewriteRule ^articles([0-9]+)-([0-9]+)-([0-9]+).html$   /article.php3?id_article=$1&artsuite=$2#sommaire_$3

                Simple non.

                Voir en ligne : mon site pour voir si ca marche...

                Répondre à ce message

    Retour au début des forums

  • Salut

    Est-ce qu’il y a moyen de n’afficher le sommaire que sur la première page ?

    Merci.

    Répondre à ce message

    Retour au début des forums

  • Bonjour à tous,

    Ce filtre est l’un des plus puissants que j’utilise. Avant tout, merci à ses auteurs.

    Seulement voilà, depuis que j’ai changé de squelette, il fonctionne de manière aléatoire... Je veux dire, parfois, il fait bien les sauts de page ; parfois, non, il renvoie à des pages vierges.

    Bien entendu, il est toujours dans mes squelettes et dans mes.fonctions.php3

    Une idée ?

    Merci d’avance

    Voir en ligne : davduf.net

    Répondre à ce message

    Retour au début des forums

  • problèmes

    7 janvier 2005 13:28, par rachouan

    Salut le filtre est impecable...sauf que j’est 2 problème... 1) je ne sais pas si c’est a cause de lui, mais lorsque je valide mon text pour l’entrer, il ne reconnait pas les sauts de lignes ; il faut que je fait 2 sauts de ligne pour le reconnaitre 2) le sommaire marche trés bien... sauf que les titre du sommaire dans le texte agissent bizarement lors d’un survol de la sourie merci pour tout

    Répondre à ce message

    Retour au début des forums

  • Petite fonction

    30 décembre 2004 23:27, par eve

    Salut ! Merci bcp pour la super fonction.

    Pour mes besoins, j’ai ajouté une fonction qui ajoute juste sur la premiere page par exemple le descriptif (et pas sur chaque page)

    Voici le code du fichier html (par exemple pour afficher le descriptif)

    [(#DESCRIPTIF*|afficher)]

    dans mes_fonctions.php3 function afficher($texte) global $artsuite ; if (empty($artsuite)) return $texte ;

    Desolée : Je vois pas un moyen pour poster le code !?! Les accolades sont interpretés et aussi le code html... donc du coup c peutetre plus difficile à lire. de tout facon, dans la fonction, vous savez ou mettre les accolades.

    a+ eve*

    Voir en ligne : connexion-allemande

    Répondre à ce message

    Retour au début des forums

  • Bonjour et tout d’abord un grand merci pour cette nouvelle fonctionnalité !!

    J’aimerais avoir un menu déroulant pour accéder aux différentes pages, exemple :
    - [page 1]
    - [page 2]
    - [page 3]

    Comment réaliser un tel menu ?

    @++ sentinelle

    Répondre à ce message

    Retour au début des forums

  • Je n’arrive pas à combiner réduire une image et découpe le texte en chapitre. Dans mon squelette "article.html" j’ai le script suivant :

    [(#TEXTE|limit_images_size200,0,1)]

    [(#TEXTE*|sommaire_article|propre)]

    [(#TEXTE*|decouper_en_page|propre|justifier)]

    Ce type de script me redonne deux fois le même texte Merci de votre aide, je ne sais plus quoi faire

    Répondre à ce message

    Retour au début des forums

0 | 25 | 50



Suivre la vie du site RSS 2.0 | Plan du site | Espace privé | Charte et vie SPIP-Contrib | SPIP | L'autre.net