Guide
Tutorial on Alarm
Using @capgo/capacitor-alarm
Capacitor Alarm Plugin interface for managing native OS alarms.
Install
bun add @capgo/capacitor-alarm
bunx cap sync
What This Plugin Exposes
createAlarm- Create a native OS alarm using the platform clock app. On Android this uses the Alarm Clock intent; on iOS this uses AlarmKit if available (iOS 16+).openAlarms- Open the platform's native alarm list UI, if available.getOSInfo- Get information about the OS and capabilities.requestPermissions- Request relevant permissions for alarm usage on the platform. On Android, may route to settings for exact alarms.
Example Usage
createAlarm
Create a native OS alarm using the platform clock app. On Android this uses the Alarm Clock intent; on iOS this uses AlarmKit if available (iOS 16+).
import { CapgoAlarm } from '@capgo/capacitor-alarm';
const result = await CapgoAlarm.createAlarm({
hour: 7,
minute: 30,
label: 'Wake up',
skipUi: false,
vibrate: true
});
console.log('Alarm created:', result.success);
openAlarms
Open the platform's native alarm list UI, if available.
import { CapgoAlarm } from '@capgo/capacitor-alarm';
const result = await CapgoAlarm.openAlarms();
if (result.success) {
console.log('Alarms UI opened');
}
getOSInfo
Get information about the OS and capabilities.
import { CapgoAlarm } from '@capgo/capacitor-alarm';
const info = await CapgoAlarm.getOSInfo();
console.log('Platform:', info.platform);
console.log('Supports native alarms:', info.supportsNativeAlarms);
if (info.platform === 'android') {
console.log('Can schedule exact alarms:', info.canScheduleExactAlarms);
}
requestPermissions
Request relevant permissions for alarm usage on the platform. On Android, may route to settings for exact alarms.
import { CapgoAlarm } from '@capgo/capacitor-alarm';
const result = await CapgoAlarm.requestPermissions({ exactAlarm: true });
if (result.granted) {
console.log('Permissions granted');
} else {
console.log('Permissions denied');
}
Full Reference
- GitHub: https://github.com/Cap-go/capacitor-alarm/
- Docs: /docs/plugins/alarm/