@atlaskit/editor-plugin-selection-extension
Version:
editor-plugin-selection-extension plugin for @atlaskit/editor-core
76 lines (74 loc) • 4.31 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.SelectionExtensionItemsComponent = exports.SelectionExtensionItems = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _reactIntl = require("react-intl");
var _uuid = require("uuid");
var _analytics = require("@atlaskit/editor-common/analytics");
var _SelectionExtensionDropdownMenu = require("./SelectionExtensionDropdownMenu");
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); }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /**
* @jsxRuntime classic
* @jsx
*/ // eslint-disable-next-line @atlaskit/platform/prefer-crypto-random-uuid -- Use crypto.randomUUID instead
var transformExtensionsToItems = function transformExtensionsToItems(extensions) {
var extensionToItems = extensions.map(function (extension) {
return {
key: extension.id,
content: extension.name,
value: {
name: extension.id
}
};
});
return [{
items: extensionToItems
}];
};
var SelectionExtensionItemsComponent = exports.SelectionExtensionItemsComponent = function SelectionExtensionItemsComponent(_ref) {
var extensions = _ref.extensions,
onExtensionClick = _ref.onExtensionClick,
editorAnalyticsAPI = _ref.editorAnalyticsAPI;
var extensionsWithIdentifier = (0, _react.useMemo)(
// eslint-disable-next-line @atlaskit/platform/prefer-crypto-random-uuid -- Use crypto.randomUUID instead
function () {
return extensions.map(function (extension) {
return _objectSpread(_objectSpread({}, extension), {}, {
id: (0, _uuid.v4)()
});
});
}, [extensions]);
var items = (0, _react.useMemo)(function () {
return transformExtensionsToItems(extensionsWithIdentifier);
}, [extensionsWithIdentifier]);
var handleOnItemActivated = function handleOnItemActivated(_ref2) {
var item = _ref2.item;
var extension = extensionsWithIdentifier.find(function (ext) {
return ext.id === item.value.name;
});
if (extension) {
onExtensionClick(extension);
if (editorAnalyticsAPI) {
editorAnalyticsAPI.fireAnalyticsEvent({
action: _analytics.ACTION.CLICKED,
actionSubject: _analytics.ACTION_SUBJECT.BUTTON,
actionSubjectId: _analytics.ACTION_SUBJECT_ID.EDITOR_PLUGIN_SELECTION_EXTENSION_ITEM,
eventType: _analytics.EVENT_TYPE.TRACK
});
}
}
};
return /*#__PURE__*/_react.default.createElement(_SelectionExtensionDropdownMenu.SelectionExtensionDropdownMenu, {
editorAnalyticsAPI: editorAnalyticsAPI,
items: items,
onItemActivated: handleOnItemActivated
});
};
// eslint-disable-next-line @typescript-eslint/ban-types
var SelectionExtensionItems = exports.SelectionExtensionItems = (0, _reactIntl.injectIntl)(SelectionExtensionItemsComponent);