UNPKG

@atlaskit/editor-plugin-breakout

Version:

Breakout plugin for @atlaskit/editor-core

75 lines (73 loc) 3.43 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.handleKeyDown = void 0; var _browser = require("@atlaskit/editor-common/browser"); var _utils = require("@atlaskit/editor-common/utils"); var _state = require("@atlaskit/editor-prosemirror/state"); var _editorSharedStyles = require("@atlaskit/editor-shared-styles"); var _experiments = require("@atlaskit/tmp-editor-statsig/experiments"); var _setBreakoutWidth = require("../editor-commands/set-breakout-width"); var KEYBOARD_RESIZE_STEP = 10; var getAncestorResizableNode = function getAncestorResizableNode(view, breakoutResizableNodes) { var selection = view.state.selection; if (selection instanceof _state.NodeSelection) { var selectedNode = selection.node; if (breakoutResizableNodes.has(selectedNode.type)) { return { node: selectedNode, pos: selection.$from.pos }; } } else if (selection instanceof _state.TextSelection) { var node = null; var nodePos = null; // only top level nodes are resizable var resolvedPos = view.state.doc.resolve(selection.$from.pos); var currentNode = resolvedPos.node(1); if (breakoutResizableNodes.has(currentNode.type)) { node = currentNode; nodePos = resolvedPos.before(1); return { node: node, pos: nodePos }; } } return null; }; var handleKeyDown = exports.handleKeyDown = function handleKeyDown(api) { return function (view, event) { var browser = (0, _browser.getBrowserInfo)(); var metaKey = browser.mac ? event.metaKey : event.ctrlKey; var isBracketKey = event.code === 'BracketRight' || event.code === 'BracketLeft'; if (metaKey && event.altKey && isBracketKey) { var _view$state$schema$no = view.state.schema.nodes, expand = _view$state$schema$no.expand, codeBlock = _view$state$schema$no.codeBlock, layoutSection = _view$state$schema$no.layoutSection; var breakoutResizableNodes = (0, _experiments.editorExperiment)('platform_synced_block', true) ? (0, _utils.getBreakoutResizableNodeTypes)(view.state.schema) : new Set([expand, codeBlock, layoutSection]); var result = getAncestorResizableNode(view, breakoutResizableNodes); if (result) { var node = result.node, pos = result.pos; var breakoutMark = node === null || node === void 0 ? void 0 : node.marks.find(function (mark) { return mark.type.name === 'breakout'; }); if (breakoutMark) { var step = event.code === 'BracketRight' ? KEYBOARD_RESIZE_STEP : -KEYBOARD_RESIZE_STEP; var newWidth = breakoutMark.attrs.width + step; if (newWidth < _editorSharedStyles.akEditorFullWidthLayoutWidth && newWidth > _editorSharedStyles.akEditorDefaultLayoutWidth) { var _api$editorViewMode; var isEditMode = (api === null || api === void 0 || (_api$editorViewMode = api.editorViewMode) === null || _api$editorViewMode === void 0 || (_api$editorViewMode = _api$editorViewMode.sharedState.currentState()) === null || _api$editorViewMode === void 0 ? void 0 : _api$editorViewMode.mode) === 'edit'; (0, _setBreakoutWidth.setBreakoutWidth)(breakoutMark.attrs.width + step, breakoutMark.attrs.mode, pos, isEditMode)(view.state, view.dispatch); view.focus(); } return true; } } } return false; }; };