Réaliser un agenda avec SPIP 1.4.2 (Archive)

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

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.

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.

Exemple d’agenda
L’agenda de Gastero Prod

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.

Utilisation de la date de publication antérieure

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.

Une hiérarchie de rubriques pour les thèmes
Le rendu de la sélection thématique

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 :

agenda.zip
Les fichiers pour mettre en place l’agenda

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é.

Notes

[1Vérifiez que vous avez configuré votre site pour gérer ce type de date supplémentaire.

[2Voir la documentation de INCLURE : http://www.uzine.net/article1828.html

Discussion

64 discussions

  • 4
    asso.bachant

    allez je me lance
    . premierement imprimer la doc

    • asso.bachant

      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 !

    • asso.bachant

      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

  • 2
    philippe

    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.

    • philippe

      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 :

    <?php
     $date = ereg_replace("^([0-9]{4})-([0-9]{2})-([0-9]{2}).*$", "\\1\\2\\3", '#DATE_REDAC');
     $az=substr($date,0,4);
     $mz=substr($date,4,2);
     $jz=substr($date,6,2);
    
     if ($date > date("Ymd", mktime(0,0,0,$M, $D - 31, $Y)) && $date < date("Ymd", mktime(0,0,0,$M, $D + 31,$Y)))    {
         if (!isset($events[$date])) {
            $events[$date] = array();
         }
         $events[$date][] = array('link' => '#URL_ARTICLE', 'title' => '[(#TITRE|texte_script)]');
         $chapo=intval('#CHAPO');
        while ($chapo>1) {
           $chapo=$chapo-1;
           $datezzz=date("Ymd",mktime(0,0,0,$mz,$jz+$chapo,$az));
           $events[$datezzz][] = array('link' => '#URL_ARTICLE', 'title' => '[(#TITRE|texte_script)]');
        }
     }
    ?>

    par :

    <?php
     $date = ereg_replace("^([0-9]{4})-([0-9]{2})-([0-9]{2}).*$", "\\1\\2\\3", '#DATE_REDAC');
     $az=substr($date,0,4);
     $mz=substr($date,4,2);
     $jz=substr($date,6,2);
    
     $date2 = ereg_replace("^([0-9]{4})-([0-9]{2})-([0-9]{2}).*$", "\\1\\2\\3", '#DATE');
     $az=substr($date,0,4);
     $mz=substr($date,4,2);
     $jz=substr($date,6,2);
    
    
     if ($date > date("Ymd", mktime(0,0,0,$M, $D - 31, $Y)) && $date < date("Ymd", mktime(0,0,0,$M, $D + 31,$Y)))    {
         if (!isset($events[$date])) {
            $events[$date] = array();
         }
         $events[$date][] = array('link' => '#URL_ARTICLE', 'title' => '[(#TITRE|texte_script)]');
         $date2=('#DATE');
        while ($date2>1) {
           $datezzz=$date2("Ymd",mktime(0,0,0,$mz,$jz+$date,$az));
           $events[$datezzz][] = array('link' => '#URL_ARTICLE', 'title' => '[(#TITRE|texte_script)]');
        }
     }
    ?>

    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 :

  • 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