react-native-alarm-module

NO LONGER GETTING UPDATES, Do not use. this module never did what I expected it to do. It won't run your app's tasks when in background. there's probably a solution, but I'm not willing to update this.


A native module for scheduling alarms. the main aim is to execute a headless js task from a set alarm. this was needed for executing a time critical task.

Supported Platforms

  • Android (Min. SDK 21)

Installation

npm install react-native-alarm-module
yarn add react-native-alarm-module

Usage

// setAlarmClock, setExact, setAndAllowWhileIdle, setExactAndAllowWhileIdle
import {setAlarm, cancelAlarm} from 'react-native-alarm-module';
import {View, Button, ToastAndroid, AppRegistry} from 'react-native';

// You have to register the task you would like executed as a headless task
AppRegistry.registerHeadlessTask('ShowToastTask', () => () => ToastAndroid.show('Alarm toast!', ToastAndroid.SHORT));

export default function App() {
  const [lastDate, setLastDate] = useState(new Date(Date.now() + 5 * 1000));

  const setAlarmOnPress = useCallback(() => {
    const newDate = new Date(Date.now() + 5 * 1000);
    setLastDate(newDate);

    setAlarm({
      taskName: 'ShowToastTask', // required
      timestamp: newDate.valueOf(), // required
      type: 'setAlarmClock', // optional
      allowedInForeground: true, // optional 
      wakeup: true, // optional
      extra: 'something extra', // optional
    });

    ToastAndroid.show(
      `alarm set for ${newDate.toISOString()}`,
      ToastAndroid.SHORT,
    );
  }, []);

  const cancel = useCallback(() => {
    cancelAlarm({
      taskName: 'ShowToastTask',
      timestamp: lastDate.valueOf(),
    });
    ToastAndroid.show(
      `alarm cancelled for ${lastDate.toISOString()}`,
      ToastAndroid.SHORT,
    );
  }, [lastDate]);

  return (
    <View>
      <Button onPress={setAlarmOnPress} title="Set Alarm in 5 seconds" />
      <Button onPress={cancel} title="Cancel last alarm" />
    </View>
  );
}

Notes

Alarm fired in background

Currently you cannot launch your app when the alarm is fired and your app is not in foreground in newer Android versions due to the newly added limitations.

setAlarmClock type for android

When setAlarmClock type is used to set an alarm on Android, this library tries to launch your application if the clock is touched. If the needed class is not found, it simply won't do anything if the clock is touched.

When you want to handle the intent, you have to use subscribeToOnNewIntent method. remember to call .remove() when you are done with it. To handle the launch intent from the alarm clock icon, you have to handle the event early in your app or you will miss it.

Canceling an alarm

cancelAlarm Uses your task name and the timestamp value the alarm was set to fire to cancel the alarm. it uses the time in seconds without the first digit as the request code under the hood to create a pending intent to cancel the alarm.

RTC_WAKEUP

To set an alarm with wakeup: true you have to add the following to your AndroidManifest.xml file, Otherwise your app will crash:

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

Rebooting

This library does not save and restore your scheduled alarm if the device is rebooted. you have to save them yourself before scheduling them with this library and setup them again on reboot using the android.intent.action.BOOT_COMPLETED broadcast and the related permission.

Contributing

See the contributing guide to learn how to contribute to the repository and the development workflow.

License

MIT