Skip to content

agence-webup/calendar

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

51 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Démo

https://agence-webup.github.io/calendar/

Installation

Ajout du CSS :

<link rel="stylesheet" href="https://rawgit.com/agence-webup/calendar/master/dist/calendar.css">

Ajout du JS :

<script src="https://rawgit.com/agence-webup/calendar/master/dist/calendar.js"></script>

Initialisation

Création de la base :

<div id="calendar"></div>

En ce qui concerne les contrôles, la base est libre, il suffit juste de bien spécifier les ID et de les passer dans options.ui :

<button id="prev"><</button>
<button id="today">today</button>
<button id="next">></button>

Instanciation du calendrier :

let calendar = new Calendar("#calendar", {
    currentDay: new Date(),
    numberOfDays: 3,
    columnsPerDay: 3,
    dayStartHour: '08:00',
    dayEndHour: '18:00',
    slotDuration: 20,
    cssClass: 'calendar',
    ui: {
        next: document.querySelector('#next'),
        prev: document.querySelector('#prev'),
        today: document.querySelector('#today'),
    },
    isCellBlocked: function(timestamp) {
        // block cells with condition
        return Date.now() > timestamp;
    },
    isCellSplited: function(timestamp) {
        return splitedSlots.includes(timestamp);
    },
    onEventClicked: function(eventId) {
        const eventIds = events.map(event => event.id); 
        alert(`Clicked events IDs: ${eventIds.join(', ')}`);
    },
    onLocked: function(start, end, callback) {
        console.log(start + '->' + end);
        setTimeout(() => {
            // commit event
            callback(null, {
                start: new Date(2017, 6, 11, 12, 0, 0, 0),
                end: new Date(2017, 6, 11, 14, 0, 0, 0),
                column: 1,
            });
        }, 1000);
    },
    onPeriodChange: function(start, end) {
        console.log(this);
        console.log(start + ' ->', end);
        this.loadEvents(events, blockedEvents);
    }
});

Callback

méthode explication
onEventClicked Appelé lors du clic sur un évènement. Renvoi l'identifiant de l'évènement / des évènements si plusieurs d'entre eux ont été mergés automatiquement
onLocked Appelé lors du blocage d'une plage horaire. Renvoi le début et la fin de la plage, ainsi qu'un callback devant être utilisé pour confirmer l'ajout de la plage après le traitement côté serveur
onPeriodChange Appelé lors d'un changement de période avec les boutons suivant, précédent et aujourd'hui. Renvoi le début et la fin de la nouvelle période. Important: il est nécessaire de penser à recharger les évènements liés à cette nouvelle période en utilisant la méthode loadEvents

Modes

Ajouter une nouvelle tâche

calendar.startAddEventMode(60, (timestamp, column) => {
    alert('Drop on column ' + column + ' at ' + timestamp);
});

Editer une tâche

calendar.startEditMode(1, (timestamp, column) => {
  alert('Drop on column ' + column + ' at ' + timestamp);
});

Bloquer des plages horaire

calendar.startLockedMode();

Supprimer un événement

# remove event with id 1
calendar.removeEvent(1);

About

Module de calendrier développé pour une application de gestion

Resources

License

Stars

Watchers

Forks

Packages

No packages published