メニューに進む

Getting Started

GitHub
クリップボードにコピー
npm install @capgo/capacitor-calendar
npx cap sync

__CAPGO_KEEP_0__の使用方法を追加します。 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 を呼び出す場合のみ、リマインダー使用方法を含めます。

Apple の参考資料: 最新のカレンダー アクセス レベルへの移行.

__CAPGO_KEEP_0__のカレンダー権限を追加します。 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',
});
}

iOSのみのReminder APIです。

リポジトリには、許可チェック、イベントの作成、ネイティブのイベントの提示、カレンダーのリスト、イベントの範囲のリストなどを含むCapacitorの例のアプリがあります。

iOSAndroid
ネイティブのカレンダーイベントの作成のiOSのデモネイティブのカレンダーイベントの作成のAndroidのデモ

APIの完全なリファレンスは、パッケージのREADMEとTypeScriptの定義で管理されています。