@atlaskit/editor-plugin-insert-block
Version:
Insert block plugin for @atlaskit/editor-core
78 lines • 3.5 kB
JavaScript
import React, { useRef } from 'react';
import { useIntl } from 'react-intl';
import { useSharedPluginStateWithSelector } from '@atlaskit/editor-common/hooks';
import { ToolTipContent, insertEmoji } from '@atlaskit/editor-common/keymaps';
import { toolbarInsertBlockMessages as messages } from '@atlaskit/editor-common/messages';
import { TOOLBAR_BUTTON_TEST_ID } from '@atlaskit/editor-common/toolbar';
import { ToolbarButton, ToolbarTooltip, EmojiIcon, useToolbarUI } from '@atlaskit/editor-toolbar';
import { expValEquals } from '@atlaskit/tmp-editor-statsig/exp-val-equals';
import { useEmojiPickerPopup } from './hooks/useEmojiPickerPopup';
import { EmojiPickerPopup } from './popups/EmojiPickerPopup';
export const EmojiButton = ({
api
}) => {
const {
formatMessage
} = useIntl();
const emojiButtonRef = useRef(null);
const {
popupsMountPoint,
popupsBoundariesElement,
popupsScrollableElement
} = useToolbarUI();
const {
emojiProviderSelector,
emojiProviderPromise,
isTypeAheadAllowed
} = useSharedPluginStateWithSelector(api, ['emoji', 'typeAhead'], 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
};
});
const emojiPickerPopup = useEmojiPickerPopup({
api,
buttonRef: emojiButtonRef
});
if (!(api !== null && api !== void 0 && api.emoji)) {
return null;
}
const getEmojiProvider = () => {
if (emojiProviderSelector) {
return Promise.resolve(emojiProviderSelector);
}
};
const emojiProvider = expValEquals('platform_editor_prevent_toolbar_layout_shifts', 'isEnabled', true) ? emojiProviderPromise : getEmojiProvider();
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(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.createElement(ToolbarTooltip, {
content: /*#__PURE__*/React.createElement(ToolTipContent, {
description: formatMessage(messages.emoji),
keymap: insertEmoji
})
}, /*#__PURE__*/React.createElement(ToolbarButton, {
iconBefore: /*#__PURE__*/React.createElement(EmojiIcon, {
label: formatMessage(messages.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: () => emojiPickerPopup.toggle(),
isSelected: emojiPickerPopup.isOpen,
isDisabled: !isTypeAheadAllowed || !emojiProvider,
testId: TOOLBAR_BUTTON_TEST_ID.EMOJI
})));
};