diff --git a/dist/plugins/calendar.d.ts b/dist/plugins/calendar.d.ts index 0be86ae5e..bebbd0ceb 100644 --- a/dist/plugins/calendar.d.ts +++ b/dist/plugins/calendar.d.ts @@ -1,19 +1,224 @@ -export declare class Calendar { - static createCalendar(options: any): void; - static deleteCalendar(calendarName: string): void; - static getCalendarOptions(): void; - static createEvent(title: any, location: any, notes: any, startDate: any, endDate: any): void; - static createEventWithOptions(title: any, location: any, notes: any, startDate: any, endDate: any, options: any): void; - static createEventInteractively(title: any, location: any, notes: any, startDate: any, endDate: any): void; - static createEventInteractivelyWithOptions(title: any, location: any, notes: any, startDate: any, endDate: any, options: any): void; - static createEventInNamedCalendar(title: any, location: any, notes: any, startDate: any, endDate: any, calendarName: any): void; - static findEvent(title: any, location: any, notes: any, startDate: any, endDate: any): void; - static listEventsInRange(startDate: any, endDate: any): void; - static listCalendars(): void; - static findAllEventsInNamedCalendar(calendarName: string): void; - static modifyEvent(title: any, location: any, notes: any, startDate: any, endDate: any, newTitle: any, newLocation: any, newNotes: any, newStartDate: any, newEndDate: any): void; - static modifyEventWithOptions(title: any, location: any, notes: any, startDate: any, endDate: any, newTitle: any, newEventLocation: any, newNotes: any, newStartDate: any, newEndDate: any, options: any): void; - static deleteEvent(title: any, location: any, notes: any, startDate: any, endDate: any): void; - static deleteEventFromNamedCalendar(title: any, location: any, notes: any, startDate: any, endDate: any, calendarName: any): void; - static openCalendar(date: any): void; +export interface CalendarOptions { + firstReminderMinutes?: number; + secondReminderMinutes?: number; + recurrence?: string; + recurrenceInterval?: number; + recurrenceEndDate?: Date; + calendarName?: string; + calendarId?: number; + url?: string; +} +export interface Calendar { + id: number; + name: string; +} +/** + * This plugin allows you to add events to the Calendar of the mobile device. + * + * Requires Cordova plugin: `cordova-plugin-calendar`. For more info, please see the [Calendar plugin docs](https://github.com/EddyVerbruggen/Calendar-PhoneGap-Plugin). + * + */ +export declare class Calendar { + /** + * Create a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.createCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string | Object} nameOrOptions either a string name or a options object. + * options: + * calendarName: string the name of the calendar + * calendarColor: string the hex color of the calendar + * @return Returns a Promise + */ + static createCalendar(nameOrOptions: string | { + calendarName: string; + calendarColor: string; + }): Promise; + /** + * Delete a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.deleteCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string} name Name of the calendar to delete. + * @return Returns a Promise + */ + static deleteCalendar(name: string): Promise; + /** + * Returns the default calendar options. + * + * @return Returns an object with the default calendar options + * ``` + * { + * firstReminderMinutes: 60, + * secondReminderMinutes: null, + * recurrence: null, // options are: 'daily', 'weekly', 'monthly', 'yearly' + * recurrenceInterval: 1, // only used when recurrence is set + * recurrenceEndDate: null, + * calendarName: null, + * calendarId: null, + * url: null + * } + * ``` + */ + static getCalendarOptions(): CalendarOptions; + /** + * Silently create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + static createEvent(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date): Promise; + /** + * Silently create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + static createEventWithOptions(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, options?: CalendarOptions): Promise; + /** + * Interactively create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + static createEventInteractively(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date): Promise; + /** + * Interactively create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + static createEventInteractivelyWithOptions(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, options?: CalendarOptions): Promise; + /** + * Find an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + static findEvent(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date): Promise; + /** + * Find an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise that resolves with the event, or rejects with an error. + */ + static findEventWithOptions(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, options?: CalendarOptions): Promise; + /** + * Find a list of events within the specified date range. (Android only) + * + * @param {Date} [startDate] The start date + * @param {Date} [endDate] The end date + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ + static listEventsInRange(startDate: Date, endDate: Date): Promise; + /** + * Get a list of all calendars. + * @return A Promise that resolves with the list of calendars, or rejects with an error. + */ + static listCalendars(): Promise; + /** + * Get a list of all future events in the specified calendar. (iOS only) + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ + static findAllEventsInNamedCalendar(calendarName: string): Promise; + /** + * Modify an event. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @return Returns a Promise + */ + static modifyEvent(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, newTitle?: string, newLocation?: string, newNotes?: string, newStartDate?: Date, newEndDate?: Date): Promise; + /** + * Modify an event with additional options. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + static modifyEventWithOptions(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, newTitle?: string, newLocation?: string, newNotes?: string, newStartDate?: Date, newEndDate?: Date, options?: CalendarOptions): Promise; + /** + * Delete an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + static deleteEvent(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date): Promise; + /** + * Delete an event from the specified Calendar. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} calendarName + * @return Returns a Promise + */ + static deleteEventFromNamedCalendar(title?: string, location?: string, notes?: string, startDate?: Date, endDate?: Date, calendarName?: string): Promise; + /** + * Open the calendar at the specified date. + * @return {Date} date + */ + static openCalendar(date: Date): Promise; } diff --git a/dist/plugins/calendar.js b/dist/plugins/calendar.js index 877f767fd..ccd0a9c86 100644 --- a/dist/plugins/calendar.js +++ b/dist/plugins/calendar.js @@ -5,35 +5,348 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, return c > 3 && r && Object.defineProperty(target, key, r), r; }; var plugin_1 = require('./plugin'); +/** + * This plugin allows you to add events to the Calendar of the mobile device. + * + * Requires Cordova plugin: `cordova-plugin-calendar`. For more info, please see the [Calendar plugin docs](https://github.com/EddyVerbruggen/Calendar-PhoneGap-Plugin). + * + */ var Calendar = (function () { function Calendar() { } - Calendar.createCalendar = function (options) { }; - Calendar.deleteCalendar = function (calendarName) { }; - Calendar.getCalendarOptions = function () { }; - Calendar.createEvent = function (title, location, notes, startDate, endDate) { }; - Calendar.createEventWithOptions = function (title, location, notes, startDate, endDate, options) { }; - Calendar.createEventInteractively = function (title, location, notes, startDate, endDate) { }; - Calendar.createEventInteractivelyWithOptions = function (title, location, notes, startDate, endDate, options) { }; - Calendar.createEventInNamedCalendar = function (title, location, notes, startDate, endDate, calendarName) { }; - Calendar.findEvent = function (title, location, notes, startDate, endDate) { }; - Calendar.listEventsInRange = function (startDate, endDate) { }; - Calendar.listCalendars = function () { }; - Calendar.findAllEventsInNamedCalendar = function (calendarName) { }; - Calendar.modifyEvent = function (title, location, notes, startDate, endDate, newTitle, newLocation, newNotes, newStartDate, newEndDate) { }; - Calendar.modifyEventWithOptions = function (title, location, notes, startDate, endDate, newTitle, newEventLocation, newNotes, newStartDate, newEndDate, options) { }; - Calendar.deleteEvent = function (title, location, notes, startDate, endDate) { }; - Calendar.deleteEventFromNamedCalendar = function (title, location, notes, startDate, endDate, calendarName) { }; - Calendar.openCalendar = function (date) { }; + /** + * Create a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.createCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string | Object} nameOrOptions either a string name or a options object. + * options: + * calendarName: string the name of the calendar + * calendarColor: string the hex color of the calendar + * @return Returns a Promise + */ + Calendar.createCalendar = function (nameOrOptions) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Delete a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.deleteCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string} name Name of the calendar to delete. + * @return Returns a Promise + */ + Calendar.deleteCalendar = function (name) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Returns the default calendar options. + * + * @return Returns an object with the default calendar options + * ``` + * { + * firstReminderMinutes: 60, + * secondReminderMinutes: null, + * recurrence: null, // options are: 'daily', 'weekly', 'monthly', 'yearly' + * recurrenceInterval: 1, // only used when recurrence is set + * recurrenceEndDate: null, + * calendarName: null, + * calendarId: null, + * url: null + * } + * ``` + */ + Calendar.getCalendarOptions = function () { + return { + firstReminderMinutes: 60, + secondReminderMinutes: null, + recurrence: null, + recurrenceInterval: 1, + recurrenceEndDate: null, + calendarName: null, + calendarId: null, + url: null + }; + }; + /** + * Silently create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + Calendar.createEvent = function (title, location, notes, startDate, endDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Silently create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + Calendar.createEventWithOptions = function (title, location, notes, startDate, endDate, options) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Interactively create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + Calendar.createEventInteractively = function (title, location, notes, startDate, endDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Interactively create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + Calendar.createEventInteractivelyWithOptions = function (title, location, notes, startDate, endDate, options) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + // deprecated + // @Cordova() + // static createEventInNamedCalendar( + // title?: string, + // location?: string, + // notes?: string, + // startDate?: Date, + // endDate?: Date, + // calendarName?: string + // ) {} + /** + * Find an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + Calendar.findEvent = function (title, location, notes, startDate, endDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Find an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise that resolves with the event, or rejects with an error. + */ + Calendar.findEventWithOptions = function (title, location, notes, startDate, endDate, options) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Find a list of events within the specified date range. (Android only) + * + * @param {Date} [startDate] The start date + * @param {Date} [endDate] The end date + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ + Calendar.listEventsInRange = function (startDate, endDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Get a list of all calendars. + * @return A Promise that resolves with the list of calendars, or rejects with an error. + */ + Calendar.listCalendars = function () { + return new Promise(function (res, rej) { }); + }; + /** + * Get a list of all future events in the specified calendar. (iOS only) + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ + Calendar.findAllEventsInNamedCalendar = function (calendarName) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Modify an event. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @return Returns a Promise + */ + Calendar.modifyEvent = function (title, location, notes, startDate, endDate, newTitle, newLocation, newNotes, newStartDate, newEndDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Modify an event with additional options. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + Calendar.modifyEventWithOptions = function (title, location, notes, startDate, endDate, newTitle, newLocation, newNotes, newStartDate, newEndDate, options) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Delete an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ + Calendar.deleteEvent = function (title, location, notes, startDate, endDate) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Delete an event from the specified Calendar. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} calendarName + * @return Returns a Promise + */ + Calendar.deleteEventFromNamedCalendar = function (title, location, notes, startDate, endDate, calendarName) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; + /** + * Open the calendar at the specified date. + * @return {Date} date + */ + Calendar.openCalendar = function (date) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise(function (res, rej) { }); + }; __decorate([ plugin_1.Cordova() ], Calendar, "createCalendar", null); __decorate([ plugin_1.Cordova() ], Calendar, "deleteCalendar", null); - __decorate([ - plugin_1.Cordova() - ], Calendar, "getCalendarOptions", null); __decorate([ plugin_1.Cordova() ], Calendar, "createEvent", null); @@ -48,10 +361,10 @@ var Calendar = (function () { ], Calendar, "createEventInteractivelyWithOptions", null); __decorate([ plugin_1.Cordova() - ], Calendar, "createEventInNamedCalendar", null); + ], Calendar, "findEvent", null); __decorate([ plugin_1.Cordova() - ], Calendar, "findEvent", null); + ], Calendar, "findEventWithOptions", null); __decorate([ plugin_1.Cordova() ], Calendar, "listEventsInRange", null); diff --git a/dist/plugins/calendar.js.map b/dist/plugins/calendar.js.map index abab58ee1..443b76e2a 100644 --- a/dist/plugins/calendar.js.map +++ b/dist/plugins/calendar.js.map @@ -1 +1 @@ -{"version":3,"file":"calendar.js","sourceRoot":"","sources":["../../src/plugins/calendar.ts"],"names":["Calendar","Calendar.constructor","Calendar.createCalendar","Calendar.deleteCalendar","Calendar.getCalendarOptions","Calendar.createEvent","Calendar.createEventWithOptions","Calendar.createEventInteractively","Calendar.createEventInteractivelyWithOptions","Calendar.createEventInNamedCalendar","Calendar.findEvent","Calendar.listEventsInRange","Calendar.listCalendars","Calendar.findAllEventsInNamedCalendar","Calendar.modifyEvent","Calendar.modifyEventWithOptions","Calendar.deleteEvent","Calendar.deleteEventFromNamedCalendar","Calendar.openCalendar"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"calendar.js","sourceRoot":"","sources":["../../src/plugins/calendar.ts"],"names":["Calendar","Calendar.constructor","Calendar.createCalendar","Calendar.deleteCalendar","Calendar.getCalendarOptions","Calendar.createEvent","Calendar.createEventWithOptions","Calendar.createEventInteractively","Calendar.createEventInteractivelyWithOptions","Calendar.findEvent","Calendar.findEventWithOptions","Calendar.listEventsInRange","Calendar.listCalendars","Calendar.findAllEventsInNamedCalendar","Calendar.modifyEvent","Calendar.modifyEventWithOptions","Calendar.deleteEvent","Calendar.deleteEventFromNamedCalendar","Calendar.openCalendar"],"mappings":"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"} \ No newline at end of file diff --git a/src/plugins/calendar.ts b/src/plugins/calendar.ts index e22cc34a3..4bb29e3c2 100644 --- a/src/plugins/calendar.ts +++ b/src/plugins/calendar.ts @@ -1,59 +1,466 @@ import {Plugin, Cordova} from './plugin'; +export interface CalendarOptions { + firstReminderMinutes?: number; + secondReminderMinutes?: number; + recurrence?: string, // options are: 'daily', 'weekly', 'monthly', 'yearly' + recurrenceInterval?: number, // only used when recurrence is set + recurrenceEndDate?: Date; + calendarName?: string; + calendarId?: number; + url?: string; +} + +export interface Calendar { + id: number, + name: string +} + +/** + * This plugin allows you to add events to the Calendar of the mobile device. + * + * Requires Cordova plugin: `cordova-plugin-calendar`. For more info, please see the [Calendar plugin docs](https://github.com/EddyVerbruggen/Calendar-PhoneGap-Plugin). + * + */ @Plugin({ name: 'Calendar', plugin: 'cordova-plugin-calendar', pluginRef: 'plugins.calendar' }) export class Calendar { + /** + * Create a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.createCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string | Object} nameOrOptions either a string name or a options object. + * options: + * calendarName: string the name of the calendar + * calendarColor: string the hex color of the calendar + * @return Returns a Promise + */ @Cordova() - static createCalendar(options:any) {} + static createCalendar(nameOrOptions: string | { calendarName: string, calendarColor: string }) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Delete a calendar. (iOS only) + * + * @usage + * ``` + * Calendar.deleteCalendar('MyCalendar').then( + * (msg) => { console.log(msg); }, + * (err) => { console.log(err); } + * ); + * ``` + * + * @param {string} name Name of the calendar to delete. + * @return Returns a Promise + */ @Cordova() - static deleteCalendar(calendarName:string) {} + static deleteCalendar(name: string) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } - @Cordova() - static getCalendarOptions() {} + /** + * Returns the default calendar options. + * + * @return Returns an object with the default calendar options + * ``` + * { + * firstReminderMinutes: 60, + * secondReminderMinutes: null, + * recurrence: null, // options are: 'daily', 'weekly', 'monthly', 'yearly' + * recurrenceInterval: 1, // only used when recurrence is set + * recurrenceEndDate: null, + * calendarName: null, + * calendarId: null, + * url: null + * } + * ``` + */ + static getCalendarOptions(): CalendarOptions { + return { + firstReminderMinutes: 60, + secondReminderMinutes: null, + recurrence: null, + recurrenceInterval: 1, + recurrenceEndDate: null, + calendarName: null, + calendarId: null, + url: null + } + } + /** + * Silently create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ @Cordova() - static createEvent(title, location, notes, startDate, endDate) {} + static createEvent( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Silently create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ @Cordova() - static createEventWithOptions(title, location, notes, startDate, endDate, options) {} + static createEventWithOptions( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + options?: CalendarOptions + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Interactively create an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ @Cordova() - static createEventInteractively(title, location, notes, startDate, endDate) {} + static createEventInteractively( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Interactively create an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ @Cordova() - static createEventInteractivelyWithOptions(title, location, notes, startDate, endDate, options) {} + static createEventInteractivelyWithOptions( + title?:string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + options?: CalendarOptions + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } - @Cordova() - static createEventInNamedCalendar(title, location, notes, startDate, endDate, calendarName) {} + // deprecated + // @Cordova() + // static createEventInNamedCalendar( + // title?: string, + // location?: string, + // notes?: string, + // startDate?: Date, + // endDate?: Date, + // calendarName?: string + // ) {} + /** + * Find an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ @Cordova() - static findEvent(title, location, notes, startDate, endDate) {} + static findEvent( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Find an event with additional options. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise that resolves with the event, or rejects with an error. + */ @Cordova() - static listEventsInRange(startDate:any, endDate:any) {} + static findEventWithOptions( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + options?: CalendarOptions + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Find a list of events within the specified date range. (Android only) + * + * @param {Date} [startDate] The start date + * @param {Date} [endDate] The end date + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ @Cordova() - static listCalendars(){} + static listEventsInRange(startDate: Date, endDate: Date) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Get a list of all calendars. + * @return A Promise that resolves with the list of calendars, or rejects with an error. + */ @Cordova() - static findAllEventsInNamedCalendar(calendarName:string) {} + static listCalendars(){ + return new Promise((res, rej) => {}); + } + /** + * Get a list of all future events in the specified calendar. (iOS only) + * @return Returns a Promise that resolves with the list of events, or rejects with an error. + */ @Cordova() - static modifyEvent(title, location, notes, startDate, endDate, newTitle, newLocation, newNotes, newStartDate, newEndDate) {} + static findAllEventsInNamedCalendar(calendarName: string) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Modify an event. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @return Returns a Promise + */ @Cordova() - static modifyEventWithOptions(title, location, notes, startDate, endDate, newTitle, newEventLocation, newNotes, newStartDate, newEndDate, options) {} + static modifyEvent( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + newTitle?: string, + newLocation?: string, + newNotes?: string, + newStartDate?: Date, + newEndDate?: Date + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } - @Cordova() - static deleteEvent(title, location, notes, startDate, endDate) {} + /** + * Modify an event with additional options. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} [newTitle] The new event title + * @param {string} [newLocation] The new event location + * @param {string} [newNotes] The new event notes + * @param {Date} [newStartDate] The new event start date + * @param {Date} [newEndDate] The new event end date + * @param {CalendarOptions} [options] Additional options, see `getCalendarOptions` + * @return Returns a Promise + */ + @Cordova() + static modifyEventWithOptions( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + newTitle?: string, + newLocation?: string, + newNotes?: string, + newStartDate?: Date, + newEndDate?: Date, + options?: CalendarOptions + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Delete an event. + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @return Returns a Promise + */ @Cordova() - static deleteEventFromNamedCalendar(title, location, notes, startDate, endDate, calendarName) {} + static deleteEvent( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + /** + * Delete an event from the specified Calendar. (iOS only) + * + * @param {string} [title] The event title + * @param {string} [location] The event location + * @param {string} [notes] The event notes + * @param {Date} [startDate] The event start date + * @param {Date} [endDate] The event end date + * @param {string} calendarName + * @return Returns a Promise + */ + @Cordova() + static deleteEventFromNamedCalendar( + title?: string, + location?: string, + notes?: string, + startDate?: Date, + endDate?: Date, + calendarName?: string + ) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } + + /** + * Open the calendar at the specified date. + * @return {Date} date + */ @Cordova() - static openCalendar(date) {} + static openCalendar(date: Date) { + // This Promise is replaced by one from the @Cordova decorator that wraps + // the plugin's callbacks. We provide a dummy one here so TypeScript + // knows that the correct return type is Promise, because there's no way + // for it to know the return type from a decorator. + // See https://github.com/Microsoft/TypeScript/issues/4881 + return new Promise((res, rej) => {}); + } }