UNPKG

@atlaskit/editor-plugin-toolbar

Version:

Toolbar plugin for @atlaskit/editor-core

63 lines 3.2 kB
import React from 'react'; import { TOOLBARS, useEditorToolbar } from '@atlaskit/editor-common/toolbar'; import { ToolbarSection, SeparatorPosition } from '@atlaskit/editor-toolbar'; import { fg } from '@atlaskit/platform-feature-flags'; var shouldShowSection = function shouldShowSection(editMode, toolbar, toolbarDocking, contextualFormattingEnabled) { if (editMode === 'view') { return false; } if (fg('platform_editor_toolbar_aifc_placement_overridden')) { if ((toolbar === null || toolbar === void 0 ? void 0 : toolbar.key) === TOOLBARS.INLINE_TEXT_TOOLBAR) { return toolbarDocking !== 'top' || contextualFormattingEnabled === 'always-inline'; } if ((toolbar === null || toolbar === void 0 ? void 0 : toolbar.key) === TOOLBARS.PRIMARY_TOOLBAR) { return toolbarDocking !== 'none' || contextualFormattingEnabled === 'always-pinned'; } } else { if ((toolbar === null || toolbar === void 0 ? void 0 : toolbar.key) === TOOLBARS.INLINE_TEXT_TOOLBAR && toolbarDocking !== 'top') { return true; } if ((toolbar === null || toolbar === void 0 ? void 0 : toolbar.key) === TOOLBARS.PRIMARY_TOOLBAR && toolbarDocking !== 'none') { return true; } } return false; }; var usePluginState = function usePluginState(_api) { var _useEditorToolbar = useEditorToolbar(), editorViewMode = _useEditorToolbar.editorViewMode, editorToolbarDockingPreference = _useEditorToolbar.editorToolbarDockingPreference, editorAppearance = _useEditorToolbar.editorAppearance; return { editorViewMode: editorViewMode, editorToolbarDockingPreference: editorToolbarDockingPreference, editorAppearance: editorAppearance }; }; export var Section = function Section(_ref) { var _api$toolbar$actions$, _api$toolbar; var children = _ref.children, parents = _ref.parents, api = _ref.api, testId = _ref.testId, showSeparatorInFullPagePrimaryToolbar = _ref.showSeparatorInFullPagePrimaryToolbar, _ref$isSharedSection = _ref.isSharedSection, isSharedSection = _ref$isSharedSection === void 0 ? true : _ref$isSharedSection; var _usePluginState = usePluginState(api), editorViewMode = _usePluginState.editorViewMode, editorToolbarDockingPreference = _usePluginState.editorToolbarDockingPreference, editorAppearance = _usePluginState.editorAppearance; var toolbar = parents.find(function (parent) { return parent.type === 'toolbar'; }); var contextualFormattingEnabled = (_api$toolbar$actions$ = api === null || api === void 0 || (_api$toolbar = api.toolbar) === null || _api$toolbar === void 0 ? void 0 : _api$toolbar.actions.contextualFormattingMode()) !== null && _api$toolbar$actions$ !== void 0 ? _api$toolbar$actions$ : 'always-pinned'; if (isSharedSection && !shouldShowSection(editorViewMode, toolbar, editorToolbarDockingPreference, contextualFormattingEnabled)) { return null; } var isFullPage = editorAppearance === 'full-page'; var hasSeparator = showSeparatorInFullPagePrimaryToolbar && isFullPage; return /*#__PURE__*/React.createElement(ToolbarSection, { testId: testId, hasSeparator: hasSeparator ? SeparatorPosition.START : hasSeparator }, children); };