@maxim_mazurok/gapi.client.calendar-v3
TypeScript icon, indicating that this package has built-in type declarations

0.0.20250714 • Public • Published

TypeScript typings for Calendar API v3

Manipulates events and other calendar data. For detailed description please check documentation.

Installing

Install typings for Calendar API:

npm install @types/gapi.client.calendar-v3 --save-dev

Usage

You need to initialize Google API client in your code:

gapi.load('client', () => {
  // now we can use gapi.client
  // ...
});

Then load api client wrapper:

gapi.client.load(
  'https://calendar-json.googleapis.com/$discovery/rest?version=v3',
  () => {
    // now we can use:
    // gapi.client.calendar
  },
);
// Deprecated, use discovery document URL, see https://github.com/google/google-api-javascript-client/blob/master/docs/reference.md#----gapiclientloadname----version----callback--
gapi.client.load('calendar', 'v3', () => {
  // now we can use:
  // gapi.client.calendar
});

Don't forget to authenticate your client before sending any request to resources:

// declare client_id registered in Google Developers Console
var client_id = '',
  scope = [
    // See, edit, share, and permanently delete all the calendars you can access using Google Calendar
    'https://www.googleapis.com/auth/calendar',

    // See and change the sharing permissions of Google calendars you own
    'https://www.googleapis.com/auth/calendar.acls',

    // See the sharing permissions of Google calendars you own
    'https://www.googleapis.com/auth/calendar.acls.readonly',

    // Make secondary Google calendars, and see, create, change, and delete events on them
    'https://www.googleapis.com/auth/calendar.app.created',

    // See, add, and remove Google calendars you’re subscribed to
    'https://www.googleapis.com/auth/calendar.calendarlist',

    // See the list of Google calendars you’re subscribed to
    'https://www.googleapis.com/auth/calendar.calendarlist.readonly',

    // See and change the properties of Google calendars you have access to, and create secondary calendars
    'https://www.googleapis.com/auth/calendar.calendars',

    // See the title, description, default time zone, and other properties of Google calendars you have access to
    'https://www.googleapis.com/auth/calendar.calendars.readonly',

    // View and edit events on all your calendars
    'https://www.googleapis.com/auth/calendar.events',

    // See the availability on Google calendars you have access to
    'https://www.googleapis.com/auth/calendar.events.freebusy',

    // See, create, change, and delete events on Google calendars you own
    'https://www.googleapis.com/auth/calendar.events.owned',

    // See the events on Google calendars you own
    'https://www.googleapis.com/auth/calendar.events.owned.readonly',

    // See the events on public calendars
    'https://www.googleapis.com/auth/calendar.events.public.readonly',

    // View events on all your calendars
    'https://www.googleapis.com/auth/calendar.events.readonly',

    // View your availability in your calendars
    'https://www.googleapis.com/auth/calendar.freebusy',

    // See and download any calendar you can access using your Google Calendar
    'https://www.googleapis.com/auth/calendar.readonly',

    // View your Calendar settings
    'https://www.googleapis.com/auth/calendar.settings.readonly',
  ],
  immediate = true;
// ...

gapi.auth.authorize(
  {client_id: client_id, scope: scope, immediate: immediate},
  authResult => {
    if (authResult && !authResult.error) {
      /* handle successful authorization */
    } else {
      /* handle authorization error */
    }
  },
);

After that you can use Calendar API resources:

/*
Deletes an access control rule.
*/
await gapi.client.calendar.acl.delete({
  calendarId: 'calendarId',
  ruleId: 'ruleId',
});

/*
Returns an access control rule.
*/
await gapi.client.calendar.acl.get({
  calendarId: 'calendarId',
  ruleId: 'ruleId',
});

/*
Creates an access control rule.
*/
await gapi.client.calendar.acl.insert({calendarId: 'calendarId'});

/*
Returns the rules in the access control list for the calendar.
*/
await gapi.client.calendar.acl.list({calendarId: 'calendarId'});

/*
Updates an access control rule. This method supports patch semantics.
*/
await gapi.client.calendar.acl.patch({
  calendarId: 'calendarId',
  ruleId: 'ruleId',
});

/*
Updates an access control rule.
*/
await gapi.client.calendar.acl.update({
  calendarId: 'calendarId',
  ruleId: 'ruleId',
});

/*
Watch for changes to ACL resources.
*/
await gapi.client.calendar.acl.watch({calendarId: 'calendarId'});

/*
Removes a calendar from the user's calendar list.
*/
await gapi.client.calendar.calendarList.delete({calendarId: 'calendarId'});

/*
Returns a calendar from the user's calendar list.
*/
await gapi.client.calendar.calendarList.get({calendarId: 'calendarId'});

/*
Inserts an existing calendar into the user's calendar list.
*/
await gapi.client.calendar.calendarList.insert({});

/*
Returns the calendars on the user's calendar list.
*/
await gapi.client.calendar.calendarList.list({});

/*
Updates an existing calendar on the user's calendar list. This method supports patch semantics.
*/
await gapi.client.calendar.calendarList.patch({calendarId: 'calendarId'});

/*
Updates an existing calendar on the user's calendar list.
*/
await gapi.client.calendar.calendarList.update({calendarId: 'calendarId'});

/*
Watch for changes to CalendarList resources.
*/
await gapi.client.calendar.calendarList.watch({});

/*
Clears a primary calendar. This operation deletes all events associated with the primary calendar of an account.
*/
await gapi.client.calendar.calendars.clear({calendarId: 'calendarId'});

/*
Deletes a secondary calendar. Use calendars.clear for clearing all events on primary calendars.
*/
await gapi.client.calendar.calendars.delete({calendarId: 'calendarId'});

/*
Returns metadata for a calendar.
*/
await gapi.client.calendar.calendars.get({calendarId: 'calendarId'});

/*
Creates a secondary calendar.
*/
await gapi.client.calendar.calendars.insert({});

/*
Updates metadata for a calendar. This method supports patch semantics.
*/
await gapi.client.calendar.calendars.patch({calendarId: 'calendarId'});

/*
Updates metadata for a calendar.
*/
await gapi.client.calendar.calendars.update({calendarId: 'calendarId'});

/*
Stop watching resources through this channel
*/
await gapi.client.calendar.channels.stop({});

/*
Returns the color definitions for calendars and events.
*/
await gapi.client.calendar.colors.get({});

/*
Deletes an event.
*/
await gapi.client.calendar.events.delete({
  calendarId: 'calendarId',
  eventId: 'eventId',
});

/*
Returns an event based on its Google Calendar ID. To retrieve an event using its iCalendar ID, call the events.list method using the iCalUID parameter.
*/
await gapi.client.calendar.events.get({
  calendarId: 'calendarId',
  eventId: 'eventId',
});

/*
Imports an event. This operation is used to add a private copy of an existing event to a calendar. Only events with an eventType of default may be imported.
Deprecated behavior: If a non-default event is imported, its type will be changed to default and any event-type-specific properties it may have will be dropped.
*/
await gapi.client.calendar.events.import({calendarId: 'calendarId'});

/*
Creates an event.
*/
await gapi.client.calendar.events.insert({calendarId: 'calendarId'});

/*
Returns instances of the specified recurring event.
*/
await gapi.client.calendar.events.instances({
  calendarId: 'calendarId',
  eventId: 'eventId',
});

/*
Returns events on the specified calendar.
*/
await gapi.client.calendar.events.list({calendarId: 'calendarId'});

/*
Moves an event to another calendar, i.e. changes an event's organizer. Note that only default events can be moved; birthday, focusTime, fromGmail, outOfOffice and workingLocation events cannot be moved.
*/
await gapi.client.calendar.events.move({
  calendarId: 'calendarId',
  destination: 'destination',
  eventId: 'eventId',
});

/*
Updates an event. This method supports patch semantics.
*/
await gapi.client.calendar.events.patch({
  calendarId: 'calendarId',
  eventId: 'eventId',
});

/*
Creates an event based on a simple text string.
*/
await gapi.client.calendar.events.quickAdd({
  calendarId: 'calendarId',
  text: 'text',
});

/*
Updates an event.
*/
await gapi.client.calendar.events.update({
  calendarId: 'calendarId',
  eventId: 'eventId',
});

/*
Watch for changes to Events resources.
*/
await gapi.client.calendar.events.watch({calendarId: 'calendarId'});

/*
Returns free/busy information for a set of calendars.
*/
await gapi.client.calendar.freebusy.query({});

/*
Returns a single user setting.
*/
await gapi.client.calendar.settings.get({setting: 'setting'});

/*
Returns all user settings for the authenticated user.
*/
await gapi.client.calendar.settings.list({});

/*
Watch for changes to Settings resources.
*/
await gapi.client.calendar.settings.watch({});

Readme

Keywords

none

Package Sidebar

Install

npm i @maxim_mazurok/gapi.client.calendar-v3

Weekly Downloads

3,056

Version

0.0.20250714

License

MIT

Unpacked Size

166 kB

Total Files

3

Last publish

Collaborators

  • maxim_mazurok