import React from 'react'; import PropTypes from 'prop-types'; import { Text, ScrollView, View, StyleSheet, Image, Dimensions } from 'react-native'; import { Provider } from 'react-redux'; import { Navigation } from 'react-native-navigation'; import SafeAreaView from 'react-native-safe-area-view'; import { gestureHandlerRootHOC, RectButton } from 'react-native-gesture-handler'; import sharedStyles from './Styles'; import scrollPersistTaps from '../utils/scrollPersistTaps'; import { isIOS, isAndroid } from '../utils/deviceInfo'; import LoggedView from './View'; import I18n from '../i18n'; import store from '../lib/createStore'; import { DARK_HEADER } from '../constants/headerOptions'; let TermsServiceView = null; let PrivacyPolicyView = null; const styles = StyleSheet.create({ container: { backgroundColor: '#f7f8fa', flex: 1 }, scroll: { marginTop: 35, backgroundColor: '#fff', borderColor: '#cbced1', borderTopWidth: StyleSheet.hairlineWidth, borderBottomWidth: StyleSheet.hairlineWidth }, separator: { backgroundColor: '#cbced1', height: StyleSheet.hairlineWidth, width: '100%', marginLeft: 20 }, item: { width: '100%', height: 48, backgroundColor: '#fff', paddingLeft: 20, paddingRight: 10, flexDirection: 'row', alignItems: 'center', justifyContent: 'space-between' }, text: { ...sharedStyles.textMedium, color: '#0c0d0f', fontSize: 18 }, disclosureIndicator: { width: 20, height: 20 } }); const Separator = () => ; /** @extends React.Component */ export default class LegalView extends LoggedView { static options() { return { ...DARK_HEADER, topBar: { ...DARK_HEADER.topBar, title: { ...DARK_HEADER.topBar.title, text: I18n.t('Legal') }, leftButtons: [{ id: 'close', icon: isAndroid ? { uri: 'back', scale: Dimensions.get('window').scale } : undefined, text: isIOS ? I18n.t('Close') : undefined, testID: 'legal-view-close' }] } }; } static propTypes = { componentId: PropTypes.string } constructor(props) { super('LegalView', props); Navigation.events().bindComponent(this); } navigationButtonPressed = ({ buttonId }) => { if (buttonId === 'close') { const { componentId } = this.props; Navigation.dismissModal(componentId); } } onPressItem = ({ route }) => { if (route === 'TermsServiceView' && TermsServiceView == null) { TermsServiceView = require('./TermsServiceView').default; Navigation.registerComponentWithRedux('TermsServiceView', () => gestureHandlerRootHOC(TermsServiceView), Provider, store); } if (route === 'PrivacyPolicyView' && PrivacyPolicyView == null) { PrivacyPolicyView = require('./PrivacyPolicyView').default; Navigation.registerComponentWithRedux('PrivacyPolicyView', () => gestureHandlerRootHOC(PrivacyPolicyView), Provider, store); } const { componentId } = this.props; Navigation.push(componentId, { component: { name: route } }); } renderItem = ({ text, route, testID }) => ( this.onPressItem({ route })} testID={testID}> {I18n.t(text)} ) render() { return ( {this.renderItem({ text: 'Terms_of_Service', route: 'TermsServiceView', testID: 'legal-terms-button' })} {this.renderItem({ text: 'Privacy_Policy', route: 'PrivacyPolicyView', testID: 'legal-privacy-button' })} ); } }