2020-01-22 14:34:46 +00:00
|
|
|
/*
|
|
|
|
* keypress actions
|
|
|
|
* @flow
|
|
|
|
*/
|
|
|
|
import keycode from 'keycode';
|
|
|
|
|
|
|
|
import store from '../ui/store';
|
2020-04-28 05:16:47 +00:00
|
|
|
import copy from '../utils/clipboard';
|
2020-01-22 14:34:46 +00:00
|
|
|
import {
|
|
|
|
toggleGrid,
|
|
|
|
togglePixelNotify,
|
|
|
|
toggleMute,
|
2020-04-28 05:16:47 +00:00
|
|
|
notify,
|
2020-01-22 14:34:46 +00:00
|
|
|
} from '../actions';
|
|
|
|
|
|
|
|
|
|
|
|
function onKeyPress(event: KeyboardEvent) {
|
|
|
|
// ignore key presses if modal is open or chat is used
|
|
|
|
if (event.target.nodeName === 'INPUT'
|
|
|
|
|| event.target.nodeName === 'TEXTAREA'
|
|
|
|
) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (keycode(event)) {
|
|
|
|
case 'g':
|
|
|
|
store.dispatch(toggleGrid());
|
|
|
|
break;
|
2020-04-28 05:16:47 +00:00
|
|
|
case 'x':
|
2020-01-22 14:34:46 +00:00
|
|
|
store.dispatch(togglePixelNotify());
|
|
|
|
break;
|
|
|
|
case 'm':
|
|
|
|
store.dispatch(toggleMute());
|
|
|
|
break;
|
2020-04-29 02:38:36 +00:00
|
|
|
case 'r': {
|
2020-04-28 05:16:47 +00:00
|
|
|
const state = store.getState();
|
|
|
|
const { hover } = state.gui;
|
|
|
|
const text = hover.join('_');
|
|
|
|
copy(text);
|
|
|
|
store.dispatch(notify('Copied!'));
|
|
|
|
break;
|
|
|
|
}
|
2020-01-22 14:34:46 +00:00
|
|
|
default:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default onKeyPress;
|