UNPKG

@atlaskit/editor-plugin-toolbar-lists-indentation

Version:

Toolbar lists and indentation plugin for @atlaskit/editor-core

179 lines (178 loc) 7.6 kB
/* ToolbarDropdown.tsx generated by @compiled/babel-plugin v0.39.1 */ import _slicedToArray from "@babel/runtime/helpers/slicedToArray"; import { ax, ix } from "@compiled/react/runtime"; import React from 'react'; import { useIntl } from 'react-intl'; import { toggleBulletList as toggleBulletListKeymap, indent as toggleIndentKeymap, toggleOrderedList as toggleOrderedListKeymap, outdent as toggleOutdentKeymap, tooltip } from '@atlaskit/editor-common/keymaps'; import { indentationMessages, listMessages } from '@atlaskit/editor-common/messages'; import { Shortcut, ToolbarDropdownTriggerWrapper, ToolbarDropdownWrapper, ToolbarExpandIcon, ToolbarSeparator } from '@atlaskit/editor-common/ui'; import { DropdownMenuWithKeyboardNavigation as DropdownMenu, ToolbarButton } from '@atlaskit/editor-common/ui-menu'; import ListBulletedIcon from '@atlaskit/icon/core/list-bulleted'; import ListNumberedIcon from '@atlaskit/icon/core/list-numbered'; import TextIndentLeftIcon from '@atlaskit/icon/core/text-indent-left'; import TextIndentRightIcon from '@atlaskit/icon/core/text-indent-right'; import { editorExperiment } from '@atlaskit/tmp-editor-statsig/experiments'; import { ToolbarType } from '../types'; export function ToolbarDropdown(props) { var _useIntl = useIntl(), formatMessage = _useIntl.formatMessage; var disabled = props.disabled, isReducedSpacing = props.isReducedSpacing, bulletListActive = props.bulletListActive, orderedListActive = props.orderedListActive, popupsMountPoint = props.popupsMountPoint, popupsBoundariesElement = props.popupsBoundariesElement, popupsScrollableElement = props.popupsScrollableElement, onItemActivated = props.onItemActivated, pluginInjectionApi = props.pluginInjectionApi; var _React$useState = React.useState(false), _React$useState2 = _slicedToArray(_React$useState, 2), isDropdownOpen = _React$useState2[0], setIsDropdownOpen = _React$useState2[1]; var _React$useState3 = React.useState(false), _React$useState4 = _slicedToArray(_React$useState3, 2), isOpenedByKeyboard = _React$useState4[0], setOpenedByKeyboard = _React$useState4[1]; var labelLists = formatMessage(listMessages.lists); // Ignored via go/ees005 // eslint-disable-next-line @typescript-eslint/no-explicit-any var onOpenChange = function onOpenChange(attrs) { setIsDropdownOpen(attrs.isDropdownOpen); }; var handleTriggerClick = function handleTriggerClick() { onOpenChange({ isDropdownOpen: !isDropdownOpen }); }; var handleOnKeyDown = function handleOnKeyDown(event) { if (event.key === 'Enter' || event.key === ' ') { event.preventDefault(); setIsDropdownOpen(!isDropdownOpen); setOpenedByKeyboard(true); } }; var items = useItems(props); var handleOnItemActivated = function handleOnItemActivated(_ref) { var item = _ref.item, _ref$shouldCloseMenu = _ref.shouldCloseMenu, shouldCloseMenu = _ref$shouldCloseMenu === void 0 ? true : _ref$shouldCloseMenu; setIsDropdownOpen(!shouldCloseMenu); return onItemActivated({ editorView: props.editorView, buttonName: item.value.name }); }; var reducedSpacing = props.toolbarType === ToolbarType.FLOATING ? 'compact' : 'none'; var activeListIcon = null; var isSelected = isDropdownOpen; if (editorExperiment('platform_editor_controls', 'variant1')) { activeListIcon = orderedListActive ? /*#__PURE__*/React.createElement(ListNumberedIcon, { spacing: "spacious", label: "" }) : /*#__PURE__*/React.createElement(ListBulletedIcon, { spacing: "spacious", label: "" }); } else { activeListIcon = /*#__PURE__*/React.createElement(ListBulletedIcon, { color: "currentColor", spacing: "spacious", label: labelLists }); isSelected = bulletListActive || orderedListActive || isDropdownOpen; } return /*#__PURE__*/React.createElement(ToolbarDropdownWrapper, null, /*#__PURE__*/React.createElement(DropdownMenu, { items: items, onItemActivated: handleOnItemActivated, mountTo: popupsMountPoint, boundariesElement: popupsBoundariesElement, scrollableElement: popupsScrollableElement, isOpen: isDropdownOpen, onOpenChange: onOpenChange, fitHeight: 188, fitWidth: 175, shouldUseDefaultRole: true // eslint-disable-next-line @atlassian/perf-linting/no-unstable-inline-props -- Ignored via go/ees017 (to be fixed) , shouldFocusFirstItem: function shouldFocusFirstItem() { if (isOpenedByKeyboard) { setOpenedByKeyboard(false); } return isOpenedByKeyboard; } }, /*#__PURE__*/React.createElement(ToolbarButton, { spacing: isReducedSpacing ? reducedSpacing : 'default', selected: isSelected, "aria-expanded": isDropdownOpen, "aria-haspopup": true, "aria-label": labelLists, disabled: disabled, onClick: handleTriggerClick, onKeyDown: handleOnKeyDown, title: labelLists, iconBefore: /*#__PURE__*/React.createElement(ToolbarDropdownTriggerWrapper, null, activeListIcon, /*#__PURE__*/React.createElement(ToolbarExpandIcon, null)) })), !(pluginInjectionApi !== null && pluginInjectionApi !== void 0 && pluginInjectionApi.primaryToolbar) && /*#__PURE__*/React.createElement(ToolbarSeparator, null)); } function useItems(props) { var _useIntl2 = useIntl(), formatMessage = _useIntl2.formatMessage; var labelUnorderedList = formatMessage(listMessages.unorderedList); var labelOrderedList = formatMessage(listMessages.orderedList); var items = [{ key: 'unorderedList', content: labelUnorderedList, value: { name: 'bullet_list' }, isDisabled: props.bulletListDisabled, isActive: Boolean(props.bulletListActive), elemAfter: /*#__PURE__*/React.createElement(Shortcut, null, tooltip(toggleBulletListKeymap)), elemBefore: editorExperiment('platform_editor_controls', 'variant1') ? /*#__PURE__*/React.createElement(ListBulletedIcon, { label: "" }) : undefined }, { key: 'orderedList', content: labelOrderedList, value: { name: 'ordered_list' }, isDisabled: props.orderedListDisabled, isActive: Boolean(props.orderedListActive), elemAfter: /*#__PURE__*/React.createElement(Shortcut, null, tooltip(toggleOrderedListKeymap)), elemBefore: editorExperiment('platform_editor_controls', 'variant1') ? /*#__PURE__*/React.createElement(ListNumberedIcon, { label: "" }) : undefined }]; if (props.showIndentationButtons) { var labelIndent = formatMessage(indentationMessages.indent); var labelOutdent = formatMessage(indentationMessages.outdent); items.push({ key: 'outdent', content: labelOutdent, value: { name: 'outdent' }, isDisabled: props.outdentDisabled, isActive: false, elemAfter: /*#__PURE__*/React.createElement(Shortcut, null, tooltip(toggleOutdentKeymap)), elemBefore: editorExperiment('platform_editor_controls', 'variant1') ? /*#__PURE__*/React.createElement(TextIndentLeftIcon, { label: "" }) : undefined }, { key: 'indent', content: labelIndent, value: { name: 'indent' }, isDisabled: props.indentDisabled, isActive: false, elemAfter: /*#__PURE__*/React.createElement(Shortcut, null, tooltip(toggleIndentKeymap)), elemBefore: editorExperiment('platform_editor_controls', 'variant1') ? /*#__PURE__*/React.createElement(TextIndentRightIcon, { label: "" }) : undefined }); } return [{ items: items }]; }