Skip to content

setInterval and setTimeout that works even if the app is running in the background

License

Notifications You must be signed in to change notification settings

mimacom/react-native-background-timer-android

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

react-native-background-timer-android

This library provides setTimeout and setInterval implementations that keep working even if the app is running in the background or the screen is locked.

Based on react-native-background-timer but with major code changes and only works on Android.

Features

  • Clear and simple API
  • Can set multiple timers
  • Keeps running when the screen is locked
  • Each timer has its own WakeLock that remains active while it's running
  • Intervals are handled entirely on the native side
  • Fault-tolerant: any exception gets reported back to JS via promises
  • TypeScript declarations included

Install

yarn add react-native-background-timer-android

Usage

import Timer from "react-native-background-timer-android";

// Start a timer that will repeatedly log "tic" after 500 milliseconds
const intervalId = Timer.setInterval(() => console.log("tic"), 500);

// Cancel the timer when you are done with it
Timer.clearInterval(intervalId);

// Start a timer that will log "tic" after 500 milliseconds just once
const timeoutId = Timer.setTimeout(() => console.log("tic"), 500);

// Cancel the timer if needed
Timer.clearTimeout(timeoutId);

API

Timer.setInterval(callback: () => void, millis: number, onError?: (error: Error) => void): number;
Timer.setTimeout(callback: () => void, millis: number, onError?: (error: Error) => void): number;
Timer.clearInterval(id: number): Promise<void>;
Timer.clearTimeout(id: number): Promise<void>;

About

setInterval and setTimeout that works even if the app is running in the background

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 91.3%
  • JavaScript 8.7%