Zum Hauptinhalt springen
Zurück zu Plugins
@capgo/capacitor-Kalender
Tutorial
von github.com/Cap-go

Kalender

Verwalte native Kalenderereignisse auf iOS und Android, einschließlich iOS-Erinnerungen

Demo

WebP-Demos mit Animation

Erstellung von Kalenderevents auf iOS und Android, exportiert als WebP-Demos mit Animation.

Quellenassets
iOS-Demo der nativen Kalendereventerstellung
iOS-Ereigniserstellung
Android-Demo für die native Erstellung von Kalenderereignissen
Erstellung von Ereignissen für Android

Richtlinie

Tutorial zum Kalender

Mit @capgo/capacitor-Kalender

Der @capgo/capacitor-calendar Das Paket ermöglicht es einer Capacitor-App, native Kalenderereignisse auf iOS und Android zu verwalten. Es kann Kalenderberechtigungen anfordern, Ereignisse und Kalender erstellen und bearbeiten, die native Kalender-UI öffnen, Kalender und Ereignisse auflisten und Remindegänge auf iOS verwalten.

Installieren

npm install @capgo/capacitor-calendar
npx cap sync

Konfigurieren von native Berechtigungen

Bei iOS fügen Sie die erforderlichen Beschreibungen Ihrer App hinzu 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 fügen Sie die erforderlichen Kalenderberechtigungen Ihrer App hinzu 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');
}

Erstelle ein Ereignis

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);

Öffne die native Ereignis-UI

await CapacitorCalendar.createEventWithPrompt({
  title: 'Planning session',
  location: 'Office',
  startDate: Date.now() + 24 * 60 * 60 * 1000,
  endDate: Date.now() + 25 * 60 * 60 * 1000,
});

Liste von Ereignissen

const now = Date.now();

const { result: events } = await CapacitorCalendar.listEventsInRange({
  from: now,
  to: now + 7 * 24 * 60 * 60 * 1000,
});

iOS-Erinnerungen

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