208 lines
5.8 KiB
JavaScript
208 lines
5.8 KiB
JavaScript
/* @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<string>}
|
|
*/
|
|
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 (
|
|
<div className = { _SNS }>
|
|
<div className = 'header'>
|
|
<img
|
|
className = 'logo'
|
|
src = '../images/logo-deep-linking.png' />
|
|
</div>
|
|
<div className = { `${_SNS}__body` }>
|
|
{
|
|
SHOW_DEEP_LINKING_IMAGE
|
|
? <img
|
|
className = 'image'
|
|
src = '../images/deep-linking-image.png' />
|
|
: null
|
|
}
|
|
<p className = { `${_SNS}__text` }>
|
|
{
|
|
translateToHTML(
|
|
t,
|
|
`${_TNS}.appNotInstalled`,
|
|
{ app: NATIVE_APP_NAME })
|
|
}
|
|
</p>
|
|
<a
|
|
href = { _URLS[Platform.OS] }
|
|
onClick = { this._onDownloadApp } >
|
|
<button className = { downloadButtonClassName }>
|
|
{ t(`${_TNS}.downloadApp`) }
|
|
</button>
|
|
</a>
|
|
<a
|
|
className = { `${_SNS}__href` }
|
|
href = { this.state.joinURL }
|
|
onClick = { this._onOpenApp }>
|
|
{/* <button className = { `${_SNS}__button` }> */}
|
|
{ t(`${_TNS}.openApp`) }
|
|
{/* </button> */}
|
|
</a>
|
|
<DialInSummary
|
|
className = 'deep-linking-dial-in'
|
|
clickableNumbers = { true }
|
|
room = { _room } />
|
|
</div>
|
|
<HideNotificationBarStyle />
|
|
</div>
|
|
);
|
|
}
|
|
|
|
_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));
|