Une demande récurrente
Les utilisateurs chevronnés de SPIP ont souvent besoin d’ajouter un plugin spécifique à une rubrique dans l’espace privé.
Par exemple, la rubrique 66 doit faire office d’agenda, on aimerait donc avoir le formulaire de gestion des évènements uniquement si l’article appartient à cette rubrique 66, et quant au groupe de mots-clefs 5, il faudrait que ses mots clefs et ceux-là uniquement permettent de configurer une carte google.
Ici, nous allons seulement montrer comment modifier l’appel du pipeline du plugin GIS pour l’appliquer uniquement sur la ou les rubriques au choix du (ou de la) webmestre.
Qu’est ce qu’un pipeline ?
Lors de la création d’un plugin SPIP, vous avez par exemple besoin d’insérer une boite à gauche, en haut, du code dans le head, ou un formulaire au milieu...on se sert alors d’un pipeline.
Au départ, on pense plutôt à un tuyau, et on a pas vraiment tort, puisque le pipeline va agir sur le flux de la page générée par SPIP.
Les explications et références directes sur les pipelines sont ici !
Chouette ! les devs de SPIP ont installés des points d’entrée le long du flux SPIP, et voila ! vous pouvez donc utiliser affiche_milieu ou post_typo et bien d’autres pipelines pour glisser votre code dans SPIP sans recopier toute la page pour la modifier.
Tout ça c’est du pipeline
Le plugin GIS joue très bien du pipeline, pour savoir où précisement, il faut aller voir dans le dossier /gis le fichier plugin.xml ou sont les définitions des entrées.
Lignes 58 de plugins/GIS/plugin.xml
<!-- Definitions des fonctions qui s'inserent dans les pipelines -->
<pipeline>
<nom>affiche_droite</nom>
<inclure>gis_pipeline.php</inclure>
</pipeline>
Ouvrons ce gis_pipeline.php pour y trouver la fonction d’inclusion qui nous intéresse.
function gis_insertar_maparticle($flux){
if (_request('exec')=='articles'){
include_spip('inc/parte_privada');
$flux['data'] .= gis_cambiar_coord($flux['arg']['id_article']);
}
return $flux;
}
On décortique, et on voit que l’appel se fait uniquement si l’url comporte exec=articles
l’autre bonne idée ici, c’est l’appel d’un autre fichier (include_spip('inc/parte_privada');
) qui s’executera alors, c’est ici qu’il faut poser nos conditions !
Ah ah, vous commençez à comprendre que c’est en amont qu’il va falloir jouer maintenant, comment en effet, demander à la fonction gis_insertar_maparticle
de choisir les articles de la rubrique que nous voulons ?
Comment CFG entre dans la danse du pipeline
Une fois la fonction de pipeline repérée, on crée le fichier cfg_gis.html pour permettre de choisir les rubriques.
Attention à le mettre dans le dossier fonds comme ceci plugins/gis/fonds/cfg_gis.html
Voici le formulaire et les boucles SPIP adequates :
#CACHE{0}
<form method="post">[(#ENV{_cfg_}|form_hidden)]
[(#REM) descriptif=
<h4>GIS sur quels objets?</h4>
Quel est l'objet qui doit être traité
<br />
<a href="http://www.spip-contrib.net/Plugin-Gis-escoitar" class="spip_out">Documentation GIS</a>
]
[(#REM) titre=GIS]
#SET{wichrub,#CONFIG{gis/rubriques_gis,'',''}}
<h4>Afficher la carte GIS sur quels objets?</h4>
<fieldset>
<legend>Quelle rubrique?</legend>
<label>Choix de la ou des rubriques à utiliser:</label>
<select name="rubriques_gis[]" multiple="multiple" size="5">
<option value="" [(#GET{wichrub}|?{'',' '})selected="selected"]>
aucunes
</option>
<BOUCLE_secteurs(RUBRIQUES) {racine} {par titre}>
<option value="#ID_RUBRIQUE" [(#ID_RUBRIQUE|in_array{#GET{wichrub}}|?{' selected="selected"'})] style="font-weight: bold;">
<strong>racine #ID_RUBRIQUE : #TITRE</strong>
</option>
<BOUCLE_rubriques(RUBRIQUES) {id_parent} {par titre}>
<option [(#ID_RUBRIQUE|in_array{#GET{wichrub}}|?{' selected="selected"'})] value="#ID_RUBRIQUE">
rubrique #ID_RUBRIQUE : #TITRE
</option>
<BOUCLE_sous_rubriques(BOUCLE_rubriques)></BOUCLE_sous_rubriques>
</BOUCLE_rubriques>
</BOUCLE_secteurs>
</select>
</fieldset>
<input type="submit" name="_cfg_ok" value="<:OK:>" />
<input type="reset" value="<:Reset:>" />
<input type="submit" name="_cfg_delete" value="<:Supprimer:>" />
</form>
Ce qui nous importe ici c’est d’avoir définit l’array de la ou des rubriques pour lesquelles nous souhaitons que les articles aient une carte GIS :#SET{wichrub,#CONFIG{gis/rubriques_gis,'',''}}
on remplit donc l’array en validant le formulaire !
le résultat à l’appel du fichier /ecrire/?exec=cfg&cfg=gis
Transformation de la fonction d’appel
Voila maintenant ce que devient la fonction gis_insertar_maparticle($flux)
function gis_insertar_maparticle($flux){
if (_request('exec')=='articles'){
//on teste si cfg est actif
if (function_exists(lire_config)) {
$arracfgrubriques_gis=lire_config("gis/rubriques_gis",' ');
global $id_article;
if ($id_article!=''){
//on cherche la rubrique de l'article
$s = spip_query("SELECT id_rubrique FROM spip_articles WHERE id_article=$id_article");
$row = spip_fetch_array($s);
$id_rubrique = $row['id_rubrique'];
//et si la rubrique est dans l'arrayrub
if (in_array($id_rubrique, $arracfgrubriques_gis)) {
include_spip('inc/parte_privada');
$flux['data'].= gis_cambiar_coord($flux['arg']['id_article']);
}
}
}else {
include_spip('inc/parte_privada');
$flux['data'].= gis_cambiar_coord($flux['arg']['id_article']);
}
}
return $flux;
}
Si cfg n’est pas actif, car parfois les utilisateurs ne l’ont pas, on ignore nos modifications, sinon on utilise ce fameux array $arracfgrubriques_gis=lire_config("gis/rubriques_gis",' ');
et si l’article appartient à la rubrique de l’array, on modifie le flux.
Conclusion
Chaque développeur de plugins devrait intégrer ainsi ce merveilleux outil que Toggg a développé pour SPIP.
Discussions par date d’activité
5 discussions
Bonsoir,
Voila je viens d’effectuer toutes les étapes dans l’article pour afficher la carte gis que dans une rubrique spécifique. Mais je rencontre un problème la carte apparait sur tous les articles de mon site. Alors que j’ai bien suivi à la lettre les instructions de l’article pourriez vous m’éclairer car je suis un peu désespéré que ça ne fonctionne pas.
Ce que je souhaiterai en fait ça serait que la carte n’apparaisse que dans les articles de la rubrique TEST GIS de mon site.
Je travail en local avec un SPIP 2.0.10, un squelette Soyez Créateurs à jour. Je suis un débutant sous SPIP.
En vous remerciant par avance d’une quelconque aide de votre part.
Merci
Répondre à ce message
Bonjour,
Merci pour cet article !
Voila je débute dans SPIP et je voudrais faire ceci :
Donc j’ai une rubrique qui utilise GIS et je voudrais qu’en en appelant le modèle il n’y est que cette rubrique et ses articles qui fassent apparaitre la carte ? (je voudrais éviter de faire un forçage sur l’id de la rubrique)
Pourriez-vous m’aider ?
Je suis en local avec un SPIP 2.0.10 et un squelette Soyez Créateurs.
Merci par avance
Guillaume
Répondre à ce message
Merci à Arno* pour son plugin
http://www.paris-beyrouth.org/Le-plugin-PB-Charts
J’ai ajouté un fichier pour, je l’espère, une optimisation de ses fonctionnalités.
Soit un CFG qui permet de choisir le mot clef à attacher aux articles qui sont à traiter par ce plugin,
cela evite de passer le traitement sur toutes les pages.
Et si CFG n’est pas installé, ça tourne comme avant.
+modif de pb_charts_actions.php sur function pb_charts_traiter_charts
Si vous souhaitez le tester, c’est par là
http://grainesdimages.com/modifs-ZIP-graines/
Bonjour,
Le lien ne semble plus fonctionner. Je souhaitais m’en inspirer pour les mots clefs spécifiques à l’agenda.
Peut-on le trouver ailleurs ?
Merci
Et voila, le client a repris la main et supprimé le dossier... pas très sympa... j’ai retrouvé les codes, je te les colle là, il faudra peut être les modifier :
Pour cfg dans fonds/cfg_pbcharts.html
dans pb_charts_actions.php
Répondre à ce message
Bonjour,
merci pour cette contribution que je viens d’adapter au plugin Agenda en ajoutant des balises multilingues pour des traductions en anglais
Voici le fichier : agenda_1_9_2\fonds\cfg_agenda.html :
<script>Agenda in which sections ? </h4>
Which section will be used?
[en]Show the agenda in the follwong sections?[fr]Afficher l'Agenda pour les articles de quelle rubrique? </h4>[en]Which section?[fr]Quelle rubrique? </legend>[en]Selection of the section to use :[fr]Choix de la ou des rubriques à utiliser: </label>
[en]none[fr]aucunes [en]root[fr]racine #ID_RUBRIQUE : #TITRE</strong>
[en]section[fr]rubrique #ID_RUBRIQUE : #TITRE
#CACHE{0}
<form method="post">[(#ENV{_cfg_}|form_hidden)]
[(#REM) descriptif=
<h4>
<br />
<a href="http://www.spip-contrib.net/Plugin-Agenda" class="spip_out">Documentation Agenda</a>
]
[(#REM) titre=Agenda]
#SET{wichrub,#CONFIG{agenda/rubriques_agenda,'',''}}
<h4>
<fieldset>
<legend>
<label>
<select name="rubriques_agenda[]" multiple="multiple" size="5">
<option value="" [(#GET{wichrub}|?{'',' '})selected="selected"]>
</option>
<BOUCLE_secteurs(RUBRIQUES) {racine} {par titre}>
<option value="#ID_RUBRIQUE" [(#ID_RUBRIQUE|in_array{#GET{wichrub}}|?{' selected="selected"'})] style="font-weight: bold;">
<strong>
</option>
<BOUCLE_rubriques(RUBRIQUES) {id_parent} {par titre}>
<option [(#ID_RUBRIQUE|in_array{#GET{wichrub}}|?{' selected="selected"'})] value="#ID_RUBRIQUE">
</option>
<BOUCLE_sous_rubriques(BOUCLE_rubriques)></BOUCLE_sous_rubriques>
</BOUCLE_rubriques>
</BOUCLE_secteurs>
</select>
</fieldset>
<input type="submit" name="_cfg_ok" value="<:OK:>" />
<input type="reset" value="<:Reset:>" />
<input type="submit" name="_cfg_delete" value="<:Supprimer:>" />
</form>
</script>
et dans : \plugins\agenda_1_9_2\agenda.php la fonction Agenda_affiche_milieu (ligne 46) :
<script>function Agenda_affiche_milieu($flux) {
if (_request('exec')=='articles'){
//on teste si cfg est actif
if (function_exists(lire_config)) {
$arracfgrubriques_gis=lire_config("agenda/rubriques_agenda",' ');
global $id_article;
if ($id_article!=''){
//on cherche la rubrique de l'article
$s = spip_query("SELECT id_rubrique FROM spip_articles WHERE id_article=$id_article");
$row = spip_fetch_array($s);
$id_rubrique = $row['id_rubrique'];
//et si la rubrique est dans l'arrayrub
if (in_array($id_rubrique, $arracfgrubriques_gis)) {
include_spip('inc/calendar');
include_spip('inc/agenda_gestion');
$id_article = $flux['args']['id_article'];
$flux['data'] .= Agenda_formulaire_article($id_article, article_editable($id_article),'articles');
}
}
}else {
include_spip('inc/calendar');
include_spip('inc/agenda_gestion');
$id_article = $flux['args']['id_article'];
$flux['data'] .= Agenda_formulaire_article($id_article, article_editable($id_article),'articles');
}
}
return $flux;
}</script>
et ajouter
<script>'supprimer' => 'delete',</script>
dans squelettes/lang/local_en.php
Je ne suis pas certain que mon adaptation est parfaite. Notamment dans
<script>[(#REM) descriptif=Agenda in which sections ? </h4>
Which section will be used?
<h4>
<br />
<a href="http://www.spip-contrib.net/Plugin-Agenda" class="spip_out">Documentation Agenda</a>
]</script>
ou je n’ai pas résussi à mettre la traduction en français, car dés que je mets les
<script>[]</script>
il y a tout qui foire et si je mets
<script><:agenda_section:></script>
avec des traductions dans les fichiers langues dans squelettes/lang, les trad ne s’affichent pas. Je les ai donc laissé en anglais.
Salutations
Rainer
Ah ! super ! Je crois que le fichier de lang doit être nommé ainsi
plugins/tonplugin/lang/tonplugin_fr.php
tu l’utilises alors comme cela dans le code d’un squelette
<:tonplugin:phrasetraduite:>
Pour SPIP 1.9.3 svn (juin 2008) voici le code pour l’agenda
cette fonction est intégrée dans agenda 1_9_3
Répondre à ce message
Bonjour
merci pour la contribe
peut-on imaginer d’insérer le plugin sur les articles qui ont tel et tel mot clé ?
Oui, je l’ai fait aussi sur GIS, je ne voulais pas que l’article soit illisible, le principe est le même, donc inutile que tu t’y recolles ! voici la boucle à insérer dans fonds/cfg_gis.html
et pour récupérer les mots choisis, dans gis_pipeline.php
ça marche bien !
Arf, j’ai lu trop vite,
Il faut rester générique, ç’est ça qui est intéressant, et choisir le groupe que l’on veut.
J’ai pour ma part opté pour un groupe « lieu » dans lequel au surprise les mots clefs sont des lieux avec carte configurée, je demande à cfg de n’appliquer la carte que sur ce groupe (grace au code précédent) et je désactive la carte sur les articles (cfg= aucune rubrique), puis j’affilie le mot clef à l’article que je veux.
ça marche ici http://www.contrelesaddictions.fr/ en un peu plus poussé encore puisque j’ai modifié le squelette pour faire apparaitre les évènements d’un lieu donné. Le groupe lieu est lié alors uniquement aux évènements.
Excellent !
Et en plus le squelette du site est très sympa.
Il n’est pas sur la zone par hasard ? ;-)
Merci !
Je n’ai pas remercié ici les créateurs du squelette multi-saisons pour SPIP, dont je me suis servi largement http://www.art-logic.info/multi_saisons/
pas le temps d’envoyer toutes mes modifs depuis, merci encore à eux
pour le squelette de la carte glouglou special events, faut piocher !
un de ces 4 je le ferais ;) mais je le réserve à art-logic si ils le veulent ;)
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 :
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.
Suivre les commentaires : |