2015-03-11 17:16:50 -07:00
|
|
|
/**
|
2015-03-23 13:35:08 -07:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
2015-03-11 17:16:50 -07:00
|
|
|
*
|
|
|
|
* @providesModule PushNotificationIOS
|
2015-03-23 17:09:14 -07:00
|
|
|
* @flow
|
2015-03-11 17:16:50 -07:00
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2015-03-16 12:33:02 -07:00
|
|
|
var NativeModules = require('NativeModules');
|
2015-03-11 17:16:50 -07:00
|
|
|
var RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
|
2015-03-24 05:31:11 -07:00
|
|
|
var RCTPushNotificationManager = require('NativeModules').PushNotificationManager;
|
|
|
|
var invariant = require('invariant');
|
2015-03-16 12:33:02 -07:00
|
|
|
|
2015-03-11 17:16:50 -07:00
|
|
|
var _notifHandlers = {};
|
2015-03-24 05:31:11 -07:00
|
|
|
var _initialNotification = RCTPushNotificationManager &&
|
|
|
|
RCTPushNotificationManager.initialNotification;
|
2015-03-11 17:16:50 -07:00
|
|
|
|
|
|
|
var DEVICE_NOTIF_EVENT = 'remoteNotificationReceived';
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Handle push notifications for your app, including permission handling and
|
|
|
|
* icon badge number.
|
|
|
|
*
|
|
|
|
* To get up and running, [configure your notifications with Apple](https://developer.apple.com/library/ios/documentation/IDEs/Conceptual/AppDistributionGuide/ConfiguringPushNotifications/ConfiguringPushNotifications.html)
|
|
|
|
* and your server-side system. To get an idea, [this is the Parse guide](https://parse.com/tutorials/ios-push-notifications).
|
|
|
|
*/
|
2015-03-11 17:16:50 -07:00
|
|
|
class PushNotificationIOS {
|
2015-03-23 17:09:14 -07:00
|
|
|
_data: Object;
|
|
|
|
_alert: string | Object;
|
|
|
|
_sound: string;
|
|
|
|
_badgeCount: number;
|
2015-03-11 17:16:50 -07:00
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Sets the badge number for the app icon on the home screen
|
|
|
|
*/
|
|
|
|
static setApplicationIconBadgeNumber(number: number) {
|
2015-03-24 05:31:11 -07:00
|
|
|
RCTPushNotificationManager.setApplicationIconBadgeNumber(number);
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Gets the current badge number for the app icon on the home screen
|
|
|
|
*/
|
|
|
|
static getApplicationIconBadgeNumber(callback: Function) {
|
2015-03-24 05:31:11 -07:00
|
|
|
RCTPushNotificationManager.getApplicationIconBadgeNumber(callback);
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Attaches a listener to remote notifications while the app is running in the
|
|
|
|
* foreground or the background.
|
|
|
|
*
|
|
|
|
* The handler will get be invoked with an instance of `PushNotificationIOS`
|
|
|
|
*/
|
|
|
|
static addEventListener(type: string, handler: Function) {
|
|
|
|
invariant(
|
|
|
|
type === 'notification',
|
|
|
|
'PushNotificationIOS only supports `notification` events'
|
|
|
|
);
|
2015-03-11 17:16:50 -07:00
|
|
|
_notifHandlers[handler] = RCTDeviceEventEmitter.addListener(
|
|
|
|
DEVICE_NOTIF_EVENT,
|
|
|
|
(notifData) => {
|
|
|
|
handler(new PushNotificationIOS(notifData));
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Requests all notification permissions from iOS, prompting the user's
|
|
|
|
* dialog box.
|
|
|
|
*/
|
2015-03-24 05:31:11 -07:00
|
|
|
static requestPermissions() {
|
|
|
|
RCTPushNotificationManager.requestPermissions();
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* See what push permissions are currently enabled. `callback` will be
|
|
|
|
* invoked with a `permissions` object:
|
|
|
|
*
|
|
|
|
* - `alert` :boolean
|
|
|
|
* - `badge` :boolean
|
|
|
|
* - `sound` :boolean
|
|
|
|
*/
|
|
|
|
static checkPermissions(callback: Function) {
|
2015-03-24 05:31:11 -07:00
|
|
|
invariant(
|
|
|
|
typeof callback === 'function',
|
|
|
|
'Must provide a valid callback'
|
|
|
|
);
|
|
|
|
RCTPushNotificationManager.checkPermissions(callback);
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Removes the event listener. Do this in `componentWillUnmount` to prevent
|
|
|
|
* memory leaks
|
|
|
|
*/
|
|
|
|
static removeEventListener(type: string, handler: Function) {
|
|
|
|
invariant(
|
|
|
|
type === 'notification',
|
|
|
|
'PushNotificationIOS only supports `notification` events'
|
|
|
|
);
|
2015-03-11 17:16:50 -07:00
|
|
|
if (!_notifHandlers[handler]) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_notifHandlers[handler].remove();
|
|
|
|
_notifHandlers[handler] = null;
|
|
|
|
}
|
|
|
|
|
2015-03-16 12:33:02 -07:00
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* An initial notification will be available if the app was cold-launched
|
|
|
|
* from a notification.
|
|
|
|
*
|
|
|
|
* The first caller of `popInitialNotification` will get the initial
|
|
|
|
* notification object, or `null`. Subsequent invocations will return null.
|
|
|
|
*/
|
2015-03-16 12:33:02 -07:00
|
|
|
static popInitialNotification() {
|
|
|
|
var initialNotification = _initialNotification &&
|
|
|
|
new PushNotificationIOS(_initialNotification);
|
|
|
|
_initialNotification = null;
|
|
|
|
return initialNotification;
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* You will never need to instansiate `PushNotificationIOS` yourself.
|
|
|
|
* Listening to the `notification` event and invoking
|
|
|
|
* `popInitialNotification` is sufficient
|
|
|
|
*/
|
2015-03-11 17:16:50 -07:00
|
|
|
constructor(nativeNotif) {
|
|
|
|
this._data = {};
|
|
|
|
|
|
|
|
// Extract data from Apple's `aps` dict as defined:
|
|
|
|
|
|
|
|
// https://developer.apple.com/library/ios/documentation/NetworkingInternet/Conceptual/RemoteNotificationsPG/Chapters/ApplePushService.html
|
|
|
|
|
|
|
|
Object.keys(nativeNotif).forEach((notifKey) => {
|
|
|
|
var notifVal = nativeNotif[notifKey];
|
|
|
|
if (notifKey === 'aps') {
|
|
|
|
this._alert = notifVal.alert;
|
|
|
|
this._sound = notifVal.sound;
|
|
|
|
this._badgeCount = notifVal.badge;
|
|
|
|
} else {
|
|
|
|
this._data[notifKey] = notifVal;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* An alias for `getAlert` to get the notification's main message string
|
|
|
|
*/
|
2015-03-23 17:09:14 -07:00
|
|
|
getMessage(): ?string | ?Object {
|
2015-03-11 17:16:50 -07:00
|
|
|
// alias because "alert" is an ambiguous name
|
|
|
|
return this._alert;
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Gets the sound string from the `aps` object
|
|
|
|
*/
|
2015-03-23 17:09:14 -07:00
|
|
|
getSound(): ?string {
|
2015-03-11 17:16:50 -07:00
|
|
|
return this._sound;
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Gets the notification's main message from the `aps` object
|
|
|
|
*/
|
2015-03-23 17:09:14 -07:00
|
|
|
getAlert(): ?string | ?Object {
|
2015-03-11 17:16:50 -07:00
|
|
|
return this._alert;
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Gets the badge count number from the `aps` object
|
|
|
|
*/
|
2015-03-23 17:09:14 -07:00
|
|
|
getBadgeCount(): ?number {
|
2015-03-11 17:16:50 -07:00
|
|
|
return this._badgeCount;
|
|
|
|
}
|
|
|
|
|
2015-03-26 09:58:51 -07:00
|
|
|
/**
|
|
|
|
* Gets the data object on the notif
|
|
|
|
*/
|
2015-03-23 17:09:14 -07:00
|
|
|
getData(): ?Object {
|
2015-03-11 17:16:50 -07:00
|
|
|
return this._data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = PushNotificationIOS;
|