@sendbird/uikit-react-native
Version:
Sendbird UIKit for React Native: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
51 lines (50 loc) • 1.62 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _reactNative = require("react-native");
const createNativeNotificationService = ({
messagingModule,
permissionModule
}) => {
const module = messagingModule();
const authorizedStatus = [messagingModule.AuthorizationStatus.AUTHORIZED, messagingModule.AuthorizationStatus.PROVISIONAL];
return {
getAPNSToken() {
return module.getAPNSToken();
},
getFCMToken() {
return module.getToken();
},
async hasPushPermission() {
if (_reactNative.Platform.OS === 'android') {
const result = await permissionModule.checkNotifications();
return result.status === 'granted';
}
if (_reactNative.Platform.OS === 'ios') {
const status = await module.hasPermission();
return authorizedStatus.includes(status);
}
return false;
},
async requestPushPermission() {
if (_reactNative.Platform.OS === 'android') {
const result = await permissionModule.requestNotifications([]);
return result.status === 'granted';
}
if (_reactNative.Platform.OS === 'ios') {
const status = await module.requestPermission();
return authorizedStatus.includes(status);
}
return false;
},
onTokenRefresh(handler) {
return module.onTokenRefresh(token => {
if (_reactNative.Platform.OS === 'android') handler(token);
});
}
};
};
var _default = exports.default = createNativeNotificationService;
//# sourceMappingURL=createNotificationService.native.js.map
;