UNPKG

@atlaskit/editor-plugin-code-block

Version:

Code block plugin for @atlaskit/editor-core

59 lines (58 loc) 2.38 kB
import { isEmptyNode } from '@atlaskit/editor-common/utils'; import { keymap } from '@atlaskit/editor-prosemirror/keymap'; import { Selection } from '@atlaskit/editor-prosemirror/state'; import { findParentNodeOfTypeClosestToPos, hasParentNodeOfType } from '@atlaskit/editor-prosemirror/utils'; import { getCursor } from './utils'; var deleteCurrentItem = function deleteCurrentItem($from) { return function (tr) { return tr.delete($from.before($from.depth), $from.after($from.depth)); }; }; var setTextSelection = function setTextSelection(pos) { return function (tr) { var newSelection = Selection.findFrom(tr.doc.resolve(pos), -1, true); if (newSelection) { tr.setSelection(newSelection); } return tr; }; }; export function keymapPlugin(schema) { return keymap({ Backspace: function Backspace(state, dispatch) { var $cursor = getCursor(state.selection); var _state$schema$nodes = state.schema.nodes, codeBlock = _state$schema$nodes.codeBlock, listItem = _state$schema$nodes.listItem, table = _state$schema$nodes.table, layoutColumn = _state$schema$nodes.layoutColumn, paragraph = _state$schema$nodes.paragraph; if (!$cursor || $cursor.parent.type !== codeBlock || !dispatch) { return false; } if ($cursor.pos === 1 || hasParentNodeOfType(listItem)(state.selection) && $cursor.parentOffset === 0) { var node = findParentNodeOfTypeClosestToPos($cursor, codeBlock); if (!node) { return false; } dispatch(state.tr.setNodeMarkup(node.pos, node.node.type, node.node.attrs, []).setBlockType($cursor.pos, $cursor.pos, paragraph)); return true; } if ($cursor.node && isEmptyNode(schema)($cursor.node()) && (hasParentNodeOfType(layoutColumn)(state.selection) || hasParentNodeOfType(table)(state.selection))) { var tr = state.tr; var insertPos = $cursor.pos; deleteCurrentItem($cursor)(tr); setTextSelection(insertPos)(tr); dispatch(tr.scrollIntoView()); return true; } // Handle not nested empty code block if (isEmptyNode(schema)($cursor.node())) { dispatch(deleteCurrentItem($cursor)(state === null || state === void 0 ? void 0 : state.tr)); return true; } return false; } }); } export default keymapPlugin;