https://agence-webup.github.io/calendar/
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>
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);
}
});
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 |
calendar.startAddEventMode(60, (timestamp, column) => {
alert('Drop on column ' + column + ' at ' + timestamp);
});
calendar.startEditMode(1, (timestamp, column) => {
alert('Drop on column ' + column + ' at ' + timestamp);
});
calendar.startLockedMode();
# remove event with id 1
calendar.removeEvent(1);