@atlaskit/editor-plugin-insert-block
Version:
Insert block plugin for @atlaskit/editor-core
84 lines (83 loc) • 4.93 kB
JavaScript
"use strict";
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.EmojiButton = void 0;
var _react = _interopRequireWildcard(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 _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
var _useEmojiPickerPopup = require("./hooks/useEmojiPickerPopup");
var _EmojiPickerPopup = require("./popups/EmojiPickerPopup");
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
var EmojiButton = exports.EmojiButton = function EmojiButton(_ref) {
var api = _ref.api;
var _useIntl = (0, _reactIntl.useIntl)(),
formatMessage = _useIntl.formatMessage;
var emojiButtonRef = (0, _react.useRef)(null);
var _useToolbarUI = (0, _editorToolbar.useToolbarUI)(),
popupsMountPoint = _useToolbarUI.popupsMountPoint,
popupsBoundariesElement = _useToolbarUI.popupsBoundariesElement,
popupsScrollableElement = _useToolbarUI.popupsScrollableElement;
var _useSharedPluginState = (0, _hooks.useSharedPluginStateWithSelector)(api, ['emoji', 'typeAhead'], function (states) {
var _states$emojiState, _states$emojiState2, _states$typeAheadStat;
return {
emojiProviderSelector: (_states$emojiState = states.emojiState) === null || _states$emojiState === void 0 ? void 0 : _states$emojiState.emojiProvider,
emojiProviderPromise: (_states$emojiState2 = states.emojiState) === null || _states$emojiState2 === void 0 ? void 0 : _states$emojiState2.emojiProviderPromise,
isTypeAheadAllowed: (_states$typeAheadStat = states.typeAheadState) === null || _states$typeAheadStat === void 0 ? void 0 : _states$typeAheadStat.isAllowed
};
}),
emojiProviderSelector = _useSharedPluginState.emojiProviderSelector,
emojiProviderPromise = _useSharedPluginState.emojiProviderPromise,
isTypeAheadAllowed = _useSharedPluginState.isTypeAheadAllowed;
var emojiPickerPopup = (0, _useEmojiPickerPopup.useEmojiPickerPopup)({
api: api,
buttonRef: emojiButtonRef
});
if (!(api !== null && api !== void 0 && api.emoji)) {
return null;
}
var getEmojiProvider = function getEmojiProvider() {
if (emojiProviderSelector) {
return Promise.resolve(emojiProviderSelector);
}
};
var emojiProvider = (0, _expValEquals.expValEquals)('platform_editor_prevent_toolbar_layout_shifts', 'isEnabled', true) ? emojiProviderPromise : getEmojiProvider();
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_EmojiPickerPopup.EmojiPickerPopup, {
isOpen: emojiPickerPopup.isOpen,
targetRef: emojiButtonRef,
emojiProvider: emojiProvider,
onSelection: emojiPickerPopup.handleSelectedEmoji,
onClickOutside: emojiPickerPopup.handleClickOutside,
onEscapeKeydown: emojiPickerPopup.handleEscapeKeydown,
onUnmount: emojiPickerPopup.onPopupUnmount,
popupsMountPoint: popupsMountPoint,
popupsBoundariesElement: popupsBoundariesElement,
popupsScrollableElement: popupsScrollableElement
}), /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarTooltip, {
content: /*#__PURE__*/_react.default.createElement(_keymaps.ToolTipContent, {
description: formatMessage(_messages.toolbarInsertBlockMessages.emoji),
keymap: _keymaps.insertEmoji
})
}, /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarButton, {
iconBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.EmojiIcon, {
label: formatMessage(_messages.toolbarInsertBlockMessages.emoji),
size: "small"
}),
ariaKeyshortcuts: "Shift+;",
ref: emojiButtonRef
// eslint-disable-next-line @atlassian/perf-linting/no-unstable-inline-props -- Ignored via go/ees017 (to be fixed)
,
onClick: function onClick() {
return emojiPickerPopup.toggle();
},
isSelected: emojiPickerPopup.isOpen,
isDisabled: !isTypeAheadAllowed || !emojiProvider,
testId: _toolbar.TOOLBAR_BUTTON_TEST_ID.EMOJI
})));
};