2017-06-30 17:23:32 +01:00
|
|
|
import { Platform } from 'react-native';
|
|
|
|
import ModuleBase from './../../utils/ModuleBase';
|
2017-03-30 16:25:27 +01:00
|
|
|
import RemoteMessage from './RemoteMessage';
|
2017-03-02 12:58:15 +00:00
|
|
|
|
2017-03-30 16:25:27 +01:00
|
|
|
const EVENT_TYPE = {
|
2017-05-30 08:26:40 +01:00
|
|
|
RefreshToken: 'messaging_token_refreshed',
|
|
|
|
Notification: 'messaging_notification_received',
|
2017-03-17 16:04:39 +00:00
|
|
|
};
|
|
|
|
|
2017-03-30 16:25:27 +01:00
|
|
|
const NOTIFICATION_TYPE = {
|
2017-03-17 16:04:39 +00:00
|
|
|
Remote: 'remote_notification',
|
|
|
|
NotificationResponse: 'notification_response',
|
|
|
|
WillPresent: 'will_present_notification',
|
|
|
|
Local: 'local_notification',
|
|
|
|
};
|
|
|
|
|
2017-03-30 16:25:27 +01:00
|
|
|
const REMOTE_NOTIFICATION_RESULT = {
|
2017-03-17 16:04:39 +00:00
|
|
|
NewData: 'UIBackgroundFetchResultNewData',
|
|
|
|
NoData: 'UIBackgroundFetchResultNoData',
|
|
|
|
ResultFailed: 'UIBackgroundFetchResultFailed',
|
|
|
|
};
|
|
|
|
|
2017-03-30 16:25:27 +01:00
|
|
|
const WILL_PRESENT_RESULT = {
|
2017-03-17 16:04:39 +00:00
|
|
|
All: 'UNNotificationPresentationOptionAll',
|
|
|
|
None: 'UNNotificationPresentationOptionNone',
|
|
|
|
};
|
2017-03-02 12:58:15 +00:00
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* IOS only finish function
|
|
|
|
* @param data
|
|
|
|
*/
|
|
|
|
function finish(data) {
|
|
|
|
if (Platform.OS !== 'ios') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!this._finishCalled && this._completionHandlerId) {
|
2017-03-27 13:26:26 +01:00
|
|
|
let result = data;
|
2017-03-17 16:04:39 +00:00
|
|
|
|
|
|
|
this._finishCalled = true;
|
|
|
|
|
|
|
|
switch (this._notificationType) {
|
|
|
|
case NOTIFICATION_TYPE.Remote:
|
|
|
|
result = result || REMOTE_NOTIFICATION_RESULT.NoData;
|
|
|
|
if (!Object.values(REMOTE_NOTIFICATION_RESULT).includes(result)) {
|
|
|
|
throw new Error('Invalid REMOTE_NOTIFICATION_RESULT value, use messaging().REMOTE_NOTIFICATION_RESULT');
|
|
|
|
}
|
|
|
|
|
|
|
|
FirebaseMessaging.finishRemoteNotification(this._completionHandlerId, result);
|
|
|
|
return;
|
|
|
|
case NOTIFICATION_TYPE.NotificationResponse:
|
|
|
|
FirebaseMessaging.finishNotificationResponse(this._completionHandlerId);
|
|
|
|
return;
|
|
|
|
case NOTIFICATION_TYPE.WillPresent:
|
|
|
|
result = result || (this.show_in_foreground ? WILL_PRESENT_RESULT.All : WILL_PRESENT_RESULT.None);
|
|
|
|
if (!Object.values(WILL_PRESENT_RESULT).includes(result)) {
|
|
|
|
throw new Error('Invalid WILL_PRESENT_RESULT value, use messaging().WILL_PRESENT_RESULT');
|
|
|
|
}
|
|
|
|
|
|
|
|
FirebaseMessaging.finishWillPresentNotification(this._completionHandlerId, result);
|
2017-06-30 17:23:32 +01:00
|
|
|
break;
|
2017-03-17 16:04:39 +00:00
|
|
|
default:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-03-02 12:58:15 +00:00
|
|
|
/**
|
|
|
|
* @class Messaging
|
|
|
|
*/
|
2017-06-30 17:23:32 +01:00
|
|
|
export default class Messaging extends ModuleBase {
|
|
|
|
constructor(firebaseApp: Object, options: Object = {}) {
|
2017-07-18 06:03:35 +01:00
|
|
|
super(firebaseApp, options, 'Messaging', true);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
get EVENT_TYPE() {
|
|
|
|
return EVENT_TYPE;
|
|
|
|
}
|
|
|
|
|
|
|
|
get NOTIFICATION_TYPE() {
|
|
|
|
return NOTIFICATION_TYPE;
|
|
|
|
}
|
|
|
|
|
|
|
|
get REMOTE_NOTIFICATION_RESULT() {
|
|
|
|
return REMOTE_NOTIFICATION_RESULT;
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
get WILL_PRESENT_RESULT() {
|
|
|
|
return WILL_PRESENT_RESULT;
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Returns the notification that triggered application open
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
getInitialNotification() {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.getInitialNotification();
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Returns the fcm token for the current device
|
|
|
|
* @returns {*|Promise.<String>}
|
|
|
|
*/
|
2017-03-02 12:58:15 +00:00
|
|
|
getToken() {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.getToken();
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Create and display a local notification
|
|
|
|
* @param notification
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
createLocalNotification(notification: Object) {
|
|
|
|
const _notification = Object.assign({}, notification);
|
|
|
|
_notification.id = _notification.id || new Date().getTime().toString();
|
|
|
|
_notification.local_notification = true;
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.createLocalNotification(_notification);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param notification
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
scheduleLocalNotification(notification: Object) {
|
|
|
|
const _notification = Object.assign({}, notification);
|
|
|
|
if (!notification.id) return Promise.reject(new Error('An id is required to schedule a local notification.'));
|
|
|
|
_notification.local_notification = true;
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.scheduleLocalNotification(_notification);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Returns an array of all scheduled notifications
|
|
|
|
* @returns {Promise.<Array>}
|
|
|
|
*/
|
|
|
|
getScheduledLocalNotifications() {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.getScheduledLocalNotifications();
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Cancel a local notification by id - using '*' will cancel
|
|
|
|
* all local notifications.
|
|
|
|
* @param id
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
cancelLocalNotification(id: string) {
|
|
|
|
if (!id) return null;
|
2017-06-30 17:23:32 +01:00
|
|
|
if (id === '*') return this._native.cancelAllLocalNotifications();
|
|
|
|
return this._native.cancelLocalNotification(id);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Remove a delivered notification - using '*' will remove
|
|
|
|
* all delivered notifications.
|
|
|
|
* @param id
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
removeDeliveredNotification(id: string) {
|
|
|
|
if (!id) return null;
|
2017-06-30 17:23:32 +01:00
|
|
|
if (id === '*') return this._native.removeAllDeliveredNotifications();
|
|
|
|
return this._native.removeDeliveredNotification(id);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-21 11:26:16 +00:00
|
|
|
/**
|
|
|
|
* Request notification permission
|
|
|
|
* @platforms ios
|
|
|
|
* @returns {*|Promise.<*>}
|
|
|
|
*/
|
|
|
|
requestPermissions() {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.requestPermissions();
|
2017-03-21 11:26:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Set notification count badge number
|
2017-03-21 11:26:16 +00:00
|
|
|
* @param n
|
2017-03-17 16:04:39 +00:00
|
|
|
*/
|
2017-03-21 11:26:16 +00:00
|
|
|
setBadgeNumber(n: number) {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.setBadgeNumber(n);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* set notification count badge number
|
|
|
|
* @returns {Promise.<Number>}
|
|
|
|
*/
|
|
|
|
getBadgeNumber() {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.getBadgeNumber();
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Subscribe to messages / notifications
|
|
|
|
* @param listener
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
2017-06-19 12:25:58 +01:00
|
|
|
onMessage(listener: Function): () => any {
|
2017-06-30 17:23:32 +01:00
|
|
|
const rnListener = this._eventEmitter.addListener(
|
2017-05-30 08:26:40 +01:00
|
|
|
EVENT_TYPE.Notification,
|
2017-06-30 17:23:32 +01:00
|
|
|
async (event) => {
|
2017-05-30 08:26:40 +01:00
|
|
|
const data = {
|
|
|
|
...event,
|
|
|
|
finish,
|
|
|
|
};
|
|
|
|
await listener(data);
|
|
|
|
|
|
|
|
if (!data._finishCalled) {
|
|
|
|
data.finish();
|
|
|
|
}
|
2017-06-30 17:23:32 +01:00
|
|
|
},
|
2017-06-19 13:14:36 +01:00
|
|
|
);
|
|
|
|
return () => rnListener.remove();
|
2017-03-17 16:04:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribe to token refresh events
|
|
|
|
* @param listener
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
2017-06-19 12:25:58 +01:00
|
|
|
onTokenRefresh(listener: Function): () => any {
|
2017-06-30 17:23:32 +01:00
|
|
|
const rnListener = this._eventEmitter.addListener(EVENT_TYPE.RefreshToken, listener);
|
2017-06-19 13:14:36 +01:00
|
|
|
return () => rnListener.remove();
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
|
|
|
|
2017-03-17 16:04:39 +00:00
|
|
|
/**
|
|
|
|
* Subscribe to a topic
|
|
|
|
* @param topic
|
|
|
|
*/
|
|
|
|
subscribeToTopic(topic: String) {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.subscribeToTopic(topic);
|
2017-03-17 16:04:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unsubscribe from a topic
|
|
|
|
* @param topic
|
|
|
|
*/
|
|
|
|
unsubscribeFromTopic(topic: String) {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.unsubscribeFromTopic(topic);
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
2017-03-21 15:11:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Send an upstream message
|
2017-03-30 16:25:27 +01:00
|
|
|
* @param remoteMessage
|
2017-03-21 15:11:07 +00:00
|
|
|
*/
|
2017-03-30 16:25:27 +01:00
|
|
|
send(remoteMessage: RemoteMessage) {
|
|
|
|
if (!(remoteMessage instanceof RemoteMessage)) {
|
|
|
|
throw new Error('messaging().send requires an instance of RemoteMessage as the first argument.');
|
|
|
|
}
|
|
|
|
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.send(remoteMessage.toJSON());
|
2017-03-21 15:11:07 +00:00
|
|
|
}
|
2017-03-02 12:58:15 +00:00
|
|
|
}
|
2017-03-30 16:25:27 +01:00
|
|
|
|
|
|
|
export const statics = {
|
|
|
|
EVENT_TYPE,
|
|
|
|
NOTIFICATION_TYPE,
|
|
|
|
REMOTE_NOTIFICATION_RESULT,
|
|
|
|
WILL_PRESENT_RESULT,
|
|
|
|
RemoteMessage,
|
|
|
|
};
|