Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ferrannp/react-native-sync-adapter
Schedule background data synchronization using React Native.
https://github.com/ferrannp/react-native-sync-adapter
android background-jobs background-sync react-native react-native-background sync sync-adapter
Last synced: 2 months ago
JSON representation
Schedule background data synchronization using React Native.
- Host: GitHub
- URL: https://github.com/ferrannp/react-native-sync-adapter
- Owner: ferrannp
- License: mit
- Created: 2017-01-20T22:54:36.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2021-08-25T16:08:12.000Z (over 3 years ago)
- Last Synced: 2024-10-13T04:46:47.764Z (3 months ago)
- Topics: android, background-jobs, background-sync, react-native, react-native-background, sync, sync-adapter
- Language: Java
- Homepage:
- Size: 505 KB
- Stars: 115
- Watchers: 4
- Forks: 17
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# react-native-sync-adapter
[![Circle CI](https://circleci.com/gh/ferrannp/react-native-sync-adapter.svg?style=shield)](https://circleci.com/gh/ferrannp/react-native-sync-adapter) [![npm version](https://badge.fury.io/js/react-native-sync-adapter.svg)](https://badge.fury.io/js/react-native-sync-adapter)
[Intelligent Job-Scheduling](https://developer.android.com/topic/performance/scheduling.html) port to React Native: Scheduling data background synchronizations that run in your JavaScript.
Read a broader introduction in the following post: [React Native and Native Modules: The Android SyncAdapter](https://blog.callstack.io/react-native-and-native-modules-the-android-syncadapter-517ddf851bf4#.qb5ed9din)
## Requirements
* React Native 0.60+## Pros
Under the hood, this library uses a [SyncAdapter](https://developer.android.com/reference/android/content/AbstractThreadedSyncAdapter.html):* Android will trigger a sync using our `syncFlexTime` to decide when is the best moment to do so (battery efficiency)
* No need to worry about internet connection
* No need to worry about the user restarting the device
* Compatible with all Android versions supported by RN (4.1+)## Caveats
This library is only for Android. If you want to do something similar on iOS, I recommend using [react-native-background-fetch](https://github.com/transistorsoft/react-native-background-fetch).## Getting started
```
yarn add react-native-sync-adapter
```### Installation
The library will be linked automatically by [Autolinking](https://github.com/react-native-community/cli/blob/master/docs/autolinking.md).
However, this library requires some manual steps:#### Manual Android required step
Open up the `string.xml` file of your Android project. You need to add the following (just change the content):
```xml
YourAppName
your.android.package.name
your.android.package.name.provider
```This will override the default values from the library and make them unique for your app.
## Usage
You need to [register a task](https://facebook.github.io/react-native/docs/headless-js-android.html#the-js-api) with a specific name and only with this specific name: `TASK_SYNC_ADAPTER`. You should do it in the same place where you register your app:```js
AppRegistry.registerComponent('MyApp', () => MyApp);
AppRegistry.registerHeadlessTask('TASK_SYNC_ADAPTER', () => TestTask);
```Then, for example, on your root component:
```js
import {useEffect} from 'react';
import SyncAdapter from 'react-native-sync-adapter';useEffect(() => {
SyncAdapter.init({
syncInterval,
syncFlexTime,
});
}, []);
```That is all! Some extras:
### Timeout
The default timeout for your Headless JS task is 5 minutes (300000ms). If you want to override this value, you will also need to override `strings.xml` again:
```xml
600000
```### User visible
By default the user will not be able to manually enable/disable syncs through the Account settings. If you want the user to have this option, you need to override `strings.xml`:
```xml
true
```### Running the task while the app is in the foreground
By default, the sync task will only run if the app is **not** in the foreground. This is one of the default [caveats](https://facebook.github.io/react-native/docs/headless-js-android.html#caveats) from HeadlessJS.
If you want to override this behavior, you can, one more time overriding `strings.xml`:```xml
true
```### Broadcast Receiver
If you want to trigger a sync natively (e.g. responding to a broadcast receiver), you can call:
```java
SyncAdapter.syncImmediately(Context context, int syncInterval, int syncFlexTime);
```## API
### init
Schedules background syncs within your app.
```js
Object: {
syncInterval: number;
syncFlexTime: number;
}
```* `syncInterval`: The amount of time in seconds that you wish to elapse between periodic syncs
* `syncFlexTime`: The amount of flex time in seconds before `syncInterval` that you permit for the sync to take place. Must be less than `syncInterval`A good example could be `syncInterval: 12 * 60 * 60` (12 hours) and `syncFlexTime: 0.5 * 60 * 60` (30 minutes).
Notice that `syncFlexTime` only works for Android 4.4+, for older versions, that value will be ignored and syncs will be always exact.
### syncImmediately
Invoke the sync task. Use the same values as in the [init](#init) call.
```js
Object: {
syncInterval: number;
syncFlexTime: number;
}
```Be aware that for this method to work (if you call it from inside your app) you need to allow the task to [work on the foreground](https://github.com/ferrannp/react-native-sync-adapter#running-the-task-while-the-app-is-in-the-foreground).
## Running example
You can try this library running the `example` app:
```
cd example && yarn && npm start
```Then just run:
```
yarn android
```**Be careful**: The installed example app will trigger a sync around every minute (so it is easy to see that is working). If you debug the app, you should be able to see the HeadlessJS ouputing: `Headless JS task was fired!` (remember not to have the app on the foreground: Unless you override this behavior). After you try it, I recommend to uninstall the app so you don't harm your device battery life.