SPIP-Contrib

SPIP-Contrib

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

273 Plugins, 191 contribs sur SPIP-Zone, 34 visiteurs en ce moment

Accueil du site > Dates, calendriers et agendas > Tris par date > Usage du filtre « unique » pour classer des articles

Usage du filtre « unique » pour classer des articles

2 juin 2005 – par cogefip, mortimer – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

2 votes

Objectif : Classer les articles d’une rubrique par date, chaque année étant dans un cadre

La boucle citée en exemple dans la doc du filtre unique produit une longue liste d’articles difficile à cadrer s’il y a beaucoup d’articles

Voici la boucle proposée

Vu ainsi la boucle n’est pas évidente à comprendre. Voici le cheminement de sa construction

-  Afficher une liste d’article avec l’année en titre (assez semblable à l’exemple de la doc)

-  Mettre chaque année dans un cadre (étape 1)

L’encart ouvert dans la partie optionnelle avant de la date provoque une erreur de parité des balises. Il faut fermer ce div avant une nouvelle année et en fin de boucle

-  Mettre chaque année dans un cadre (étape 2)

La balise fermante introduite avant la date n’a pas de balise ouvrante au premier passage dans la boucle. Il faut l’ouvrir dans la partie optionnelle avant de la boucle. Cela va créer un groupe de balise vide avec une class="muette" qui interdit l’affichage par le butineur.

-  Mettre chaque année dans un cadre (étape 3)

En itérant ainsi pour chaque phase on obtient la boucle proposée.

PNG - 11.9 ko
Articles listés par date
Utilisation du filtre UNIQUE pour classer les articles par date

Voici le code généré (nettoyé et indenté) pour la visualisation proposée ci dessus et visible sur le site d’étude castorsmag

Pour information les styles utilisés

Aller plus loin

Eviter les blocs vides

Dans la version actuel de la boucle archive, on se retrouve avec des blocs de balises qui ne servent pas : <div class="muette"><ul class="muette"><li class="muette"><ul class="muette"></ul></li></ul></div>

Dans un navigateur qui supporte les css, ce n’est pas un problème. Mais quand on veut être accessible ou lisible par des navigateurs en mode texte, c’est moins sympathique.

Voici donc une version de la boucle qui évite cela :

La boucle commence par 2 tests pour fermer les balises du mois :

  1. le premier vérifie qu’on n’est pas au début de la boucle, puisqu’il n’y a pas besoin de fermer les balises dans ce cas là,
  2. le deuxième si l’on est au début de la boucle, fait croire que l’on a bien fermé les balises, mais n’affiche rien en fait.

Ensuite, la boucle est à peut prêt similaire, on ouvre les div et ul pour l’année et le mois si nécessaire grâce au filtre |unique et on affiche toujours le titre de l’article.

Dans le code optionnel après la boucle on ferme une fois toutes les balises des blocs puisqu’on est sûr d’avoir affiché au moins un article, donc au moins une année et un mois.

Une autre écriture de la boucle est possible en faisant un test sur le compteur de la boucle.

Avant d’afficher l’année si nécessaire, on passe par un test pour savoir si on n’est pas dans le premier passage [(#COMPTEUR_BOUCLE|>{1}|?{'</ul></li></ul></div>',''})] on ferme alors le mois et l’année qui précedent.

Avant d’afficher le mois si nécessaire, on teste si on vient d’ouvrir une nouvelle année [(#DATE|annee|unique{nouvelle}|?{'','</ul></li>'})] sinon on ferme le mois précédent

Les archives d’un certain mois, d’une certaine année

Le critère de la boucle _archive présenté affiche les archives pour une certaine rubrique. On pourrait vouloir plutôt afficher des archives pour certaines dates.

On peut pour cela, ajouter un critère {date == ^[(#ENV{mois,.})]}. Celui ci va limiter l’affichage aux articles ayant des dates suivants une certaine expression régulière passé dans l’url.

Ainsi, si on met :
-   ?mois=2005-04-22 alors on n’aura que les articles du 22 Avril 2005,
-   ?mois=2005-04 donnera tous les articles d’Avril 2005,
-   ?mois=2005 donnera tous les articles de 2005,
-   ?mois=200 donnera tous les articles des années 2000 (2001, 2002, ...),
-   ?mois=.*-12- donnera tous les articles de tous les mois de Décembre,
-  etc...

Pour simplifier ce genre d’écriture, on peut ajouter un filtre dans mes_fonctions :

Ce filtre va ajouter la variable mois de la date sur laquelle on l’applique dans l’url de la page actuelle et retourner cette url. On peut alors écrire la boucle :

Pour avoir des liens sur les noms de mois et d’année qui retourneront une liste d’article pour ce mois ou cette année.

P.-S.

Cette boucle remplace très avantageusement une boucle récursive qui faisait le même travail sous la version 1.7.2 Voir les articles Calendrier des articles et Une liste d’articles triés par mois

Retour en haut de la page

Vos commentaires

  • Le 22 mai 2006 à 10:54, par alias85 En réponse à : Usage du filtre ’unique’ pour classer des articles

    Cette contrib me parait très utile pur le site que j’ai à réaliser mais comme je débute, je ne comprends où les différents codes doivent être insérés. Serait-il possible de me l’indiquer ?
    Merci

    Répondre à ce message

  • Le 2 mai 2006 à 03:28, par Corentin En réponse à : Usage du filtre ’unique’ pour classer des articles

    Très bonne contrib... Merci beaucoup.

    J’ai cependant fait quelques modifs :
    -  Ajout de l’image (miniature) de la Rubrique de l’Article.
    -  Ajout de la date et de l’auteur devant chaque Titre d’article.
    -  Changement de la taille des Mois.
    -  Exclusion des Articles comportant l’attribut (mot clé) « exclu_actualites ».

    Voici ce que donne mon code :

    <B_archive>
     <div>
     <div class="muette"><ul class="muette"><li class="muette"><ul class="muette">
       <BOUCLE_archive(ARTICLES) {par date} {inverse} {titre_mot!=exclu_actualites}>
         [</ul></li></ul></div><div class="encart archives"><p class="titre">(#DATE|annee|unique)</p><ul><li><ul>]
           [</ul></li><li><font size="1"><b>(#DATE|affdate{'Y-m'}|unique|nom_mois)</b></font><ul>]
             <li>[(#LOGO_RUBRIQUE|left||reduire_image{8})][(#DATE|jour)]/[(#DATE|mois)] - Par <BOUCLE_AUTEUR1(AUTEURS){id_article}{", "}{par nom}>#NOM</BOUCLE_AUTEUR1> - <a href="#URL_ARTICLE" title="commentaire">#TITRE</a></li>
       <br>
            </BOUCLE_archive>
         </ul></li></ul></div>
      </div>  
    </B_archive>

    Répondre à ce message

  • Le 10 août 2005 à 00:15, par @lexandre En réponse à : > Usage du filtre ’unique’ pour classer des articles

    Bonjour.

    Merci pour cet article tout simplement génial. Bravo pour la clareté de tes explications.
    Testé sur instits.fr.

    Répondre à ce message

Répondre à cet article

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

  • Transaction : créer des formulaires avec paiement en ligne

    13 mars 2011 – 32 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Transaction est une extension du plugin de création de formulaires Formidable pour concevoir des formulaires de paiement en ligne et les connecter aux principales API bancaires françaises. Présentation Transaction introduit 3 nouveaux types de (...)

  • Formulaire de contact avancé

    23 mars 2009 – 1041 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Un formulaire de contact configurable, avec de multiples options.

  • Squelette Multi-Saisons

    19 février 2009 – 226 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Un squelette qui change de couleurs suivant les saisons, un graphisme tout en rondeurs et de très nombreuses options.

  • JQuery Masonry

    15 août 2011 – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Ce plugin est un portage pour Spip du plugin jQuery Masonry de David DeSandro : http://masonry.desandro.com/ Principe Ce plugin réorganise les blocs de votre page page d’après une grille (de manière verticale et horizontale) pour réduire au maximum (...)

  • Thélia

    26 juin 2007 – 835 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Une approche basée sur l’utilisation conjointe des deux logiciels SPIP et Thélia pour la réalisation de sites de publication et de vente en ligne