Carnet Wiki

Ma-Premiere-Application-SPIP-3

Version 12 — Mars 2012 YannX

Pour ré-organiser le fonctionnement de son etablissement, ma moman doit refaire et distribuer des fiches « métier », pour l’ensemble des intervenants.

Commençant à réfléchir au problème, nous l’avons très vite modélisé, puis maquetté, et un prototype opérationnel était disponible en moins de trois heures...

Cette expérience nous a tellement surpris, qu’il m’a paru interessant de vous faire découvrir un autre usage de SPIP, d’autant qu’il met en oeuvre plusieurs facilités méconnues de spip

Mots -clés : secteurs et variantes, articles virtuels, mots-clés et groupes pièces jointes, boucles et récursivité, ré-emploi de noisettes, paramètres par défaut, critères optionnels, surcharge de formulaires, mots sur mots...

Analyse de la structuration des données

Commençons par analyser le contenu à gérer [1] : la fiche Metier se compose par sélection de plusieurs Taches et Activités, une Activité étant définie comme regroupant plusieurs Activités ou Taches élémentaires.
Il s’agit donc de descriptions textuelles libres (articles rubriques),qui seront communes au cadre d’emplois de l’etablissement, valables pour toutes les fiches qui seront définies ou modifiées ulterieurement.

Mais ces fiches font aussi appel à des Savoirs, savoir-etre ou savoir-faire, à choisir dans des listes de mots-expressions : dans chacun de ces deux groupes de mots, qui recouvrent des notions différentes, il peut y en avoir jusqu’à une cinquantaine ; on pense immédiatement à gérer ces éléments avec la gestion avancée des groupes de mots-clés, souvent oubliés dans SPIP.

Enfin, on voudrait définir les fiches articles Métiers qui nous intéressent au final, en leur adjoignant l’utilisation de plusieurs activités et taches : de la même façon qu’un mot-clé établit un lien de la fiche avec un savoir, le lien d’une fiche avec ses activités (et taches associées), sera marqué par un mot-clé portant sur les rubriques (et/ou articles) : ceci demande simplement de créer un mot-clé marqueur associé à chaque métier [2], que nous devrons ensuite associer à chaque enregistrement à adjoindre à la fiche Metier.

Saisir des structures de données

Précisons que l’ensemble des manipulations ci-après a été réalisé par l’interface privée du nouveau SPIP3 sans aucune modification...
Les premières pages écrites sur le nouveau site [3] n’étaient que des articles traditionnels, mis dans une première rubrique, nommée Documentation, prévue pour faciliter la réflexion collaborative : ce n’est qu’après que nous sommes passés à la modélisation d’un prototype opérationnel.

-  Activités
La gestion des Activités va s’élaborer dans un Secteur dédié : créons à la racine du site (le libellé correspondant n’apparait plus ?) une nouvelle rubrique, à l’interieur de laquelle sont immédiatement générées trois activités (leurs TITREs sont écrits en Majsucule, de façon à mieux voir ce qui se passe, tant au niveau des données [4]que pour distinguer des détails pour l’utilisatrice.

Partant du principe que les Taches sont élémentaires, et qu’elle peuvent donner lieu à des détails de procédure, et d’outillage, assez complexe, nous créerons des Articles pour chaque tache identifiée : ceux-ci sont mis (et publiés immédiatement) dans chacune des trois activités saisies plus haut.

Comme une activité semble trop complexe, on la décompose en sous-activités, et d’ailleurs récursivement car même cette démarche connexe est à structurer en plusieurs activités de domaines différents ; à cette occasion, apparait la nécessite de ré-organiser les activités, par domaine d’abord, par catégorie-métier ensuite.
Après création de nouvelles têtes de chapitre dans le Secteur des Activités, l’interface privée permet facilement de modifier la rubrique de rattachement pour la descendre sous la tête de chapitre correspondante.

-  Plan du Site
Regardons un peu ce qui a été saisi : c’est l’affichage traditionnel du Plan du site, et c’est l’occasion pour ma moman de découvrir la puissance des boucles récursives dans SPIP...
Avec toute notre catégorisation des activités et sous-activités, par activités types dans le secteur, visualiser les TITREs et ID de nos activités, sous-activités, sous-sous.....sous-sous-activités, avec les taches qui y sont détaillées à tout niveau serait bien agréable : nous avons expurgé quelques enrichissements de style CSS, de la traditionnelle boucle [5] plan (limité au secteur n°7 des Activités) ci-dessous, avec un paramètre par défaut, qui permettra ultérieurement de limiter l’édition à un seul domaine d’activité partiel.

<BOUCLE_depart(RUBRIQUES){id_parent = #ENV{id_rubrique,7}}>
<h2>#ID_RUBRIQUE. #TITRE  (#ID_SECTEUR)</h2> 
<BOUCLE_rubriques(RUBRIQUES){id_parent}{tout}> 
	<li><strong><a href="#URL_RUBRIQUE"  [ title="(#DESCRIPTIF|supprimer_tags|attribut_html)"] >#TITRE*</a>
		</strong> [#ID_RUBRIQUE]  :


<B_articles>
	   <ul>
	<BOUCLE_articles(ARTICLES) {id_rubrique} {tout}>
			<li><a href="#URL_ARTICLE"  
                               [title="(#DESCRIPTIF|supprimer_tags|attribut_html)"] > 
                               #TITRE*</a> (#ID_ARTICLE) 
			</li>
	</BOUCLE_articles>
		</ul>
	</B_articles>


<BOUCLE_sous_rubriques(BOUCLE_rubriques)></BOUCLE_sous_rubriques> 
       [(#REM)     ######################################################]


</li>
       </BOUCLE_rubriques>
	</ul>
	</B_rubriques>


</BOUCLE_depart>


Nota Bene : Le [parcours->http://www . parcours récursif souligné ci-dessus vous plait-il  ? developpez.net/forums/d1127404/bases-donnees/langage-sql/hierarchie-recursivite-table-mysql/] [récursif->http://sqlpro.developpez.com/cours/arborescence/]automatisé ci-dessus vous plait-il ?

Tiens, l’une des taches doit etre effectuée à l’identique dans deux activités qui n’ont rien à voir : acceptons les articles virtuels dans la configuration, et il suffit lors de la création dez l’article-tache dans la seconde Activité, d’indiquer le numéro du premier article dans le CHAPO, et le tour est joué.
Peut-etre que « polyHierarchie » dont on me disait du bien lundi, apporterait une autre solution, mais c’est de ce Dimanche que SPIP3 [6] accepte la mise-en-place automatique de quelques plugins immédiatement indispensables [7]... (voir ci-dessous).

La Gestion des Mots-clés

Pour définir les mots-clés, et permettre de les regrouper par thèmes, il faut aller dans l’espace privéà la Configuration de Spip, plus précisement le « Contenu du Site », et descendre jusqu’au pavé « Mots-clés », pour les activer ; nous en profiterons pour activer aussi la Gestion des Documents joints (juste en dessous).

Nous créons ensuite trois groupes de mots-clés, SAVOIR-etre et SAVOIR-faire, et le troisième pour enregistrer des SAVOIR-professionnels, que nous complétons avec une dizaine de mots ou de phrases chacun.

-  Visualisation des codes
Le problème de tous ces mots-clés et de leurs groupes, c’est qu’il faut se souvenir des numéros d’#ID_ affectés à la création, pour pouvoir afficher les mots affectés dans le groupe SAVOIR-faire [8].
Vite fait, une page -très classique- va nous afficher tous les mots-clés definis, rangés par groupes de mots, avec leur intitulé #TITRE, et le code d’identification associé : foin de la présentation, un simple ?page=mots et le tour est joué, par le fichier ci-dessous placé en ./squelette/mots.html

[(#REM) MOTS = tous les mots-clés  (limités à un groupe si spécifié) ]
[(#REM)<h1>Tous les mots-clés </h1><a href="#URL_PAGE{groupes_mots}"></a>]
<BOUCLE_groupes(GROUPES_MOTS){par titre}{id_groupe?}>
    <h2> [  #ID_GROUPE ] <a href="#URL_PAGE{mots,id_groupe}">[(#TITRE)]</a> [: (#TEXTE)]</h2>
      <BOUCLE_mots(MOTS)'{id_groupe}>
         #ID_MOT <a href="#URL_MOT">[(#TITRE)]</a>
      </BOUCLE_mots>
</BOUCLE_groupes>

Utilisation des données

Les Métiers vont être définis comme articles dans un autre secteur (N°27), organisés selon une arborescence de filières par autant de sous-rubriques : pour afficher chaque Metier, on préparera une variante du squelette article [9].
Pour établir le lien avec les savoirs ou les activités, on définira un mot-clé marqueur de l’article, donc il serait raisonnable d’ouvrir un groupe spécialisé correspondant (ce sera le groupe $id_groupe=9 voir ci-après), associé aux Articles metiers.
Nous aurions pu avoir une autre structuration, -uniquement en mots-clés- qui sera évoquée en fin d’article.

Pour créer une fiche métier, créons un article, et créons immédiatement le mot-clé marqueur correspondant, que nous lui associons aussitot : reste à lier les savoirs, les activités et taches choisies : cela veut dire aller « marquer » chaque Activité [10], Tache [11]ou Savoir [12]avec ce marqueur.

Il faut reconnaitre que l’interface privée de SPIP n’est pas tres ergonomique de ce point de vue, mais déjà parfaitement opérationnelle [13].
-  Donc, dans l’interface privée, prenons dans l’ordre les activités voulues, et rajoutons-leur le mot-clé marqueur du groupe Métier.
-  Nous pourrions marquer de meme tous les articles voulus dans les Activités correspondantes, mais en fait nous allons faire une première hypothèse simplificatrice : toutes les taches dépendant d’une activité selectionnée sont supposées sélectionnées.

Comment afficher les Activités correspondantes : ce sont toutes les rubriques, toujours dans notre secteur 7 qui ’portent’ le mot-clé marqueur spécifique : affichons-les

[(#REM) Mot = Noisette d'affichage d'usage d'un mot-clé ]
<h2>Usage du Mot clé </h2><a href="#URL_PAGE{groupes_mots}"></a>
<BOUCLE_rub(RUBRIQUES){id_mot}{id_secteur=7}>
         #ID_RUBRIQUE <a href="#RUBRIQUE">[(#TITRE)]</a><br />
         <BOUCLE_art(ARTICLES){id_rubrique}>
           <h4>#TITRE </h4>
            #TEXTE
           </BOUCLE_art>
</BOUCLE_rub>

Un appel du type ?page=mot&id_mot= doit faciliter l’appel partiel (à valider) : en fait, il nous suffit de déployer un squelette associé au métier voulu, que nous appelons metier.html.
Souvenons-nous que nous y avons défini un Article du Secteur n° p 21 pour l’obtenir, nous aurions aussi pu l’appeler article-21.html, à condition de dupliquer déjà le squelette natif article.html dans notre dossier squelettes, du moins quand nous l’aurons retouvé : comme je n’ai pas cherché où c’etait sous SPIP3, j’ai récupéré un vieux squelette de 1.9, et cela le fait....

Come il n’y a encore qu’un seul mot-clé marqueur dans le groupe des métiers, il suffit de faire :

[(#REM)   METIER  noisette dédiée à l'affichage des métiers (par son mot-clé) ]
<h2>Actvités Associées</h2>
<BOUCLE_mot(MOTS){id_groupe IN 9 }>
   #INCLURE{fond=mot, id_mot=#ID_MOT}
</BOUCLE_mot>

Et nous utilisons directement en noisette la page précédente (ayant installé Escal à l’arrache, je ne l’avais pas mise en ./squelettes/contenu/, ce qui serait plus joli encore !)

Tant qu’a faire, ou va un peu structurer une page de menu sommaire, car il commence à y avoir des pages a connaitre :

[(#REM)    un sommaire vite-fait (avec des appels à la Z) ]
<ul>
<li> Accès au <a href="./ecrire/">Privé</a></li>
<li> Accès au <a href="#URL_PAGE{contenu/page-plantout}">Plan Tous</a></li>
<li> Accès au <a href="#URL_PAGE{activites}">Activités</a></li>
<li> Accès au <a href="#URL_PAGE{metier}">Poste Métier défini</a></li>
<li> Accès au <a href="#URL_PAGE{mots}">Mots</a></li>
<li> Accès au <a href="#URL_PAGE{mot}">Mot</a></li>
</ul>

Il n’y a plus qu’a rajouter à l’affichage de notre premier Metier, l’affichage de compétences, savoirs et autres documents joints, pour que le prototype fasse .... ce que nous n’aurions espérer !

Rajoutosn donc une boucle récupérant tous les savoirs des deux groupes prédéfinis, et comme pendant ce temps d’autres relations ont été saises et modélisées , une boucle de plus : voilà  !

[(#REM) noisette d'accès aux Savoirs liés à une fiche article métier id_article ]
<h2>SAVOIRS </h2><a href="#URL_PAGE{groupes_mots}"></a>
<BOUCLE_groupes(GROUPES_MOTS){par titre}{id_groupe IN 2,3}>
    <h3> [  #ID_GROUPE ] <a href="#URL_MOT">[(#TITRE)]</a> [: (#TEXTE)]</h3>
      <BOUCLE_mots(MOTS){id_groupe}>
         #ID_MOT <a href="#URL_MOT">[(#TITRE)]</a>
      </BOUCLE_mots>
</BOUCLE_groupes>
<code>


et comme pendant ce temps d'autres relations ont été saisies et modélisées, passons cette boucle en noisette de facon a pouvoir la réutiliser !


<code class="spip">
[(#REM)   METIER  affichage du métier associé (par son mot-clé) ]
<h2>Actvités Associées</h2>
<BOUCLE_mot(MOTS){id_groupe IN 9 }>
   #INCLURE{fond=mot, id_mot=#ID_MOT}
</BOUCLE_mot>


<h2>SAVOIRS </h2><a href="#URL_PAGE{groupes_mots}"></a>
<BOUCLE_groupes(GROUPES_MOTS){par titre}{id_groupe IN 2,3}>
    <h3> [  #ID_GROUPE ] <a href="#URL_MOT">[(#TITRE)]</a> [: (#TEXTE)]</h3>
      <BOUCLE_mots(MOTS){id_groupe}>
         #ID_MOT <a href="#URL_MOT">[(#TITRE)]</a>
      </BOUCLE_mots>
</BOUCLE_groupes>


<h1>Relations </h1><a href="#URL_PAGE{groupes_mots}"></a>
<BOUCLE_relations(GROUPES_MOTS){par titre}{id_groupe IN 6,7}>
    <h2> [  #ID_GROUPE ] <a href="#URL_MOT">[(#TITRE)]</a> [: (#TEXTE)]</h2>
      <BOUCLE_interloc(MOTS){id_groupe}>
         #ID_MOT <a href="#URL_MOT">[(#TITRE)]</a>
      </BOUCLE_interloc>
</BOUCLE_relations>

Bon, c’est pas fini : il se trouve que la gestionnaire des Métiers aimerait bien pouvoir « marquer » une activité principale pour mettre son #DESCRIPTIF en complément affiché au Métier : tant qu’il n’y a qu’un seul métier , cela se résout en prenant un second mot-clé marqueur principal ou secondaire d’un groupe complémentaire « Mission »...

Mais, pour prévoir une généralisation , en pensant au plugin « Mots sur Mots », et dans l’idée d’avoir peut-etre des « attributs » sur ces mot-clés, il faudrait on veut donc pouvoir affecter un mot-clé à.... un mot-clé !
Outre la modification (vite apportée) au code original de SPIP, il faut donc affecter ce mot-clé « principal » ou « secondaire », au mot-clé caractéristique, ou plutôt ici, à une occurrence du lien « métier » branché à l’Activité principale voulue....
_ L’interface n’existe pas (encore) en standard...car il faudrait une« double affectation » aux paramètres du mot-clé (sur l’objet et son #ID_, et sur un identifieur d’une occurrence de lien du mot-clé #ID... [14]

Quoiqu’il en soit, voila finalement notre bloc-noisette-contenu pour une fiche-article-métier (soit une fiche choisie, sion une au hasard..) : voilà !

[(#REM) fiche métier  METIER  affichage du métier associé (par son mot-clé) ]
<BOUCLE_fiche(ARTICLES){id_article?}{id_secteur= 7} {par hasard}{0,1}>
<h1>Fiche Metier : #TITRE</h1>
   #TEXTE
 
  <BOUCLE_princip(RUBRIQUES){
<h2>Activités Associées</h2>
<BOUCLE_mot(MOTS){id_groupe IN 9 }>
   #INCLURE{fond=mot, id_mot=#ID_MOT}
</BOUCLE_mot>


<h2>SAVOIRS </h2><a href="#URL_PAGE{groupes_mots}"></a>
<INCLURE{fond=mot, id_groupe IN (2,3),env}>     <!-- env passe le "id_article" necessaire --><BOUCLE_groupes(GROUPES_MOTS){par titre}{id_groupe IN 2,3}>
    <h3> [  #ID_GROUPE ] <a href="#URL_MOT">[(#TITRE)]</a> [: (#TEXTE)]</h3>
      <BOUCLE_mots(MOTS){id_groupe}>
         #ID_MOT <a href="#URL_MOT">[(#TITRE)]</a>
      </BOUCLE_mots>
</BOUCLE_groupes>


<h2>Relations </h2>
<INCLURE{fond=mot, id_groupe IN (4,5),env}>     <!-- env passe le "id_article" necessaire -->



Et maintenant !  [15]D’abord, il reste tout de meme a valider le fonctionnement sur plusieurs fiches métiers (en relisant la noisette MOT ci-dessus, qui devrait pour bien faire etre insérée dans l’article métier, et je crois qu’il y a encore à a affiner quelques détails pour redescendre le mot-clé marqueur dans les boucles de Savoirs et de Relations !) ; cela passera lors de l’intégration dans le squelette metier definitif, auquel on rajoutera la boucle d’affichage des documents joints.

Ensuite, et bien, il serait tout de meme plus agréable d’obtenir un formulaire complet de saisie des mots-clés par groupe au moyen des cases a cocher ; pareillement pour la saisie des Activités, ce qui est presque fait faitr en récupérant le bloc formulaires/inc-select-rubriques initialement créé pour l’usage exclusif du plugin Accès Restreint, en changeant une ligne d’appel pour accéder à partir d’une rubrique ou sous-rubrique des Activités.

Après quoi ? Vous ferez appel à un WebMestre CSS pour représenter tout cela en mise-en-forme à la page ; j’avais voulu tester Escal, sinon, j’aurais déjà tout passer en Z et c’etait quasiment fini !


En fait, il faut admettre que cela a pris l’après-midi, mais tout compris !
Un espace Web php5-MySQL etait disponible sur un serveur Apache local : l’occasion a paru intéressante de se lancer avec la prochaine version....

-  téléchargement et installation de spip_loader, modifié pour chargé SPIP3 beta deux,
-  début d’adjonction de quelques plugins : impossible avec cette version.
( la version téléchargée étant incomplète, une réponse rapide sur IRC nous oriente vers la SVN : ree-installée en-cours de travail toujourspar spip_loader, sans meme aller chercher le spip_loader_dev qui nous a été indiqué : probable qu’une version finalisée de SPIP3 sera vite proposée.. en tous cas j’espere !
-  redaction de quelques textes précisant les choses, en particulier posant le vocabulaire utilisé

Pouvoir utiliser les mots-clés sur les mots-clés était l’idée initiale conduisant à choisir tout de suite SPIP3 : manque de chance, l’investigation des menus montre une batterie impressionnante d’objets pour recevoir les mots-clés.... sauf (!) les mots-clés : qu’à cela ne tienne, utilisons var_mode=inclure dans l’interface privée, qui nous oriente vers groupe_mots_edit, plus spécifiquement le FORMULAIRE inc-choisir_groupesmots_tables_liées.
Retour aux codes de SPIP (SPIP3 est écrit en formulaires CVT de SPIP) à la première exploration des répertoires de extensions, on repère mots, on trouve le formulaire concerné, c’est un squelette, et la simple boucle commence par deux filtres {cle!=spip_mots}{cle!=spip_groupes_mots} ; supprimons ces trente caractères dans une copie de ce fichier en ./squelettes/formulaires, et la surcharge de SPIP nous permet désormais de .... poser des mots-clés sur les mots clés ! Bingo [16]