UNPKG

@atlaskit/editor-common

Version:

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

71 lines 3.71 kB
import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _createClass from "@babel/runtime/helpers/createClass"; import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized"; import _inherits from "@babel/runtime/helpers/inherits"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } import React, { Component } from 'react'; import { ProviderFactory, WithProviders } from '../provider-factory'; import { ExtensionComponent } from './ExtensionComponent'; export var Extension = /*#__PURE__*/function (_Component) { _inherits(Extension, _Component); var _super = _createSuper(Extension); function Extension(props) { var _this; _classCallCheck(this, Extension); _this = _super.call(this, props); _defineProperty(_assertThisInitialized(_this), "renderWithProvider", function (_ref) { var extensionProvider = _ref.extensionProvider; var _this$props = _this.props, node = _this$props.node, getPos = _this$props.getPos, editorView = _this$props.editorView, handleContentDOMRef = _this$props.handleContentDOMRef, extensionHandlers = _this$props.extensionHandlers, references = _this$props.references, editorAppearance = _this$props.editorAppearance, pluginInjectionApi = _this$props.pluginInjectionApi, eventDispatcher = _this$props.eventDispatcher, showMacroInteractionDesignUpdates = _this$props.showMacroInteractionDesignUpdates; return /*#__PURE__*/React.createElement(ExtensionComponent, { editorView: editorView, node: node, getPos: getPos, references: references, extensionProvider: extensionProvider, handleContentDOMRef: handleContentDOMRef, extensionHandlers: extensionHandlers, editorAppearance: editorAppearance, pluginInjectionApi: pluginInjectionApi, eventDispatcher: eventDispatcher, showMacroInteractionDesignUpdates: showMacroInteractionDesignUpdates }); }); _this.providerFactory = props.providerFactory || new ProviderFactory(); return _this; } _createClass(Extension, [{ key: "componentWillUnmount", value: function componentWillUnmount() { if (!this.props.providerFactory) { // new ProviderFactory is created if no `providers` has been set // in this case when component is unmounted it's safe to destroy this providerFactory this.providerFactory.destroy(); } } }, { key: "render", value: function render() { return /*#__PURE__*/React.createElement(WithProviders, { providers: ['extensionProvider'], providerFactory: this.providerFactory, renderNode: this.renderWithProvider }); } }]); return Extension; }(Component); _defineProperty(Extension, "displayName", 'Extension');