/* @flow */ import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { connect } from 'react-redux'; import { createDeepLinkingPageEvent, sendAnalytics } from '../../analytics'; import { translate, translateToHTML } from '../../base/i18n'; import { HideNotificationBarStyle, Platform } from '../../base/react'; import { DialInSummary } from '../../invite'; import { _TNS } from '../constants'; import { generateDeepLinkingURL } from '../functions'; declare var interfaceConfig: Object; /** * The namespace of the CSS styles of DeepLinkingMobilePage. * * @private * @type {string} */ const _SNS = 'deep-linking-mobile'; /** * The map of platforms to URLs at which the mobile app for the associated * platform is available for download. * * @private * @type {Array} */ const _URLS = { android: interfaceConfig.MOBILE_DOWNLOAD_LINK_ANDROID || 'https://play.google.com/store/apps/details?id=org.jitsi.meet', ios: interfaceConfig.MOBILE_DOWNLOAD_LINK_IOS || 'https://itunes.apple.com/us/app/jitsi-meet/id1165103905' }; /** * React component representing mobile browser page. * * @class DeepLinkingMobilePage */ class DeepLinkingMobilePage extends Component<*, *> { state: Object; /** * DeepLinkingMobilePage component's property types. * * @static */ static propTypes = { /** * The name of the conference attempting to being joined. */ _room: PropTypes.string, /** * The function to translate human-readable text. * * @public * @type {Function} */ t: PropTypes.func }; /** * Initializes a new {@code DeepLinkingMobilePage} instance. * * @param {Object} props - The read-only React {@code Component} props with * which the new instance is to be initialized. */ constructor(props) { super(props); // Bind event handlers so they are only bound once per instance. this._onDownloadApp = this._onDownloadApp.bind(this); this._onOpenApp = this._onOpenApp.bind(this); } /** * Initializes the text and URL of the `Start a conference` / `Join the * conversation` button which takes the user to the mobile app. * * @inheritdoc */ componentWillMount() { this.setState({ joinURL: generateDeepLinkingURL() }); } /** * Implements the Component's componentDidMount method. * * @inheritdoc */ componentDidMount() { sendAnalytics( createDeepLinkingPageEvent( 'displayed', 'DeepLinkingMobile', { isMobileBrowser: true })); } /** * Implements React's {@link Component#render()}. * * @inheritdoc * @returns {ReactElement} */ render() { const { _room, t } = this.props; const { NATIVE_APP_NAME, SHOW_DEEP_LINKING_IMAGE } = interfaceConfig; const downloadButtonClassName = `${_SNS}__button ${_SNS}__button_primary`; return (
{ SHOW_DEEP_LINKING_IMAGE ? : null }

{ translateToHTML( t, `${_TNS}.appNotInstalled`, { app: NATIVE_APP_NAME }) }

{/* */}
); } _onDownloadApp: () => {}; /** * Handles download app button clicks. * * @returns {void} */ _onDownloadApp() { sendAnalytics( createDeepLinkingPageEvent( 'clicked', 'downloadAppButton', { isMobileBrowser: true })); } _onOpenApp: () => {}; /** * Handles open app button clicks. * * @returns {void} */ _onOpenApp() { sendAnalytics( createDeepLinkingPageEvent( 'clicked', 'openAppButton', { isMobileBrowser: true })); } } /** * Maps (parts of) the Redux state to the associated props for the * {@code DeepLinkingMobilePage} component. * * @param {Object} state - The Redux state. * @private * @returns {{ * _room: string * }} */ function _mapStateToProps(state) { return { _room: state['features/base/conference'].room }; } export default translate(connect(_mapStateToProps)(DeepLinkingMobilePage));