UNPKG

@atlaskit/editor-plugin-media

Version:

Media plugin for @atlaskit/editor-core

53 lines (51 loc) 2.23 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _reactIntl = require("react-intl"); var _hooks = require("@atlaskit/editor-common/hooks"); var _media = require("@atlaskit/editor-common/media"); var _uiMenu = require("@atlaskit/editor-common/ui-menu"); var _attachment = _interopRequireDefault(require("@atlaskit/icon/core/attachment")); var onClickMediaButton = function onClickMediaButton(showMediaPicker) { return function () { showMediaPicker(); return true; }; }; var selector = function selector(states) { var _states$mediaState, _states$mediaState2; return { allowsUploads: (_states$mediaState = states.mediaState) === null || _states$mediaState === void 0 ? void 0 : _states$mediaState.allowsUploads, showMediaPicker: (_states$mediaState2 = states.mediaState) === null || _states$mediaState2 === void 0 ? void 0 : _states$mediaState2.showMediaPicker }; }; var ToolbarMedia = function ToolbarMedia(_ref) { var isDisabled = _ref.isDisabled, isReducedSpacing = _ref.isReducedSpacing, intl = _ref.intl, api = _ref.api; var _useSharedPluginState = (0, _hooks.useSharedPluginStateWithSelector)(api, ['media'], selector), allowsUploads = _useSharedPluginState.allowsUploads, showMediaPicker = _useSharedPluginState.showMediaPicker; if (!allowsUploads || !showMediaPicker) { return null; } var toolbarMediaTitle = _media.toolbarMediaMessages.toolbarMediaTitle; return /*#__PURE__*/_react.default.createElement(_uiMenu.ToolbarButton, { buttonId: _uiMenu.TOOLBAR_BUTTON.MEDIA, onClick: onClickMediaButton(showMediaPicker), disabled: isDisabled, title: intl.formatMessage(toolbarMediaTitle), spacing: isReducedSpacing ? 'none' : 'default', iconBefore: /*#__PURE__*/_react.default.createElement(_attachment.default, { label: intl.formatMessage(toolbarMediaTitle) }) }); }; // eslint-disable-next-line @typescript-eslint/ban-types var _default_1 = (0, _reactIntl.injectIntl)(ToolbarMedia); var _default = exports.default = _default_1;