UNPKG

@atlaskit/editor-plugin-selection-extension

Version:

editor-plugin-selection-extension plugin for @atlaskit/editor-core

101 lines (99 loc) 5.11 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getToolbarComponents = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _react = _interopRequireDefault(require("react")); var _toolbar = require("@atlaskit/editor-common/toolbar"); var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals"); var _MenuItem = require("./toolbar-components/MenuItem"); var _registerInlineToolbar = require("./toolbar-components/register-inline-toolbar"); var _migrateSelectionExtention = require("./utils/migrate-selection-extention"); var getToolbarComponents = exports.getToolbarComponents = function getToolbarComponents(_ref) { var _config$extensionList, _config$extensions, _config$extensions2; var api = _ref.api, config = _ref.config; var extensionToolbarComponents = (config === null || config === void 0 || (_config$extensionList = config.extensionList) === null || _config$extensionList === void 0 ? void 0 : _config$extensionList.flatMap(function (extension, index) { return (0, _registerInlineToolbar.registerInlineToolbar)({ api: api, extension: extension, index: index }); })) || []; /** * Continue to support firstParty apps for now as some apps haven't migrated yet, this simply converts apps to new ExtensionMenuItemConfiguration type * to process easier. extensionList and extensions?.firstParty will most likely be mutually exclusive. * * **Warning:** This is called on every selection change to ensure calls to api?.selectionExtension.actions.getSelectionAdf() are * fresh and up to date. */ var firstPartyExtensions = (config === null || config === void 0 || (_config$extensions = config.extensions) === null || _config$extensions === void 0 || (_config$extensions = _config$extensions.firstParty) === null || _config$extensions === void 0 ? void 0 : _config$extensions.map(function (extension) { return (0, _migrateSelectionExtention.migrateSelectionExtensionToMenuItem)(extension, api); }).filter(function (extension) { return extension !== undefined; })) || []; var externalExtensions = (config === null || config === void 0 || (_config$extensions2 = config.extensions) === null || _config$extensions2 === void 0 || (_config$extensions2 = _config$extensions2.external) === null || _config$extensions2 === void 0 ? void 0 : _config$extensions2.map(function (extension) { return (0, _migrateSelectionExtention.migrateSelectionExtensionToMenuItem)(extension, api); }).filter(function (extension) { return extension !== undefined; })) || []; return [{ type: _toolbar.APPS_SECTION.type, key: _toolbar.APPS_SECTION.key, parents: [{ type: 'toolbar', key: _toolbar.TOOLBARS.INLINE_TEXT_TOOLBAR, rank: _toolbar.TOOLBAR_RANK[_toolbar.APPS_SECTION.key] }, { type: 'toolbar', key: _toolbar.TOOLBARS.PRIMARY_TOOLBAR, rank: _toolbar.TOOLBAR_RANK[_toolbar.APPS_SECTION.key] }] }].concat((0, _toConsumableArray2.default)(extensionToolbarComponents), (0, _toConsumableArray2.default)(registerFirstPartyExtensions(api, firstPartyExtensions)), (0, _toConsumableArray2.default)(registerExternalExtensions(api, externalExtensions))); }; var registerFirstPartyExtensions = function registerFirstPartyExtensions(api, extensions) { var components = []; if (extensions.length === 0 && (0, _expValEquals.expValEquals)('platform_editor_toolbar_hide_overflow_menu', 'isEnabled', true)) { return components; } components.push({ type: _toolbar.FIRST_PARTY_EXTENSIONS_MENU_ITEM.type, key: _toolbar.FIRST_PARTY_EXTENSIONS_MENU_ITEM.key, parents: [{ type: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION.type, key: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION.key, rank: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION_RANK[_toolbar.FIRST_PARTY_EXTENSIONS_MENU_ITEM.key] }], component: function component() { return /*#__PURE__*/_react.default.createElement(_MenuItem.MenuItem, { api: api, extensionMenuItems: extensions }); } }); return components; }; var registerExternalExtensions = function registerExternalExtensions(api, extensions) { var components = []; if (extensions.length === 0 && (0, _expValEquals.expValEquals)('platform_editor_toolbar_hide_overflow_menu', 'isEnabled', true)) { return components; } components.push({ type: _toolbar.EXTERNAL_EXTENSIONS_MENU_ITEM.type, key: _toolbar.EXTERNAL_EXTENSIONS_MENU_ITEM.key, parents: [{ type: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION.type, key: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION.key, rank: _toolbar.OVERFLOW_EXTENSIONS_MENU_SECTION_RANK[_toolbar.EXTERNAL_EXTENSIONS_MENU_ITEM.key] }], component: function component() { return /*#__PURE__*/_react.default.createElement(_MenuItem.MenuItem, { api: api, extensionMenuItems: extensions }); } }); return components; };