UNPKG

@atlaskit/editor-plugin-breakout

Version:

Breakout plugin for @atlaskit/editor-core

182 lines (180 loc) 8.37 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.resizingPluginKey = exports.createResizingPlugin = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _safePlugin = require("@atlaskit/editor-common/safe-plugin"); var _utils = require("@atlaskit/editor-common/utils"); var _document = require("@atlaskit/editor-common/utils/document"); var _state = require("@atlaskit/editor-prosemirror/state"); var _editorSharedStyles = require("@atlaskit/editor-shared-styles"); var _experiments = require("@atlaskit/tmp-editor-statsig/experiments"); var _handleKeyDown = require("./handle-key-down"); var _resizingMarkView = require("./resizing-mark-view"); var _singlePlayerExpand = require("./utils/single-player-expand"); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var addBreakoutToResizableNode = function addBreakoutToResizableNode(_ref) { var node = _ref.node, pos = _ref.pos, newState = _ref.newState, newTr = _ref.newTr, breakoutResizableNodes = _ref.breakoutResizableNodes, isFullWidthEnabled = _ref.isFullWidthEnabled; var updatedDocChanged = false; var updatedTr = newTr; var $pos = newState.doc.resolve(pos); var isTopLevelNode = ($pos === null || $pos === void 0 ? void 0 : $pos.depth) === 0; if (breakoutResizableNodes.has(node.type) && isTopLevelNode) { var breakout = newState.schema.marks.breakout; var expand = newState.schema.nodes.expand; var breakoutMark = node.marks.find(function (mark) { return mark.type === breakout; }); var isExpand = node.type === expand; if (!breakoutMark) { var width = isFullWidthEnabled ? _editorSharedStyles.akEditorFullWidthLayoutWidth : _editorSharedStyles.akEditorDefaultLayoutWidth; updatedTr = newTr.setNodeMarkup(pos, node.type, node.attrs, [breakout.create({ width: width })]); if (isExpand) { (0, _singlePlayerExpand.updateExpandedStateNew)({ tr: updatedTr, node: node, pos: pos, isLivePage: true }); } updatedDocChanged = true; } else if ((breakoutMark === null || breakoutMark === void 0 ? void 0 : breakoutMark.attrs.width) === null || (breakoutMark === null || breakoutMark === void 0 ? void 0 : breakoutMark.attrs.width) === undefined) { var mode = breakoutMark.attrs.mode; // if breakout is present on node, but page appearance is 'full width' force width to full width to maintain backwards compatibility var newWidth = isFullWidthEnabled || mode === 'full-width' ? _editorSharedStyles.akEditorFullWidthLayoutWidth : _editorSharedStyles.akEditorCalculatedWideLayoutWidth; updatedTr = newTr.setNodeMarkup(pos, node.type, node.attrs, [breakout.create({ width: newWidth, mode: mode })]); if (isExpand) { (0, _singlePlayerExpand.updateExpandedStateNew)({ tr: updatedTr, node: node, pos: pos, isLivePage: true }); } updatedDocChanged = true; } } return { updatedTr: updatedTr, updatedDocChanged: updatedDocChanged }; }; var resizingPluginKey = exports.resizingPluginKey = new _state.PluginKey('breakout-resizing'); var pluginState = { init: function init() { return { breakoutNode: undefined, activeGuidelineLabel: undefined }; }, apply: function apply(tr, pluginState) { var meta = tr.getMeta(resizingPluginKey); if (meta) { switch (meta.type) { case 'UPDATE_BREAKOUT_NODE': return _objectSpread(_objectSpread({}, pluginState), {}, { breakoutNode: meta.data }); case 'UPDATE_ACTIVE_GUIDELINE_KEY': return _objectSpread(_objectSpread({}, pluginState), {}, { activeGuidelineKey: meta.data.activeGuidelineKey }); case 'CLEAR_ACTIVE_GUIDELINE_KEY': return _objectSpread(_objectSpread({}, pluginState), {}, { activeGuidelineKey: undefined }); case 'RESET_STATE': return { activeGuidelineLabel: undefined, breakoutNode: undefined }; } } return pluginState; } }; var createResizingPlugin = exports.createResizingPlugin = function createResizingPlugin(api, getIntl, nodeViewPortalProviderAPI, options) { return new _safePlugin.SafePlugin({ key: resizingPluginKey, state: pluginState, props: { markViews: { breakout: function breakout(mark, view) { return new _resizingMarkView.ResizingMarkView(mark, view, api, getIntl, nodeViewPortalProviderAPI); } }, handleKeyDown: (0, _handleKeyDown.handleKeyDown)(api) }, appendTransaction: function appendTransaction(transactions, oldState, newState) { var _api$editorViewMode; if ((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) === 'view') { return; } var newTr = newState.tr; var hasDocChanged = false; var _newState$schema$node = newState.schema.nodes, expand = _newState$schema$node.expand, codeBlock = _newState$schema$node.codeBlock, layoutSection = _newState$schema$node.layoutSection; var breakoutResizableNodes = (0, _experiments.editorExperiment)('platform_synced_block', true) ? (0, _utils.getBreakoutResizableNodeTypes)(newState.schema) : new Set([expand, codeBlock, layoutSection]); var isFullWidthEnabled = !((options === null || options === void 0 ? void 0 : options.allowBreakoutButton) === true); if ((0, _document.isReplaceDocOperation)(transactions, oldState)) { newState.doc.forEach(function (node, pos) { var _addBreakoutToResizab = addBreakoutToResizableNode({ node: node, pos: pos, newState: newState, newTr: newTr, breakoutResizableNodes: breakoutResizableNodes, isFullWidthEnabled: isFullWidthEnabled }), updatedTr = _addBreakoutToResizab.updatedTr, updatedDocChanged = _addBreakoutToResizab.updatedDocChanged; newTr = updatedTr; hasDocChanged = hasDocChanged || updatedDocChanged; }); } else { transactions.forEach(function (tr) { var isAddingResizableNodes = tr.steps.some(function (step) { return (0, _utils.stepAddsOneOf)(step, breakoutResizableNodes); }); if (isAddingResizableNodes) { var changedNodes = (0, _document.getChangedNodes)(tr); changedNodes.forEach(function (_ref2) { var node = _ref2.node, pos = _ref2.pos; var _addBreakoutToResizab2 = addBreakoutToResizableNode({ node: node, pos: pos, newState: newState, newTr: newTr, breakoutResizableNodes: breakoutResizableNodes, isFullWidthEnabled: isFullWidthEnabled }), updatedTr = _addBreakoutToResizab2.updatedTr, updatedDocChanged = _addBreakoutToResizab2.updatedDocChanged; newTr = updatedTr; hasDocChanged = hasDocChanged || updatedDocChanged; }); } }); } if (hasDocChanged) { return newTr; } } }); };