UNPKG

@uiw/react-md-editor

Version:

A markdown editor with preview, implemented with React.js and TypeScript.

71 lines (61 loc) 2.09 kB
import insertText from '../../utils/InsertTextAtPosition'; import { TextAreaTextApi } from '../../commands'; import { insertBeforeEachLine } from '../../commands/list'; /** * - `13` - `Enter` * - `9` - `Tab` */ function stopPropagation(e) { e.stopPropagation(); e.preventDefault(); } export default (function (options, e) { var target = e.target; var starVal = target.value.substr(0, target.selectionStart); var valArr = starVal.split('\n'); var currentLineStr = valArr[valArr.length - 1]; var textArea = new TextAreaTextApi(target); if (!options.tabSize) { options.tabSize = 2; } /** * `9` - `Tab` */ if (e.keyCode === 9) { stopPropagation(e); var space = new Array(options.tabSize + 1).join(' '); var val = space; if (target.selectionStart !== target.selectionEnd) { var _star = target.value.substring(0, target.selectionStart).split('\n'); var _end = target.value.substring(0, target.selectionEnd).split('\n'); var modifiedTextLine = []; _end.forEach(function (item, idx) { if (item !== _star[idx]) { modifiedTextLine.push(item); } }); var modifiedText = modifiedTextLine.join('\n'); var oldSelectText = target.value.substring(target.selectionStart, target.selectionEnd); var newStarNum = target.value.substring(0, target.selectionStart).length; textArea.setSelectionRange({ start: target.value.indexOf(modifiedText), end: target.selectionEnd }); var modifiedTextObj = insertBeforeEachLine(modifiedText, space); textArea.replaceSelection(modifiedTextObj.modifiedText); textArea.setSelectionRange({ start: newStarNum + options.tabSize, end: newStarNum + oldSelectText.length + modifiedTextLine.length * options.tabSize }); } else { return insertText(target, val); } } else if (e.keyCode === 13 && /^-\s/.test(currentLineStr)) { /** * `13` - `Enter` */ stopPropagation(e); return insertText(target, "\n- "); } }); //# sourceMappingURL=hotkeys.js.map