2018-02-22 04:58:55 +00:00
|
|
|
/* global interfaceConfig */
|
2016-12-01 18:55:42 +00:00
|
|
|
|
2018-02-22 04:58:55 +00:00
|
|
|
import Button from '@atlaskit/button';
|
|
|
|
import { FieldTextStateless } from '@atlaskit/field-text';
|
|
|
|
import { AtlasKitThemeProvider } from '@atlaskit/theme';
|
2016-12-01 18:55:42 +00:00
|
|
|
import React from 'react';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
|
2017-03-01 02:55:12 +00:00
|
|
|
import { translate } from '../../base/i18n';
|
2017-01-17 22:16:08 +00:00
|
|
|
import { Watermarks } from '../../base/react';
|
2016-12-01 18:55:42 +00:00
|
|
|
|
2017-01-28 23:34:57 +00:00
|
|
|
import { AbstractWelcomePage, _mapStateToProps } from './AbstractWelcomePage';
|
2016-11-23 21:46:46 +00:00
|
|
|
|
|
|
|
/**
|
2016-12-16 03:00:06 +00:00
|
|
|
* The Web container rendering the welcome page.
|
|
|
|
*
|
|
|
|
* @extends AbstractWelcomePage
|
2016-11-23 21:46:46 +00:00
|
|
|
*/
|
2016-12-01 18:55:42 +00:00
|
|
|
class WelcomePage extends AbstractWelcomePage {
|
|
|
|
/**
|
2016-12-16 03:00:06 +00:00
|
|
|
* Initializes a new WelcomePage instance.
|
|
|
|
*
|
|
|
|
* @param {Object} props - The read-only properties with which the new
|
|
|
|
* instance is to be initialized.
|
|
|
|
*/
|
2016-12-01 18:55:42 +00:00
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2016-12-16 03:00:06 +00:00
|
|
|
|
2017-01-17 22:16:08 +00:00
|
|
|
this.state = {
|
|
|
|
...this.state,
|
|
|
|
|
|
|
|
generateRoomnames:
|
|
|
|
interfaceConfig.GENERATE_ROOMNAMES_ON_WELCOME_PAGE
|
|
|
|
};
|
2016-12-01 18:55:42 +00:00
|
|
|
|
2018-02-22 04:58:55 +00:00
|
|
|
/**
|
|
|
|
* The HTML Element used as the container for additional content. Used
|
|
|
|
* for directly appending the additional content template to the dom
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @type {HTMLTemplateElement|null}
|
|
|
|
*/
|
|
|
|
this._additionalContentRef = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The template to use as the main content for the welcome page. If
|
|
|
|
* not found then only the welcome page head will display.
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @type {HTMLTemplateElement|null}
|
|
|
|
*/
|
|
|
|
this._additionalContentTemplate = document.getElementById(
|
|
|
|
'welcome-page-additional-content-template');
|
|
|
|
|
2017-10-13 19:31:05 +00:00
|
|
|
// Bind event handlers so they are only bound once per instance.
|
2016-12-16 03:00:06 +00:00
|
|
|
this._onRoomChange = this._onRoomChange.bind(this);
|
2018-02-22 04:58:55 +00:00
|
|
|
this._setAdditionalContentRef
|
|
|
|
= this._setAdditionalContentRef.bind(this);
|
2016-12-01 18:55:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-09-14 09:46:35 +00:00
|
|
|
* Implements React's {@link Component#componentDidMount()}. Invoked
|
|
|
|
* immediately after this component is mounted.
|
2016-12-16 03:00:06 +00:00
|
|
|
*
|
|
|
|
* @inheritdoc
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
2016-12-01 18:55:42 +00:00
|
|
|
componentDidMount() {
|
|
|
|
if (this.state.generateRoomnames) {
|
|
|
|
this._updateRoomname();
|
|
|
|
}
|
2018-02-22 04:58:55 +00:00
|
|
|
|
|
|
|
if (this._shouldShowAdditionalContent()) {
|
|
|
|
this._additionalContentRef.appendChild(
|
|
|
|
this._additionalContentTemplate.content.cloneNode(true));
|
|
|
|
}
|
2016-12-01 18:55:42 +00:00
|
|
|
}
|
|
|
|
|
2016-11-23 21:46:46 +00:00
|
|
|
/**
|
|
|
|
* Implements React's {@link Component#render()}.
|
|
|
|
*
|
|
|
|
* @inheritdoc
|
|
|
|
* @returns {ReactElement|null}
|
|
|
|
*/
|
|
|
|
render() {
|
2018-02-22 04:58:55 +00:00
|
|
|
const { t } = this.props;
|
|
|
|
const { APP_NAME } = interfaceConfig;
|
|
|
|
const showAdditionalContent = this._shouldShowAdditionalContent();
|
|
|
|
|
2016-11-23 21:46:46 +00:00
|
|
|
return (
|
2018-02-22 04:58:55 +00:00
|
|
|
<AtlasKitThemeProvider mode = 'light'>
|
|
|
|
<div
|
|
|
|
className = { `welcome ${showAdditionalContent
|
|
|
|
? 'with-content' : 'without-content'}` }
|
|
|
|
id = 'new_welcome_page'>
|
|
|
|
<div className = 'header'>
|
|
|
|
<div className = 'header-image' />
|
|
|
|
<Watermarks />
|
|
|
|
<div className = 'header-text'>
|
|
|
|
<h1 className = 'header-text-title'>
|
|
|
|
{ t('welcomepage.title') }
|
|
|
|
</h1>
|
|
|
|
<p className = 'header-text-description'>
|
|
|
|
{ t('welcomepage.appDescription',
|
|
|
|
{ app: APP_NAME }) }
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
<div id = 'new_enter_room'>
|
|
|
|
<form
|
|
|
|
className = 'enter-room-input'
|
|
|
|
onSubmit = { this._onJoin }>
|
|
|
|
<FieldTextStateless
|
|
|
|
autoFocus = { true }
|
|
|
|
id = 'enter_room_field'
|
|
|
|
isLabelHidden = { true }
|
|
|
|
label = 'enter_room_field'
|
|
|
|
onChange = { this._onRoomChange }
|
|
|
|
placeholder = { this.state.roomPlaceholder }
|
|
|
|
shouldFitContainer = { true }
|
|
|
|
type = 'text'
|
|
|
|
value = { this.state.room } />
|
|
|
|
</form>
|
|
|
|
<Button
|
|
|
|
appearance = 'primary'
|
|
|
|
className = 'welcome-page-button'
|
|
|
|
id = 'enter_room_button'
|
|
|
|
onClick = { this._onJoin }
|
|
|
|
type = 'button'>
|
|
|
|
{ t('welcomepage.go') }
|
|
|
|
</Button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{ showAdditionalContent
|
|
|
|
? <div
|
|
|
|
className = 'welcome-page-content'
|
|
|
|
ref = { this._setAdditionalContentRef } />
|
|
|
|
: null }
|
|
|
|
</div>
|
|
|
|
</AtlasKitThemeProvider>
|
2016-11-23 21:46:46 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-12-16 03:00:06 +00:00
|
|
|
/**
|
|
|
|
* Overrides the super to account for the differences in the argument types
|
|
|
|
* provided by HTML and React Native text inputs.
|
|
|
|
*
|
|
|
|
* @inheritdoc
|
|
|
|
* @override
|
|
|
|
* @param {Event} event - The (HTML) Event which details the change such as
|
|
|
|
* the EventTarget.
|
|
|
|
* @protected
|
|
|
|
*/
|
|
|
|
_onRoomChange(event) {
|
|
|
|
super._onRoomChange(event.target.value);
|
|
|
|
}
|
|
|
|
|
2016-11-23 21:46:46 +00:00
|
|
|
/**
|
2018-02-22 04:58:55 +00:00
|
|
|
* Sets the internal reference to the HTMLDivElement used to hold the
|
|
|
|
* welcome page content.
|
2016-11-23 21:46:46 +00:00
|
|
|
*
|
2018-02-22 04:58:55 +00:00
|
|
|
* @param {HTMLDivElement} el - The HTMLElement for the div that is the root
|
|
|
|
* of the welcome page content.
|
2016-11-23 21:46:46 +00:00
|
|
|
* @private
|
2018-02-22 04:58:55 +00:00
|
|
|
* @returns {void}
|
2016-11-23 21:46:46 +00:00
|
|
|
*/
|
2018-02-22 04:58:55 +00:00
|
|
|
_setAdditionalContentRef(el) {
|
|
|
|
this._additionalContentRef = el;
|
2016-11-23 21:46:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-02-22 04:58:55 +00:00
|
|
|
* Returns whether or not additional content should be displayed belowed
|
|
|
|
* the welcome page's header for entering a room name.
|
2016-11-23 21:46:46 +00:00
|
|
|
*
|
|
|
|
* @private
|
2018-02-22 04:58:55 +00:00
|
|
|
* @returns {boolean}
|
2016-11-23 21:46:46 +00:00
|
|
|
*/
|
2018-02-22 04:58:55 +00:00
|
|
|
_shouldShowAdditionalContent() {
|
|
|
|
return interfaceConfig.DISPLAY_WELCOME_PAGE_CONTENT
|
|
|
|
&& this._additionalContentTemplate
|
|
|
|
&& this._additionalContentTemplate.content
|
|
|
|
&& this._additionalContentTemplate.innerHTML.trim();
|
2016-11-23 21:46:46 +00:00
|
|
|
}
|
|
|
|
}
|
2016-12-01 18:55:42 +00:00
|
|
|
|
2017-02-23 16:56:25 +00:00
|
|
|
export default translate(connect(_mapStateToProps)(WelcomePage));
|