跳过内容

入门指南

GitHub
终端窗口
npm install @capgo/capacitor-calendar
npx cap sync

iOS 设置

iOS 设置

添加您的应用程序需要的使用说明 ios/App/App/Info.plist:

<key>NSCalendarsUsageDescription</key>
<string>This app needs calendar access.</string>
<key>NSCalendarsWriteOnlyAccessUsageDescription</key>
<string>This app needs permission to add calendar events.</string>
<key>NSCalendarsFullAccessUsageDescription</key>
<string>This app needs permission to read and manage calendar events.</string>
<key>NSRemindersUsageDescription</key>
<string>This app needs reminders access.</string>
<key>NSRemindersFullAccessUsageDescription</key>
<string>This app needs permission to read and manage reminders.</string>

iOS 17 及更高版本区分只写和全日历访问。仅在您的应用程序调用提醒 API 时才包括提醒使用说明。

苹果参考: 迁移到最新的日历访问级别.

Android 设置

Android 设置

添加日历权限 android/app/src/main/AndroidManifest.xml:

<uses-permission android:name="android.permission.READ_CALENDAR" />
<uses-permission android:name="android.permission.WRITE_CALENDAR" />

Android参考: 日历提供者用户权限.

请求日历访问

标题:请求日历访问
import { CapacitorCalendar } from '@capgo/capacitor-calendar';
const permission = await CapacitorCalendar.requestFullCalendarAccess();
if (permission.result !== 'granted') {
throw new Error('Calendar permission was not granted');
}

仅添加事件的应用程序使用 requestWriteOnlyCalendarAccess()仅在 Android 上读取流程时使用 requestReadOnlyCalendarAccess().

日期以毫秒为单位的 Unix 时间戳

import { CapacitorCalendar } from '@capgo/capacitor-calendar';
const startDate = Date.now() + 60 * 60 * 1000;
const endDate = startDate + 60 * 60 * 1000;
const { id } = await CapacitorCalendar.createEvent({
title: 'Product review',
location: 'Capgo',
startDate,
endDate,
description: 'Created with @capgo/capacitor-calendar',
});
console.log('Created event', id);

打开本机事件编辑器

标题:打开本机事件编辑器
await CapacitorCalendar.createEventWithPrompt({
title: 'Planning session',
location: 'Office',
startDate: Date.now() + 24 * 60 * 60 * 1000,
endDate: Date.now() + 25 * 60 * 60 * 1000,
});

在 Android 上,基于提示的创建和修改调用返回 null如果需要找到创建的事件 ID,请列出事件。

即将到来的事件

标题:即将到来的事件
const now = Date.now();
const oneWeekFromNow = now + 7 * 24 * 60 * 60 * 1000;
const { result: events } = await CapacitorCalendar.listEventsInRange({
from: now,
to: oneWeekFromNow,
});
const { result: calendars } = await CapacitorCalendar.listCalendars();
const { result: defaultCalendar } = await CapacitorCalendar.getDefaultCalendar();
const calendarId = defaultCalendar?.id ?? calendars[0]?.id;

selectCalendarsWithPrompt() 在 iOS 上可用,当您想要显示系统日历选择器时。

const permission = await CapacitorCalendar.requestFullRemindersAccess();
if (permission.result === 'granted') {
await CapacitorCalendar.createReminder({
title: 'Send launch notes',
dueDate: Date.now() + 2 * 24 * 60 * 60 * 1000,
notes: 'Created with @capgo/capacitor-calendar',
});
}

提示 API 仅限 iOS。

仓库包含一个 Capacitor 示例应用,示例应用包含权限检查、事件创建、原生事件提示、日历列表和事件范围列表。

iOSAndroid
iOS 原生日历事件创建示例Android 原生日历事件创建示例

完整的 API 参考文档在包 README 和 TypeScript 定义中维护