// @flow import React, { Component } from 'react'; import { Linking, Platform, View } from 'react-native'; import { WebView } from 'react-native-webview'; import { type Dispatch } from 'redux'; import { openDialog } from '../../../../base/dialog'; import { translate } from '../../../../base/i18n'; import { IconClose } from '../../../../base/icons'; import JitsiScreen from '../../../../base/modal/components/JitsiScreen'; import { LoadingIndicator } from '../../../../base/react'; import { connect } from '../../../../base/redux'; import HeaderNavigationButton from '../../../../mobile/navigation/components/HeaderNavigationButton'; import { navigateRoot } from '../../../../mobile/navigation/rootNavigationContainerRef'; import { screen } from '../../../../mobile/navigation/routes'; import { getDialInfoPageURLForURIString } from '../../../functions'; import DialInSummaryErrorDialog from './DialInSummaryErrorDialog'; import styles, { INDICATOR_COLOR } from './styles'; type Props = { dispatch: Dispatch, /** * Default prop for navigating between screen components(React Navigation). */ navigation: Object, /** * Default prop for navigating between screen components(React Navigation). */ route: Object, /** * Translation function. */ t: Function }; /** * Implements a React native component that displays the dial in info page for a specific room. */ class DialInSummary extends Component { /** * Initializes a new instance. * * @inheritdoc */ constructor(props: Props) { super(props); this._onNavigateToRoot = this._onNavigateToRoot.bind(this); this._onError = this._onError.bind(this); this._onNavigate = this._onNavigate.bind(this); this._renderLoading = this._renderLoading.bind(this); } /** * Implements React's {@link Component#componentDidMount()}. Invoked * immediately after mounting occurs. * * @inheritdoc * @returns {void} */ componentDidMount() { const { navigation, t } = this.props; navigation.setOptions({ headerLeft: () => { if (Platform.OS === 'ios') { return ( ); } return ( ); } }); } /** * Implements React's {@link Component#render()}. * * @inheritdoc */ render() { const { route } = this.props; const summaryUrl = route.params?.summaryUrl; return ( ); } _onNavigateToRoot: () => void; /** * Callback to handle navigation back to root. * * @returns {void} */ _onNavigateToRoot() { navigateRoot(screen.root); } _onError: () => void; /** * Callback to handle the error if the page fails to load. * * @returns {void} */ _onError() { this.props.dispatch(openDialog(DialInSummaryErrorDialog)); } _onNavigate: Object => Boolean; /** * Callback to intercept navigation inside the webview and make the native app handle the dial requests. * * NOTE: We don't navigate to anywhere else form that view. * * @param {any} request - The request object. * @returns {boolean} */ _onNavigate(request) { const { url } = request; const { route } = this.props; const summaryUrl = route.params?.summaryUrl; if (url.startsWith('tel:')) { Linking.openURL(url); } return url === getDialInfoPageURLForURIString(summaryUrl); } _renderLoading: () => React$Component; /** * Renders the loading indicator. * * @returns {React$Component} */ _renderLoading() { return ( ); } } export default translate(connect()(DialInSummary));