Créer un calendrier dynamique en Javascript avec FullCalendar

Posté par seiyar81 le 24 octobre 2010 | Laisser un commentaire (0)

Comme on le sait jQuery possède un nombre de plugins tout simplement énorme ! Il y a certes du tri à faire et certains plugins tente de réinventer la roue, en vain…

FullCalendar ne fait pas partie de ceux-là. Vous avez besoin d’ajouter un calendrier permettant une gestion des évènements, un affichage par jour/semaine/mois, et thèmable ? Alors il vous faut FullCalendar !

Le plugin offre plusieurs vues pour afficher les évènements : par jour, semaine, mois avec des versions type agenda ou basique.
Un de ces autres points forts c’est d’être compatible avec jQuery UI et il s’adapte ainsi à votre thème tout seul, plutôt pratique.
Une extension lui permet même de récupérer les évènements de votre Google Calendar !

Voyons voir un peu comment le mettre en place :

	$(document).ready(function() {

		var date = new Date();
		var d = date.getDate();
		var m = date.getMonth();
		var y = date.getFullYear();

		$('#calendar').fullCalendar({
			header: {
				left: 'prev,next today',
				center: 'title',
				right: 'month,agendaWeek,agendaDay'
			},
			theme: true,
			editable: true,
			events: [
				{
					id: 1
					title: 'Aller sur Yriase.fr',
					start: new Date(y, m, 28),
					end: new Date(y, m, 29),
					url: 'http://www.yriase.fr/',
					allDay: true
				},
				{
					id: 2
					title: 'Nourrir le chat !',
					start: new Date(y, m, 28, 8, 0),
					end: new Date(y, m, 29, 8, 15),
					allDay: false
				}
			]
		});

	});

Ce bout de code plutôt simple, inialise votre Calendrier avec 2 évènements et l’adaptation au thème jQuery UI. Le proriété editable indique que les évènements ne peuvent être déplacés (peut être remplacée par la propriété editable de chanque évènement).

Comme vous pouvez le constater les évènements sont en réalité des objets JSON, auxquels on peut donc ajouter des proriétés.
Ainsi on peut par exemple ajouter une propriété type qui pourrait nous permettre de filtrer les évènements par type.
Ce qui serait encore mieux serait de pouvoir ajouter un bouton ou ensemble de boutons pour filtrer, qui soient intégrés au calendrier.
Ca tombe bien, j’avais prévu d’expliquer comme faire !

Le but de la manoeuvre est simple, ajouter des boutons au calendrier simplement en modifiant les valeurs dans la déclaration de la propriété header. Par exemple :

			header: {
				left: 'prev,next today',
				center: 'title',
				right: 'all,mandatory,not_mandatory month,agendaWeek,agendaDay'
			}

On ajoute ici trois boutons donc all,mandatory, not_mandatory pour afficher/cacher les évènements obligatoires ou pas. Pas très original mais c’est bon pour l’exemple !

Maintenant il va nous falloir modifier un petit peu le fichier fullcalendar.js.
Aux alentours de la ligne 80, la déclaration de la propriété buttonText.
Ajouter au tableau les lignes :
all: ‘All’,
mandatory: ‘Mandatory’,
not_mandatory: ‘Not Mandatory’,

Ensuite vers la ligne 710 cherchez :

              if (publicMethods[buttonName]) {
			buttonClick = publicMethods[buttonName];
	      }
	       else if (views[buttonName]) {
			buttonClick = function() {
			  button.removeClass(tm + '-state-hover');
			  changeView(buttonName)
			};
	     }

et ajoutez après :

else {
      buttonClick = function() {
	button.removeClass(tm + '-state-hover');
        button.addClass(tm + '-state-active');
        if(button.hasClass('fc-button-all')) {
              $('.fc-button-mandatory').removeClass(tm + '-state-active');
              $('.fc-button-not_mandatory').removeClass(tm + '-state-active');
        } else if (button.hasClass('fc-button-mandatory')) {
              $('.fc-button-all').removeClass(tm + '-state-active');
              $('.fc-button-not_mandatory').removeClass(tm + '-state-active');
        } else if (button.hasClass('fc-button-not_mandatory')) {
              $('.fc-button-all').removeClass(tm + '-state-active');
              $('.fc-button-mandatory').removeClass(tm + '-state-active');
        }
      };
 }

Cette partie s’occupe de marquer comme actif le bouton cliqué.
Enfin juste après se trouve cette partie :

if (icon) {
	button = $("
"); } else if (text) { ...

Mettez dans le corps du else if(text) :

if(buttonName == 'all')
  button = $("


");
else
  button = $("


");

Maintenant il ne vous reste plus qu’a mettre en place les fonctions pour filtrer les évènements selon leur type.
Mais ça ce sera pour une autre fois !

Catégorie: Développement Web, Javascript | Laisser un commentaire (0)

Giganews atteint 800 jours de rétention

Posté par seiyar81 le 17 octobre 2010 | Laisser un commentaire (0)
Giganews Usenet Newsgroup

Giganews Usenet vient d’officialiser son passage à 800 jours de rétention binaire assurée ! D’abord le premier à atteindre 1 an de rétention puis 2 aujourd’hui la limite des 800 jours vient d’être atteinte et ce n’est pas fini !

En effet Giganews Usenet compte bien continuer sur sa lancée et proposer à ses clients bien plus que 800 jours, avec comme objectif de toujours garder au minimum 99% de complétion.

A noter également que de nouvelles fonctionnalités ont été ajoutées à VyprVPN, le sevice de VPN offert avec l’abonnement Diamond de Giganews Usenet.
On peut maintenant se connecter au VPN via L2TP, OpenVPN et PPTP !

De plus il est possible de rajouter pour 5$/mois une option ajoutant un pare-feu NAT.
Ce pare-feu protège votre connexion VPN en rejetant par exemple les paquets envoyés par des personnes mal intentionnées.
A essayer d’urgence donc ! Plus de détail sur le blog de Golden Frog.

Catégorie: Brèves, Geek, Internet | Laisser un commentaire (0)

QtBlogger : quelques nouvelles

Posté par seiyar81 le 15 octobre 2010 | Laisser un commentaire (0)

Logo QtBlogger

Pas de news depuis un moment, essentiellement à cause du temps que prend le développement de QtBlogger et aussi mon activité professionnelle.
La moindre des choses est donc de donner des news de l’avancement du projet !

Plusieurs fonctionnalités sont maintenant pleinement opérationnelles :

  • Gestions des articles et des pages
  • Gestion des commentaires (par articles ou bien tous)
  • Gestion des mots-clefs/catégories
  • Gestion des médias : partie très importante de QtBlogger
    • l’éditeur d’image possède un système de plugin pour lui ajouter des fonctionnalités
    • filtrages des médias par mots-clefs
  • Gestion des paramètres : tous les paramètres du blog peuvent être gérés via QtBlogger

Voilà pour une liste succinte des fonctionnalités présentes, les principales à venir sont :

  • Gestion des plugins du blog : activation/désactivation, mises à jour, et prise en charge des options
  • Suggestion d’image pendant la rédaction des articles/pages
  • Gestion des liens, des templates, des widgets et enfin un éditeur pour modifier les fichiers (coloration syntaxique etc)

Maintenant on retourne travailler avant de revenir donner d’autres nouvelles !

Catégorie: Qt, Wordpress, Yriase | Laisser un commentaire (0)