REMARQUE : Cet article présente une très ancienne manière de faire un agenda, pour SPIP 1.4.2. Il y a désormais un plugin Agenda qui permet de faire un agenda de manière plus propre et plus efficace.
ATTENTION : Cet article présente une ancienne version du mécanisme utilisé sur le site Gastero Prod, sur lequel est disponible un article de présentation du nouveau système plus performant.
[SPIP 1.4.2] Il peut être tentant d’utiliser SPIP pour présenter un agenda d’événements sous forme de calendrier. Plutôt que devoir intégrer un logiciel externe spécialisé, et en attendant que SPIP intègre un nouveau type de données, voici un squelette mêlant boucles SPIP et code PHP.
De quelles informations avons-nous besoin ?
La première étape consiste à déterminer comment les informations seront stockées dans SPIP, et donc saisies par les rédacteurs.
L’objectif principal étant qu’un rédacteur puisse définir une date à laquelle un événement donné doit avoir lieu, nous avons besoin des éléments suivants :
- Au moins un champ de type texte ;
- Un champ de type date.
Pour le champ texte, c’est simple, et nous allons même pouvoir nous régaler. SPIP nous en propose au moins 3 très utiles et systématiquement présents quel que soit le paramétrage du site : le titre, le descriptif et le texte.
La date de publication antérieure ou la vraie date de publication ?
La date de publication d’un article est déterminée automatiquement lors de sa validation, ce qui signifie que l’auteur ne peut pas la préciser à l’avance. Elle peut en revanche être modifiée par le valideur, mais elle n’est donc pas vraiment utile pour indiquer une date d’événement - surtout si on a configuré son site pour que SPIP ne publie pas les articles post-datés.
Heureusement, SPIP propose aussi une date de publication antérieure, normalement utilisée pour indiquer à quelle date a été publié un article repris ultérieurement dans SPIP, et qui peut être définie librement par le rédacteur [1].
C’est cette date que nous allons utiliser pour définir les événements de l’agenda.
Organiser les événements
Si l’agenda doit contenir beaucoup d’informations de nature diverse, il peut s’avérer utile de les qualifier (concert, film, réunion ?) pour les mettre en évidence et éventuellement ensuite les afficher de manière sélective.
Dans SPIP deux méthodes de classement viennent immédiatement à l’esprit :
- Classement par rubrique (et éventuellement sous-rubriques) ;
- Classement par mot-clé.
Dans cet exemple, nous allons utiliser les rubriques, ce qui nous permettra de constituer toute une arborescence pour stocker les articles événements ; cela va nous permettre de filtrer les types d’événements avec une notion de granularité progressive (c’est pas chic ça ?).
Dans l’agenda de Gastero Prod, le rubriquage n’est pas très développé, mais il est déjà possible de sélectionner uniquement les événements musicaux, et éventuellement de filtrer encore plus en ne considérant que les concerts.
Notez au passage que les logos des rubriques sont utilisés pour illustrer les événements.
Intégrer l’agenda dans la partie publique
Voilà, les événements sont créés dans une arborescence de rubriques thématiques et sont positionnés à une date, passons aux choses sérieuses, l’intégration de l’agenda résultant dans les pages du site.
Première chose à faire, télécharger le package qui va grandement vous simplifier la tâche :
Ce package contient les fichiers suivants :
agenda.css |
La feuille de style permettant de personnaliser l’affichage de l’agenda |
agenda.html/php3 |
Le squelette de l’agenda, à inclure dans vos propres squelettes, et son .php3 associé |
agenda_themes.html/php3 |
Le squelette des thèmes de l’agenda, à inclure dans vos propres squelettes, et son .php3 associé |
Pour insérer l’agenda dans votre site, le plus simple est de créer un squelette particulier pour la rubrique de votre agenda. J’ai par exemple créé le squelette rubrique-43.html
sur Gastero Prod puisque la rubrique d’agenda porte l’identifiant 43.
Dans ce squelette, les éléments suivant sont à ajouter. Tout d’abord, dans l’entête, il faut ajouter la référence de la feuille de style supplémentaire à utiliser :
<link rel="stylesheet" href="agenda.css" type="text/css" />
Ensuite, il faut ajouter l’agenda lui-même, grâce à un simple INCLURE
[2] placé à l’intérieur de la boucle principale RUBRIQUE
:
<INCLURE(agenda.php3){id_rubrique}>
Enfin, il faut ajouter la sélection de l’arborescence thématique :
<INCLURE(agenda_themes.php3){id_rubrique=43}>
Notez que pour cette fois-ci, il faut préciser l’identifiant de la rubrique de l’agenda. C’est pour que l’arborescence thématique soit toujours complète, même si l’on n’affiche qu’une thématique particulière.
Quelques remarques techniques
Les paramètres de navigation d’un mois à l’autre sont passés dans l’URL au travers des variables var_nav_month
et var_nav_year
. On utilise la notation var_xxx
pour indiquer à SPIP de ne pas prendre en compte ces variables pour le calcul du cache de la page, ce qui permet à la fois de limiter l’impact sur le cache (un seul fichier cache traitera toutes les pages de l’agenda) et d’accélérer l’affichage (puisque SPIP n’aura besoin d’aller chercher les données dans la base qu’une seule fois pour toutes ces pages).
La sélection des événements à afficher se fait en PHP car il n’est pas possible de sélectionner une plage de dates dans une boucle SPIP. Une boucle avec pour seul critère la restriction thématique éventuelle est donc utilisée, et une variable PHP de type tableau nommée $events
est remplie avec la liste des événements susceptibles d’être affichés dans le calendrier du mois demandé.
Discussions par date d’activité
64 discussions
allez je me lance
. premierement imprimer la doc
creation de la rubrique qui porte le n° 15
création du squelette
« rubrique-15.html »
voici le squelette
@@ !DOCTYPE html PUBLIC « -//W3C//DTD HTML 4.01 Transitional//FR »>
@@html>
@@head>
@@meta http-equiv=« content-type » content=« text/html ;charset=iso-8859-1 »>
@@title>[(#NOM_SITE_SPIP)]@@/title>
@@BOUCLE_metatags(mots)id_mottout« , »doublons>
(#TITRE@@/BOUCLE_metatags>
@@meta name=« robot » content=« follow, index, all »>
<@@eta name="revisit-after" content="15 days">
@@link rel=« stylesheet » href=« agenda.css » type=« text/css » />
@@/head>
@@ ?php
include(« haut1.html ») ;
?>
@@body bgcolor=« #ffffff » leftmargin=« 0 » marginheight=« 0 » marginwidth=« 0 » topmargin=« 10 »>
@@INCLURE(agenda.php3)id_rubrique>
@@INCLURE(agenda_themes.php3)id_rubrique=15>
@@ ?php
include(« bas.html ») ;
?>
@@/body>
— transfert par FTP SUR MON SITE
ça n’a pas l’air de fonctionner !
idiot que je suis, enfin le coup de l’article associé pour afficher la rubrique................
il suffisait de créer un article.
C’est agenda est super !.
petite question :
comment valider un évenement pour qu’il s’affiche tous les an a la même date.
Répondre à ce message
Il est écrit que dans SPIP deux méthodes de classement viennent immédiatement à l’esprit :
Classement par rubrique (et éventuellement sous-rubriques) ;
Classement par mot-clé.
Quelqu’un a t il déjà utilisé un classement par mot clé ?
J’ai essayé quelques modifications sans succès.
Un mot clé agenda à affecter aux articles concernés.
Petites modifs dans agenda.html.
vers la ligne 18
vers la ligne 35
Et enlever la partie des sous rubriques
Et cela semble ok
Pour ceux que cela intéresse tout est ok, à voir dans l’agenda.
Il faut donc appliquer le principe des dates et le mot agenda aux articles que l’on souhaite avoir dans l’agenda.
Pour le skel vous faîtes comme d’hab.
Répondre à ce message
Merci bocoup pour cet agenda, il tourne bien... :-)
J’ai juste un petit probleme je n’arrive pas a changer ses couleurs dans la feuille de styles, meme en les modifiant et sauvegardant l’agenda garde toujours la meme apparence... J’en utilise une deuxieme pour mon site, mais je ne pense pas que cela pose de probleme...
Si vous pouviez m’aider je vous en serai reconnaissant ;-) Merci
Répondre à ce message
Bonjour,
pour l’agenda, je me demande si l’on ne pourrais pas utiliser le champ #DATE_REDAC à la place de #CHAPO (cf commentaire de M LO) pour les événements qui durent plusieurs jours, voire semaine..
je voudrais faciliter la vie des rédacteurs. si j’ai bien compris pour utiliser #CHAPO il faut d’abord compter les jours couverts par l’évènement.
j’ai essayé de transformer le code :
par :
comme je ne suis pas au top avec ces codes, je me retrouve avec une erreur :
Call to undefined function : 2003-06-16 00:00:00()
à la ligne 38 qui est (évidemment) :
$datezzz=$date2(« Ymd »,mktime(0,0,0,$mz,$jz+$date,$az)) ;
si un contrib peut m’aider sans avoir à se casser la tête, çà me dépannerait.
Merci
DD
PS j’ai cru comprendre que les prochaines versions de SPIP amélioreraient la gestion d’agenda, en attendant, vive le bricolage !
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 : |