Groupes de mots clés arborescents

Ce plugin permet de gérer une arborescence de groupes de mots clés. Les sous groupes de mots héritent des propriétés du groupe racine (sur quoi peut on le lier ? peut il y avoir un ou plusieurs mots). Les formulaires de liens qui permettent de lier les mots à des éléments montrent toute l’arborescence du groupe racine pour choisir le mot.

Démonstration vidéo

Pour les gens pressés voici une capture vidéo du fonctionnement du plugin :

Fonctionnement

Ce plugin permet donc une gestion arborescente des groupes de mots clés.
Les formulaires de liens, comme le montrent la capture, affichent les groupes racine et permet de sélectionner un mot dans l’ensemble de leur arborescence :

Sélecteurs de mots
3 groupes avec des utilisations techniques différentes :
  • Le premier sans rien de particulier et peu de mots
  • Le second ne peut sélectionner qu’un mot dans toute la hiérarchie
  • Le 3e est un groupe « important » qui a beaucoup de mots : il faut lancer une recherche pour obtenir une liste de résultats, qui indiquent les sous groupes éventuels des réponses

Modifications des tables SQL

Il ajoute dans les tables des groupes de mots les colonnes suivantes :

  • id_parent (indiquant l’identifiant du groupe parent, sinon 0)
  • id_groupe_racine (indiquant l’identifiant du groupe racine).

Il ajoute dans les tables des mots la colonne suivante :

  • id_groupe_racine (indiquant également l’identifiant du groupe racine).

Boucles et critères sur les groupes

L’ajout des colonnes précédemment citées permettent de gérer des critères id_parent et racine sur les groupes et les mots.

Ainsi, on peut sélectionner le groupe parent ou le groupe racine

<BOUCLE_gr(GROUPES_MOTS){id_groupe}>
   Sélectionne un groupe quelconque
   <BOUCLE_parent(GROUPES_MOTS){id_parent}>
      Sélectionne le parent du groupe précédent
  </BOUCLE_parent>
   <BOUCLE_racine(GROUPES_MOTS){id_groupe_racine}>
      Sélectionne la racine du groupe précédent
   </BOUCLE_racine>
</BOUCLE_gr>

On peut sélectionner tous les groupes racine :

<BOUCLE_racine(GROUPES_MOTS){racine}>
   Sélectionne tous les groupes racine, c'est a dire de plus haut niveau
</BOUCLE_racine>

Et donc faire des hiérarchies : lister hiérarchiquement tous les groupes :

<B_racine>
<ul>
	<BOUCLE_racine(GROUPES_MOTS){racine}>
	<li>#TITRE
		<B_sous_groupes>
		<ul>
			<BOUCLE_sous_groupes(GROUPES_MOTS){id_parent}>
			<li>#TITRE
				<BOUCLE_groupes_recursifs(BOUCLE_sous_groupes) />
			</li>
			</BOUCLE_sous_groupes>
		</ul>
		</B_sous_groupes>
	</li>
	</BOUCLE_racine>
</ul>
</B_racine>

Enfin, on peut obtenir tous les groupes appartenant à une branche donnée :

<BOUCLE_branche(GROUPES_MOTS){branche_groupe}>
	Sélectionne tous les groupes de l'id_groupe en cours.
</BOUCLE_branche>

Boucles et critères sur les mots

Sélectionne les mots d’une branche

<BOUCLE_mots(MOTS){branche_groupe}>
    Sélectionne les mots dans toute la branche !
</BOUCLE_mots>

Sélectionner les mots du groupe parent

<BOUCLE_gr(GROUPES_MOTS){id_groupe}>
    Le groupe en cours...
 
    <BOUCLE_mots(MOTS){id_groupe}>
        Les mots du groupe
    </BOUCLE_mots>
 
    <BOUCLE_mots_parent(MOTS){id_groupe=#ID_PARENT}>
        Les mots du groupe parent à notre groupe
    </BOUCLE_mots_parent>
 
    <BOUCLE_mots_racine(MOTS){id_groupe=#ID_GROUPE_RACINE}>
        Les mots du groupe racine de notre groupe
    </BOUCLE_mots_racines>
</BOUCLE_gr>

Discussion

18 discussions

  • 1

    Hello !

    J’ai un bug étrange ici en interne sur un SPIP 3.2.1 SVN [24144] (version plugin 1.2.10)

    Dès que je modifie à postériori un sous-groupe de mots, il perd son groupe parent et repasse systématiquement en groupe de 1er niveau. cf captures.

    autre chose : je ne sais pas si c’est normal mais seul les groupes de 1er niveau sont configurables (association aux objets / groupe recommandé / mot-clé choix unique ...). Et c’est pas super pratique

    une idée ? une piste ?
    Merci d’avance :)

    • je me répond à moi même, au moins sur la 2e partie : Groupes de mots clés arborescents a Query Path en dépendance, or ...

      marcimat
      ....Dans le plugin Groupes de mots arborescents, j’utilise ce plugin pour ajouter du code HTML sous le formulaire d’édition d’un groupe après le titre, et pour enlever une partie du HTML également lorsque nous sommes dans un groupe enfant d’un autre. ...

      ..../...
       // les paramètres techniques sont uniquement sur les groupes racine
                      if ($env['id_parent']) {
                              $qp->top('body')->find('li.fieldset_config')->remove();
                      }
       
      .../....

      Tant pis ...

    Répondre à ce message

  • 1

    Est-ce que c’est possible de faire fonctionner ce plugin avec le plugin mots partout et ainsi pouvoir classer les mots-clés qu’on ajoute en espace public ?

    • 15 métros après la bataille ! Mais mieux vaut tard ... comme on dit ...

      Perso, j’utilise et fait parfaitement cohabiter les 2 plugins, aussi bien en environement SPIP autonome que mutualisé. Et jusqu’ici... « It works ! »... comme dirait l’autre ^^

    Répondre à ce message

  • Bonjour,

    Juste un petit mot pour préciser qu’il serait utile d’indiquer dans la documentation de la boucle MOTS que la balise #URL_GROUPE_MOT fonctionne et renvoie l’adresse du groupe en partie publique.

    Bonne journée ! ;-)

    Répondre à ce message

  • Bonjour !

    Déjà merci pour ce plugin qui m’aide beaucoup à organiser les mots-clés mais j’aimerai savoir pourquoi il était impossible d’attacher une restriction à des sous-rubrique ?

    Ma hiérarchie de rubrique fait par exemple : Histoire > Antiquité > Rome antique

    Dans la sous-sous-rubrique Rome antique, les article peuvent avoir plusieurs mots-clés (empereurs, économie, république, etc) et j’aimerai que ces mots-clés ne soient disponibles que pour les articles de la rubique Rome Antique sauf que c’est impossible puisque seule la rubrique Histoire pourra avoir une restriction

    Il y a t-il un moyen de modifier ça ?

    Merci et très bonne continuation

    Répondre à ce message

  • 1
    Julien

    Est-il possible de le rendre compatible avec le plugin Coche-Mots ?

    Quand on a beaucoup de mots clés a sélectionner, c’est frustrant de devoir se passer de ce plugin.

    Merci.

    • Normalement, la version 1.1.0 du plugin Coche Mots devraient être compatible avec les mots clés arborescents.

    Répondre à ce message

  • Coucou,

    Juste pour dire que j’ai trouvé dans les squelettes de l’espace privé la boucle :

    <BOUCLE_hier(HIERARCHIE_GROUPES_MOTS){tous}{" > "}>
    #TITRE
    </BOUCLE_hier>

    qui n’est pas documentée ici mais pourtant très utile.

    Si je ne me trompe, elle ne fonctionne que dans une <BOUCLE(MOTS)>

    Répondre à ce message

  • Bonjour,

    Je souhaiterai pouvoir définir un squelette spécifique aux mots clés d’un groupe « parent » mais n’y parviens pas :/

    Voici la structure :
    GROUPE (id 25)
    %%SOUS GROUPE 1 (id 26)
    %%%%MOT
    %%%%MOT
    %%SOUS GROUPE 2 (id 27)
    %%%%MOT
    %%%%MOT

    L’idée est donc d’avoir un squelette pour tous les mots du groupe parent « GROUPE ».

    J’utilise les « squelettes » mot.html et groupe.html tels que proposés ici : http://contrib.spip.net/Squelettes-pour-groupes-et-par-groupes-de-mots

    Mais si un squelette mots-26.html fonctionne bien, impossible d’utiliser un mots-25.html (qui n’a donc pas de mots clés directement dans son groupe).

    Dans le fichier mot.html, j’ai bien essayé de remplacer #ID_GROUPE par #ID_PARENT mais sans succès (je n’avais pas grand espoir...).

    Est-ce possible ? Si oui, comment faire ?

    Merci :)

    Répondre à ce message

  • 1

    Petite coquille
    Bonjour Matthieu : il y a une petite coquille dans le code de la boucle « racine » (§ faire des hiérarchies) : la boucle n’est pas correctement fermée (<B_racine> au lieu de </B_racine> attendu)
    Bien le bonjour de Bretagne !

    Répondre à ce message

  • 1

    bonjour
    quand je veux créer un nouveau groupe, j’obtiens l’erreur

    Parse error: syntax error, unexpected T_FUNCTION, expecting ')' in /home/amidesk/www/foristo/plugins/auto/querypath/v1.1.0/lib/querypath-3.0.0/src/qp.php on line 61

    et quand je fais retour

    Warning: array_shift() [function.array-shift]: The argument should be an array in /home/amidesk/www/foristo/ecrire/inc/filtres_ecrire.php on line 503

    Une idée ?

    SPIP 3.0.16 zspip tincredible

    merci

    Répondre à ce message

  • 2

    Bonjour,

    Après avoir installé le plug-in, je ne peux plus utiliser « Modifier ce groupe de mots » ou « Ajouter groupe de mots ».

    Il semble que l’erreur soit dans QueryPath : Parse error : syntax error, unexpected T_FUNCTION, expecting ’)’ in /homepages/0/d160156354/htdocs/plugins/auto/querypath/v1.1.1/lib/querypath-3.0.3/src/qp.php on line 61

    Je regrette vraiment, car ce plug-in me serait très très utile.

    Merci pour toute réponse ! :)

    • Il n’y a pas d’erreur dans le code de la librairie pourtant. Plus précisément, la librairie utilise une écriture de fonction qui nécessite PHP 5.3 pour fonctionner. Je suppose que votre version de PHP est moins récente ?

    • Merci infiniment de votre réponse rapide.
      J’ai upgradé ma version de PHP à 5.5 et ça fonctionne maintenant parfaitement.

    Répondre à ce message

Ajouter un commentaire

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

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

Dernière modification de cette page le 22 octobre 2017