Leitfaden
Tutorial zum Kalender
Mit @capgo/capacitor-calendar verwenden
Die @capgo/capacitor-calendar Das Paket ermöglicht es einer Capacitor-App, native Kalenderereignisse auf iOS und Android zu verwalten. Es kann Kalenderberechtigungen anfordern, Ereignisse erstellen und bearbeiten, die native Kalender-UI öffnen, Kalender und Ereignisse auflisten und Reminders auf iOS verwalten.
Installieren
npm install @capgo/capacitor-calendar
npx cap sync
Konfigurieren Sie native Berechtigungen
Bei iOS müssen Sie die von Ihrer App benötigten Nutzungsbeschreibungen hinzufügen 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>NSRemindersFullAccessUsageDescription</key>
<string>This app needs permission to read and manage reminders.</string>
Bei Android müssen Sie die Kalenderberechtigungen hinzufügen, die Ihre App benötigt android/app/src/main/AndroidManifest.xml:
<uses-permission android:name="android.permission.READ_CALENDAR" />
<uses-permission android:name="android.permission.WRITE_CALENDAR" />
Berechtigung anfordern
import { CapacitorCalendar } from '@capgo/capacitor-calendar';
const permission = await CapacitorCalendar.requestFullCalendarAccess();
if (permission.result !== 'granted') {
throw new Error('Calendar permission was not granted');
}
Ereignis erstellen
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);
Native Ereignis-UI öffnen
await CapacitorCalendar.createEventWithPrompt({
title: 'Planning session',
location: 'Office',
startDate: Date.now() + 24 * 60 * 60 * 1000,
endDate: Date.now() + 25 * 60 * 60 * 1000,
});
Ereignisse auflisten
const now = Date.now();
const { result: events } = await CapacitorCalendar.listEventsInRange({
from: now,
to: now + 7 * 24 * 60 * 60 * 1000,
});
iOS-Erinnerungen verwalten
const permission = await CapacitorCalendar.requestFullRemindersAccess();
if (permission.result === 'granted') {
await CapacitorCalendar.createReminder({
title: 'Send launch notes',
dueDate: Date.now() + 2 * 24 * 60 * 60 * 1000,
});
}
Erinnerungen sind nur auf iOS verfügbar.
Vollständige Referenz
- GitHub: https://github.com/Cap-go/capacitor-kalender/
- Dokumentation: /docs/plugins/calendar/