bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/settings/submenus/application/component.jsx

257 lines
9.3 KiB
React
Raw Normal View History

2016-05-06 05:14:39 +08:00
import React from 'react';
import Button from '/imports/ui/components/button/component';
2017-01-27 23:41:11 +08:00
import cx from 'classnames';
import Toggle from '/imports/ui/components/switch/component';
2017-04-11 05:11:48 +08:00
import { defineMessages, injectIntl } from 'react-intl';
2017-10-06 03:18:30 +08:00
import BaseMenu from '../base/component';
2018-01-08 14:17:18 +08:00
import { styles } from '../styles';
const MIN_FONTSIZE = 0;
const MAX_FONTSIZE = 4;
2017-04-11 05:11:48 +08:00
const intlMessages = defineMessages({
applicationSectionTitle: {
id: 'app.submenu.application.applicationSectionTitle',
description: 'Application section title',
},
2018-08-14 03:16:22 +08:00
audioAlertLabel: {
id: 'app.submenu.application.audioAlertLabel',
2017-04-11 05:21:54 +08:00
description: 'audio notification label',
2017-04-11 05:11:48 +08:00
},
2018-08-14 03:16:22 +08:00
pushAlertLabel: {
id: 'app.submenu.application.pushAlertLabel',
2017-04-11 05:21:54 +08:00
description: 'push notifiation label',
2017-04-11 05:11:48 +08:00
},
fontSizeControlLabel: {
id: 'app.submenu.application.fontSizeControlLabel',
2017-04-11 05:21:54 +08:00
description: 'label for font size ontrol',
2017-04-11 05:11:48 +08:00
},
increaseFontBtnLabel: {
id: 'app.submenu.application.increaseFontBtnLabel',
2017-04-11 05:21:54 +08:00
description: 'label for button to increase font size',
2017-04-11 05:11:48 +08:00
},
increaseFontBtnDesc: {
id: 'app.submenu.application.increaseFontBtnDesc',
2017-04-11 05:21:54 +08:00
description: 'adds descriptive context to increase font size button',
2017-04-11 05:11:48 +08:00
},
decreaseFontBtnLabel: {
id: 'app.submenu.application.decreaseFontBtnLabel',
2017-04-11 05:21:54 +08:00
description: 'label for button to reduce font size',
2017-04-11 05:11:48 +08:00
},
decreaseFontBtnDesc: {
id: 'app.submenu.application.decreaseFontBtnDesc',
2017-04-11 05:21:54 +08:00
description: 'adds descriptive context to decrease font size button',
2017-04-11 05:11:48 +08:00
},
languageLabel: {
id: 'app.submenu.application.languageLabel',
description: 'displayed label for changing application locale',
},
ariaLanguageLabel: {
id: 'app.submenu.application.ariaLanguageLabel',
description: 'aria label for locale change section',
},
2017-06-03 03:25:02 +08:00
languageOptionLabel: {
id: 'app.submenu.application.languageOptionLabel',
description: 'default change language option when locales are available',
},
noLocaleOptionLabel: {
id: 'app.submenu.application.noLocaleOptionLabel',
description: 'default change language option when no locales available',
},
2017-04-11 05:11:48 +08:00
});
class ApplicationMenu extends BaseMenu {
2016-05-06 05:14:39 +08:00
constructor(props) {
super(props);
2018-01-31 00:41:45 +08:00
this.state = {
settingsName: 'application',
settings: props.settings,
isLargestFontSize: false,
isSmallestFontSize: false,
};
}
handleUpdateFontSize(size) {
2017-06-03 03:25:02 +08:00
const obj = this.state;
obj.settings.fontSize = size;
this.handleUpdateSettings(this.state.settingsName, obj.settings);
}
setHtmlFontSize(size) {
document.getElementsByTagName('html')[0].style.fontSize = size;
2017-06-03 03:25:02 +08:00
}
changeFontSize(size) {
2017-06-03 03:25:02 +08:00
const obj = this.state;
obj.settings.fontSize = size;
this.setState(obj, () => {
this.setHtmlFontSize(this.state.settings.fontSize);
this.handleUpdateFontSize(this.state.settings.fontSize);
});
2016-05-06 05:14:39 +08:00
}
handleIncreaseFontSize() {
const currentFontSize = this.state.settings.fontSize;
const availableFontSizes = this.props.fontSizes;
const canIncreaseFontSize = availableFontSizes.indexOf(currentFontSize) < MAX_FONTSIZE;
2018-01-30 19:20:51 +08:00
const fs = canIncreaseFontSize ? availableFontSizes.indexOf(currentFontSize) + 1 : MAX_FONTSIZE;
this.changeFontSize(availableFontSizes[fs]);
if (fs === MAX_FONTSIZE) this.setState({ isLargestFontSize: true });
this.setState({ isSmallestFontSize: false });
2017-06-03 03:25:02 +08:00
}
handleDecreaseFontSize() {
const currentFontSize = this.state.settings.fontSize;
const availableFontSizes = this.props.fontSizes;
const canDecreaseFontSize = availableFontSizes.indexOf(currentFontSize) > MIN_FONTSIZE;
2018-01-30 19:20:51 +08:00
const fs = canDecreaseFontSize ? availableFontSizes.indexOf(currentFontSize) - 1 : MIN_FONTSIZE;
this.changeFontSize(availableFontSizes[fs]);
if (fs === MIN_FONTSIZE) this.setState({ isSmallestFontSize: true });
this.setState({ isLargestFontSize: false });
2017-06-03 03:25:02 +08:00
}
2017-04-06 20:36:59 +08:00
handleSelectChange(fieldname, options, e) {
2017-06-03 03:25:02 +08:00
const obj = this.state;
obj.settings[fieldname] = e.target.value.toLowerCase().replace('_', '-');
2017-04-06 20:36:59 +08:00
this.handleUpdateSettings('application', obj.settings);
}
2017-01-27 23:41:11 +08:00
render() {
2018-01-30 19:20:51 +08:00
const { availableLocales, intl } = this.props;
const { isLargestFontSize, isSmallestFontSize } = this.state;
2017-04-06 20:36:59 +08:00
2016-05-06 05:14:39 +08:00
return (
2018-12-06 01:42:31 +08:00
<div>
<div>
2017-04-19 03:14:39 +08:00
<h3 className={styles.title}>
{intl.formatMessage(intlMessages.applicationSectionTitle)}
</h3>
2017-01-27 23:41:11 +08:00
</div>
<div className={styles.form}>
<div className={styles.row}>
2017-04-26 22:08:47 +08:00
<div className={styles.col} aria-hidden="true">
2017-01-27 23:41:11 +08:00
<div className={styles.formElement}>
<label className={styles.label}>
2018-08-14 03:16:22 +08:00
{intl.formatMessage(intlMessages.audioAlertLabel)}
2017-01-27 23:41:11 +08:00
</label>
</div>
</div>
<div className={styles.col}>
2017-04-25 10:27:28 +08:00
<div className={cx(styles.formElement, styles.pullContentRight)}>
2017-04-26 22:08:47 +08:00
<Toggle
icons={false}
2018-08-15 10:35:58 +08:00
defaultChecked={this.state.settings.chatAudioAlerts}
onChange={() => this.handleToggle('chatAudioAlerts')}
2018-08-14 03:16:22 +08:00
ariaLabel={intl.formatMessage(intlMessages.audioAlertLabel)}
2017-06-03 03:25:02 +08:00
/>
2017-01-27 23:41:11 +08:00
</div>
</div>
</div>
<div className={styles.row}>
<div className={styles.col} aria-hidden="true">
2018-01-30 19:20:51 +08:00
<div className={styles.formElement}>
2017-01-27 23:41:11 +08:00
<label className={styles.label}>
2018-08-14 03:16:22 +08:00
{intl.formatMessage(intlMessages.pushAlertLabel)}
2017-01-27 23:41:11 +08:00
</label>
</div>
</div>
<div className={styles.col}>
2017-04-25 10:27:28 +08:00
<div className={cx(styles.formElement, styles.pullContentRight)}>
2017-04-26 22:08:47 +08:00
<Toggle
icons={false}
2018-08-15 10:35:58 +08:00
defaultChecked={this.state.settings.chatPushAlerts}
onChange={() => this.handleToggle('chatPushAlerts')}
2018-08-14 03:16:22 +08:00
ariaLabel={intl.formatMessage(intlMessages.pushAlertLabel)}
2017-06-03 03:25:02 +08:00
/>
2017-01-27 23:41:11 +08:00
</div>
</div>
</div>
2017-04-06 20:36:59 +08:00
<div className={styles.row}>
<div className={styles.col} aria-hidden="true">
2017-04-06 20:36:59 +08:00
<div className={styles.formElement}>
<label className={styles.label}>
{intl.formatMessage(intlMessages.languageLabel)}
2017-04-06 20:36:59 +08:00
</label>
</div>
</div>
<div className={styles.col}>
2018-04-24 23:39:15 +08:00
<div
id="changeLangLabel"
aria-label={intl.formatMessage(intlMessages.ariaLanguageLabel)}
/>
2018-01-30 19:20:51 +08:00
<label
aria-labelledby="changeLangLabel"
className={cx(styles.formElement, styles.pullContentRight)}
>
{availableLocales && availableLocales.length > 0 ? (
2017-11-25 04:26:03 +08:00
<select
defaultValue={this.state.settings.locale}
2017-11-25 04:26:03 +08:00
className={styles.select}
onChange={this.handleSelectChange.bind(this, 'locale', availableLocales)}
>
2018-01-30 19:20:51 +08:00
<option disabled>{intl.formatMessage(intlMessages.languageOptionLabel)}</option>
{availableLocales.map((locale, index) => (
<option key={index} value={locale.locale}>
2017-11-25 04:26:03 +08:00
{locale.name}
2018-01-30 19:20:51 +08:00
</option>
))}
2017-11-25 04:26:03 +08:00
</select>
2018-01-30 19:20:51 +08:00
) : null}
</label>
2017-04-06 20:36:59 +08:00
</div>
</div>
2017-06-03 03:25:02 +08:00
<hr className={styles.separator} />
2017-01-27 23:41:11 +08:00
<div className={styles.row}>
<div className={styles.col}>
<div className={styles.formElement}>
<label className={styles.label}>
2017-04-11 05:11:48 +08:00
{intl.formatMessage(intlMessages.fontSizeControlLabel)}
2017-01-27 23:41:11 +08:00
</label>
</div>
</div>
<div className={styles.col}>
<div className={cx(styles.formElement, styles.pullContentCenter)}>
<label className={cx(styles.label, styles.bold)}>
{this.state.settings.fontSize}
2017-01-27 23:41:11 +08:00
</label>
</div>
</div>
<div className={styles.col}>
<div className={cx(styles.formElement, styles.pullContentRight)}>
2017-03-09 22:34:33 +08:00
<div className={styles.pullContentRight}>
<div className={styles.col}>
<Button
onClick={() => this.handleDecreaseFontSize()}
color="primary"
icon="substract"
2017-06-03 03:25:02 +08:00
circle
hideLabel
label={intl.formatMessage(intlMessages.decreaseFontBtnLabel)}
disabled={isSmallestFontSize}
2017-03-09 22:34:33 +08:00
/>
</div>
<div className={styles.col}>
<Button
onClick={() => this.handleIncreaseFontSize()}
color="primary"
icon="add"
2017-06-03 03:25:02 +08:00
circle
hideLabel
label={intl.formatMessage(intlMessages.increaseFontBtnLabel)}
disabled={isLargestFontSize}
2017-03-09 22:34:33 +08:00
/>
</div>
</div>
2017-01-27 23:41:11 +08:00
</div>
</div>
2016-05-06 05:14:39 +08:00
</div>
</div>
</div>
);
}
2017-06-03 03:25:02 +08:00
}
2017-04-11 05:11:48 +08:00
export default injectIntl(ApplicationMenu);