add command + s for save, detect os for control + s, add to keyboard shortcut list
This commit is contained in:
parent
41e6ce1c78
commit
12c0581ee0
2 changed files with 54 additions and 29 deletions
|
@ -2,12 +2,17 @@ import React, { PropTypes } from 'react';
|
|||
import InlineSVG from 'react-inlinesvg';
|
||||
const exitUrl = require('../../../images/exit.svg');
|
||||
|
||||
function KeyboardShortcutModal(props) {
|
||||
class KeyboardShortcutModal extends React.Component {
|
||||
componentDidMount() {
|
||||
this.isMac = navigator.userAgent.toLowerCase().indexOf('mac') !== -1;
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<section className="keyboard-shortcuts">
|
||||
<header className="keyboard-shortcuts__header">
|
||||
<h2>Keyboard Shortcuts</h2>
|
||||
<button className="keyboard-shortcuts__close" onClick={props.closeModal}>
|
||||
<button className="keyboard-shortcuts__close" onClick={this.props.closeModal}>
|
||||
<InlineSVG src={exitUrl} alt="Close Keyboard Shortcuts Overlay" />
|
||||
</button>
|
||||
</header>
|
||||
|
@ -16,6 +21,12 @@ function KeyboardShortcutModal(props) {
|
|||
<span className="keyboard-shortcut__command">Shift + Tab</span>
|
||||
<span>Tidy</span>
|
||||
</li>
|
||||
<li className="keyboard-shortcut-item">
|
||||
<span className="keyboard-shortcut__command">
|
||||
{this.isMac ? 'Command + S' : 'Control + S'}
|
||||
</span>
|
||||
<span>Save</span>
|
||||
</li>
|
||||
<li className="keyboard-shortcut-item">
|
||||
<span className="keyboard-shortcut__command">Command + [</span>
|
||||
<span>Indent Code Right</span>
|
||||
|
@ -32,6 +43,7 @@ function KeyboardShortcutModal(props) {
|
|||
</section>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
KeyboardShortcutModal.propTypes = {
|
||||
closeModal: PropTypes.func.isRequired
|
||||
|
|
|
@ -32,6 +32,7 @@ class IDEView extends React.Component {
|
|||
super(props);
|
||||
this._handleConsolePaneOnDragFinished = this._handleConsolePaneOnDragFinished.bind(this);
|
||||
this._handleSidebarPaneOnDragFinished = this._handleSidebarPaneOnDragFinished.bind(this);
|
||||
this.handleGlobalKeydown = this.handleGlobalKeydown.bind(this);
|
||||
}
|
||||
|
||||
componentDidMount() {
|
||||
|
@ -51,6 +52,9 @@ class IDEView extends React.Component {
|
|||
this.consoleSize = this.props.ide.consoleIsExpanded ? 180 : 29;
|
||||
this.sidebarSize = this.props.ide.sidebarIsExpanded ? 200 : 20;
|
||||
this.forceUpdate();
|
||||
|
||||
this.isMac = navigator.userAgent.toLowerCase().indexOf('mac') !== -1;
|
||||
document.addEventListener('keydown', this.handleGlobalKeydown, false);
|
||||
}
|
||||
|
||||
componentWillUpdate(nextProps) {
|
||||
|
@ -113,6 +117,15 @@ class IDEView extends React.Component {
|
|||
});
|
||||
}
|
||||
|
||||
handleGlobalKeydown(e) {
|
||||
if (e.key === 's' && ((e.metaKey && this.isMac) || (e.ctrlKey && !this.isMac))) {
|
||||
console.log('about to save project');
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
this.props.saveProject();
|
||||
}
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className="ide">
|
||||
|
|
Loading…
Reference in a new issue