Full Calendar
Bootstrap full calendar plugin
Note: This documentation is for an older version of Bootstrap (v.4). A
newer version is available for Bootstrap 5. We recommend migrating to the latest version of our product - Material Design for
Bootstrap 5.
Go to docs v.5
Bootstrap full calendar plugin is an extension that allows you to create calendar functionality.
Thanks to this plugin you will be able to easily create new events, manage current events, move existing events between other days, and integrate with your Google Calendar.
To start working with full calendar plugin see "Getting Started" tab on this page.
Basic Example
A few predefined events allowing you to see how the plugin looks like.
<div id="calendar"></div>
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay,listWeek'
},
defaultDate: '2018-11-16',
navLinks: true,
eventLimit: true,
events: [{
title: 'Front-End Conference',
start: '2018-11-16',
end: '2018-11-18'
},
{
title: 'Hair stylist with Mike',
start: '2018-11-20',
allDay: true
},
{
title: 'Car mechanic',
start: '2018-11-14T09:00:00',
end: '2018-11-14T11:00:00'
},
{
title: 'Dinner with Mike',
start: '2018-11-21T19:00:00',
end: '2018-11-21T22:00:00'
},
{
title: 'Chillout',
start: '2018-11-15',
allDay: true
},
{
title: 'Vacation',
start: '2018-11-23',
end: '2018-11-29'
},
]
});
Dynamically added events
Find out how easy it is to add new events with the Full Calendar plugin! One button, and the event is already in your calendar.
<div id="calendar"></div>
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'addEventButton',
right: 'month,agendaWeek,agendaDay,listWeek'
},
defaultDate: '2018-11-16',
navLinks: true,
editable: true,
eventLimit: true,
events: [{
title: 'Simple static event',
start: '2018-11-16',
description: 'Super cool event'
},
],
customButtons: {
addEventButton: {
text: 'Add new event',
click: function () {
var dateStr = prompt('Enter date in YYYY-MM-DD format');
var date = moment(dateStr);
if (date.isValid()) {
$('#calendar').fullCalendar('renderEvent', {
title: 'Dynamic event',
start: date,
allDay: true
});
} else {
alert('Invalid Date');
}
}
}
},
dayClick: function (date, jsEvent, view) {
var date = moment(date);
if (date.isValid()) {
$('#calendar').fullCalendar('renderEvent', {
title: 'Dynamic event from date click',
start: date,
allDay: true
});
} else {
alert('Invalid');
}
},
});
Events with tooltips
You can easily add tooltip to an event in the calendar. This way you can easily remember what this event is all about.
<div id="calendar"></div>
$('#calendar').fullCalendar({
defaultView: 'month',
defaultDate: '2018-11-12',
eventRender: function (eventObj, $el) {
$el.popover({
title: eventObj.title,
content: eventObj.description,
trigger: 'hover',
placement: 'top',
container: 'body'
});
},
events: [{
title: 'All Day Event',
description: 'description for All Day Event',
start: '2018-11-01'
},
{
title: 'Long Event',
description: 'description for Long Event',
start: '2018-10-07',
end: '2018-11-10'
},
{
id: 999,
title: 'Repeating Event',
description: 'description for Repeating Event',
start: '2018-11-09T16:00:00'
},
{
id: 999,
title: 'Repeating Event',
description: 'description for Repeating Event',
start: '2018-11-16T16:00:00'
},
{
title: 'Conference',
description: 'description for Conference',
start: '2018-11-11',
end: '2018-11-13'
},
{
title: 'Meeting',
description: 'description for Meeting',
start: '2018-11-12T10:30:00',
end: '2018-11-12T12:30:00'
},
{
title: 'Lunch',
description: 'description for Lunch',
start: '2018-11-12T12:00:00'
},
{
title: 'Meeting',
description: 'description for Meeting',
start: '2018-11-12T14:30:00'
},
{
title: 'Birthday Party',
description: 'description for Birthday Party',
start: '2018-11-13T07:00:00'
},
{
title: 'Click for Google',
description: 'description for Click for Google',
url: 'http://google.com/',
start: '2018-11-28'
}
]
});
Movable events
Didn't you do something today? Set it aside for tomorrow! Full Calendar allows you to move events between other days.
<div id="calendar"></div>
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay,listWeek'
},
defaultDate: '2018-11-16',
navLinks: true,
editable: true,
eventLimit: true,
events: [{
title: 'All Day Event',
start: '2018-11-01'
},
{
title: 'Long Event',
start: '2018-11-07',
end: '2018-11-10'
},
{
id: 999,
title: 'Repeating Event',
start: '2018-11-09T16:00:00'
},
{
id: 999,
title: 'Repeating Event',
start: '2018-11-16T16:00:00'
},
{
title: 'Conference',
start: '2018-11-11',
end: '2018-11-13'
},
{
title: 'Meeting',
start: '2018-11-12T10:30:00',
end: '2018-11-12T12:30:00'
},
{
title: 'Lunch',
start: '2018-11-12T12:00:00'
},
{
title: 'Meeting',
start: '2018-11-12T14:30:00'
},
{
title: 'Happy Hour',
start: '2018-11-12T17:30:00'
},
{
title: 'Dinner',
start: '2018-11-12T20:00:00'
},
{
title: 'Birthday Party',
start: '2018-11-13T07:00:00'
},
{
title: 'Click for Google',
url: 'https://google.com/',
start: '2018-11-28'
}
]
});
Long dynamic events
Select few days and create an event with one click! Just like in Google Calendar.
<div id="calendar"></div>
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'addEventButton',
right: 'month,agendaWeek,agendaDay,listWeek'
},
defaultDate: '2018-11-16',
navLinks: true,
editable: true,
eventLimit: true,
events: [{
title: 'Simple static event',
start: '2018-11-16',
description: 'Super cool event'
},
],
customButtons: {
addEventButton: {
text: 'Add new event',
click: function () {
var dateStr = prompt('Enter date in YYYY-MM-DD format');
var date = moment(dateStr);
if (date.isValid()) {
$('#calendar').fullCalendar('renderEvent', {
title: 'Dynamic event',
start: date,
allDay: true
});
} else {
alert('Invalid Date');
}
}
}
},
dayClick: function (date, jsEvent, view) {
var date = moment(date);
if (date.isValid()) {
$('#calendar').fullCalendar('renderEvent', {
title: 'Dynamic event from date click',
start: date,
allDay: true
});
} else {
alert('Invalid');
}
},
});
Full Calendar options list
Below options are available to use in Full Calendar.
Name | Type | Default | Description | Available values | Example |
---|---|---|---|---|---|
header |
object | left: 'title', center: ' ', right: 'today prev, next' | Defines the buttons and title at the top of the calendar. | title, prev, next, prevYear, nextYear, today |
header: {left: 'title', center: ' ', right: 'today prev, next' } |
footer |
object | false | Defines the controls at the bottom of the calendar. | title, prev, next, prevYear, nextYear, today |
footer: {left: 'title', center: ' ', right: 'today prev, next' } |
titleFormat |
object | - | Determines the text that will be displayed in the header’s title. | - |
titleFormat: 'MM/YYYY' |
buttonText |
object | buttonText: {today: 'today', month: 'month, week: 'week', day: 'day', list: 'list'} | Defines the buttons and title at the top of the calendar. | - |
buttonText: {today: 'today', month: 'month, week: 'week', day: 'day', list: 'list'} |
buttonIcons |
object | prev: 'left-single-arrow', next: 'right-single-arrow', prevYear: 'left-double-arrow', nextYear: 'right-double-arrow' | Icons that will be displayed in buttons of the header/footer. | 'left-single-arrow', 'right-single-arrow', 'left-double-arrow', 'right-double-arrow' |
buttonIcons: {next: 'right-single-arrow', prevYear: 'left-double-arrow', nextYear: 'right-double-arrow'} |
customButtons |
object | - | Defines custom buttons that can be used in the header/footer. Specify a hash of custom buttons. Then reference them from the header setting. | text, click, icon, themeIcon, bootstrapGlyphicon |
customButtons: { myCustomButton: { text: 'Custom', click: function() { alert('Clicked the custom button'); } } }, header: {left: 'myCustomButton', center: ' ', right: ' ' } |
Below events are available to use in Full Calendar.
Name | Type | Description | Example |
---|---|---|---|
eventClick |
any | The event is fired when user has clicked the event. | eventClick: function(calEvent, jsEvent, view) { console.log('click', calEvent.title); } |
eventMouseover |
any | The event is fired when user has mouseover the event. | eventMouseover: function(calEvent, jsEvent, view) { console.log('mouseover', calEvent); } |
eventMouseout |
any | The event is fired when user has mouseout the event. | eventMouseout: function(calEvent, jsEvent, view) { console.log('mouseout', calEvent); } |
Full Calendar - getting started : download & setup
Download
This plugin requires a purchase.
Buy full calendar plugin
Installation tutorial
Note: The video below shows a different plugin, but it does not matter. The installation process is the same for all plugins.