Actually Backendless JS-SDK is totally adapted for working in React Native applications, you can use almost the entire Backendless API, but also there are some features which require Native iOS/Android implementation.
Additional Backendless features:
- Support Push Notification Templates
- Device Registration becomes more simpler
Backendless.Messaging.registerDevice(['channelName'])
- Listeners for Push Notifications
Backendless.Messaging.addPushNotificationListener(callback); Backendless.Messaging.removePushNotificationListener(callback); Backendless.Messaging.addPushNotificationActionListener(callback); Backendless.Messaging.removePushNotificationActionListener(callback);
npm i backendless backendless-react-native -S
import { Platform } from 'react-native';
import Backendless from 'backendless';
import 'backendless-react-native';
const APP_ID = 'YOUR_APP_ID';
const API_KEY = Platform.select({
ios : 'YOUR_IOS_API_KEY',
android: 'YOUR_ANDROID_API_KEY'
});
Backendless.initApp(APP_ID, API_KEY);
Recommended to use corresponding Api Keys for each platform, but you can use any Api Key, for ex: JS_API_KEY or REST_API_KEY
Backendless.initApp(APP_ID, ANY_API_KEY);
Backendless.Messaging.registerDevice(['default']).then(onSuccess).catch(onFail);
Backendless.Messaging.unregisterDevice().then(onSuccess).catch(onFail);
Backendless.Messaging.addPushNotificationListener(callback)
Backendless.Messaging.removePushNotificationListener(callback)
function callback(notification:Object){
// notification.message => "push message"
// notification.title => "push title"
// notification.subtitle => "push subtitle"
// notification.sound => null
// notification.badge => 2
// notification.attachmentUrl => "https://backendlessappcontent.com/.../files/banner-4.jpg"
// notification.contentAvailable => 0
// notification.mutableContent => 1
// notification.customHeaders => { myHeaderKey: "myHeaderValue" }
// notification.templateName => "testName"
}
Backendless.Messaging.addPushNotificationActionListener(callback)
Backendless.Messaging.removePushNotificationActionListener(callback)
function callback(action:Object){
// action.id => "action id"
// action.inlineReply => "some text"
// action.notification.message => "push message"
// action.notification.title => "push title"
// action.notification.subtitle => "push subtitle"
// action.notification.sound => null
// action.notification.badge => 2
// action.notification.attachmentUrl => "https://backendlessappcontent.com/.../files/banner-4.jpg"
// action.notification.contentAvailable => 0
// action.notification.mutableContent => 1
// action.notification.customHeaders => { myHeaderKey: "myHeaderValue" }
// action.notification.templateName => "testName"
}
Backendless.Messaging.getInitialNotificationAction().then(onSuccess).catch(onFail)
function onSuccess(action:Object){
// action.id => "action id"
// action.inlineReply => "some text"
// action.notification.message => "push message"
// action.notification.title => "push title"
// action.notification.subtitle => "push subtitle"
// action.notification.sound => null
// action.notification.badge => 2
// action.notification.attachmentUrl => "https://backendlessappcontent.com/.../files/banner-4.jpg"
// action.notification.contentAvailable => 0
// action.notification.mutableContent => 1
// action.notification.customHeaders => { myHeaderKey: "myHeaderValue" }
// action.notification.templateName => "testName"
}
Backendless.Messaging.getAppBadgeNumber().then(onGetSuccess).catch(onFail)
function onGetSuccess(badge:Number){
}
Backendless.Messaging.setAppBadgeNumber(badge:Number).then(onSetSuccess).catch(onFail)
function onSetSuccess(void){
}
Backendless.Messaging.getNotifications().then(onSuccess).catch(onFail)
function onSuccess(notifications:Array<Object>){
}
Backendless.Messaging.cancelAlldNotifications().then(onSuccess).catch(onFail)
function onSuccess(void){
}
Backendless.Messaging.cancelNotification(notification.id).then(onSuccess).catch(onFail)
function onSuccess(void){
}