@atlaskit/editor-plugin-breakout
Version:
Breakout plugin for @atlaskit/editor-core
75 lines (73 loc) • 3.43 kB
JavaScript
;
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;
};
};