react-native-safari-view
Version:
A React Native wrapper for Safari View Controller
55 lines (47 loc) • 1.38 kB
JavaScript
/**
* @providesModule SafariViewManager
*/
;
import {
NativeModules,
NativeEventEmitter,
processColor
} from 'react-native';
const NativeSafariViewManager = NativeModules.SafariViewManager;
const eventEmitter = new NativeEventEmitter(NativeSafariViewManager);
export default {
show(options) {
if (options && options.tintColor) {
options.tintColor = processColor(options.tintColor);
}
if (options && options.barTintColor) {
options.barTintColor = processColor(options.barTintColor);
}
return NativeSafariViewManager.show(options);
},
dismiss() {
NativeSafariViewManager.dismiss();
},
isAvailable() {
return NativeSafariViewManager.isAvailable();
},
addEventListener(event, listener) {
if (event === 'onShow') {
return eventEmitter.addListener('SafariViewOnShow', listener);
} else if (event === 'onDismiss') {
return eventEmitter.addListener('SafariViewOnDismiss', listener);
} else {
console.warn(`Trying to subscribe to unknown event: ${event}`);
return {
remove: () => {}
};
}
},
removeEventListener(event, listener) {
if (event === 'onShow') {
eventEmitter.removeListener('SafariViewOnShow', listener);
} else if (event === 'onDismiss') {
eventEmitter.removeListener('SafariViewOnDismiss', listener);
}
}
};