mirror of
https://github.com/ianstormtaylor/slate.git
synced 2025-02-24 09:13:24 +01:00
127 lines
2.2 KiB
JavaScript
127 lines
2.2 KiB
JavaScript
|
|
import keycode from 'keycode'
|
|
import { IS_WINDOWS, IS_MAC } from '../utils/environment'
|
|
|
|
/**
|
|
* Export.
|
|
*/
|
|
|
|
export default {
|
|
|
|
/**
|
|
* The core `onKeyDown` handler.
|
|
*
|
|
* @param {Event} e
|
|
* @param {State} state
|
|
* @param {Editor} editor
|
|
* @return {State or Null} newState
|
|
*/
|
|
|
|
onKeyDown(e, state, editor) {
|
|
const key = keycode(e.which)
|
|
|
|
switch (key) {
|
|
case 'enter': {
|
|
e.preventDefault()
|
|
return state.split()
|
|
}
|
|
|
|
case 'backspace': {
|
|
// COMPAT: Windows has a special "cut" behavior for the shift key.
|
|
if (IS_WINDOWS && e.shiftKey) return
|
|
e.preventDefault()
|
|
return isWord(e)
|
|
? state.save().backspaceWord()
|
|
: state.save().deleteBackward()
|
|
}
|
|
|
|
case 'delete': {
|
|
// COMPAT: Windows has a special "cut" behavior for the shift key.
|
|
if (IS_WINDOWS && e.shiftKey) return
|
|
e.preventDefault()
|
|
return isWord(e)
|
|
? state.save().deleteWord()
|
|
: state.save().deleteForward()
|
|
}
|
|
|
|
case 'y': {
|
|
if (!isCtrl(e) || !IS_WINDOWS) return
|
|
e.preventDefault()
|
|
return state.redo()
|
|
}
|
|
|
|
case 'z': {
|
|
if (!isCommand(e)) return
|
|
e.preventDefault()
|
|
return IS_MAC && e.shiftKey
|
|
? state.redo()
|
|
: state.undo()
|
|
}
|
|
|
|
default: {
|
|
console.log('Unhandled key down.')
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Does an `e` have the word-level modifier?
|
|
*
|
|
* @param {Event} e
|
|
* @return {Boolean}
|
|
*/
|
|
|
|
function isWord(e) {
|
|
if (IS_MAC && e.altKey) return true
|
|
if (e.ctrlKey) return true
|
|
return false
|
|
}
|
|
|
|
/**
|
|
* Does an `e` have the control modifier?
|
|
*
|
|
* @param {Event} e
|
|
* @return {Boolean}
|
|
*/
|
|
|
|
function isCtrl(e) {
|
|
return e.ctrlKey && !e.altKey
|
|
}
|
|
|
|
/**
|
|
* Does an `e` have the option modifier?
|
|
*
|
|
* @param {Event} e
|
|
* @return {Boolean}
|
|
*/
|
|
|
|
function isOption(e) {
|
|
return IS_MAC && e.altKey
|
|
}
|
|
|
|
/**
|
|
* Does an `e` have the shift modifier?
|
|
*
|
|
* @param {Event} e
|
|
* @return {Boolean}
|
|
*/
|
|
|
|
function isShift(e) {
|
|
return e.shiftKey
|
|
}
|
|
|
|
/**
|
|
* Does an `e` have the command modifier?
|
|
*
|
|
* @param {Event} e
|
|
* @return {Boolean}
|
|
*/
|
|
|
|
function isCommand(e) {
|
|
return IS_MAC
|
|
? e.metaKey && !e.altKey
|
|
: e.ctrlKey && !e.altKey
|
|
}
|