Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

Date de publication
22/01/08
Commentaires
6 commentaires
Tags
,

Je suis tombé il y a quelque temps sur une problématique que je n’avais jamais rencontrée au cours de mes nombreuses expériences avec SPIP, et il s’avère qu’une solution très élégante est possible en n’utilisant que la syntaxe de SPIP, là où il aurait fallu il n’y a pas si longtemps que cela utiliser du code PHP dans le squelette. Suivez le guide...

Imaginez que vous ayez dans votre site de nombreux sites référencés, avec la syndication activée, et des mots clefs thématiques associés à ces sites. Cela peut vous rappeler Sedna, sauf que les mots clefs peuvent être multiples pour un site alors que Sedna utilise des rubriques, forcément uniques pour chaque site.

Imaginez maintenant que vous souhaitiez afficher dans une page les dernières nouveautés de tous les sites ayant un mot clef donné.

La solution simple — qui fonctionne depuis longtemps avec SPIP — est de lister les sites qui ont le mot clef, et de lister pour chacun les derniers articles syndiqués. Le problème de cette solution, c’est que vous devez vérifier chaque site pour savoir s’il y a du nouveau. Le problème est encore plus grave si vous souhaitez utiliser une pagination, puisqu’elle sera nécessairement sur les sites plutôt que sur les articles syndiqués.

Ma problématique du jour était donc de lister tous les articles syndiqués dans leur ordre chronologique, donc sans devoir passer par les sites au préalable, et voici la solution :


<BOUCLE_mot_courant(MOTS){titre=mot_clef}>
  #SET{sites,#ARRAY}
  <B_sites>
  <BOUCLE_sites(SITES){id_mot}>
    [(#SET{sites,[(#GET{sites}|push{#ID_SYNDIC})]})]
  </BOUCLE_sites>
    <B_derniers_liens>
      #ANCRE_PAGINATION
      <dt><span>Actualité du Web</span></dt>
      <dd id="actu-web">
        [(#PAGINATION{accessible})]
        <dl>
          <BOUCLE_derniers_liens(SYNDIC_ARTICLES){id_syndic IN #GET**{sites}}{pagination 5}{par date}{inverse}>
            <dt>#TITRE</dt>
            <dd class="origine">Sur <a href="#URL_ARTICLE">#NOM_SITE</a></dd>
            <dd class="date">[(#DATE|affdate)]</dd>
            [<dd class="auteur"><cite>(#LESAUTEURS)</cite></dd>]
            [<dd><blockquote><p>(#DESCRIPTIF)</p></blockquote></dd>]
          </BOUCLE_derniers_liens>
        </dl>
        [(#PAGINATION{accessible})]
      </dd>
    </B_derniers_liens>
  </B_sites>
  <//B_sites>
</BOUCLE_mot_courant>
 

Ce code fonctionne avec SPIP 1.9.2c [1], mais ne devrait plus être nécessaire avec SPIP 1.9.3, la boucle SYNDIC_ARTICLES acceptant maintenant le paramètre {id_mot_syndic} [2] !

Notes

[1] A condition d’ajouter le filtre « push », dont voici le code :


function push($array, $val) {
        if($array == '' OR !array_push($array, $val)) return '';
        return $array;
}
 

[2] Voir le commit SVN 11019.

RSS

Commentaires

Commenter cet article

  • 28 janvier 2008 17h32, Thomas

    Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

    J’ai bien peur que le filtre push ne soit compatible qu’en 1.9.2 SVN car je n’ai pas l’impression que cela fonctionne en 1.9.2c ou 1.9.2d :( J’ai même essayé array_push en vain...

    Répondre à ce commentaire

    • 30 janvier 2008 09h02, Nicolas Hoizey

      Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

      Je fais marcher ce code sur une 1.9.2c, je t’assure !

      Répondre à ce commentaire

      • 12 février 2008 13h23

        Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

        J’utilise un tableau pour utiliser le critère "IN" dans une boucle et pour ma part il m’indique :

        Erreur : filtre « push » non défini

         :/ J’ai l’impression d’avoir le même problème... je sais qu’il n’y a pas d’erreur de saisie et ma version SPIP est la 1.9.2d sur un serveur local MAMP.

        Répondre à ce commentaire

        • 12 février 2008 13h37, Nicolas Hoizey

          Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

          Je viens de comprendre, le filtre « push » que j’utilise est en fait celui présent dans le plugin « nuage » ! ;-)

          J’ajoute son code à l’article.

          Répondre à ce commentaire

          • 12 février 2008 13h45

            Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

            Merci ! Ça va me sauver la vie ! :)

            Répondre à ce commentaire

          • 12 février 2008 15h52

            Amusons nous avec des boucles SPIP et les petits nouveaux #GET, #SET et #ARRAY

            Un dernier commentaire pour donc indiquer que cela a déverrouillé mon travail sur 2 sites internet... Sur chacun d’eux, le but pour moi était de lister un certain type de rubriques (avec différents médias "texte", "photo", "vidéo" représentés par des articles) dans un tableau, un tableau de type #ARRAY essentiel pour filtrer ces rubriques avec le critère IN et la fonction #GET dans des zones précises d’affichage du site.

            Cela m’évite de devoir affecter un mot clé par article (que l’utilisateur du site aurait dû systématiquement renseigner)... du coup j’utilise astucieusement le #DESCRIPTIF des rubriques pour créer les listes "texte", "photo", "vidéo" à l’aide de boucles RUBRIQUES en faisant du "push" dans des variables #ARRAY... ensuite je récupère la variable désirée pour créer des boucles qui filtrent le type de média voulu.

            Depuis que la fonction "push" a rejoint mon petit fichier "mes_fonctions.php" dans le dossier squelette... tout roule à merveille !

            Un grand merci encore et encore... :)

            PS : je suis bavard, mais c’est pour en aider d’autres comme moi lorsque Google aura mis les pieds ici... ;)

            Répondre à ce commentaire

RSS

Derniers articles

Derniers commentaires