- Notifications
You must be signed in to change notification settings - Fork0
React Native Local and Remote Notifications
License
justhive/react-native-push-notification
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
React Native Local and Remote Notifications for iOS and Android
| Component Version | RN Versions | README |
|---|---|---|
| 1.0.7 | <= 0.27 | Open |
| 1.0.8 | 0.28 | Open |
| 2.0.1 | 0.29 | Open |
| 2.0.2 | 0.30, 0.31, 0.32 | Open |
| >= 2.1.0 | >= 0.33 | Open |
npm install --save react-native-push-notification
react-native link
NOTE: For Android, you will still have to manually update the AndroidManifest.xml (as below) in order to use Scheduled Notifications.
Having a problem? Read thetroubleshooting guide before raising an issue.
The component uses PushNotificationIOS for the iOS part.
Please see: PushNotificationIOS
NOTE: To use a specificplay-service-gcm version, use in yourandroid/app/build.gradle (change8.1.0 for your version):
...dependencies {... compile project(':react-native-push-notification') compile ('com.google.android.gms:play-services-gcm:8.1.0') { force=true; }}
In yourAndroidManifest.xml
..... <uses-permissionandroid:name="android.permission.WAKE_LOCK" /> <permissionandroid:name="${applicationId}.permission.C2D_MESSAGE"android:protectionLevel="signature" /> <uses-permissionandroid:name="${applicationId}.permission.C2D_MESSAGE" /> <uses-permissionandroid:name="android.permission.VIBRATE" /> <uses-permissionandroid:name="android.permission.RECEIVE_BOOT_COMPLETED"/> <application ....> <receiverandroid:name="com.google.android.gms.gcm.GcmReceiver"android:exported="true"android:permission="com.google.android.c2dm.permission.SEND" > <intent-filter> <actionandroid:name="com.google.android.c2dm.intent.RECEIVE" /> <categoryandroid:name="${applicationId}" /> </intent-filter> </receiver> <receiverandroid:name="com.dieam.reactnativepushnotification.modules.RNPushNotificationPublisher" /> <receiverandroid:name="com.dieam.reactnativepushnotification.modules.RNPushNotificationBootEventReceiver"> <intent-filter> <actionandroid:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> <serviceandroid:name="com.dieam.reactnativepushnotification.modules.RNPushNotificationRegistrationService"/> <serviceandroid:name="com.dieam.reactnativepushnotification.modules.RNPushNotificationListenerService"android:exported="false" > <intent-filter> <actionandroid:name="com.google.android.c2dm.intent.RECEIVE" /> </intent-filter> </service> .....
Inandroid/settings.gradle
...include':react-native-push-notification'project(':react-native-push-notification').projectDir= file('../node_modules/react-native-push-notification/android')
Manually register module inMainApplication.java (if you did not usereact-native link):
importcom.dieam.reactnativepushnotification.ReactNativePushNotificationPackage;// <--- Import PackagepublicclassMainApplicationextendsApplicationimplementsReactApplication {privatefinalReactNativeHostmReactNativeHost =newReactNativeHost(this) {@OverrideprotectedbooleangetUseDeveloperSupport() {returnBuildConfig.DEBUG; }@OverrideprotectedList<ReactPackage>getPackages() {returnArrays.<ReactPackage>asList(newMainReactPackage(),newReactNativePushNotificationPackage()// <---- Add the Package ); } }; ....}
varPushNotification=require('react-native-push-notification');PushNotification.configure({// (optional) Called when Token is generated (iOS and Android)onRegister:function(token){console.log('TOKEN:',token);},// (required) Called when a remote or local notification is opened or receivedonNotification:function(notification){console.log('NOTIFICATION:',notification);},// ANDROID ONLY: GCM Sender ID (optional - not required for local notifications, but is need to receive remote push notifications)senderID:"YOUR GCM SENDER ID",// IOS ONLY (optional): default: all - Permissions to register.permissions:{alert:true,badge:true,sound:true},// Should the initial notification be popped automatically// default: truepopInitialNotification:true,/** * (optional) default: true * - Specified if permissions (ios) and token (android and ios) will requested or not, * - if not, you must call PushNotificationsHandler.requestPermissions() later */requestPermissions:true,});
When any notification is opened or received the callbackonNotification is called passing an object with the notification data.
Notification object example:
{foreground:false,// BOOLEAN: If the notification was received in foreground or notuserInteraction:false,// BOOLEAN: If the notification was opened by the user from the notification area or notmessage:'My Notification Message',// STRING: The notification messagedata:{},// OBJECT: The push data}
PushNotification.localNotification(details: Object)
EXAMPLE:
PushNotification.localNotification({/* Android Only Properties */id:'0',// (optional) Valid unique 32 bit integer specified as string. default: Autogenerated Unique IDticker:"My Notification Ticker",// (optional)autoCancel:true,// (optional) default: truelargeIcon:"ic_launcher",// (optional) default: "ic_launcher"smallIcon:"ic_notification",// (optional) default: "ic_notification" with fallback for "ic_launcher"bigText:"My big text that will be shown when notification is expanded",// (optional) default: "message" propsubText:"This is a subText",// (optional) default: nonecolor:"red",// (optional) default: system defaultvibrate:true,// (optional) default: truevibration:300,// vibration length in milliseconds, ignored if vibrate=false, default: 1000tag:'some_tag',// (optional) add tag to messagegroup:"group",// (optional) add group to messageongoing:false,// (optional) set whether this is an "ongoing" notification/* iOS only properties */alertAction:// (optional) default: viewcategory:// (optional) default: nulluserInfo:// (optional) default: null (object containing additional notification data)/* iOS and Android properties */title:"My Notification Title",// (optional, for iOS this is only used in apple watch, the title will be the app name on other iOS devices)message:"My Notification Message",// (required)playSound:false,// (optional) default: truesoundName:'default',// (optional) Sound to play when the notification is shown. Value of 'default' plays the default sound. It can be set to a custom sound such as 'android.resource://com.xyz/raw/my_sound'. It will look for the 'my_sound' audio file in 'res/raw' directory and play it. default: 'default' (default sound is played)number:'10',// (optional) Valid 32 bit integer specified as string. default: none (Cannot be zero)repeatType:'day',// (Android only) Repeating interval. Could be one of `week`, `day`, `hour`, `minute, `time`. If specified as time, it should be accompanied by one more parameter 'repeatTime` which should the number of milliseconds between each intervalactions:'["Yes", "No"]',// (Android only) See the doc for notification actions to know more});
PushNotification.localNotificationSchedule(details: Object)
EXAMPLE:
PushNotification.localNotificationSchedule({message:"My Notification Message",// (required)date:newDate(Date.now()+(60*1000))// in 60 secs});
In android, add your custom sound file to[project_root]/android/app/src/main/res/raw
In iOS, add your custom sound file to the projectResources in xCode.
In the location notification json specify the full file name:
soundName: 'my_sound.mp3'PushNotification.cancelLocalNotifications(details);
The thedetails parameter allows you to specify auserInfo dictionary that can be used to match one or morescheduled notifications. Eachmatched notification is cancelled and its alerts removed from the notification centre. The RN docs suggest this is an optional parameter, butit is not.
PushNotification.cancelLocalNotifications({id:'123'});
PushNotification.cancelAllLocalNotifications()
Cancels all scheduled notifications AND clears the notifications alerts that are in the notification centre.
NOTE: there is currently no api for removing specific notification alerts from the notification centre.
(Android only) SpecifyrepeatType and optionallyrepeatTime while scheduling the local notification. Check the local notification example above.
For iOS, the repeating notification should land soon. It has already been merged to themaster
(Android only)Refer to this issue to see an example of a notification action.
Two things are required to setup notification actions.
This is done by specifying anactions parameters while configuring the local notification. This is an array of strings where each string is a notificaiton action that will be presented with the notification.
For e.g.actions: '["Accept", "Reject"]' // Must be in string format
The array itself is specified in string format to circumvent some problems because of the way JSON arrays are handled by react-native android bridge.
For each action specified in theactions field, we need to add a handler that is called when the user clicks on the action. This can be done in thecomponentWillMount of your main app file or in a separate file which is imported in your main app file. Notification actions handlers can be configured as below:
import PushNotificationAndroid from 'react-native-push-notification'(function() { // Register all the valid actions for notifications here and add the action handler for each action PushNotificationAndroid.registerNotificationActions(['Accept','Reject','Yes','No']); DeviceEventEmitter.addListener('notificationActionReceived', function(action){ console.log ('Notification action received: ' + action); const info = JSON.parse(action.dataJSON); if (info.action == 'Accept') { // Do work pertaining to Accept action here } else if (info.action == 'Reject') { // Do work pertaining to Reject action here } // Add all the required actions handlers });})();For iOS, you can use thispackage to add notification actions.
PushNotification.setApplicationIconBadgeNumber(number: number)
Works natively in iOS.
Uses theShortcutBadger on Android, and as such will not work on all Android devices.
Same parameters asPushNotification.localNotification()
PushNotification.checkPermissions(callback: Function) Check permissions
PushNotification.getApplicationIconBadgeNumber(callback: Function) get badge number
PushNotification.abandonPermissions() Abandon permissions
About
React Native Local and Remote Notifications
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Releases
Packages0
Languages
- Java81.1%
- JavaScript18.9%