import React from 'react'; import { StackNavigationOptions } from '@react-navigation/stack'; import { FlatList, Linking } from 'react-native'; import I18n from '../i18n'; import { withTheme } from '../theme'; import { themes } from '../lib/constants'; import StatusBar from '../containers/StatusBar'; import * as List from '../containers/List'; import { DEFAULT_BROWSER_KEY } from '../utils/openLink'; import { isIOS } from '../utils/deviceInfo'; import SafeAreaView from '../containers/SafeAreaView'; import UserPreferences from '../lib/methods/userPreferences'; import { events, logEvent } from '../utils/log'; type TValue = 'inApp' | 'systemDefault:' | 'googlechrome:' | 'firefox:' | 'brave:'; interface IBrowsersValues { title: string; value: TValue; } const DEFAULT_BROWSERS: IBrowsersValues[] = [ { title: 'In_app', value: 'inApp' }, { title: isIOS ? 'Safari' : 'Browser', value: 'systemDefault:' } ]; const BROWSERS: IBrowsersValues[] = [ { title: 'Chrome', value: 'googlechrome:' }, { title: 'Firefox', value: 'firefox:' }, { title: 'Brave', value: 'brave:' } ]; interface IDefaultBrowserViewState { browser: any; supported: any[]; } interface IDefaultBrowserViewProps { theme: string; } class DefaultBrowserView extends React.Component { private mounted?: boolean; static navigationOptions = (): StackNavigationOptions => ({ title: I18n.t('Default_browser') }); constructor(props: IDefaultBrowserViewProps) { super(props); this.state = { browser: null, supported: [] }; if (isIOS) { this.init(); } } componentDidMount() { this.mounted = true; const browser = UserPreferences.getString(DEFAULT_BROWSER_KEY); this.setState({ browser }); } init = () => { BROWSERS.forEach(browser => { const { value } = browser; Linking.canOpenURL(value).then(installed => { if (installed) { if (this.mounted) { this.setState(({ supported }) => ({ supported: [...supported, browser] })); } else { const { supported } = this.state; // @ts-ignore this.state.supported = [...supported, browser]; } } }); }); }; isSelected = (value: TValue) => { const { browser } = this.state; if (!browser && value === 'systemDefault:') { return true; } return browser === value; }; changeDefaultBrowser = (newBrowser: TValue) => { logEvent(events.DB_CHANGE_DEFAULT_BROWSER, { browser: newBrowser }); try { const browser = newBrowser || 'systemDefault:'; UserPreferences.setString(DEFAULT_BROWSER_KEY, browser); this.setState({ browser }); } catch { logEvent(events.DB_CHANGE_DEFAULT_BROWSER_F); } }; renderIcon = () => { const { theme } = this.props; return ; }; renderItem = ({ item }: { item: IBrowsersValues }) => { const { title, value } = item; return ( this.changeDefaultBrowser(value)} testID={`default-browser-view-${title}`} right={() => (this.isSelected(value) ? this.renderIcon() : null)} translateTitle={false} /> ); }; renderHeader = () => ( <> ); render() { const { supported } = this.state; return ( item.value} contentContainerStyle={List.styles.contentContainerStyleFlatList} renderItem={this.renderItem} ListHeaderComponent={this.renderHeader} ListFooterComponent={List.Separator} ItemSeparatorComponent={List.Separator} /> ); } } export default withTheme(DefaultBrowserView);