import React from 'react'; import { WebView } from 'react-native-webview'; import { connect } from 'react-redux'; import { DrawerScreenProps } from '@react-navigation/drawer'; import I18n from '../../i18n'; import StatusBar from '../../containers/StatusBar'; import * as HeaderButton from '../../containers/HeaderButton'; import { withTheme } from '../../theme'; import { getUserSelector } from '../../selectors/login'; import SafeAreaView from '../../containers/SafeAreaView'; import { AdminPanelStackParamList } from '../../stacks/types'; interface IAdminPanelViewProps { baseUrl: string; token: string; } interface INavigationOptions { navigation: DrawerScreenProps; isMasterDetail: boolean; } class AdminPanelView extends React.Component { static navigationOptions = ({ navigation, isMasterDetail }: INavigationOptions) => ({ headerLeft: isMasterDetail ? undefined : () => , title: I18n.t('Admin_Panel') }); render() { const { baseUrl, token } = this.props; if (!baseUrl) { return null; } return ( {}} source={{ uri: `${baseUrl}/admin/info?layout=embedded` }} injectedJavaScript={`Meteor.loginWithToken('${token}', function() { })`} /> ); } } const mapStateToProps = (state: any) => ({ baseUrl: state.server.server, token: getUserSelector(state).token }); export default connect(mapStateToProps)(withTheme(AdminPanelView));