SPIP-Contrib

SPIP-Contrib

عربي | Deutsch | English | Español | français | italiano | Nederlands

286 Plugins, 197 contribs sur SPIP-Zone, 246 visiteurs en ce moment

Accueil > Dates, calendriers et agendas > Plugin Agenda > SPIP 3, Agenda et FullCalendar

SPIP 3, Agenda et FullCalendar

6 août 2012 – par Maïeul – 263 commentaires

28 votes

Ceci est une « contribution pédagogique », qui montre par l’exemple comment développer une nouvelle fonctionnalité pour SPIP.

Depuis SPIP 3, l’affichage d’un agenda sous forme de calendrier par jour/semaine/mois à changé. Les filtres |agenda_memo et apparentés sont désormais obsolètes. Il en est de même pour les filtres agendafull_memo et apparentés du plugin Agenda.

Désormais, l’affichage d’un calendrier s’appuie sur la librairie javascript FullCalendar. Voici un tutoriel pour comprendre comment s’en servir avec Agenda 3.0.

Pour une première approche, vous pouvez utiliser le plugin Agenda Fullcalendar facile.

Souhait

Nous souhaitons afficher tous les événements (publiés) du site sous forme calendaire, en proposant d’abord un affichage par mois, avec possibilité de basculer en affichage par semaine ou par jour.

PNG - 39.8 ko
Agenda souhaité au final

Pré-requis

  • SPIP 3.0.x, en ayant conservé l’organiseur dans plugins-dist.
  • Plugin Agenda 3.6.11 minimum.
  • Compréhension de la mécanique des squelettes de SPIP.
  • Quelques évènements à afficher.

Vous n’avez pas besoin d’installer la librairire FullCalendar : elle est livrée avec SPIP.

Principe de base

Pour afficher notre agenda nous allons :

  1. créer un squelette agenda.html, avec un div dont l’attribut id est agenda.
  2. appeler dans le squelette le script fullcalendar et ses feuilles de styles.
  3. utiliser ce script pour afficher l’agenda dans dans la div#agenda.
  4. créer un squelette agenda.json.html fournissant au script les données à afficher dans l’agenda.

Fichiers manipulés

 
Dans cet article nous manipulons deux fichiers squelettes : 

  • agenda.html (qui contient le code nécessaire à l’affichage du calendrier).
  • agenda.json.html (qui nous permet de générer une liste d’événements compatible avec le script fullcalendar).

Si l’un de ces squelette existe déjà, je vous invite à utiliser le mécanisme de surcharge de SPIP.

Création du squelette

Il nous faut créer un squelette agenda.html complet (à savoir une page SPIP classique avec les balises

etc), dans lequel nous mettons un div dont l’attribut id est agenda à l’endroit où nous souhaitons que l’agenda s’affiche.

Au dessus de ce div, nous allons appeler :

  • la version compressée du script fullcalendar
  • les styles associés à ce script.

Pour ce faire, nous utilisons la balise #CHEMIN :

  1. <link rel='stylesheet' type='text/css' href='#CHEMIN{lib/fullcalendar/fullcalendar.css}' />
  2. <script type='text/javascript' src='#CHEMIN{lib/fullcalendar/fullcalendar.min.js}'></script>
  3. <div id="agenda">
  4. </div>

Télécharger

Appel à l’agenda

Nous allons maintenant ajouter les fonctions javascript qui permette d’afficher l’agenda. Pour ce faire, nous allons mettre au dessus du div (cela pourrait être dedans ou en dessous, cela importe peu) le code suivant, que je vais commenter :

  1. <script type="text/javascript">/*<![CDATA[*/
  2. jQuery(document).ready(function() {
  3.  
  4.  
  5. jQuery('#agenda').fullCalendar({
  6. editable: false,
  7. events: "[(#URL_PAGE{agenda.json})]",
  8. header: {
  9. left: 'prevYear,prev,next,nextYear today',
  10. center: 'title',
  11. right: 'month,agendaWeek,agendaDay'
  12. },
  13. firstDay: 1,
  14. monthNames:['<:date_mois_1|attribut_html:>','<:date_mois_2|attribut_html:>','<:date_mois_3|attribut_html:>','<:date_mois_4|attribut_html:>','<:date_mois_5|attribut_html:>','<:date_mois_6|attribut_html:>','<:date_mois_7|attribut_html:>','<:date_mois_8|attribut_html:>','<:date_mois_9|attribut_html:>','<:date_mois_10|attribut_html:>','<:date_mois_11|attribut_html:>','<:date_mois_12|attribut_html:>'],
  15. monthNamesShort:['<:date_mois_1_abbr|attribut_html:>','<:date_mois_2_abbr|attribut_html:>','<:date_mois_3_abbr|attribut_html:>','<:date_mois_4_abbr|attribut_html:>','<:date_mois_5_abbr|attribut_html:>','<:date_mois_6_abbr|attribut_html:>','<:date_mois_7_abbr|attribut_html:>','<:date_mois_8_abbr|attribut_html:>','<:date_mois_9_abbr|attribut_html:>','<:date_mois_10_abbr|attribut_html:>','<:date_mois_11_abbr|attribut_html:>','<:date_mois_12_abbr|attribut_html:>'],
  16. dayNames:['<:date_jour_1|attribut_html:>','<:date_jour_2|attribut_html:>','<:date_jour_3|attribut_html:>','<:date_jour_4|attribut_html:>','<:date_jour_5|attribut_html:>','<:date_jour_6|attribut_html:>','<:date_jour_7|attribut_html:>'],
  17. dayNamesShort:['<:date_jour_1_abbr|attribut_html:>','<:date_jour_2_abbr|attribut_html:>','<:date_jour_3_abbr|attribut_html:>','<:date_jour_4_abbr|attribut_html:>','<:date_jour_5_abbr|attribut_html:>','<:date_jour_6_abbr|attribut_html:>','<:date_jour_7_abbr|attribut_html:>'],
  18. buttonText: {
  19. today: '<:date_aujourdhui|attribut_html:>',
  20. month: '<:organiseur:cal_par_mois|attribut_html:>',
  21. day: '<:organiseur:cal_par_jour|attribut_html:>',
  22. week: '<:organiseur:cal_par_semaine|attribut_html:>'
  23. },
  24. weekMode : 'liquid',
  25. loading: function(bool) {
  26. if (bool) $('#calendrier-loading').show();
  27. else $('#calendrier-loading').hide();
  28. },
  29. timeFormat: {
  30.  
  31. agenda: "H'h'mm{ - H'h'mm}",
  32.  
  33. '': "H'h'(mm)"
  34. },
  35. axisFormat: "H'h'(mm)",
  36. allDayText:'<:organiseur:cal_jour_entier|attribut_html:>',
  37. columnFormat: {
  38. month: 'ddd',
  39. week: 'ddd d/M',
  40. day: 'dddd d/M'
  41. },
  42. titleFormat: {
  43. month: 'MMMM yyyy',
  44. week: "d [ MMM] [ yyyy]{ '&#8212;' d MMM yyyy}",
  45. day: 'dddd d MMM yyyy'
  46. },
  47. dayClick: function(date, allDay, jsEvent, view) {
  48. if(view.name=='month'){
  49. $('.fc-button-agendaWeek').click();
  50. $('#calendrier').fullCalendar( 'gotoDate', date );
  51. }
  52. else
  53. if(view.name=='agendaWeek'){
  54. $('.fc-button-agendaDay').click();
  55. $('#calendrier').fullCalendar( 'gotoDate', date );
  56. }
  57. },
  58. isRTL : [(#LANG_DIR|=={rtl}|?{true,false})]
  59. })
  60.  
  61. });
  62. /*]]>*/</script>

Télécharger

  • l. 2 jQuery(document).ready(function() signifie qu’à la fin du chargement du document, le navigateur va exécuter la fonction dans les accolades qui suivent.
  • l. 5 $('#agenda').fullCalendar signifie que nous allons demander à javascript de modifier le div dont l’id est égale à agenda pour y mettre à la place .…l’agenda.
  • Le code entre parenthèse puis accolade correspond aux options passées à l’agenda (l. 5-59) :
    • l. 6 : on ne peut éditer les évènements depuis l’agenda.
    • l. 7 : on récuperera la liste des évènements via un squelette agenda.json.html, nous détaillerons ce squelette dans la partie suivante
    • l. 8-12 : qu’affiche-t-on dans l’entête de l’agenda ? :
      • l. 9 : à gauche, on met les boutons de navigation par mois/semaines/jours (selon le type de calendrier) et par années (dans tout les cas).
      • l. 10 : au centre, on affiche le titre de l’agenda, correspondant à la période affichée (par ex. « Août 2012 »).
      • l. 11 : à droite, on affiche la bascule vers l’agenda en mode mois, semaine ou jour.
    • l. 13 : le premier jour de la semaine est le lundi (=1)
    • l. 14 : noms des mois, définis avec les chaînes de langues de SPIP.
    • l. 15 : noms des mois en abrégé.
    • l. 16 : noms des jours.
    • l. 17 : nom des jours en abrégé.
    • l. 18-23 : textes des boutons.
    • l. 24 : selon les mois, on affichera 4, 5 ou 6 semaines, mais en faisant varier visuellement la hauteur des semaines, pour avoir un mois dont la hauteur est constante. Je renvoie à la documentation sur weekMode.
    • l. 25-27 : permet d’afficher un contenu le temps que l’agenda se charge. Nous en parlerons plus loins.
    • l. 29-34 : formatage des heures dans l’agenda :
      • l. 31 : lorsqu’on est par semaine ou par jour, on affiche l’heure et les minutes.
      • l. 33 : dans les autres cas, juste l’heure.
    • l. 35 : formatage des heures sur l’axe vertical (pour l’affichage par jours).
    • l. 36 : texte indiquant qu’un événement dure une journée entière.
    • l. 37-41 : formatage des dates dans les entêtes de colonnes :
      • l. 38 : pour l’affichage par mois.
      • l. 39 : pour l’affichage par semaines.
      • l. 40 : pour l’affichage par jours.
    • l. 42-46 : titre de l’agenda :
      • l. 43 : lors de l’affichage par mois.
      • l. 44 : lors de l’affichage par semaines.
      • l. 46 : lors de l’affichage par jours.
    • l. 47-57 : action à executer lorsqu’on clique sur un jour.
    • l. 58 : notre agenda doit-il se lire de gauche à droite ou de droite à gauche ?

D’autres options sont bien sûr possible : on se reportera à la documentation de FullCalendar.

Sélection des évènements à afficher

Pour pouvoir afficher les évènements, il va falloir nous fabriquer un squelette agenda.json.html (cf. l. 7) qui retournera les évènements qui nous intéreressent sous forme de donnée JSON.

La page spip.php?page=agenda.json sera automatiquement appelée par FullCalendar, qui lui passera deux arguments, variant selon la période demandée :

  • start, correspondant au timestamp de la date de début.
  • end, correspondant au timestamp de la date de fin.

Dans le squelette agenda.json.html correspondant à cette page, nous pourrons récuperer ces informations via : #ENV{start} et #ENV{end} (voir mon article sur la balise #ENV). On pourrait éventuellement passer d’autres arguments, en appliquant le filtre |parametre_url sur #URL_PAGE{agenda.json}.

Voilà un squelette agenda.json.html basique :

  1. #HTTP_HEADER{Content-Type: application/json; charset=#CHARSET}
  2. [<BOUCLE_evenements(EVENEMENTS){', '}{par date_debut}
  3. {agendafull date_debut,date_fin, periode,
  4. #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}}, #VAL{d}|date{#ENV{start}},
  5. #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}}
  6. >
  7. [(#ARRAY{id,#ID_EVENEMENT,
  8. title,[(#TITRE|html2unicode|unicode2charset)],
  9. allDay,[(#HORAIRE|=={non}|?{#EVAL{true},#EVAL{false}})],
  10. start,#DATE_DEBUT,
  11. end,#DATE_FIN,
  12. url,#URL_ARTICLE,
  13. description,[(#DESCRIPTIF|html2unicode|unicode2charset)]}|json_encode)]
  14. </BOUCLE_evenements>]

Télécharger

Je commente rapidement ce squelette :

  • l. 1. On demande à SPIP de :
    • Ne pas insérer de boutons d’administration.
    • Dire au navigateur que la page retournée est du json, et fournir le charset.
    • l. 2 et l .15, les crochets servent à indiquer que nous retournons plusieurs objets JSON, chacun correspondant à un évènements.
    • l. 2 nous bouclons sur les évènements. Entre chaque élèment de la boucle, nous affichons une virgule ({", "}). Nous trions par date de début : ceci servira plus loin lors de l’affichage des données sans Javascript.
    • l. 3-5 pour sélectionner les évènements, nous utilisons le critère agendafull. Les options de ce critère nous indique :
      • date_debut : que le champ date_debut servira pour repérer … date de début de sélection.
      • date_fin : que le champ date_fin servira pour repérer … date de fin de sélection.
      • periode que la période sélectionné sera déterminée par les options suivantes.
      • #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}},     #VAL{d}|date{#ENV{start}} que le début de la période correspond à la date passée dans #ENV{start}. La syntaxe un peu absconse que vous voyiez issu permet d’extraire, respectivement, l’année, le mois et la jour depuis un timestamp.
      • #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}</cpde> que la fin de la période correspond à la date passée dans <code>#ENV{end}.
  • l. 7-14 : nous remplissons un tableau SPIP via #ARRAY, puis nous le transformons en objet JSON, via le filtre ||json_encode. Ce tableau comprend les entrées suivantes :
    • id : identifiant unique pour FullCalendar. Ca tombe bien, SPIP attribut un identifiant à chaque évenement : #ID_EVENEMENT
    • title : le titre. On transforme les entité HTML en caractère unicode (|html2unicode) puis on s’assure de proposer des données avec le bon charset (|unicode2charset).
    • allDay : on précise si l’évènement dure toute la journée. Utilisée pour l’affichage par jour. Pour préciser cela, on s’appuie sur le champ #HORAIRE qui contient justement cette information. On utilise #EVAL pour indiquer qu’on insére une valeur booléenne et non pas textuelle.
    • start : date de début. On garde le format SQL.
    • end : date de fin. On garde le format SQL.
    • url : lien. Pour le coup, on renvoie vers l’article.
    • description : description de l’évènement. Là encore, on converti en Unicode, puis dans le charset correct.

À noter que l’on pourrait définir d’autres données pour chaque évènement : on se refera à la documentation de l’objet Event de FullCalendar. Par exemple, on pourrait indiquer des classe HTML en fonction de la rubrique.

Il vous faut également créer un fichier agenda.json_fonctions.php contenant les lignes suivantes :

  1. <?php
  2.  
  3. include_spip('inc/json');
  4. ?>

Télécharger

Ceci assurera que le filtre json_encode est bien chargé [1].

Et pour les personnes sans Javascript ?

Et oui, tout le monde n’a pas de Javascript. Comment on fait alors ? La solution consiste à afficher un calendrier sous forme de liste dans un div dont l’id est calendrier-loading. Si Javascript est activé, FullCalendar va masquer ce div.

Comme on a déjà fabriqué une boucle dans le squelette agenda.json.html, nous allons nous en reservir, afin d’éviter de dupliquer les critères. Pour ce faire, nous allons utiliser la boucle DATA de SPIP 3.

Nous mettons donc dans le squelette agenda.html :

  1. <B_agenda>
  2. <div id="calendrier-loading">
  3. <p class="pagination">#PAGINATION</p>
  4. <BOUCLE_agenda(DATA){source json, #PRODUIRE{fond=agenda.json, start=0,end=2147483647,_=#REM|time}}{pagination 15}>
  5. <dl>
  6. [<dt><:agenda:evenement_titre:></dt>
  7. <dd><a href="#VALEUR{url}">(#VALEUR{title})</a></dd>]
  8.  
  9. [<dt><:agenda:evenement_date:></dt>
  10. <dd>(#VALEUR{start}|Agenda_affdate_debut_fin{#VALEUR{end},#VALEUR{allDay}|=={true}|?{non,oui}})</dd>]
  11.  
  12. [<dt><:agenda:evenement_descriptif:></dt>
  13. <dd>(#VALEUR{description})</dd>]
  14. </dl>
  15. </BOUCLE_agenda>
  16. <p class="pagination">#PAGINATION</p>
  17. </div>
  18. </B_agenda>

Télécharger

  • l. 1-3 : partie optionnelle avant de la boucle, avec la pagination éventuelle.
  • l. 4 : code de la boucle. Nous bouclons sur des données ((DATA)) au format json ({source json) extrait du fichier produit (#PRODUIRE) par le squelette agenda.json.html avec la valeur de start égale à 0, c’est à dire au 1 janvier 1970 à minuit, et la valeur end égale à 2147483647, c’est à dire à la date maximale gérée par les ordinateurs actuel, le 19 janvier 2038, 3h14m7s [2]. Ainsi, nous sommes sûr de récuperer tout les évènements de l’agenda. L’option _=#REM|time permet de s’assurer de ne pas avoir de cache, puisque nous passons comme argument le moment d’appel (|time). Nous paginons de 15 en 15.
  • l. 5-14 : nous affichons les données pour chaque évènement, via #VALEUR{donne}. Ces données sont tirées du JSON.
  • l. 16 et suivante ; partie optionelle arrière de la boucle.

On obtient alors un agenda, certe sommaire, mais au moins existant sans Javascript :

PNG - 27.2 ko
Agenda pour les personnes sans Javascript

Conclusion

Vous voilà maintenant prêt à avoir un agenda avec FullCalendar. Bien sûr, il y aurait beaucoup de chose à améliorer, cependant cet article aborde déjà beaucoup de notions :
-  produire du JSON avec SPIP.
-  le formatage de FullCalendar.
-  les boucles DATA.

Notes

[1Dans certain cas, que je n’ai pas encore réussi à déterminer précisément, il n’y a pas besoin de cela...

[2Voir l’article sur le bug de l’an 2038.

Dernière modification de cette page le 29 octobre 2016

Retour en haut de la page

Tout afficher

Vos commentaires

  • Le 17 novembre à 16:35, par kramix En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour,

    déjà, merci pour la doc’ qui m’a bien aidée jusqu’à présent, mais voila que je calle... Et impossible de trouver ce que je cherche sur le net...

    Mon objectif est assez simple, ajouter une classe (Via un className) dans le json afin de pouvoir varier le Background-color en fonction de l’emplacement de l’évènement dans mon arborescence, via les stylesheets (Et ce sans toucher au JS, tant que possible... :x).

    Donc, voila déjà mon json :

    #HTTP_HEADER{Content-type:text/javascript;}
    [
    <BOUCLE_presse(EVENEMENTS){id_rubrique=6}{', '}{par date_debut}       
    {agendafull date_debut,date_fin, periode,
            #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}}, #VAL{d}|date{#ENV{start}},
            #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}}
            >
                                            [(#ARRAY{id,#ID_EVENEMENT,
    title,[(#TITRE|html2unicode|unicode2charset)],
    allDay,[(#HORAIRE|=={non}|?{#EVAL{true},#EVAL{false}})],
    start,#DATE_DEBUT,
    end,#DATE_FIN,
    url,#URL_ARTICLE,
    className,jaune,
    description,[(#DESCRIPTIF|html2unicode|unicode2charset)]}|json_encode)]
    </BOUCLE_presse>
    ,
    <BOUCLE_evenements(EVENEMENTS){id_rubrique!=6}{', '}{par date_debut}{doublons}
    {agendafull date_debut,date_fin, periode,
            #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}},     #VAL{d}|date{#ENV{start}},
            #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}}
            >
                                            [(#ARRAY{id,#ID_EVENEMENT,
    title,[(#TITRE|html2unicode|unicode2charset)],
    allDay,[(#HORAIRE|=={non}|?{#EVAL{true},#EVAL{false}})],
    start,#DATE_DEBUT,
    end,#DATE_FIN,
    url,#URL_ARTICLE,
    description,[(#DESCRIPTIF|html2unicode|unicode2charset)]}|json_encode)]
    </BOUCLE_evenements>]

    De base, aucun soucis, mon calendrier s’affiche correctement, les couleurs suivent... Mais, lorsque je regarde les évènements passés, je découvre que l’agenda n’affiche simplement pas les évènements de la période octobre 2015 à octobre 2016...

    Concernant le fichier HTML, il reste sensiblement le même que celui servant d’exemple ici, à la différence que j’ai adapté les chemins, bien sur...

    Des idées, des pistes, des erreurs à relever ?

    Merci d’avance !

    • Le 17 novembre à 16:38, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      a priori la question des couleurs et celle des évènements passés sont indépendantes.

      il faudrait ouvrir le fichier .json produit pour voir si les evenements y sont bien. Si ce n’est pas le cas, sans doute un problème dans le passage des paramètres.

    • Le 17 novembre à 16:42, par kramix En réponse à : SPIP 3, Agenda et FullCalendar

      Désolé pour le double post, mais j’ai oublié un détail intéressant :

      suivant l’identifiant de rubrique, le résultat n’est pas le même... Par exemple, si dans la deuxième boucle, j’utilise un « id_rubrique !=40 », pas de soucis, tout s’affiche, tandis qu’un « id_rubrique=40 » me renverra la même erreur que le « id_rubrique !=6 »... Et non, je ne me suis pas trompé, le problème s’inverse bien suivant l’ID rubrique, alors que rien ne le justifie dans mon arbo’...

    • Le 17 novembre à 16:45, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      honnetement, sans site de démo, je ne peux pas savoir. Il faut vraiment regarder le résultat du .json et vérifier que tout y est.

    • Le 17 novembre à 16:58, par kramix En réponse à : SPIP 3, Agenda et FullCalendar

      il faudrait ouvrir le fichier .json produit pour voir si les evenements y sont bien.

      Je l’ai fait, et oui, ils y sont... Je vais me pencher sur le passage des paramètres, du coup... En espérant ne pas y rester des jours.

      Merci !

    Répondre à ce message

  • Le 18 octobre à 15:38, par Cassius En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour,
    Serait-il possible, sous SPIP, de réaliser un agenda partagé multi-utilisateurs ?
    Il servirait à plusieurs associations pour afficher leurs prévisions de manifestations, activités, événements, afin de pouvoir éventuellement se concerter pour éviter de programmer des activités pouvant se concurrencer le même jour ou à la même période.
    Merci par avance,
    Cordialement,
    Patrick

    • Le 18 octobre à 16:54, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      Bah, heu oui, c’est possible. Il suffit d’un site SPIP avec le plugin agenda.

    • Le 18 octobre à 19:06, par Cassius36 En réponse à : SPIP 3, Agenda et FullCalendar

      Merci mais cela suffira-t-il pour que plusieurs associations utilisatrices aient chacune une ligne pour y inscrire (ou pas) leurs événements ? C’est d’un agenda MULTI-UTILISATEURS dont j’aurais besoin

    • Le 18 octobre à 19:08, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      bah heu… il suffit de créer un compte par association. je vois pas trop le souci.

    • Le 18 octobre à 22:19, par Cassius36 En réponse à : SPIP 3, Agenda et FullCalendar

      Tu veux dire que plusieurs utilisateurs peuvent utiliser un seul et même agenda (donc avec une ligne chacun dans un seul et même tableau) ? Car si plusieurs associations devaient toutes ouvrir l’agenda des autres pour savoir les événements qu’elles projettent, ça serait pas vraiment pratique !

    • Le 19 octobre à 10:42, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      oui. il y a une page qui résume tous les evenements dans l’espace privé. Tu peux selon ton arrangement mettre l’agenda sur un seul article, ou bien sur un article par association et la page récapitulative évite les chevauchement.

    • Le 25 octobre à 18:23, par cassius En réponse à : SPIP 3, Agenda et FullCalendar

      Bonsoir,

      J’ai ajouté le plugin Agenda 3 (avec son associé Calendrier mini qui l’accompagne automatiquement mais ça ne me fait pas apparaître pour autant un agenda quelque part...

      Comment faire ?

      Les explications ci-dessus sont largement hors de portée de ma comprenoire de total débutant !

      Cordialement,
      Cassius

    • Le 25 octobre à 18:27, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      quel squelette utilisez vous ?

    • Le 25 octobre à 19:04, par cassius En réponse à : SPIP 3, Agenda et FullCalendar

      Le squelette de base de SPIP.
      adresse : lasociale.lautre.net
      Et je n’y comprends rien !
      Je peux vous donner le mot de passe pour y entrer si vous voulez car c’est pour le moment un site d’essai.

      Cordialement,
      Cassius
      PS : Mais dans l’immédiat je vais dîner chez des amis...

    • Le 25 octobre à 22:05, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      Il faut juste savoir qu’il est normal que rien n’apparaisse, puisque cela relève du squelette de faire apparaître quelque chose… et que le squelette standard n’est pas prévu pour l’agenda, puisque celui-ci n’est pas livré avec SPIP.

      je vais essayer de fabriquer un plugin clickdrome pour installer cela automatiquement. Cela prend pas trop de temps normalement, mais pas avant ce week-end.

    • Le 25 octobre à 23:13, par cassius En réponse à : SPIP 3, Agenda et FullCalendar

      Merci beaucoup !

      Je pense que cela rendra bien service à de nombreux débutants comme moi et même à SPIP car ce genre de difficulté est de nature à détourner les gens de ce logiciel.

      Cordialement,
      Cassius

    • Le 29 octobre à 14:56, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      voilà, je t’invite à lire cet article : Agenda Fullcalendar facile.

    Répondre à ce message

  • Le 12 juillet à 18:04, par Christophe En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour,

    J’essaie d’éditer un formulaire de saisie des événements depuis l’interface publique (http://mnelille.lautre.net/spip.php?page=agenda_formulaire) mais je n’arrive pas à afficher les calendriers des dates comme dans l’interface privée et à faire en sorte que le calendrier des répétitions soit caché tant que je n’ai pas cliqué sur répétition. Certainement une fonction qu’il faut appeler mais je n’arrive pas trouver quoi...
    Merci par avance,
    Cordialement,

    Christophe

    • Le 12 juillet à 19:19, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      Ce message ne concerne pas cet article qui traite uniquement de l’affichage fullcalendar.

      Je vous suggère la prochaine fois de poser la question sur la liste des utilisateurs de SPIP.

      je n’ai aucune idée pour votre problème, mais je vous suggère de regarder ce que donne un &var_mode=inclure dans l’espace privé pour voir les squelettes utilisés et s’en inspirer.

      Bien à vous

    • Le 13 juillet à 09:51, par Christophe En réponse à : SPIP 3, Agenda et FullCalendar

      Ah oui désolé, j’ai vu Agenda 3 dans le titre et je me suis arrêté à ça.
      Cordialement,

    Répondre à ce message

  • Le 17 juin à 19:46, par  ??? En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour,
    y a t’il un moyen d’afficher le fullcalendar (affichage du calendrier) par année ??? si on choisit une année il y a tous les mois qui s’affichent et leurs événements
    MErci de votre réponse

    Répondre à ce message

  • Le 16 juin à 20:52, par Thomas En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour,

    Question bête... Où trouve-t-on le « Plugin Agenda 3.6.11 minimum »... ??
    Tout ce que je vois c’est la version 3.14.18 qui semble bien être la toute dernière version... (sur la page Contrib appellée Agenda 2.0 (sic)).. Vois pas de versions supérieures..

    Merci de votre aide (et du travail).

    Répondre à ce message

  • Le 14 juin à 11:47, par Teenoo En réponse à : SPIP 3, Agenda et FullCalendar

    Ah j’aime bien cette contrib :) Je pense que je vais l’utiliser sur un projet à la place du Calendrier Mini... En revanche, il y a un point que je souhaiterais voir avec vous.

    Comment pourrait-on gérer un lien vers une page (inclure) avec l’ensemble des événements du jour mais sur la même page en utilisant donc ajax ?
    A gauche le calendrier, à droite la liste des événements du jour, mise à jour au clic sur une date :)

    Merci pour les piste !

    Répondre à ce message

  • Le 20 avril à 22:56, par DD En réponse à : SPIP 3, Agenda et FullCalendar

    Hello,

    En utilisant le mode debug sur ma page spip.php ?page=agenda&var_profile=1&var_mode=recalcul il y a une erreur qui s’affiche (mais mon calendrier lui s’affiche bien) :

    Erreur SQL 1146
    1146Table 'site.agendas' doesn't exist
    SHOW CREATE TABLE `agendas`

    J’ai cherché mais pas trouvé d’où cela peut venir.

    dd

    Répondre à ce message

  • Le 2 mars à 13:43, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour et merci pour ce post,

    Tout fonctionne très bien pour moi. J’utilise l’agenda pour afficher la disponibilité d’une maison de location. En fait actuellement si j’ai une réservation cela marque une bande de couleur sur une date de réservation... et en fait j’aimerai faire l’inverse c’est à dire avoir toujours mon bandeau de couleur de visible sauf sur mes semaines de réservation. Du coup le bandeau de couleur marquerait les périodes disponibles.

    Merci d’avance

    • Le 2 mars à 13:47, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      Il serait assez complexe de marquer les disponibilités à partir des indisponibilités, puisque le temps est infini. Pourquoi tout simplement ne pas mettre dans l’agenda un evenement « disponible » ?

    • Le 2 mars à 16:17, par 1138 En réponse à : SPIP 3, Agenda et FullCalendar

      Et avec du CSS ?

    • Le 2 mars à 16:21, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      je ne vois pas comment.

    • Le 3 mars à 10:51, par 1138 En réponse à : SPIP 3, Agenda et FullCalendar

      Bon, je raconte peut-être des bêtises mais n’est-il pas possible de modifier légèrement le javascript pour donner une classe aux cellules ayant un contenu ?

      On pourrait dès lors choisir des couleurs de fond différentes (voire un texte, etc.) Bon, ce n’est pas exactement la demande de Julia – qui évoquait les bandes colorées – mais ça lui conviendrait peut-être.

    • Le 3 mars à 11:37, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

      Merci pour vos réponses,

      Ah oui effectivement avec la css je sais pas... peut être définir une bande colorée dans tout le tableau et lorsque la bande de réservation du tableau apparait elle viens se superposer sur l’autre... du coup si la bande de réservation est de la même couleur que le fond de la case on a l’impression d’une case vide.

    • Le 3 mars à 11:45, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      a mon avis il faut plus faire cela au niveau semantique. Prendre une periode de temps sufissament large (genre J-10 ans à J + 30 ans). Classer les reservations par date de début. Considérer que le début d’une réservation marque en réalité la fin d’une période libre, et que la fin d’une réservation marque le début de la période libre suivante.

    • Le 3 mars à 18:46, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

      Ok merci Maïeul pour ta réponse,

      Le truc c’est que ce n’est vraiment pas pratique à utiliser comme cela...

    • Le 3 mars à 18:48, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      j’ai bien compris. D’où ma suggestion de fabrique un agenda.json.html perso, qui inverse les infos. Cela ne doit pas etre très compliqué, mais je n’ai pas le temps de faire des tests…

    • Le 3 mars à 19:11, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

      ah oui je comprends mieux. Effectivement je ne sais pas coder en javascript donc ça va être trop compliqué pour moi.

      Merci pour tes réponses.

    • Le 3 mars à 19:13, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      en soi il n’y a pas besoin de savoir coder en javascript : il faut savoir coder en SPIP.

      Regardez à quoi ressemble le javascript généré -> cela vous fait un modèle. Il vous faut juste généré un js sur le même modèle, mais avec les dates autrements…

    • Le 5 mars à 18:54, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

      Merci,

      Je viens de regarder agenda.json.html et ce n’est pas vraiment du codage classique de boucle non plus.... je vais essayer de faire des tests à tâtons mais c’est pas gagné ;)

    • Le 5 mars à 18:57, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      à part l’emploi de #ARRAY, je ne vois pas en quoi ce n’est pas une boucle classique … une seule boucle …

    • Le 26 mars à 10:26, par Julia En réponse à : SPIP 3, Agenda et FullCalendar

      Bonjour,

      Bon après de nombreux tests infructueux, je n’ai toujours pas trouvé la bonne solution.... si quelqu’un peu m’aider ♥

      Merci

    Répondre à ce message

  • Le 12 janvier à 13:04, par gaston En réponse à : SPIP 3, Agenda et FullCalendar

    Bonjour ,

    J’utilisais ce pluging pour spip 2.1 pour un site d’association ;
    Le temps passe et je me dit qu’il faudrait que je migre le site sur spip 3.0.

    C’est un outil assez important pour l’association, donc pour le moment, impossible de quitter spip 2.1, et j’espère qu’il sera encore mise a jour quelques temps...

    Je vois que ce pluging est passé en « contribution pédagogique », mais au vue des commentaires, cela semble marcher pour spip 3, par contre je voie pas où je peux le telecharger pour tester ?

    • Le 12 janvier à 13:49, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      Passer en SPIP 3.0, voire mieux en SPIP 3.1est effectivement une bonne idée. Le plugin agenda se telecharge sur la page dédiée, voire mieux s’installe depuis l’espace privée de SPIP 3.1.

      Quant à fullcalendar (affichage du calendrier) il est livré avec SPIP 3.1, donc inutile de se fatiguer.

    • Le 12 janvier à 16:00, par gaston En réponse à : SPIP 3, Agenda et FullCalendar

      Merci de votre réponse
      FULL Calendar est dans spip 3.1 ? super !

      Je vais regarder ça, je voulais d’abord passé de 2.1 a 3.0 pour voir si il y avait de gros bug, a priori non, je vais passer au 3.1, et voir comment cela se présente.

    • Le 12 janvier à 17:22, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      pour être précis fullcalendar est livré avec le plugins « organiseur » livré par défaut avec SPIP 3.0 et 3.1 et normalement non désactivable depuis l’espace privé.

    • Le 26 février à 13:43, par Ruchemania En réponse à : SPIP 3, Agenda et FullCalendar

      Bonjour
      Je suis sous SPIP 3.1 et quand je suis les explication, je fais tout ce qui et dit, j’ai bien l’affichage du tableau mais tout le texte est en dessous, puis encore dessous comme si je n’avais pas le le javascript.
      Pour SPIP 3.x y à il juste un code à insérer ?
      Merci

    • Le 26 février à 13:49, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      heu, je n’ai pas compris. Normalement si vous suivez cela, ça doit marcher. On peut avoir une url d’exemple ?

    • Le 26 février à 17:53, par Ruchemania En réponse à : SPIP 3, Agenda et FullCalendar

      voilà le lien vers la page agenda : http://agenda-gers.fr/spip.php?page=agenda

    • Le 27 février à 18:26, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      je viens de regarder, et je ne vois AUCUN intégration de fullcalendar…

    • Le 3 mars à 13:29, par ruchemania En réponse à : SPIP 3, Agenda et FullCalendar

      Bonjour
      En fait cela venait d’un problème d’affichage du au CSS
      Merci

    Répondre à ce message

  • Le 9 novembre 2015 à 23:36, par Cécile En réponse à : SPIP 3, Agenda et FullCalendar

    Bonsoir
    J’ai suivi les explications d’un post du forum plus bas pour afficher les événements différents avec plusieurs couleurs en fonction du mot clé de l’article et j’aimerai que ces couleurs s’affichent visuellement toujours dans le même ordre mais je n’y arrive pas.
    j’ai rajouté par num titre à la boucle événements, ce qui en classe certaines mais pas toutes...
    http://www.gite-cabane-ali-nais.com/Tarifs-Formulaire-de-reservation (par ex. voir décembre 30/12 au 03/01, le vert et orange ne sont pas sur la même ligne)... il parait que ça perturbe les internautes qui veulent réserver...
    Merci

    1. #HTTP_HEADER{Content-type:text/javascript;}
    2. [
    3. <BOUCLE_evenements(EVENEMENTS){', '}{par num titre}
    4. {agendafull date_debut,date_fin, periode,
    5. #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}}, #VAL{d}|date{#ENV{start}},
    6. #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}}
    7. >
    8. <BOUCLE_mot(MOTS){id_article}>
    9. [(#ARRAY{id,#ID_EVENEMENT,
    10. title,[(#_evenements:TITRE|html2unicode|unicode2charset)],
    11. allDay,[(#HORAIRE|=={non}|?{#EVAL{true},#EVAL{false}})],
    12. start,#DATE_DEBUT,
    13. end,#DATE_FIN,
    14. className,#TITRE,
    15. description,[(#DESCRIPTIF|html2unicode|unicode2charset)]}|json_encode)]
    16. </BOUCLE_mot>
    17. </BOUCLE_evenements>
    18. ]

    Télécharger

    • Le 10 novembre 2015 à 10:10, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      si j’ai bien compris 1 mot = 1 couleur. vous voulez classer par couleur -> donc vous voulez classer par mot.

      Donc il faut inverser la logique des boucles : d’abord une boucle MOTS, puis une boucle article dans la boucle mot, puis une boucle evenement dans la boucle article. Cela devrait normalement fonctionner (à tester)

    • Le 12 novembre 2015 à 21:30, par Cécile En réponse à : SPIP 3, Agenda et FullCalendar

      Bonjour et merci Maïeul

      Après pas mal de tâtonnements j’ai fini par « presque » y arriver... Si pour des plages de dates, j’ai des évènements avec les 3 couleurs, celles ci s’affichent dans le bon ordre (violet, orange, vert) mais si par exemple j’ai des dates de réservation qui se chevauchent avec 1 ou 2 couleurs, ça ne marche plus...

      j’ai fini par comprendre que c’était logique, en fait, il faudrait que dans le calendrier un espace fixe soit allouée à chaque couleur... 1 couleur ---> on la voit et pas de couleur —> du vide. Je n’ai pas l’impression que l’on puisse gérer ça avec les css puisque les évènements sont positionnés en absolu avec left, top et width en fonction des dates.

      Sinon, javascript désactivé j’aurai bien aimé n’afficher que les réservations à partir de la date du jour mais start<=0 comme age<=0 ne fonctionne pas sur la boucle agenda de agenda.html

      http://www.gite-cabane-ali-nais.com/spip.php?page=agenda2 (décembre est plus parlant visuellement)

      1. #HTTP_HEADER{Content-type:text/javascript;}
      2. #SET{virgule,''}
      3. [
      4. <BOUCLE_mots(MOTS){id_groupe=2}{par titre}>
      5. <BOUCLE_article(ARTICLES){id_mot}{par titre}>
      6. <B_evenements>
      7. #GET{virgule}
      8. <BOUCLE_evenements(EVENEMENTS){', '}{id_article}{!par date}
      9. {agendafull date_debut,date_fin, periode,
      10. #VAL{Y}|date{#ENV{start}}, #VAL{m}|date{#ENV{start}}, #VAL{d}|date{#ENV{start}},
      11. #VAL{Y}|date{#ENV{end}}, #VAL{m}|date{#ENV{end}}, #VAL{d}|date{#ENV{end}}}
      12. >
      13. <BOUCLE_mot(MOTS){id_article}>
      14. [(#ARRAY{id,#ID_EVENEMENT,
      15. title,[(#_evenements:TITRE|html2unicode|unicode2charset)],
      16. allDay,[(#HORAIRE|=={non}|?{#EVAL{true},#EVAL{false}})],
      17. start,#DATE_DEBUT,
      18. end,#DATE_FIN,
      19. className,#TITRE,
      20. description,[(#DESCRIPTIF|html2unicode|unicode2charset)]}|json_encode)]
      21. </BOUCLE_mot>
      22. </BOUCLE_evenements>
      23. #SET{virgule,','}
      24. </B_evenements>
      25. </BOUCLE_article>
      26. </BOUCLE_mots>
      27. ]

      Télécharger

    • Le 12 novembre 2015 à 21:36, par Maïeul En réponse à : SPIP 3, Agenda et FullCalendar

      a oui, evidemment. Peut être une solution : mettre des faux evenements si pas de mots clef ? on laisse la boucle calculer cela.

      L’argument start je ne connais pas en general. Mais {age} ne peut pas fonctionner, il faut utiliser {age_debut} (de même que {date} n’existe pas, mais {date_debut}.

    Répondre à ce message

Répondre à cet article

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 Les choses à faire avant de poser une question (Prolégomènes aux rapports de bugs. )
Ajouter un document

Retour en haut de la page

Ça discute par ici

  • Metas +

    3 décembre – commentaires

    Améliorez l’indexation de vos articles dans les moteurs et leur affichage sur les réseaux sociaux grâce aux métadonnées Dublin Core, Open Graph et Twitter Card. Installation Activer le plugin dans le menu dédié. Dans le panel de configuration, (...)

  • Critère {mots}

    6 août 2009 – 316 commentaires

    Permettre de sélectionner facilement des objets SPIP ayant un ou des mots clefs en communs.

  • LinkCheck : vérificateur de liens

    13 février 2015 – 64 commentaires

    Ce plugin permet de chercher et tester l’ensemble des liens présents dans les objets. Vous pourrez donc en quelques clics connaître les liens brisés ou défectueux qui se sont immiscés dans le contenu de votre site SPIP. La vérification s’effectue en (...)

  • Import ICS 2 (agenda distant)

    2 août – 39 commentaires

    La version 2 du plugin « import ICS » en reprend la principale fonctionnalité, à savoir l’ajout automatique d’évènements distants dans la liste des évènements d’un site. À la différence de la première version, elle ne dépend pas du plugin « Séminaire » et est (...)

  • GIS 4

    11 août 2012 – 1286 commentaires

    Présentation et nouveautés La version 4 de GIS abandonne la libraire Mapstraction au profit de Leaflet. Cette librairie permet de s’affranchir des librairies propriétaires tout en gardant les mêmes fonctionnalités, elle propose même de nouvelles (...)