Boucle pour récupérer l’article contenant un document

Une petite boucle utile qui permet de récupérer l’article contenant une image prise au hasard.

<BOUCLE_d(DOCUMENTS_LIENS documents)
          {objet = article}
          {par hasard}{extension==jpg|png|gif}
          {0, 1}>
          [<a href="#URL_ARTICLE{#ID_OBJET}">
(#LOGO_DOCUMENT||inserer_attribut{alt, #TITRE}|inserer_attribut{class, right photo}) </a> ]
</BOUCLE_d> 

La boucle ici recherche dans la table de jointure entre les documents DOCUMENTS_LIENS et les différents objets de spip (article, rubrique, ...) susceptible de contenir un document.

Merci à la liste qui m’a permis de résoudre ce problème.

Discussion

8 discussions

  • 2

    J’ai voulu adapter ce script pour lier un document donné à l’article (au moins un) auquel il est lié. Je n’arrive pas à faire apparaitre le titre de l’article, voici ce que j’ai tenté :

    <BOUCLE_origine(documents_liens documents)
              {objet = article}
              {id_document}
              {0, 1}>
              [<a href="[(#URL_ARTICLE{#ID_OBJET})]">Lire l'article[ (#TITRE{#ID_OBJET})]</a>]
    </BOUCLE_origine>

    Manifestement [ (#TITRE{#ID_OBJET})] ne convient pas…

    • J’ai trouvé finalement, voici la boucle :

      <BOUCLE_origine(documents_liens documents){objet = article}{id_document}{0, 1}>
       <a href="[(#URL_ARTICLE{#ID_OBJET})]">Lire l'article<BOUCLE_queltitre(ARTICLES){id_article=#ID_OBJET}>[ : (#TITRE)]</BOUCLE_queltitre></a>
       </BOUCLE_origine>

      Si ça peut servir…

    • Oui ou plus simplement qu’une boucle utilisez une balise #INFO_ :
      #INFO_TITRE{article, #ID_OBJET}
      voir la doc : https://www.spip.net/5544

    Répondre à ce message

  • 1

    Bonsoir,
    Je viens de passer un site de SPIP 2 À 3 et la boucle suivante n’affiche plus rien :

    <BOUCLE_d(DOCUMENTS documents_liens articles types_documents)
             {objet = article}
             {id_rubrique=35}
             {0, 1}>
    [<a href="#URL_DOCUMENT">
    (#FICHIER
        |image_passe_partout{255,165}
        |image_recadre{255,165,center}
        |image_aplatir{jpg,ffffff}
        |inserer_attribut{class,spip_documents_center})</a>]
    </BOUCLE_d>

    J’ai essayé les différents exemples alternatifs sur cette page sans succès (je ne sais plus trop quelle est la dernière version du coup) mais il semblerait que le code initial ne soit pas valide pour SPIP3.

    Merci
    dd

    • <B_documents>
      <BOUCLE_documents(DOCUMENTS documents_liens){objet = article}{id_document}>
         --> ici les documents
      </BOUCLE_documents>			
      
      </B_documents>
      	RIEN
      <//B_documents>

    Répondre à ce message

  • 1

    Voici la boucle qui a finalement marché sous spip 2.1.5 :

    <BOUCLE_images(documents_liens documents)
    {objet = article}
    {extension IN png,jpg,gif}
    {0, 5}
    {statut=publie}
    >
    <a href="[(#URL_ARTICLE{#ID_OBJET})]" [title="(#TITRE|attribut_html|couper{80})"] class="vignette_photos_menu">                                               [(#LOGO_DOCUMENT||image_reduire{0,104}|inserer_attribut{alt,[(#TITRE|attribut_html|couper{80})]})]
    </a>
    </BOUCLE_images>
    • Voici la boucle qui marche vraiment pour avoir un affichage aléatoire :

      <BOUCLE_images(documents_liens documents){extension IN png,jpg,gif}{par hasard}{0, 5}{statut=publie}>
                                                      <a href="[(#URL_ARTICLE{#ID_OBJET})]" [title="(#TITRE|attribut_html|couper{80})"] class="vignette_photos_menu">
                                                     [(#LOGO_DOCUMENT||image_reduire{0,104}|image_recadre{158,104,'center','999999'}|inserer_attribut{alt,[(#TITRE|attribut_html|couper{80})]})]
                                                  </a>
                                              </BOUCLE_images>

    Répondre à ce message

  • 3
    Itinerrant

    Bonjour,

    J’utilise en effet cette boucle qui fonctionne très bien pour afficher une image au hasard, avec un lien vers l’article qui la contient. En revanche, elle ne semble pas tenir compte du statut (publié, en cours de rédaction, etc.) de l’article en question, ce qui fait qu’on se retrouve parfois avec un lien vers un article non publié, et donc inopérant.

    Quelqu’un aurait-il une idée pour circonvenir ce problème ?

    Merci,

    Itinerrant

    • <BOUCLE_d(DOCUMENTS_LIENS documents articles)
                {objet = article}
                {par hasard}{extension==jpg|png|gif}
                {0, 1}{statut=publie}>
                [<a href="#URL_ARTICLE{#ID_OBJET}">
      (#LOGO_DOCUMENT||inserer_attribut{alt, #TITRE}|inserer_attribut{class, right photo}) </a> ]
      </BOUCLE_d>

      pas sûr que ca marche en 2.0 mais ca marche en 2.1

      si ca marche pas en 2.0, testez ceci :

      <BOUCLE_d(DOCUMENTS_LIENS documents articles)
                {objet = article}
                {par hasard}{extension==jpg|png|gif}
                {0, 1}{articles.statut=publie}>
                [<a href="#URL_ARTICLE{#ID_OBJET}">
      (#LOGO_DOCUMENT||inserer_attribut{alt, #TITRE}|inserer_attribut{class, right photo}) </a> ]
      </BOUCLE_d>
    • Itinerrant

      Bonjour,

      La seconde solution a l’air de fonctionner en 2.0, merci beaucoup !

      Itinerrant

    Répondre à ce message

  • 1

    Bonjour,

    Cette boucle (très utile) ne fonctionne plus avec Spip 2.1.
    Quelqu’un saurait il comment la rendre compatible ?

    Merci :o)

    • remplacez DOCUMENTS_LIENS par spip_DOCUMENTS_LIENS

      ou bien (l’un ou l’autre)

      dans mes_options.php

      global $table_des_tables;
      $table_des_tables['documents_liens']='documents_liens';

    Répondre à ce message

  • 1

    Merci de ta réponse... claire mais qui ne m’éclaire pas tant que ça. J’avais bien compris la requète. C’est l’écriture #URL_ARTICLE{#ID_OBJET} qui m’épatait !

    Je me demandais comment elle fonctionnait. #URL_ARTICLE est une balise dynamique qui reconstitue d’une manière un peu magique à mes yeux l’url d’un article et on peut un peu s’attendre à une écriture du genre #URL_ARTICLE{#ID_ARTICLE}. Là, la présence de #ID_OBJETc’est un peu inattendu et je souhaitais savoir si c’était documenté quelque part... Peut-être faut-il tout simplement penser que #ID_OBJET est tout simplement un objet plus général englobant tous les objets (articles, rubriques, documents...) de SPIP ?

    • non non.
      rien de magique ici.

      dans la table de liaison spip_documents_liens, id_objet est l’id de l’objet (article, rubrique, mot, site...) pour lequel il existe un lien avec le document d’id id_document.

      +-------------+----------+----------+-----+
      ! id_document ! id_objet !    objet !  vu !
      +-------------+----------+----------+-----+
      !          14 !       36 !  article ! oui !
      !         363 !       66 ! rubrique ! non !
      !         ... !      ... !      ... ! ... !

      ici, le document d’id 14 est inclu (« vu = oui ») dans l’article (objet = article) dont l’url est #URL_ARTICLE{36} (id_article étant construit à partir de « id_objet = 36 »)

      voir une explication peut-être plus complète dans ce thread de la liste spip.user http://thread.gmane.org/gmane.comp....

    Répondre à ce message

  • La table DOCUMENTS_LIENS a la structure suivante

    Field Type Null Key Default Extra
    id_document bigint(21) NO PRI 0
    id_objet bigint(21) NO PRI 0
    objet varchar(25) NO PRI NULL
    vu enum(’non’,’oui’) NO non

    Dans la boucle, on cherche le document pris {par hasard} ,à condition que ce soit une image {extension==jpg|png|gif} et que l’objet (c’est à dire ici le contenant de l’image) soit un article {objet = article}
    . La boucle retourne alors l’id_objet de l’objet article.

    J’espère que c’est clair !!!_

    SPIP reconstruit ensuite l’url à partir de la balise #URL_ARTICLE.

    Répondre à ce message

  • Une petite explication de texte pour l’écriture pour aider à comprendre comment « marche » cette écriture... ?
    #URL_ARTICLE{#ID_OBJET}
    C’est documenté qqpart ?
    Merci d’avance

    Répondre à ce message

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

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

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom