Le règne du sur mesure

Choisir son squelette avec un mot clé.

Comment à l’aide d’un mot clé vous pouvez décider quel squelette vous appliquerez pour tel article ou telle rubrique...

Le problème

En assurant une formation sur spip auprès d’instituteurs du Maine et Loire il m’a été posé un problème pour lequel je n’avais pas de solution :

-  Certaines rubriques qui étaient consacrées aux horaires de l’école devaient être capables de présenter les 2 ou 3 articles qu’elles contenaient sans aucun lire la suite ou lien vers d’autres articles ;

-  De plus grosses rubriques qui contenaient des articles plus volumineux et plus nombreux sur les travaux de leurs élèves ne devaient présenter qu’une introduction de ces articles avec les liens lire la suite classiques.

Le souci était que le choix d’un squelette pour la présentation d’une rubrique était unique et ce qui était adapté pour l’un ne l’était plus pour l’autre...

Utiliser des squelettes spécifiques aux rubriques ne faisaient que repousser le problème à plus tard et demande plus de difficultés pour la maintenance du site.

Il n’y a qu’une seule rubrique.html alors comment faire ?

Le début de la solution

Neoram m’a montré une solution simple à ce problème - loin de moi l’idée de prétendre donc qu’elle est de moi ; cet article se borne à essayer de la présenter de la façon la plus claire possible.

En fonction d’un mot clé associé à une rubrique on appellera tel ou tel squelette.

On va donc créer 3 squelettes

-  Deux squelettes pour les deux présentation spécifiques (horaire ou travaux)
-  Un squelette par défaut si aucun mot clé n’a été choisi

1. sous_rubrique-horaire.html

<BOUCLE_rub(RUBRIQUES){id_rubrique}>
    Liste des horaires de l'etablissement 
    <BOUCLE_art(ARTICLES){id_rubrique}>         
        <h2>#TITRE</h2>
        <h3>#SURTITRE</h3><h3>#SOUS_TITRE</h3>
        <p>#CHAPO</p><p>#TEXTE</p>
    </BOUCLE_art>
</BOUCLE_rub>

Vous voyez il présente de façon complète tous les articles

2. sous_rubrique-travaux.html

<BOUCLE_rub(RUBRIQUES){id_rubrique}>
    <BOUCLE_art(ARTICLES){id_rubrique}>
        Liste des horaires de l'etablissement  
        <h2>#TITRE</h2>
        <h3>#SURTITRE</h3><h3>#SOUS_TITRE</h3>
        <p>#CHAPO</p>
        <a href='#URL_ARTICLE'>Lire la suite</a>
    </BOUCLE_art>
</BOUCLE_rub>

Celui-là ne présente pas l’article au complet mais juste un lien lire la suite avec le chapeau.

3. sous_rubrique-defaut.html
il s’agit du squelette appelé par défaut si aucun mot clé n’est précisé.

<BOUCLE_rub(RUBRIQUES){id_rubrique}>
    <BOUCLE_art(ARTICLES){id_rubrique}>    
        <a href='#URL_ARTICLE'>#TITRE</a>
    </BOUCLE_art>
</BOUCLE_rub>

celui-là est très simple.

Ça se complique un peu, la solution arrive

Voici maintenant le code plus complexe de « sous_rubrique.php3 » que j’expliquerai plus en détail après... Néanmoins faites en une première lecture pour comprendre ultérieurement.

<?php

//on analyse la valeur de la variable $squelette_rubrique
if($squelette_rubrique){
      $squelette_rubrique="-".$squelette_rubrique;
}else{
      $squelette_rubrique="-defaut";
}

//on construit $fond en fonction de $squelette_rubrique
$fond = "sous_rubrique".$squelette_rubrique;
$delais = 24 * 3600;

include ("inc-public.php3");

?>

Maintenant voici le code tant attendu (roulement de tambour !!!!) du squelette rubrique.html

On suppose au préalable :
-  Que vous avez créé un groupe de mot clé que vous appellerez « squelette de rubrique » qui aura pour id 11 par exemple (à adapter à votre site bien entendu).
-  Que dans ce nouveau groupe de mot clé vous avez créé les mots clés
« horaire » et « travaux ».

<BOUCLE_squelette_rubrique(MOTS){id_rubrique}{id_groupe=11}{0,1}>
       <?php $squelette_rubrique='[(#TITRE|texte_script)]'; ?>
 </BOUCLE_squelette_rubrique>
 <INCLURE(sous_rubrique.php3){id_rubrique}>

Et voilà le tour est joué !


Recollons les morceaux :

Etape 1

BOUCLE_squelette_rubrique dans rubrique.html va récupérer le mot clé du groupe 11 c’est-à-dire du groupe « squelette de rubrique » et va l’affecter à la variable $squelette_rubrique (n’oubliez de remplacer le chiffre 11 par le numéro de votre goupe de mot clé).

Etape 2

Cette variable $squelette_rubrique est récupérée par le script « sous_rubrique.php3 » qui va alors construire la valeur de $fond en fonction de ce mot clé (relisez son code) :
-  Si $squelette_rubrique vaut « horaire » alors $fond vaut sous_rubrique-horaire
-  Si $squelette_rubrique vaut « travaux » alors $fond vaut sous_rubrique-travaux
-  Si $squelette_rubrique vaut rien alors $fond vaut sous_rubrique-defaut

Etape 3

inc_public.php3 génère la page grâce la valeur qu’aura prise $fond


Et voilà, en espérant avoir été clair. N’hésitez pas à me faire part de vos remarques pour améliorer la lisibilité de cet article. Bien sûr le principe est généralisable à un grand nombre de mots clés et de squelettes :-) Vous n’êtes limités que par votre imagination !

Discussion

15 discussions

  • katmandou

    Voici ma solution pour choisir le squelette d’un article avec un mot clé, toute simple en spip (pas de php), mais le principe est le même.

    <B_choix_skel>
    <BOUCLE_choix_skel(MOTS){id_groupe=1}{id_article}>
    #SET{skel,#TITRE}
    </BOUCLE_choix_skel>
    </B_choix_skel>
    #SET{skel,« skel_par_defaut »}
    <//B_choix_skel>
    <INCLURE {fond=(#GET{skel})}{id_article}>

    Pour les débutants, il suffit de renommer article.html en skel_par_defaut.html, et de copier ce code dans article.html.
    Pour par exemple utiliser un article avec le squelette mon-squelette.html, il suffit de créer un groupe (numéro 1) de mots clés, et dans cet article de sélectionner le mot clé mon-squelette.

    Répondre à ce message

  • ma solution en SPIP 2

    <BOUCLE_rubrique_principal(RUBRIQUES){id_rubrique}>
    <BOUCLE_hi(HIERARCHIE) {id_rubrique} {tout} {0,1}{type_mot=Squelettes_rubrique} {inverse}>
        [(#REM) la rubrique ou  une rubrique de sa hiérarchie  ( prééminence à la plus proche de ma rubrique ) a un mot clé  dans Squelettes_rubrique ]
    	<BOUCLE_sqhi(MOTS) {id_rubrique} {0,1}{type=Squelettes_rubrique} >
    	 	<INCLURE{fond=rubrique-#TITRE}{id_rubrique=#_rubrique_principal:ID_RUBRIQUE}{self=#SELF}{lang} >
        </BOUCLE_sqhi>
    </BOUCLE_hi>
    </B_hi>
       [(#REM)pas de mot clé dans Squelettes_rubriques]
    	<INCLURE{fond=rubrique-normal}{id_rubrique=#_rubrique_principal:ID_RUBRIQUE}{self=#SELF}{lang} >
    <//B_hi>
    
    </BOUCLE_rubrique_principal>
    <:aucune_rubrique:>
    <//B_rubrique_principal>

    Répondre à ce message

  • 1

    Salut c’est exactement ce dont j’ai besoin pour mon site. mais je n’arrive pas à utiliser ta contrib (je suis un peu nul en info).
    C’est peut etre a cause de id_groupe je n’arrive pas à savoir comment trouver l’identifiant de mon groupe de mot
    Peut tu m’aider

    • Vas dans ta partie admin http://adressedetonsiteweb/ecrire,
      tu cliques sur le lien mots-clés puis tu cliques sur modifier ce groupe de mots-clés et là tu vois dans l’adresse (barre en haut de ton explorateur) l’ID du groupe de mots-cles.

      Paul

    Répondre à ce message

  • 1

    Bonjour et merci pour cette contrib,

    Je suis sous 1.9.2 et j’utilise :

    <BOUCLE_squelette_rubrique(MOTS){id_rubrique}{type=Squelettes}{0,1}>
    	<?php $squelette_rubrique='[(#TITRE|texte_script)]'; ?>
    </BOUCLE_squelette_rubrique>
    <INCLURE(sous_rubrique.php){id_rubrique}>

    pour la page rubrique.html et des pages sous_rubrique-defaut.html et autres sous_rubriques-motcle.html appelées par le(s) mot(s) clè(s) : « motcle »... choisis dans le groupe de mots clès : « Squelettes »

    Tout fonctionne très bien, Je l’ai adapté aux articles : seulement le système d’affichage des documents ne fonctionne pas, car il appelle des paramètres #ID_DOCUMENT et #URL_ARTICLE qui se perd ???

    Des idées ? par avance,merci beaucoup.

    • Désolé, je rajoute le fichier sous_rubrique.php :

      <?php
      
      //on analyse la valeur de la variable $squelette_rubrique
      if($squelette_rubrique){
            $squelette_rubrique="-".$squelette_rubrique;
      }else{
            $squelette_rubrique="-defaut";
      }
      
      //on construit $fond en fonction de $squelette_rubrique
      $fond = "sous_rubrique".$squelette_rubrique;
      $delais = 24 * 3600;
      
      include ("spip.php");
      
      ?>

      /code>

      Pour tout ceux que celà pourrait aider !

    Répondre à ce message

  • 5

    J’utilise cette contrib en 1.8 . Je choisis les squelettes de mes rubriques et articles en fonction des mots clés.
    Cela marche trés biens sauf si on doit passer un parametre ( id d’un document par exemple) comme pour la gallery walma.

    par contre en 1.9 cela ne fonctionne plus du tout. Je ne sais plus ou positionner le choix du squelette qui était dans sous_rubrique.php3 sans conserver ce fichier.
    qui a une idée ?

    <?php
    
    //on analyse la valeur de la variable $squelette_rubrique
    if ($squelette_rubrique)
         {$squelette_rubrique="-".$squelette_rubrique;}
    else
         {$squelette_rubrique="-defaut";}
    
    //on construit $fond en fonction de $squelette_rubrique
    $fond = "sous_rubrique".$squelette_rubrique;
    $delais = 0;
    
    include ("inc-public.php3");
    
    ?>
    • Salut, j’ai aussi été confronté à ce problème pour le passage à la 1.9

      2 solutions en attendant une véritable modification de la contrib :

      -  utiliser le couple php3/html comme dans la 1.8.3 qui fonctionne toujours même si c’est pas le top puisque ce système va être abandonné progressivement

      -  utiliser une modification de la boucle postée par cyril ci-dessus en l’adaptant à une boucle rubrique...
      comme je connais rien au php, je suis passé tout simplement par un succession de boucle, chacune appelant un mot-clé de mes rubriques.

      ça donne ceci :

       <BOUCLE_principale(RUBRIQUES) {id_rubrique}>
      
      <BOUCLE_mot1(MOTS){id_rubrique}{titre=mot1}>
      <INCLURE{fond=sous_rubrique-mot1}{id_rubrique}>
      </BOUCLE_mot1>
      
      <BOUCLE_mot2(MOTS){id_rubrique}{titre=mot2}>
      <INCLURE{fond=sous_rubrique-mot2}{id_rubrique}>
      </BOUCLE_mot2>
      
      <BOUCLE_mot3(MOTS){id_rubrique}{titre=mot3}>
      <INCLURE{fond=sous_rubrique-mot3}{id_rubrique}>
      </BOUCLE_mot3>
      
      <//B_mot1>
      <//B_mot2>
      <//B_pmot3>
      
      </BOUCLE_principale>
      
      <INCLURE{fond=sous_rubrique-defaut}{id_rubrique}>
      
      <//B_principale> 

      Bon et voila, ça a l’air de marcher...

    • cela marche mais ce n’est plus générique

      j’aurai souhaité quelque chose comme

      <B_squelette_rubrique>
        <BOUCLE_squelette_rubrique(MOTS){id_rubrique}{type=Squelettes}{0,1}>
                    [<INCLURE {fond=rubrique-(#TITRE|texte_script)}{id_rubrique}>]
       </BOUCLE_squelette_rubrique>
      </B_squelette_rubrique>
      <INCLURE{fond=rubrique-defaut}{id_rubrique}>
      <//B_squelette_rubrique>

      mais spip n’a pas l’air d’apprécié .. page blanche

    • seb je dois avoir un autre pb car la boucle de cyril me donne aussi une page blanche..
      même si je corrige le pmot3 .

    • Effectivement ya un pb dès que la page n’a pas de mot-clé...
      Essaie cette solution :

      <B_squelette_rubrique>
      
      <BOUCLE_squelette_rubrique(MOTS){id_rubrique}{id_groupe==^1}{0,1}>		
      
      	<BOUCLE_selection_squelette(MOTS){id_rubrique}{titre=#TITRE}>
      	<INCLURE {fond=sous_rubrique-(#TITRE|texte_script)}{id_rubrique}>
      	</BOUCLE_selection_squelette>
      
      </BOUCLE_squelette_rubrique>	
      	
      </B_squelette_rubrique>
      
      	<BOUCLE_squelette_defaut(MOTS){id_groupe !==^1}{0,1}>			
      	<INCLURE{fond=sous_rubrique-defaut}{id_rubrique}>		
      	</BOUCLE_squelette_defaut>
      	
      <//B_squelette_rubrique>	

      Pour que ça marche il faut créer comme dans la contrib initiale un groupe de mot clefs qui contient les mots clefs correspondant aux différents squelette du site. Dans mon cas le groupe de mot cléfs correspond à l’id_group=1 et ensuite il faut dissocier les boucle, une pour quand l’id_groupe=1 (alors on choisit le mot clef qui correspond à notre squelette de sous rubrique) et quand l’id_groupe est différent de 1 auquel cas on prend en compte le squelette de sous_rubrique par défaut.....

      Dis moi si ça marche pour toi STP

    • cela ne marche pas mais le problème n’est pas dans la boucle

      si dans rubrique.html je met simplement
      <INCLURE{fond=sous_rubrique-defaut}{id_rubrique} > donne une page vide

      avec en url http://127.0.0.1/nomsite/spip.php?rubrique76

      si je renomme sous_rubrique-defaut.html en rubrique.html j’ai bien ma rubrique...le pb est-il lié à id_rubrique ?

      par contre dans les articles j’ai INCLURE{fond=entete}{lang}> et ça cela marche

    Répondre à ce message

  • 1

    Je ne sais plus où j’ai trouvé cette contrib...
    Pour changer de squelette d’article par mot clef, créez le fichier article.html (attention de ne pas écraser l’ancien) contenant :

    <BOUCLE_principale(ARTICLES) {id_article}> 
    
    <BOUCLE_agenda(MOTS){id_article}{titre_mot=agenda}> 
    <INCLURE(article-agenda.php3){id_article}> 
    </BOUCLE_agenda> 
    
    <BOUCLE_galerie(MOTS){id_article}{titre_mot=galerie}> 
    <INCLURE(article-galerie.php3){id_article}> 
    </BOUCLE_galerie> 
    
    <INCLURE(article-normal.php3){id_article}> 
    
    <//B_galerie> 
    
    <//B_agenda> 
    
    </BOUCLE_principale> 
    
    <//B_principale>


    puis les fichiers article-normal.html, article-agenda.html, article-galerie.html dans votre dossier squelette avec les fichiers habituels article-*.php3 à la racine du site.
    Le squelette est alors choisi en attribuant un mot-clef (unique) agenda ou galerie du groupe de mots « affichage » par exemple (qui peut ensuite être enlevé de la navigation par mot clef avec le filtre {groupe_mot!='id du groupe de mot affichage'} sur l’article voire la rubrique, l’article ne possédant pas de mot clef aura le squelette article-normal.html.

    Cette boucle n’étant pas de moi ; un lien vers la contrib originale (si vous la connaissez) serait bienvenue dans cet article bien référencé, à la place de ce message.

    Répondre à ce message

  • 2

    Merci pour cette contrib. qui fonctionne parfaitement avec les rubriques.
    Cependant je n’arrive pas à faire la même chose pour les articles, j’ai remplacé partout rubrique par article mais ça ne fonctionne pas. Peux-tu donner un exemple pour les articles.
    Peut-être que mon erreur est dans ce code

    <BOUCLE_squelette_article(MOTS){id_article}{id_groupe=11}{0,1}>
           <?php $squelette_article='[(#TITRE|texte_script)]'; ?>
     </BOUCLE_squelette_article>
     <INCLURE(sous_article.php3){id_article}>

    Par avance merci.

    Paul

    • g le meme problème, ca ne marche pas avec les articles :-/

    • Bonjour.

      Quelqu’un a trouvé la solution pour personnaliser les squelettes pour les articles depuis ?

    Répondre à ce message

  • Il semble qu’il y ait une petit limite en passage de paramêtres.

    En effet, si l’on a differents squelettes utilisant chacun des parametres complémentaire à id_rubrique, il est nécessaire de les passer dans leur ensemble dans le squelette de plus haut niveau.

    Sinon, c’est exellente contrib élégante et très simple à utiliser.

    Répondre à ce message

  • Arachnos

    Je pense qu’il est utile de préciser que les noms sous-rubrique_« X ».html sont modifiables à souhait et peuvent très bien donner rub_« X ».html ; ainsi rub_defaut.html la page par défaut, rub_programme.html pour l’affichage d’un programme de Festival, de théâtre par exemple, comme celui dont je m’occupe en ce moment.

    Idem sur les articles, mais l’article ne demandait pas de précision.

    Répondre à ce message

  • 2

    Très bien tout ca, et bien expliqué, merci !

    Je ne sais pas si vous avez regardé bloog (le site est HS pour le moment pour cause d’attaque ...), mais la solution mise en oeuvre ressemble beaucoup à ca et la structuration proposée me semble bien pensée.

    ca se base sur un groupe de mots nommé squelette, après, si on choisit de mettre toto, c’est le squelette __rubrique-toto.html qui est utilisé.

    • Oui, c’est un peu pénible ces attaques à répétition sur les serveurs qui distribuent du logiciel libre...

      Mais moi ca me fait plutot plaisir, ca montre que c’est pas si mal que ca ce qu’on propose ;o).

    • Ben ouais !

      ça empêche pas de dire que bloog est de retour http://bloog.net/ et que c’est - à mon avis - la meilleur solution (merci Booz)

      ben qu’est-ce que vous attendez ?!... allez vite voir comment ça marche !

      installation

      bonne continuation & @++
      aly

    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