events from Google Calendar
FullCalendar can display events from a public Google Calendar. Google Calendar can serve as a backend that manages and persistently stores event data (a feature that FullCalendar currently lacks).
Before you code…
You must first have a Google Calendar API Key:
- Go to the Google Developer Console and create a new project (it might take a second).
- Once in the project, go to APIs & auth > APIs on the sidebar.
- Find “Calendar API” in the list and turn it ON.
- On the sidebar, click APIs & auth > Credentials.
- In the “Public API access” section, click “Create new Key”.
- Choose “Browser key”.
- If you know what domains will host your calendar, enter them into the box. Otherwise, leave it blank. You can always change it later.
- Your new API key will appear. It might take second or two before it starts working.
Make your Google Calendar public:
- In the Google Calendar interface, locate the “My calendars” area on the left.
- Hover over the calendar you need and click the downward arrow.
- A menu will appear. Click “Share this Calendar”.
- Check “Make this calendar public”.
- Make sure “Share only my free/busy information” is unchecked.
- Click “Save”.
Obtain your Google Calendar’s ID:
- In the Google Calendar interface, locate the “My calendars” area on the left.
- Hover over the calendar you need and click the downward arrow.
- A menu will appear. Click “Calendar settings”.
- In the “Calendar Address” section of the screen, you will see your Calendar ID. It will look something like “abcd1234@group.calendar.google.com”.
Getting Set Up
You must include the google-calendar
plugin. If you are using an ES6 build system then do something like this:
import { Calendar } from '@fullcalendar/core';
import googleCalendarPlugin from '@fullcalendar/google-calendar';
...
let calendar = new Calendar(calendarEl, {
plugins: [ googleCalendarPlugin ]
});
Alternatively, you can use a global bundle:
<script src='fullcalendar/dist/index.global.js'></script>
<script>
...
var calendar = new FullCalendar.Calendar(calendarEl, {
// no plugin config required!
});
...
</script>
Writing the code
Now it’s time to initialize your calendar in JavaScript. This is the most minimal example:
let calendar = new Calendar(calendarEl, {
plugins: [ googleCalendarPlugin ],
googleCalendarApiKey: '<YOUR API KEY>',
events: {
googleCalendarId: 'abcd1234@group.calendar.google.com'
}
});
If you want to specify some Event Source options, you can include them in the events
object:
let calendar = new Calendar(calendarEl, {
plugins: [ googleCalendarPlugin ],
googleCalendarApiKey: '<YOUR API KEY>',
events: {
googleCalendarId: 'abcd1234@group.calendar.google.com',
className: 'gcal-event' // an option!
}
});
View a demo that displays US holidays from Google Calendar.
Multiple Google Calendars
You can specify multiple Google Calendars by using the eventSources
option:
<script type='text/javascript'>
document.addEventListener('DOMContentLoaded', function() {
var calendarEl = document.getElementById('calendar');
var calendar = new FullCalendar.Calendar(calendarEl, {
googleCalendarApiKey: '<YOUR API KEY>',
eventSources: [
{
googleCalendarId: 'abcd1234@group.calendar.google.com'
},
{
googleCalendarId: 'efgh5678@group.calendar.google.com',
className: 'nice-event'
}
]
});
calendar.render();
});
</script>
Extended Properties
Google Calendar’s API allows you to specify Extended Properties for your events. The extended properties will be available in the extendedProps
hash of each Event Object.
Advanced
If you need different API keys per calendar, you can set a googleCalendarApiKey
option on each individual Event Source when written in extended form.
For detecting errors, use the Event Source Object’s failure
callback.