-
Notifications
You must be signed in to change notification settings - Fork 45
/
index.js
70 lines (59 loc) · 2.71 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/**
* @format
*/
import { AppRegistry, Alert } from 'react-native';
import App from './App';
import { name as appName } from './app.json';
import PushNotificationIOS from '@react-native-community/push-notification-ios';
import PushNotification from 'react-native-push-notification';
import { EventRegister } from 'react-native-event-listeners';
import { set } from './src/utils/Storage';
const { emit } = EventRegister;
/**
* Push Notifications Configurations
* We will just use EventRegister to pass up.
*/
PushNotification.configure({
// (optional) Called when Token is generated (iOS and Android)
onRegister: function (token) {
console.log('[PushNotification.onRegister() #token]', token);
emit('onNotificationsRegister', token);
set('token', token);
},
// (required) Called when a remote is received or opened, or local notification is opened
onNotification: function (notification) {
console.log('[PushNotification.onNotification() #notification]', notification);
emit('onNotification', notification);
// (required) Called when a remote is received or opened, or local notification is opened
notification.finish(PushNotificationIOS.FetchResult.NoData);
},
// (optional) Called when Registered Action is pressed and invokeApp is false, if true onNotification will be called (Android)
onAction: function (notification) {
console.log('[PushNotification.onAction() #notification.action]', notification.action);
console.log('[PushNotification.onAction() #notification]', notification);
emit('onNotificationsAction', notification);
},
// (optional) Called when the user fails to register for remote notifications. Typically occurs when APNS is having issues, or the device is a simulator. (iOS)
onRegistrationError: function (err) {
console.log('[PushNotification.onRegistrationError() #err]', err.message, err);
emit('onNotificationsRegistrationError', err);
},
// IOS ONLY (optional): default: all - Permissions to register.
permissions: {
alert: true,
badge: true,
sound: true,
},
// Should the initial notification be popped automatically
// default: true
popInitialNotification: 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
* - if you are not using remote notification or do not have Firebase installed, use this:
* requestPermissions: Platform.OS === 'ios'
*/
requestPermissions: true,
});
AppRegistry.registerComponent(appName, () => App);