bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/shortcut-help/component.jsx

132 lines
3.8 KiB
React
Raw Normal View History

2018-05-01 03:18:29 +08:00
import React, { Component } from 'react';
import { defineMessages, injectIntl } from 'react-intl';
import browser from 'browser-detect';
2018-05-01 03:18:29 +08:00
import Modal from '/imports/ui/components/modal/simple/component';
import _ from 'lodash';
import { styles } from './styles';
const intlMessages = defineMessages({
title: {
id: 'app.shortcut-help.title',
2018-05-03 11:33:28 +08:00
description: 'modal title label',
2018-05-01 03:18:29 +08:00
},
closeLabel: {
id: 'app.shortcut-help.closeLabel',
2018-05-03 11:33:28 +08:00
description: 'label for close button',
2018-05-01 03:18:29 +08:00
},
closeDesc: {
id: 'app.shortcut-help.closeDesc',
2018-05-03 11:33:28 +08:00
description: 'description for close button',
2018-05-01 03:18:29 +08:00
},
accessKeyNotAvailable: {
id: 'app.shortcut-help.accessKeyNotAvailable',
2018-05-03 11:33:28 +08:00
description: 'message shown in place of access key table if not supported',
},
comboLabel: {
id: 'app.shortcut-help.comboLabel',
2018-05-03 11:33:28 +08:00
description: 'heading for key combo column',
},
functionLabel: {
id: 'app.shortcut-help.functionLabel',
2018-05-03 11:33:28 +08:00
description: 'heading for shortcut function column',
},
2018-05-01 03:18:29 +08:00
openOptions: {
id: 'app.shortcut-help.openOptions',
2018-05-03 11:33:28 +08:00
description: 'describes the open options shortcut',
2018-05-01 03:18:29 +08:00
},
toggleUserList: {
id: 'app.shortcut-help.toggleUserList',
2018-05-03 11:33:28 +08:00
description: 'describes the toggle userlist shortcut',
2018-05-01 03:18:29 +08:00
},
toggleMute: {
id: 'app.shortcut-help.toggleMute',
2018-05-03 11:33:28 +08:00
description: 'describes the toggle mute shortcut',
2018-05-01 03:18:29 +08:00
},
togglePublicChat: {
id: 'app.shortcut-help.togglePublicChat',
2018-05-03 11:33:28 +08:00
description: 'describes the toggle public chat shortcut',
2018-05-01 03:18:29 +08:00
},
hidePrivateChat: {
id: 'app.shortcut-help.hidePrivateChat',
2018-05-03 11:33:28 +08:00
description: 'describes the hide public chat shortcut',
2018-05-01 03:18:29 +08:00
},
closePrivateChat: {
id: 'app.shortcut-help.closePrivateChat',
2018-05-03 11:33:28 +08:00
description: 'describes the close private chat shortcut',
2018-05-01 03:18:29 +08:00
},
openActions: {
id: 'app.shortcut-help.openActions',
2018-05-03 11:33:28 +08:00
description: 'describes the open actions shortcut',
2018-05-01 03:18:29 +08:00
},
openStatus: {
id: 'app.shortcut-help.openStatus',
2018-05-03 11:33:28 +08:00
description: 'describes the open status shortcut',
2018-05-01 03:18:29 +08:00
},
joinAudio: {
id: 'app.audio.joinAudio',
2018-05-03 11:33:28 +08:00
description: 'describes the join audio shortcut',
2018-05-01 03:18:29 +08:00
},
leaveAudio: {
id: 'app.audio.leaveAudio',
2018-05-03 11:33:28 +08:00
description: 'describes the leave audio shortcut',
2018-05-01 03:18:29 +08:00
},
});
2018-05-02 08:02:45 +08:00
const SHORTCUTS_CONFIG = Meteor.settings.public.app.shortcuts;
2018-05-01 03:18:29 +08:00
class ShortcutHelpComponent extends Component {
render() {
const { intl } = this.props;
const shortcuts = Object.values(SHORTCUTS_CONFIG);
const { name } = browser();
2018-05-01 03:18:29 +08:00
let accessMod = null;
switch (name) {
case 'chrome':
case 'edge':
accessMod = 'Alt';
break;
case 'firefox':
accessMod = 'Alt + Shift';
break;
case 'safari':
case 'crios':
case 'fxios':
accessMod = 'Control + Alt';
break;
}
2018-05-01 03:18:29 +08:00
return (
<Modal
title={intl.formatMessage(intlMessages.title)}
dismiss={{
label: intl.formatMessage(intlMessages.closeLabel),
description: intl.formatMessage(intlMessages.closeDesc),
}}
>
{ !accessMod ? <p>{intl.formatMessage(intlMessages.accessKeyNotAvailable)}</p> :
<span>
<table className={styles.shortcutTable}>
<tbody>
<tr>
<th>{intl.formatMessage(intlMessages.comboLabel)}</th>
<th>{intl.formatMessage(intlMessages.functionLabel)}</th>
2018-05-01 03:18:29 +08:00
</tr>
{shortcuts.map(shortcut => (
<tr key={_.uniqueId('hotkey-item-')}>
<td className={styles.keyCell}>{`${accessMod} + ${shortcut.accesskey}`}</td>
<td className={styles.descCell}>{intl.formatMessage(intlMessages[`${shortcut.descId}`])}</td>
</tr>
))}
</tbody>
</table>
</span>
}
2018-05-01 03:18:29 +08:00
</Modal>
);
}
}
export default injectIntl(ShortcutHelpComponent);