react/features/settings/components/web/MoreTab.js (297 lines of code) (raw):

// @flow import { Checkbox } from '@atlaskit/checkbox'; import DropdownMenu, { DropdownItem, DropdownItemGroup } from '@atlaskit/dropdown-menu'; import React from 'react'; import keyboardShortcut from '../../../../../modules/keyboardshortcut/keyboardshortcut'; import { AbstractDialogTab } from '../../../base/dialog'; import type { Props as AbstractDialogTabProps } from '../../../base/dialog'; import { translate } from '../../../base/i18n'; import TouchmoveHack from '../../../chat/components/web/TouchmoveHack'; import { SS_DEFAULT_FRAME_RATE } from '../../constants'; /** * The type of the React {@code Component} props of {@link MoreTab}. */ export type Props = { ...$Exact<AbstractDialogTabProps>, /** * The currently selected desktop share frame rate in the frame rate select dropdown. */ currentFramerate: string, /** * The currently selected language to display in the language select * dropdown. */ currentLanguage: string, /** * All available desktop capture frame rates. */ desktopShareFramerates: Array<number>, /** * Whether or not follow me is currently active (enabled by some other participant). */ followMeActive: boolean, /** * All available languages to display in the language select dropdown. */ languages: Array<string>, /** * Whether or not to display the language select dropdown. */ showLanguageSettings: boolean, /** * Whether or not to display moderator-only settings. */ showModeratorSettings: boolean, /** * Whether or not to display the prejoin settings section. */ showPrejoinSettings: boolean, /** * Whether or not to show prejoin screen. */ showPrejoinPage: boolean, /** * Invoked to obtain translated strings. */ t: Function }; /** * The type of the React {@code Component} state of {@link MoreTab}. */ type State = { /** * Whether or not the desktop share frame rate select dropdown is open. */ isFramerateSelectOpen: boolean, /** * Whether or not the language select dropdown is open. */ isLanguageSelectOpen: boolean }; /** * React {@code Component} for modifying language and moderator settings. * * @augments Component */ class MoreTab extends AbstractDialogTab<Props, State> { /** * Initializes a new {@code MoreTab} instance. * * @param {Object} props - The read-only properties with which the new * instance is to be initialized. */ constructor(props: Props) { super(props); this.state = { isFramerateSelectOpen: false, isLanguageSelectOpen: false }; // Bind event handler so it is only bound once for every instance. this._onFramerateDropdownOpenChange = this._onFramerateDropdownOpenChange.bind(this); this._onFramerateItemSelect = this._onFramerateItemSelect.bind(this); this._onLanguageDropdownOpenChange = this._onLanguageDropdownOpenChange.bind(this); this._onLanguageItemSelect = this._onLanguageItemSelect.bind(this); this._onShowPrejoinPageChanged = this._onShowPrejoinPageChanged.bind(this); this._onKeyboardShortcutEnableChanged = this._onKeyboardShortcutEnableChanged.bind(this); } /** * Implements React's {@link Component#render()}. * * @inheritdoc * @returns {ReactElement} */ render() { const content = []; content.push(this._renderSettingsLeft()); content.push(this._renderSettingsRight()); return ( <div className = 'more-tab box' key = 'more'> { content } </div> ); } _onFramerateDropdownOpenChange: (Object) => void; /** * Callback invoked to toggle display of the desktop share framerate select dropdown. * * @param {Object} event - The event for opening or closing the dropdown. * @private * @returns {void} */ _onFramerateDropdownOpenChange({ isOpen }) { this.setState({ isFramerateSelectOpen: isOpen }); } _onFramerateItemSelect: (Object) => void; /** * Callback invoked to select a frame rate from the select dropdown. * * @param {Object} e - The key event to handle. * @private * @returns {void} */ _onFramerateItemSelect(e) { const frameRate = e.currentTarget.getAttribute('data-framerate'); super._onChange({ currentFramerate: frameRate }); } _onLanguageDropdownOpenChange: (Object) => void; /** * Callback invoked to toggle display of the language select dropdown. * * @param {Object} event - The event for opening or closing the dropdown. * @private * @returns {void} */ _onLanguageDropdownOpenChange({ isOpen }) { this.setState({ isLanguageSelectOpen: isOpen }); } _onLanguageItemSelect: (Object) => void; /** * Callback invoked to select a language from select dropdown. * * @param {Object} e - The key event to handle. * * @returns {void} */ _onLanguageItemSelect(e) { const language = e.currentTarget.getAttribute('data-language'); super._onChange({ currentLanguage: language }); } _onShowPrejoinPageChanged: (Object) => void; /** * Callback invoked to select if the lobby * should be shown. * * @param {Object} e - The key event to handle. * * @returns {void} */ _onShowPrejoinPageChanged({ target: { checked } }) { super._onChange({ showPrejoinPage: checked }); } _onKeyboardShortcutEnableChanged: (Object) => void; /** * Callback invoked to select if global keyboard shortcuts * should be enabled. * * @param {Object} e - The key event to handle. * * @returns {void} */ _onKeyboardShortcutEnableChanged({ target: { checked } }) { keyboardShortcut.enable(checked); super._onChange({ keyboardShortcutEnable: checked }); } /** * Returns the React Element for the desktop share frame rate dropdown. * * @returns {ReactElement} */ _renderFramerateSelect() { const { currentFramerate, desktopShareFramerates, t } = this.props; const frameRateItems = desktopShareFramerates.map(frameRate => ( <DropdownItem data-framerate = { frameRate } key = { frameRate } onClick = { this._onFramerateItemSelect }> { `${frameRate} ${t('settings.framesPerSecond')}` } </DropdownItem>)); return ( <div className = 'settings-sub-pane-element' key = 'frameRate'> <h2 className = 'mock-atlaskit-label'> { t('settings.desktopShareFramerate') } </h2> <div className = 'dropdown-menu'> <TouchmoveHack flex = { true } isModal = { true }> <DropdownMenu isOpen = { this.state.isFramerateSelectOpen } onOpenChange = { this._onFramerateDropdownOpenChange } shouldFitContainer = { true } trigger = { currentFramerate ? `${currentFramerate} ${t('settings.framesPerSecond')}` : '' } triggerButtonProps = {{ shouldFitContainer: true }} triggerType = 'button'> <DropdownItemGroup> { frameRateItems } </DropdownItemGroup> </DropdownMenu> </TouchmoveHack> </div> <div className = 'mock-atlaskit-label'> { parseInt(currentFramerate, 10) > SS_DEFAULT_FRAME_RATE ? t('settings.desktopShareHighFpsWarning') : t('settings.desktopShareWarning') } </div> </div> ); } /** * Returns the React Element for keyboardShortcut settings. * * @private * @returns {ReactElement} */ _renderKeyboardShortcutCheckbox() { const { t } = this.props; return ( <div className = 'settings-sub-pane-element' key = 'keyboard-shortcut'> <h2 className = 'mock-atlaskit-label'> { t('keyboardShortcuts.keyboardShortcuts') } </h2> <Checkbox isChecked = { keyboardShortcut.getEnabled() } label = { t('prejoin.keyboardShortcuts') } name = 'enable-keyboard-shortcuts' onChange = { this._onKeyboardShortcutEnableChanged } /> </div> ); } /** * Returns the menu item for changing displayed language. * * @private * @returns {ReactElement} */ _renderLanguageSelect() { const { currentLanguage, languages, t } = this.props; const languageItems = languages.map(language => ( <DropdownItem data-language = { language } key = { language } onClick = { this._onLanguageItemSelect }> { t(`languages:${language}`) } </DropdownItem>)); return ( <div className = 'settings-sub-pane-element' key = 'language'> <h2 className = 'mock-atlaskit-label'> { t('settings.language') } </h2> <div className = 'dropdown-menu'> <TouchmoveHack flex = { true } isModal = { true }> <DropdownMenu isOpen = { this.state.isLanguageSelectOpen } onOpenChange = { this._onLanguageDropdownOpenChange } shouldFitContainer = { true } trigger = { currentLanguage ? t(`languages:${currentLanguage}`) : '' } triggerButtonProps = {{ shouldFitContainer: true }} triggerType = 'button'> <DropdownItemGroup> { languageItems } </DropdownItemGroup> </DropdownMenu> </TouchmoveHack> </div> </div> ); } /** * Returns the React Element for modifying prejoin screen settings. * * @private * @returns {ReactElement} */ _renderPrejoinScreenSettings() { const { t, showPrejoinPage } = this.props; return ( <div className = 'settings-sub-pane-element' key = 'prejoin-screen'> <h2 className = 'mock-atlaskit-label'> { t('prejoin.premeeting') } </h2> <Checkbox isChecked = { showPrejoinPage } label = { t('prejoin.showScreen') } name = 'show-prejoin-page' onChange = { this._onShowPrejoinPageChanged } /> </div> ); } /** * Returns the React element that needs to be displayed on the right half of the more tabs. * * @private * @returns {ReactElement} */ _renderSettingsRight() { const { showLanguageSettings } = this.props; return ( <div className = 'settings-sub-pane right' key = 'settings-sub-pane-right'> { showLanguageSettings && this._renderLanguageSelect() } { this._renderFramerateSelect() } </div> ); } /** * Returns the React element that needs to be displayed on the left half of the more tabs. * * @returns {ReactElement} */ _renderSettingsLeft() { const { showPrejoinSettings } = this.props; return ( <div className = 'settings-sub-pane left' key = 'settings-sub-pane-left'> { showPrejoinSettings && this._renderPrejoinScreenSettings() } { this._renderKeyboardShortcutCheckbox() } </div> ); } } export default translate(MoreTab);