UNPKG

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

Version:

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

179 lines (178 loc) 10.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.ListsIndentationHeroButtonNew = exports.ListsIndentationHeroButtonCollapsed = exports.ListsIndentationHeroButton = void 0; var _react = _interopRequireDefault(require("react")); var _reactIntl = require("react-intl"); var _hooks = require("@atlaskit/editor-common/hooks"); var _keymaps = require("@atlaskit/editor-common/keymaps"); var _messages = require("@atlaskit/editor-common/messages"); var _toolbar = require("@atlaskit/editor-common/toolbar"); var _editorToolbar = require("@atlaskit/editor-toolbar"); var _task = _interopRequireDefault(require("@atlaskit/icon/core/task")); function useListsIndentationHeroButtonInfo(_ref) { var api = _ref.api, parents = _ref.parents, defaultListType = _ref.defaultListType; var _useIntl = (0, _reactIntl.useIntl)(), formatMessage = _useIntl.formatMessage; var _useSharedPluginState = (0, _hooks.useSharedPluginStateWithSelector)(api, ['list', 'taskDecision'], function (states) { var _states$listState, _states$listState2, _states$listState3, _states$taskDecisionS; return { bulletListActive: (_states$listState = states.listState) === null || _states$listState === void 0 ? void 0 : _states$listState.bulletListActive, bulletListDisabled: (_states$listState2 = states.listState) === null || _states$listState2 === void 0 ? void 0 : _states$listState2.bulletListDisabled, orderedListActive: (_states$listState3 = states.listState) === null || _states$listState3 === void 0 ? void 0 : _states$listState3.orderedListActive, taskListActive: (_states$taskDecisionS = states.taskDecisionState) === null || _states$taskDecisionS === void 0 ? void 0 : _states$taskDecisionS.isInsideTask }; }), bulletListActive = _useSharedPluginState.bulletListActive, bulletListDisabled = _useSharedPluginState.bulletListDisabled, orderedListActive = _useSharedPluginState.orderedListActive, taskListActive = _useSharedPluginState.taskListActive; var getListType = taskListActive ? 'taskList' : orderedListActive ? 'orderedList' : defaultListType; var taskListKeymap = _keymaps.toggleTaskList; var getKeymap = getListType === 'taskList' ? taskListKeymap : getListType === 'orderedList' ? _keymaps.toggleOrderedList : _keymaps.toggleBulletList; var shortcut = (0, _keymaps.formatShortcut)(getKeymap); var keymap = getKeymap; var message = getListType === 'taskList' ? formatMessage(_messages.tasksAndDecisionsMessages.taskList) : getListType === 'orderedList' ? formatMessage(_messages.listMessages.orderedList) : formatMessage(_messages.listMessages.bulletedList); var onClick = function onClick() { var inputMethod = (0, _toolbar.getInputMethodFromParentKeys)(parents); if (getListType === 'taskList') { var _api$taskDecision; api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 || (_api$taskDecision = api.taskDecision) === null || _api$taskDecision === void 0 ? void 0 : _api$taskDecision.commands.toggleTaskList()); } else if (getListType === 'orderedList') { api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 ? void 0 : api.list.commands.toggleOrderedList(inputMethod)); } else { api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 ? void 0 : api.list.commands.toggleBulletList(inputMethod)); } }; var iconBefore = getListType === 'taskList' ? /*#__PURE__*/_react.default.createElement(_task.default, { label: formatMessage(_messages.tasksAndDecisionsMessages.taskList), size: "small" }) : getListType === 'orderedList' ? /*#__PURE__*/_react.default.createElement(_editorToolbar.ListNumberedIcon, { label: formatMessage(_messages.listMessages.orderedList), size: "small" }) : /*#__PURE__*/_react.default.createElement(_editorToolbar.ListBulletedIcon, { label: formatMessage(_messages.listMessages.bulletedList), size: "small" }); var isSelected = getListType === 'bulletList' ? bulletListActive : getListType === 'orderedList' ? orderedListActive : taskListActive; var isDisabled = !orderedListActive && !taskListActive && bulletListDisabled; return { shortcut: shortcut, keymap: keymap, message: message, onClick: onClick, iconBefore: iconBefore, isSelected: isSelected, isDisabled: isDisabled }; } var ListsIndentationHeroButtonCollapsed = exports.ListsIndentationHeroButtonCollapsed = function ListsIndentationHeroButtonCollapsed(_ref2) { var api = _ref2.api, parents = _ref2.parents; var _useListsIndentationH = useListsIndentationHeroButtonInfo({ api: api, parents: parents, defaultListType: 'bulletList' }), shortcut = _useListsIndentationH.shortcut, keymap = _useListsIndentationH.keymap, message = _useListsIndentationH.message, onClick = _useListsIndentationH.onClick, iconBefore = _useListsIndentationH.iconBefore, isSelected = _useListsIndentationH.isSelected, isDisabled = _useListsIndentationH.isDisabled; return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarTooltip, { content: /*#__PURE__*/_react.default.createElement(_keymaps.ToolTipContent, { description: message, keymap: keymap }) }, /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarButton, { iconBefore: iconBefore, isSelected: isSelected, isDisabled: isDisabled, ariaKeyshortcuts: shortcut, onClick: onClick })); }; var ListsIndentationHeroButtonNew = exports.ListsIndentationHeroButtonNew = function ListsIndentationHeroButtonNew(_ref3) { var api = _ref3.api, parents = _ref3.parents; var _useListsIndentationH2 = useListsIndentationHeroButtonInfo({ api: api, parents: parents, defaultListType: 'orderedList' }), shortcut = _useListsIndentationH2.shortcut, keymap = _useListsIndentationH2.keymap, message = _useListsIndentationH2.message, onClick = _useListsIndentationH2.onClick, iconBefore = _useListsIndentationH2.iconBefore, isSelected = _useListsIndentationH2.isSelected, isDisabled = _useListsIndentationH2.isDisabled; return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarTooltip, { content: /*#__PURE__*/_react.default.createElement(_keymaps.ToolTipContent, { description: message, keymap: keymap }) }, /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarButton, { iconBefore: iconBefore, isSelected: isSelected, isDisabled: isDisabled, ariaKeyshortcuts: shortcut, onClick: onClick })); }; var ListsIndentationHeroButton = exports.ListsIndentationHeroButton = function ListsIndentationHeroButton(_ref4) { var api = _ref4.api, parents = _ref4.parents; var _useIntl2 = (0, _reactIntl.useIntl)(), formatMessage = _useIntl2.formatMessage; var _useSharedPluginState2 = (0, _hooks.useSharedPluginStateWithSelector)(api, ['list', 'taskDecision'], function (states) { var _states$listState4, _states$listState5, _states$listState6, _states$taskDecisionS2; return { bulletListActive: (_states$listState4 = states.listState) === null || _states$listState4 === void 0 ? void 0 : _states$listState4.bulletListActive, bulletListDisabled: (_states$listState5 = states.listState) === null || _states$listState5 === void 0 ? void 0 : _states$listState5.bulletListDisabled, orderedListActive: (_states$listState6 = states.listState) === null || _states$listState6 === void 0 ? void 0 : _states$listState6.orderedListActive, taskListActive: (_states$taskDecisionS2 = states.taskDecisionState) === null || _states$taskDecisionS2 === void 0 ? void 0 : _states$taskDecisionS2.isInsideTask }; }), bulletListActive = _useSharedPluginState2.bulletListActive, bulletListDisabled = _useSharedPluginState2.bulletListDisabled, orderedListActive = _useSharedPluginState2.orderedListActive, taskListActive = _useSharedPluginState2.taskListActive; var taskListKeymap = _keymaps.toggleTaskList; var shortcut = taskListActive ? (0, _keymaps.formatShortcut)(taskListKeymap) : orderedListActive ? (0, _keymaps.formatShortcut)(_keymaps.toggleOrderedList) : (0, _keymaps.formatShortcut)(_keymaps.toggleBulletList); var onClick = function onClick() { var inputMethod = (0, _toolbar.getInputMethodFromParentKeys)(parents); if (taskListActive) { var _api$taskDecision2; api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 || (_api$taskDecision2 = api.taskDecision) === null || _api$taskDecision2 === void 0 ? void 0 : _api$taskDecision2.commands.toggleTaskList()); } else if (orderedListActive) { api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 ? void 0 : api.list.commands.toggleOrderedList(inputMethod)); } else { api === null || api === void 0 || api.core.actions.execute(api === null || api === void 0 ? void 0 : api.list.commands.toggleBulletList(inputMethod)); } }; return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarTooltip, { content: taskListActive ? formatMessage(_messages.tasksAndDecisionsMessages.taskList) : orderedListActive ? formatMessage(_messages.listMessages.orderedList) : formatMessage(_messages.listMessages.bulletedList) }, /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarButton, { iconBefore: taskListActive ? /*#__PURE__*/_react.default.createElement(_task.default, { label: formatMessage(_messages.tasksAndDecisionsMessages.taskList), size: "small" }) : orderedListActive ? /*#__PURE__*/_react.default.createElement(_editorToolbar.ListNumberedIcon, { label: formatMessage(_messages.listMessages.orderedList), size: "small" }) : /*#__PURE__*/_react.default.createElement(_editorToolbar.ListBulletedIcon, { label: formatMessage(_messages.listMessages.bulletedList), size: "small" }), isSelected: bulletListActive || orderedListActive || taskListActive, isDisabled: !orderedListActive && !taskListActive && bulletListDisabled, ariaKeyshortcuts: shortcut, onClick: onClick })); };