samedi 13 septembre 2003, par Robert Sebille. Dernier ajout mardi 5 décembre 2006
Affiche X liens vers des articles, par page, dans une rubrique et place les liens adéquats (X articles précédents, liens vers 10 pages/rubriques maxi à compter de celle où on se trouve, X articles suivants). Utilise du PHP dans la boucle.
Si, dans le squelette rubrique.html, on a mis une BOUCLE(ARTICLES) avec le paramêtre {tout}, les pages rubriques vont grandir au fur et à mesure du remplissage du site. Si on a limité le nombre d’articles (avec le paramètre {0, 20}, par exemple), on « perd » les plus anciens.
L’avantage de cette boucle, est qu’on n’est plus obligé de limiter le nombre de liens vers les articles dans une page rubrique, tout en évitant de voir grandir cette page à l’infini. C’est ce qu’on appelle la pagination.
le code + la boucle à copier / coller dans la page rubrique.
le fichier article-pagine.inc à télécharger dans le répertoire racine de votre site spip (là où il y a les squelettes .php3).
N’oubliez pas de télécharger aussi fleche-gauche.gif et fleche-droite.gif dans /NAVPICS.
A propos des squelette inclus : Si vous mettez la boucle dans un squelette inclus, il est nécessaire mais apparament pas suffisant d’appeler le squelette inclus avec . Il faut en plus, ré-imbriquer la boucle dans une boucle rubriques et dans le squelette inclus lui-même. On ne sait pas pourquoi, mais on sait que sinon ca ne marche pas bien. Celui qui trouve va passer pour un fortiche ;-). En bref pour les squelettes inclus, ca donne ceci :
<BOUCLE_rubrique(RUBRIQUES){id_rubrique}>
Le code et la boucle ci-dessous ...
</BOUCLE_rubrique>
1) le code + la boucle à copier / coller dans la page rubrique
2)le code contenu dans "article-pagine.inc
Remarque de mise à jour
Changements dans la version III L’appel de fonction qui provoquait la Fatal error : Call to undefined function : getarticlelinks() sur certains sites a été supprimé et remplacé par un fichier inclus (article-pagine.inc) qui contient le code (qui n’est donc plus dans mes_fonctions.php3)
Une correction a été apportée au code qui obligeait à ce que la page traitée soit une page rubrique. Ce peut-être maintenant n’importe quelle boucle qui supporte le critère Spip {debut_xxx,b} (relire cette doc sur spip.net ), une boucle mot, par exemple, ou encore une boucle SYNDIC_ARTICLES, comme sur cette page, etc. Il faut bien sur alors adapter les boucles spip au cas choisi
Pour ceux qui avaient implémenté la version II et qui souhaitent passer à la version III
1) Uploader le fichier "article-pagine.inc" dans le répertoire racine de votre site spip (là où il y a les squelettes .php3).
2) Dans le code du squelette .html à paginer, remplacer
les anciennes lignes :
par ces nouvelles :
3) Supprimer le code de la fonction "getArticleLinks(.." de votre fichier mes_fonctions.php3. (ce dernier point n’est pas obligatoire, mais inutile de charger du code devenu inutile).
Bonjour ! D’abord, merci de coder des trucs comme ça, vraiment nécéssaires (j’en ai besoin depuis le début !) d’une part, et d’assurer ainsi le support, d’autre part !
Ce que je cherche à faire, c’est d’utiliser ce hack sur ma page de sommaire, où j’affiche la liste de TOUTES les breves de TOUTES les rubriques (genre blog) un peu comme si c’était une rubrique, mais qui contient tout.
De fait, juste en remplaçant ARTICLE par BREVE, le script me trouve le nombre de breves, mais j’ai du mal à comprendre comment je peux lui dire de ne pas s’occuper des rubriques ?
J’espere que je suis clair... ? Ce qui est sur, c’est que je cherche à faire ça depuis longtemps ! Donc, je triche, et j’en suis à quatre & ;quot;fausses& ;quot; pages de sommaire, qui me servent juste à incrémenter la boucle
& ;lt;BOUCLE_breves(BREVES) par dateinverse0,24& ;gt; avec un lien vers la page suivante, qui elle, contient
& ;lt;BOUCLE_breves(BREVES) par dateinverse24,48& ;gt;
Et ainsi de suite, et je n’aime pas devoir dupliquer comme ça du code :/
Bonjour
Tout d’abord merci pour cette contrib très pratique !
Petite question : comment faire pour inverser les chiffres présents après "Pages :" ? En fait actuellement j’ai "Pages : 3 | 2 | 1" où le 3 correspond à mes articles les plus récents, et je voudrais que ceux-ci soient désignés par un 1, ce qui me semble plus logique...
Merci pour vos avis !
oui, ca dépend quelle logique ;-). Ceci dit, ca implique de reprogrammer la partie de article-pagine.inc qui se trouve sous le commentaire php // Milieu. Ce que je n’ai malheureusement pas le temps de faire pour le moment. En y réfléchissant, je me dis qu’il faudrait globalement améliorer et adapter ma contrib au spip actuel. c-a-d,
permettre le choix de la numérotation (commencant à 1 ou à la dernière page)
adapter au système de langues
permettre le choix du dessin des flèches (ou pas)
permettre le choix du nombre de liens affichés vers les pages (actuellement, c 10 par défaut)
l’adapter au page du moteur de recherche (comme l’a fait " erational, le 25 juin 2004 : > Pagination moteur de recherche" v. sur ce forum).
quoi d’autre ?
Ce qui fait tout de même un peu de boulot ;)
Je vais m’y mettre 1 de ces 4, mais ca ne sera sans doute pas, vu mon emploi du temps actuel, avant quelques mois.
Bonjour,
j’ai bien utilisé ce script pour paginer une liste d’articles à l’intérieur d’une page rubrique.
Par contre, je n’ai pas réussi la mise au point sur le résultat d’une recherche, faute de trouver le bon param à utiliser. Le nombre de pages est bien calculé, mais c’est toujours la première qui s’affiche.
Quelqu’un aurait-il réussi ce type de mise en page ?
Si je trouve une solution, je vous le dis, promis..
quelqu’un vient de trouver une solution à cela. Elle est sur le forum de l’article.
Voir le message : erational, le 25 juin 2004 : > Pagination moteur de recherche
merci beaucoup, le script fonctionne tres bien... sauf sur le moteur de recherche car on l’appelle de la facon suivante recherche.php ?recherche=brest et non en recherche.php ?id_recherche=brest
voici ma solution au début du script
// hack pour paginer recherche
if ($type != "recherche") $type2 = "id_$type";
else $type2 = $type;
et ensuite remplacer ds le code id_$type par $type2
¿Il y a des personnes avec pagination dans INCLURE et ça marche ?
J’ai de la pagination dans un squelette inclus et avec le boucle ROUBRIQUES dans les deux squelettes, mais ça ne marche pas : on affiché le premiére page tout le temp n’import quelle page je demande, et si je recalcul une page on affiché cette tout le temp. En breve : on affiché tout le temp le derniére page recalculé.
J’ai cherché la CACHE et il y a une seule fichier ’seccion-76.f80c9e’ avec le premieres 10 articles (ou le derniére page recalcule).
Ainsi, je croi que c’est un probléme avec les INCLURE et la cache. J’ai cherché dans le code de SPIP et il paraît que <INCLURE(seccion.php3) {id_rubrique}> généré un seul fichier a la CACHE pour chaque rubrique ’seccion-76...’ (76 c’est le id_rubrique actuel). Ainsi, il faut générer a la CACHE des fichiers pout chaque rubrique-debut (seccion-76-0..., seccion-76-10...) et pour ça il faut un deuxiéme critére dans le INCLURE avec le debut.
J’ia ne sais pas s’il y a maniére pour faire ça, mais j’ai utilisé un “truc” pour ajouter des variables a l’URL dans le contexte actuel (il y a une spip-contrib a tester avec ça id_article=488)
Dans rubrique.html
<BOUCLE_rubrique(RUBRIQUES) {id_rubrique}>
Ça ajoute la variable 'debut_indice' a l'URL dans le contexte actuel.
La balise #URL_SITE_SPIP ne sert a rien, seulement pour lancer le filtre
$idtype et $type servent à construire les url des liens qui s’affichent, si il y a plusieurs pages de titres d’articles ou de brèves. Par exemple, http://www.monsite.org/rubrique.php3?id_rubrique=n°&debut_article=n°
Pour afficher la liste des brèves avec une sélection sur un mot clé, il faut afficher cela dans un squelette "rubrique" ou "mot". Donc ici, les paramètres seront : $idtype=#ID_RUBRIQUE;$type="rubrique";, s’il s’agit d’un squelette "rubrique", $idtype=#ID_MOT;$type="mot";, s’il s’agit d’un squelette "mot".
NB : Ce script s’applique uniquement aux squelettes qui vont afficher une liste d’articles, ou de breves, .. (un squelette rubrique, mot, auteur qui fait cela), et jamais aux squelettes article ou breve. Donc $idtype=#ID_ARTICLE;$type="article"; ou $idtype=#ID_BREVE;$type="breve"; n’aura jamais de sens.
Dans un squelette rubrique, pour sélectioner sur un mot clé, il faut inclure dans la boucle spip un critère sur le mot clé choisi {titre_mot=xxxx} ou {type_mot=yyyy}. Dans un squelette "mot", ce sera plutôt {id_mot} ou {id_groupe}. Mais tout cela n’est-il pas déjà dans la doc de spip à http://www.spip.net/fr_rubrique143.html ? ;-)
C’est pas très cliar !!! Autant je comprends bien que #IDRUBRIQUE se retorte à une terminologine typiquement spipienne, autant "rubrique" non. Est ce le nom du couple php3/squlette ? Si par exemple je fais une rubrique spéciale metier avec un couple metier.php3/metier.html, le $type = "metier" ?
Désolé, mais je n’arrive absolument pas à faire marcher ce système de pagination :
en SPIP 1.5.2, la page est blanche (développement local) et
en SPIP 1.7, ... j’ai des rubrique vides, ce qui n’est absolument pas le cas.
J’ajouterai que les commentaires et l’aide sont insuffisants.
J’adore SPIP, et j’aimerais pouvoir utiliser des trucs comme ça, mais ... malgré tous mes essais d’une journée, ma compréhension partielle mais suffisante de SPIP et php, rien n’y fait.
Développons SPIP, mais développons vraiment pour tous !!!
Aucun problème pour moi ... d’autant que je suis formateur et tuteur sur des plate formes d’apprentissage à distance, ce serait avec joie. Mais il faut que je comprenne comment ça fonctionne précisément, pour pouvoir localiser toutes les bêtises qu’on peut faire. Ce qui ne marche pas avec.
Tiens, par exemple, je fais une pagination avec des boucle articles : Il y a un tableau autour et dedans et une autre boucle dont surtout une documents absolument nécessaire : est ce que ça perturbe ?
Les incompatibilités avec les différentes versions de SPIP sont à peine listées. Qu’est ce qui perturbe ? J’ai essayé en 1.5.2 et en 1.7, sur un serveur distant et en local ...
Faire un tutoriel vraiment efficace nécessite de faire un véritable plan de test en amon ... et je n’arrive pas à faire le plus petit début de fonctionnement.
Alors voilà, j’aimerais bien aider, mais j’peux point (tzoin tzoin tzoin).
est-ce que tu as essayé la nouvelle version mise en ligne aujourd’hui ? ton problème ressemble à celui décrit dans l’article et qui est fixé depuis (ps : il semble cela dit qu’il s’agisse d’un problème spécifique a easyphp car je ne l’ai pas rencontré lors de mes tests (local sous mac os x et sur mon site)
Suggestions :
As-tu adapté le code de la boucle à l’option choisie ? pour une page mot, il faut bien sur mettre :
$idtype=#ID_MOT; $type = "mot";
(à la place de $idtype=#ID_RUBRIQUE; $type = "rubrique";)
Penser à faire recalculer la page et à vider le cache du navigateur
Je l’avais pas fait (ignorant que je suis !!)...Ceci dit cela ne fonctionne toujours pas. J’ai refait toute la manip depuis le debut...rien n’y fait...toujours la même erreur...
A propos des squelette inclus : Si vous mettez la boucle dans un squelette inclus, il est nécessaire mais apparament pas suffisant d’appeler le squelette inclus avec <INCLURE(mon_squelette.php3){id_rubrique}>. Il faut en plus, ré-imbriquer la boucle dans une boucle rubriques et dans le squelette inclus lui-même. On ne sait pas pourquoi, mais on sait que sinon ca ne marche pas bien. Celui qui trouve va passer pour un fortiche ;-). En bref pour les squelettes inclus, ca donne ceci :
<BOUCLE_rubrique(RUBRIQUES){id_rubrique}>
Le code et la boucle ...
</BOUCLE_rubrique>
et d’ailleurs à tes boucles en général... car à ma connaissance, c l’origine typique d’un problème du type <blink> ... </blink> avec spip
Je ne suis pas dans cette configuration d’inclure. J’ai verifié mes boucles, refait même la manip depuis le depart avec les correction que vous m’avez tous suggérées. Rien n’y fait. En revanche tu fais reference à des blink /blink et en effet, la ligne sur laquelle l’erreur est mentionnée dans la page contient bien ces balises dont je n’ai aucune idée de la signification. En tout cas merci pour votre aide, si une idée vous vient, merci de m’en faire part !!
la mention des codes <blink>...</blink> te signale une erreur dans ton code spip, le problème n’est a priori pas lié à la contrib mais a tes boucles, je te suggére de repartir a zero et d’y aller par étapes simples.
J’ai eu le meme probleme et je suis passe par tout ce qui s’est dit ici. Mais as-tu pense a remplace id_rubrique par id_mot dans la boucle compte_articles. Ca a resolu mes problemes
Cet article a été mis à jour pour tenir compte des remarques et erreurs constatés par certains. C’est pourquoi, comme indiqué ici : « FAQ SPIP-Contrib », les messages des forums ont été supprimés.
Notez, comme l’avait dit François, qu’il existe également une autre solution de pagination : Xpagination
Bonjour à tous,
Comme Dany, j’utilise le script dans mot.php3, et aussi dans rubrique.php3. Dans cette dernière, pas de problème, cela fonctionne très bien. Par contre dans la page "mot" : aucune erreur mais la pagination ne s’affiche pas !!! La page se découpe bien à X articles mais sans pagination ? J’utilise une boucle "articles" avec id_mot.
Avec les variables $idtype = #ID_MOT et $type = "mot"
Si quelqu’un a une idée du problème !!
Merci par avance.
Francois.
c’est pourtant cette version du script sur un squelette mot qui fonctionne ici
Suggestions de vérification :
Vérifier le code spip
et surtout le code php (le code qui est entre <?php ... ?>. Par exemple, le nom des variables du script d’origine ne doit pas être changé ($total, $compteur, etc.). Le nom de la variable php $debut_article doit être le même que le paramètre de la boucle qui affiche les articles {debut_article, XX} (le mieux est de laisser debut_article comme dans le script original). Vérifier également s’il ne manque pas un ; (point-virgule) quelque part, ...