UNPKG

@atlaskit/editor-common

Version:

A package that contains common classes and components for editor and renderer

601 lines (597 loc) • 29.3 kB
import _extends from "@babel/runtime/helpers/extends"; import _slicedToArray from "@babel/runtime/helpers/slicedToArray"; import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties"; import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator"; import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _createClass from "@babel/runtime/helpers/createClass"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _inherits from "@babel/runtime/helpers/inherits"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; var _excluded = ["extensionProvider", "showLivePagesBodiedMacrosRendererView", "node"]; import _regeneratorRuntime from "@babel/runtime/regenerator"; function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /* eslint-disable @repo/internal/react/no-class-components */ import React, { Component, useEffect, useLayoutEffect, useRef, useState } from 'react'; import memoizeOne from 'memoize-one'; import { NodeSelection } from '@atlaskit/editor-prosemirror/state'; import { fg } from '@atlaskit/platform-feature-flags'; import { getExtensionModuleNodePrivateProps, getNodeRenderer } from '../extensions'; import { getExtensionRenderer, nodeToJSON, toJSON } from '../utils'; import Extension from './Extension/Extension'; import { isEmptyBodiedMacro } from './Extension/Extension/extension-utils'; import InlineExtension from './Extension/InlineExtension'; import MultiBodiedExtension from './MultiBodiedExtension'; /* temporary type until FG cleaned up */ /* temporary type until FG cleaned up */ var getBodiedExtensionContent = function getBodiedExtensionContent(node) { var bodiedExtensionContent = []; node.content.forEach(function (childNode) { bodiedExtensionContent.push(nodeToJSON(childNode)); }); return !!bodiedExtensionContent.length ? bodiedExtensionContent : node.attrs.text; }; export var ExtensionComponentOld = /*#__PURE__*/function (_Component) { function ExtensionComponentOld() { var _this; _classCallCheck(this, ExtensionComponentOld); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, ExtensionComponentOld, [].concat(args)); _defineProperty(_this, "privatePropsParsed", false); _defineProperty(_this, "state", {}); _defineProperty(_this, "mounted", false); // memoized to avoid rerender on extension state changes _defineProperty(_this, "getNodeRenderer", memoizeOne(getNodeRenderer)); _defineProperty(_this, "getExtensionModuleNodePrivateProps", memoizeOne(getExtensionModuleNodePrivateProps)); _defineProperty(_this, "setIsNodeHovered", function (isHovered) { _this.setState({ isNodeHovered: isHovered }); }); _defineProperty(_this, "setShowBodiedExtensionRendererView", function (showRendererView) { _this.setState({ showBodiedExtensionRendererView: showRendererView }); }); // Ignored via go/ees005 // eslint-disable-next-line @typescript-eslint/no-explicit-any _defineProperty(_this, "setStateFromPromise", function (stateKey, promise) { promise && promise.then(function (p) { if (!_this.mounted) { return; } _this.setState(_defineProperty({}, stateKey, p)); }); }); /** * Parses any private nodes once an extension provider is available. * * We do this separately from resolving a node renderer component since the * private props come from extension provider, rather than an extension * handler which only handles `render`/component concerns. */ _defineProperty(_this, "parsePrivateNodePropsIfNeeded", /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() { var _this$props$node$attr, extensionType, extensionKey, privateProps; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: if (!(_this.privatePropsParsed || !_this.state.extensionProvider)) { _context.next = 2; break; } return _context.abrupt("return"); case 2: _this.privatePropsParsed = true; _this$props$node$attr = _this.props.node.attrs, extensionType = _this$props$node$attr.extensionType, extensionKey = _this$props$node$attr.extensionKey; /** * getExtensionModuleNodePrivateProps can throw if there are issues in the * manifest */ _context.prev = 4; _context.next = 7; return _this.getExtensionModuleNodePrivateProps(_this.state.extensionProvider, extensionType, extensionKey); case 7: privateProps = _context.sent; _this.setState({ _privateProps: privateProps }); _context.next = 14; break; case 11: _context.prev = 11; _context.t0 = _context["catch"](4); // eslint-disable-next-line no-console console.error('Provided extension handler has thrown an error\n', _context.t0); /** We don't want this error to block renderer */ /** We keep rendering the default content */ case 14: case "end": return _context.stop(); } }, _callee, null, [[4, 11]]); }))); _defineProperty(_this, "handleExtension", function (pmNode, actions) { var _pmNode$marks; var _this$props = _this.props, extensionHandlers = _this$props.extensionHandlers, editorView = _this$props.editorView, rendererExtensionHandlers = _this$props.rendererExtensionHandlers; var showBodiedExtensionRendererView = _this.state.showBodiedExtensionRendererView; // State will only be true if the gate is on and meets requirements var _pmNode$attrs = pmNode.attrs, extensionType = _pmNode$attrs.extensionType, extensionKey = _pmNode$attrs.extensionKey, parameters = _pmNode$attrs.parameters, text = _pmNode$attrs.text; var isBodiedExtension = pmNode.type.name === 'bodiedExtension'; if (isBodiedExtension && !showBodiedExtensionRendererView) { return; } var fragmentLocalId = pmNode === null || pmNode === void 0 || (_pmNode$marks = pmNode.marks) === null || _pmNode$marks === void 0 || (_pmNode$marks = _pmNode$marks.find(function (m) { return m.type.name === 'fragment'; })) === null || _pmNode$marks === void 0 || (_pmNode$marks = _pmNode$marks.attrs) === null || _pmNode$marks === void 0 ? void 0 : _pmNode$marks.localId; var content = isBodiedExtension ? getBodiedExtensionContent(pmNode) : text; var node = { type: pmNode.type.name, extensionType: extensionType, extensionKey: extensionKey, parameters: parameters, content: content, localId: pmNode.attrs.localId, fragmentLocalId: fragmentLocalId }; if (isBodiedExtension) { var rendererExtensionHandler = rendererExtensionHandlers === null || rendererExtensionHandlers === void 0 ? void 0 : rendererExtensionHandlers[extensionType]; // Forge bodied extensions don't get rendererExtensionHandlers passed in and use extensionHandlerFromProvider from the below logic instead if (rendererExtensionHandler) { return getExtensionRenderer(rendererExtensionHandler)(node, toJSON(editorView.state.doc)); } } var result; if (extensionHandlers && extensionHandlers[extensionType]) { var render = getExtensionRenderer(extensionHandlers[extensionType]); result = render(node, editorView.state.doc, actions); } if (!result) { var extensionHandlerFromProvider = _this.state.extensionProvider && _this.getNodeRenderer(_this.state.extensionProvider, extensionType, extensionKey); if (extensionHandlerFromProvider) { var NodeRenderer = extensionHandlerFromProvider; if (node.type === 'multiBodiedExtension') { return /*#__PURE__*/React.createElement(NodeRenderer, { node: node, references: _this.props.references, actions: actions }); } else { return /*#__PURE__*/React.createElement(NodeRenderer, { node: node, references: _this.props.references }); } } } return result; }); return _this; } _inherits(ExtensionComponentOld, _Component); return _createClass(ExtensionComponentOld, [{ key: "UNSAFE_componentWillMount", value: // Ignored via go/ees005 // eslint-disable-next-line react/no-unsafe function UNSAFE_componentWillMount() { this.mounted = true; var _this$props2 = this.props, node = _this$props2.node, showLivePagesBodiedMacrosRendererView = _this$props2.showLivePagesBodiedMacrosRendererView; // We only care about this empty state on first page load or insertion to determine the view if (!!(showLivePagesBodiedMacrosRendererView !== null && showLivePagesBodiedMacrosRendererView !== void 0 && showLivePagesBodiedMacrosRendererView(nodeToJSON(node))) && !isEmptyBodiedMacro(node)) { this.setState({ showBodiedExtensionRendererView: true }); } } }, { key: "componentDidMount", value: function componentDidMount() { var extensionProvider = this.props.extensionProvider; if (extensionProvider) { this.setStateFromPromise('extensionProvider', extensionProvider); } } }, { key: "componentDidUpdate", value: function componentDidUpdate() { this.parsePrivateNodePropsIfNeeded(); } }, { key: "componentWillUnmount", value: function componentWillUnmount() { this.mounted = false; } // Ignored via go/ees005 // eslint-disable-next-line react/no-unsafe }, { key: "UNSAFE_componentWillReceiveProps", value: function UNSAFE_componentWillReceiveProps(nextProps) { var extensionProvider = nextProps.extensionProvider; if (extensionProvider && this.props.extensionProvider !== extensionProvider) { this.setStateFromPromise('extensionProvider', extensionProvider); } } }, { key: "render", value: function render() { var _this$state$_privateP; var _this$props3 = this.props, node = _this$props3.node, handleContentDOMRef = _this$props3.handleContentDOMRef, editorView = _this$props3.editorView, references = _this$props3.references, editorAppearance = _this$props3.editorAppearance, pluginInjectionApi = _this$props3.pluginInjectionApi, getPos = _this$props3.getPos, eventDispatcher = _this$props3.eventDispatcher, macroInteractionDesignFeatureFlags = _this$props3.macroInteractionDesignFeatureFlags, showLivePagesBodiedMacrosRendererView = _this$props3.showLivePagesBodiedMacrosRendererView, showUpdatedLivePages1PBodiedExtensionUI = _this$props3.showUpdatedLivePages1PBodiedExtensionUI; var selection = editorView.state.selection; var selectedNode = selection instanceof NodeSelection && selection.node; var position = typeof getPos === 'function' && getPos(); var resolvedPosition = position && editorView.state.doc.resolve(position); var isNodeNested = !!(resolvedPosition && resolvedPosition.depth > 0); if (node.type.name === 'multiBodiedExtension') { return /*#__PURE__*/React.createElement(MultiBodiedExtension, { node: node, editorView: editorView, getPos: getPos, handleContentDOMRef: handleContentDOMRef, tryExtensionHandler: this.tryExtensionHandler.bind(this), eventDispatcher: eventDispatcher, pluginInjectionApi: pluginInjectionApi, editorAppearance: editorAppearance, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, isNodeNested: isNodeNested, isNodeHovered: this.state.isNodeHovered, setIsNodeHovered: this.setIsNodeHovered }); } var extensionHandlerResult = this.tryExtensionHandler(undefined); switch (node.type.name) { case 'extension': case 'bodiedExtension': return /*#__PURE__*/React.createElement(Extension, { node: node, getPos: this.props.getPos, references: references, extensionProvider: this.state.extensionProvider, handleContentDOMRef: handleContentDOMRef, view: editorView, editorAppearance: editorAppearance, hideFrame: (_this$state$_privateP = this.state._privateProps) === null || _this$state$_privateP === void 0 ? void 0 : _this$state$_privateP.__hideFrame, pluginInjectionApi: pluginInjectionApi, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, isNodeHovered: this.state.isNodeHovered, isNodeNested: isNodeNested, setIsNodeHovered: this.setIsNodeHovered, showLivePagesBodiedMacrosRendererView: !!(showLivePagesBodiedMacrosRendererView !== null && showLivePagesBodiedMacrosRendererView !== void 0 && showLivePagesBodiedMacrosRendererView(nodeToJSON(node))), showUpdatedLivePages1PBodiedExtensionUI: !!(showUpdatedLivePages1PBodiedExtensionUI !== null && showUpdatedLivePages1PBodiedExtensionUI !== void 0 && showUpdatedLivePages1PBodiedExtensionUI(nodeToJSON(node))), showBodiedExtensionRendererView: this.state.showBodiedExtensionRendererView, setShowBodiedExtensionRendererView: this.setShowBodiedExtensionRendererView }, extensionHandlerResult); case 'inlineExtension': return /*#__PURE__*/React.createElement(InlineExtension, { node: node, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, pluginInjectionApi: pluginInjectionApi, isNodeHovered: this.state.isNodeHovered, setIsNodeHovered: this.setIsNodeHovered }, extensionHandlerResult); default: return null; } } }, { key: "tryExtensionHandler", value: function tryExtensionHandler(actions) { var node = this.props.node; try { var extensionContent = this.handleExtension(node, actions); if (extensionContent && /*#__PURE__*/React.isValidElement(extensionContent)) { return extensionContent; } } catch (e) { // eslint-disable-next-line no-console console.error('Provided extension handler has thrown an error\n', e); /** We don't want this error to block renderer */ /** We keep rendering the default content */ } return null; } }]); }(Component); export var ExtensionComponentNew = function ExtensionComponentNew(props) { var extensionProviderResolver = props.extensionProvider, showLivePagesBodiedMacrosRendererView = props.showLivePagesBodiedMacrosRendererView, node = props.node, restProps = _objectWithoutProperties(props, _excluded); var _useState = useState(undefined), _useState2 = _slicedToArray(_useState, 2), extensionProvider = _useState2[0], setExtensionProvider = _useState2[1]; var _useState3 = useState(!!(showLivePagesBodiedMacrosRendererView !== null && showLivePagesBodiedMacrosRendererView !== void 0 && showLivePagesBodiedMacrosRendererView(nodeToJSON(node))) && !isEmptyBodiedMacro(node)), _useState4 = _slicedToArray(_useState3, 2), showBodiedExtensionRendererView = _useState4[0], setShowBodiedExtensionRendererView = _useState4[1]; var mountedRef = useRef(true); useLayoutEffect(function () { mountedRef.current = true; return function () { mountedRef.current = false; }; }, []); useEffect(function () { extensionProviderResolver === null || extensionProviderResolver === void 0 || extensionProviderResolver.then(function (provider) { if (mountedRef.current) { setExtensionProvider(provider); } }); }, [extensionProviderResolver]); return /*#__PURE__*/React.createElement(ExtensionComponentInner // Ignored via go/ees005 // eslint-disable-next-line react/jsx-props-no-spreading , _extends({}, restProps, { extensionProvider: extensionProvider, node: node, showLivePagesBodiedMacrosRendererView: showLivePagesBodiedMacrosRendererView, showBodiedExtensionRendererView: showBodiedExtensionRendererView, setShowBodiedExtensionRendererView: setShowBodiedExtensionRendererView })); }; var ExtensionComponentInner = /*#__PURE__*/function (_Component2) { function ExtensionComponentInner() { var _this2; _classCallCheck(this, ExtensionComponentInner); for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { args[_key2] = arguments[_key2]; } _this2 = _callSuper(this, ExtensionComponentInner, [].concat(args)); _defineProperty(_this2, "privatePropsParsed", false); _defineProperty(_this2, "state", {}); // memoized to avoid rerender on extension state changes _defineProperty(_this2, "getNodeRenderer", memoizeOne(getNodeRenderer)); _defineProperty(_this2, "getExtensionModuleNodePrivateProps", memoizeOne(getExtensionModuleNodePrivateProps)); _defineProperty(_this2, "setIsNodeHovered", function (isHovered) { _this2.setState({ isNodeHovered: isHovered }); }); /** * Parses any private nodes once an extension provider is available. * * We do this separately from resolving a node renderer component since the * private props come from extension provider, rather than an extension * handler which only handles `render`/component concerns. */ _defineProperty(_this2, "parsePrivateNodePropsIfNeeded", /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() { var _this2$props$node$att, extensionType, extensionKey, privateProps; return _regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: if (!(_this2.privatePropsParsed || !_this2.props.extensionProvider)) { _context2.next = 2; break; } return _context2.abrupt("return"); case 2: _this2.privatePropsParsed = true; _this2$props$node$att = _this2.props.node.attrs, extensionType = _this2$props$node$att.extensionType, extensionKey = _this2$props$node$att.extensionKey; /** * getExtensionModuleNodePrivateProps can throw if there are issues in the * manifest */ _context2.prev = 4; _context2.next = 7; return _this2.getExtensionModuleNodePrivateProps(_this2.props.extensionProvider, extensionType, extensionKey); case 7: privateProps = _context2.sent; _this2.setState({ _privateProps: privateProps }); _context2.next = 14; break; case 11: _context2.prev = 11; _context2.t0 = _context2["catch"](4); // eslint-disable-next-line no-console console.error('Provided extension handler has thrown an error\n', _context2.t0); /** We don't want this error to block renderer */ /** We keep rendering the default content */ case 14: case "end": return _context2.stop(); } }, _callee2, null, [[4, 11]]); }))); _defineProperty(_this2, "handleExtension", function (pmNode, actions) { var _pmNode$marks2; var _this2$props = _this2.props, extensionHandlers = _this2$props.extensionHandlers, editorView = _this2$props.editorView, showBodiedExtensionRendererView = _this2$props.showBodiedExtensionRendererView, rendererExtensionHandlers = _this2$props.rendererExtensionHandlers; var _pmNode$attrs2 = pmNode.attrs, extensionType = _pmNode$attrs2.extensionType, extensionKey = _pmNode$attrs2.extensionKey, parameters = _pmNode$attrs2.parameters, text = _pmNode$attrs2.text; var isBodiedExtension = pmNode.type.name === 'bodiedExtension'; if (isBodiedExtension && !showBodiedExtensionRendererView) { return; } var fragmentLocalId = pmNode === null || pmNode === void 0 || (_pmNode$marks2 = pmNode.marks) === null || _pmNode$marks2 === void 0 || (_pmNode$marks2 = _pmNode$marks2.find(function (m) { return m.type.name === 'fragment'; })) === null || _pmNode$marks2 === void 0 || (_pmNode$marks2 = _pmNode$marks2.attrs) === null || _pmNode$marks2 === void 0 ? void 0 : _pmNode$marks2.localId; var content = isBodiedExtension ? getBodiedExtensionContent(pmNode) : text; var node = { type: pmNode.type.name, extensionType: extensionType, extensionKey: extensionKey, parameters: parameters, content: content, localId: pmNode.attrs.localId, fragmentLocalId: fragmentLocalId }; if (isBodiedExtension) { var rendererExtensionHandler = rendererExtensionHandlers === null || rendererExtensionHandlers === void 0 ? void 0 : rendererExtensionHandlers[extensionType]; // Forge bodied extensions don't get rendererExtensionHandlers passed in and use extensionHandlerFromProvider from the below logic instead if (rendererExtensionHandler) { return getExtensionRenderer(rendererExtensionHandler)(node, toJSON(editorView.state.doc)); } } var result; if (extensionHandlers && extensionHandlers[extensionType]) { var render = getExtensionRenderer(extensionHandlers[extensionType]); result = render(node, editorView.state.doc, actions); } if (!result) { var extensionHandlerFromProvider = _this2.props.extensionProvider && _this2.getNodeRenderer(_this2.props.extensionProvider, extensionType, extensionKey); if (extensionHandlerFromProvider) { var NodeRenderer = extensionHandlerFromProvider; if (node.type === 'multiBodiedExtension') { return /*#__PURE__*/React.createElement(NodeRenderer, { node: node, references: _this2.props.references, actions: actions }); } else { return /*#__PURE__*/React.createElement(NodeRenderer, { node: node, references: _this2.props.references }); } } } return result; }); return _this2; } _inherits(ExtensionComponentInner, _Component2); return _createClass(ExtensionComponentInner, [{ key: "componentDidUpdate", value: function componentDidUpdate() { this.parsePrivateNodePropsIfNeeded(); } }, { key: "render", value: function render() { var _this$state$_privateP2; var _this$props4 = this.props, node = _this$props4.node, handleContentDOMRef = _this$props4.handleContentDOMRef, editorView = _this$props4.editorView, references = _this$props4.references, editorAppearance = _this$props4.editorAppearance, pluginInjectionApi = _this$props4.pluginInjectionApi, getPos = _this$props4.getPos, eventDispatcher = _this$props4.eventDispatcher, macroInteractionDesignFeatureFlags = _this$props4.macroInteractionDesignFeatureFlags, extensionProvider = _this$props4.extensionProvider, showLivePagesBodiedMacrosRendererView = _this$props4.showLivePagesBodiedMacrosRendererView, showUpdatedLivePages1PBodiedExtensionUI = _this$props4.showUpdatedLivePages1PBodiedExtensionUI, showBodiedExtensionRendererView = _this$props4.showBodiedExtensionRendererView, setShowBodiedExtensionRendererView = _this$props4.setShowBodiedExtensionRendererView; var selection = editorView.state.selection; var selectedNode = selection instanceof NodeSelection && selection.node; var position = typeof getPos === 'function' && getPos(); var resolvedPosition = position && editorView.state.doc.resolve(position); var isNodeNested = !!(resolvedPosition && resolvedPosition.depth > 0); if (node.type.name === 'multiBodiedExtension') { return /*#__PURE__*/React.createElement(MultiBodiedExtension, { node: node, editorView: editorView, getPos: getPos, handleContentDOMRef: handleContentDOMRef, tryExtensionHandler: this.tryExtensionHandler.bind(this), eventDispatcher: eventDispatcher, pluginInjectionApi: pluginInjectionApi, editorAppearance: editorAppearance, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, isNodeNested: isNodeNested, isNodeHovered: this.state.isNodeHovered, setIsNodeHovered: this.setIsNodeHovered }); } var extensionHandlerResult = this.tryExtensionHandler(undefined); switch (node.type.name) { case 'extension': case 'bodiedExtension': return /*#__PURE__*/React.createElement(Extension, { node: node, getPos: this.props.getPos, references: references, extensionProvider: extensionProvider, handleContentDOMRef: handleContentDOMRef, view: editorView, editorAppearance: editorAppearance, hideFrame: (_this$state$_privateP2 = this.state._privateProps) === null || _this$state$_privateP2 === void 0 ? void 0 : _this$state$_privateP2.__hideFrame, pluginInjectionApi: pluginInjectionApi, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, isNodeHovered: this.state.isNodeHovered, isNodeNested: isNodeNested, setIsNodeHovered: this.setIsNodeHovered, showLivePagesBodiedMacrosRendererView: !!(showLivePagesBodiedMacrosRendererView !== null && showLivePagesBodiedMacrosRendererView !== void 0 && showLivePagesBodiedMacrosRendererView(nodeToJSON(node))), showUpdatedLivePages1PBodiedExtensionUI: !!(showUpdatedLivePages1PBodiedExtensionUI !== null && showUpdatedLivePages1PBodiedExtensionUI !== void 0 && showUpdatedLivePages1PBodiedExtensionUI(nodeToJSON(node))), showBodiedExtensionRendererView: showBodiedExtensionRendererView, setShowBodiedExtensionRendererView: setShowBodiedExtensionRendererView }, extensionHandlerResult); case 'inlineExtension': return /*#__PURE__*/React.createElement(InlineExtension, { node: node, macroInteractionDesignFeatureFlags: macroInteractionDesignFeatureFlags, isNodeSelected: selectedNode === node, pluginInjectionApi: pluginInjectionApi, isNodeHovered: this.state.isNodeHovered, setIsNodeHovered: this.setIsNodeHovered }, extensionHandlerResult); default: return null; } } }, { key: "tryExtensionHandler", value: function tryExtensionHandler(actions) { var node = this.props.node; try { var extensionContent = this.handleExtension(node, actions); if (extensionContent && /*#__PURE__*/React.isValidElement(extensionContent)) { return extensionContent; } } catch (e) { // eslint-disable-next-line no-console console.error('Provided extension handler has thrown an error\n', e); /** We don't want this error to block renderer */ /** We keep rendering the default content */ } return null; } }]); }(Component); export var ExtensionComponent = function ExtensionComponent(props) { if (fg('platform_editor_react18_extension_component_v2')) { // Ignored via go/ees005 // eslint-disable-next-line react/jsx-props-no-spreading return /*#__PURE__*/React.createElement(ExtensionComponentNew, props); } // Ignored via go/ees005 // eslint-disable-next-line react/jsx-props-no-spreading return /*#__PURE__*/React.createElement(ExtensionComponentOld, props); };