@atlaskit/editor-common
Version:
A package that contains common classes and components for editor and renderer
273 lines (272 loc) • 14.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ExtensionComponent = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _memoizeOne = _interopRequireDefault(require("memoize-one"));
var _state = require("@atlaskit/editor-prosemirror/state");
var _extensions = require("../extensions");
var _utils = require("../utils");
var _Extension = _interopRequireDefault(require("./Extension/Extension"));
var _InlineExtension = _interopRequireDefault(require("./Extension/InlineExtension"));
var _MultiBodiedExtension = _interopRequireDefault(require("./MultiBodiedExtension"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
var ExtensionComponent = exports.ExtensionComponent = /*#__PURE__*/function (_Component) {
(0, _inherits2.default)(ExtensionComponent, _Component);
var _super = _createSuper(ExtensionComponent);
function ExtensionComponent() {
var _this;
(0, _classCallCheck2.default)(this, ExtensionComponent);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "privatePropsParsed", false);
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {});
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "mounted", false);
// memoized to avoid rerender on extension state changes
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "getNodeRenderer", (0, _memoizeOne.default)(_extensions.getNodeRenderer));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "getExtensionModuleNodePrivateProps", (0, _memoizeOne.default)(_extensions.getExtensionModuleNodePrivateProps));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "setIsNodeHovered", function (isHovered) {
_this.setState({
isNodeHovered: isHovered
});
});
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "setStateFromPromise", function (stateKey, promise) {
promise && promise.then(function (p) {
if (!_this.mounted) {
return;
}
_this.setState((0, _defineProperty2.default)({}, 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.
*/
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "parsePrivateNodePropsIfNeeded", /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
var _this$props$node$attr, extensionType, extensionKey, privateProps;
return _regenerator.default.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]]);
})));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "handleExtension", function (pmNode, actions) {
var _pmNode$marks;
var _this$props = _this.props,
extensionHandlers = _this$props.extensionHandlers,
editorView = _this$props.editorView;
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) {
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 node = {
type: pmNode.type.name,
extensionType: extensionType,
extensionKey: extensionKey,
parameters: parameters,
content: text,
localId: pmNode.attrs.localId,
fragmentLocalId: fragmentLocalId
};
var result;
if (extensionHandlers && extensionHandlers[extensionType]) {
var render = (0, _utils.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.default.createElement(NodeRenderer, {
node: node,
references: _this.props.references,
actions: actions
});
} else {
return /*#__PURE__*/_react.default.createElement(NodeRenderer, {
node: node,
references: _this.props.references
});
}
}
}
return result;
});
return _this;
}
(0, _createClass2.default)(ExtensionComponent, [{
key: "UNSAFE_componentWillMount",
value: function UNSAFE_componentWillMount() {
this.mounted = 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;
}
}, {
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$props2 = this.props,
node = _this$props2.node,
handleContentDOMRef = _this$props2.handleContentDOMRef,
editorView = _this$props2.editorView,
references = _this$props2.references,
editorAppearance = _this$props2.editorAppearance,
pluginInjectionApi = _this$props2.pluginInjectionApi,
getPos = _this$props2.getPos,
eventDispatcher = _this$props2.eventDispatcher,
showMacroInteractionDesignUpdates = _this$props2.showMacroInteractionDesignUpdates;
var selection = editorView.state.selection;
var selectedNode = selection instanceof _state.NodeSelection && selection.node;
if (node.type.name === 'multiBodiedExtension') {
return /*#__PURE__*/_react.default.createElement(_MultiBodiedExtension.default, {
node: node,
editorView: editorView,
getPos: getPos,
handleContentDOMRef: handleContentDOMRef,
tryExtensionHandler: this.tryExtensionHandler.bind(this),
eventDispatcher: eventDispatcher,
pluginInjectionApi: pluginInjectionApi,
editorAppearance: editorAppearance,
showMacroInteractionDesignUpdates: showMacroInteractionDesignUpdates,
isNodeSelected: selectedNode === node,
isNodeHovered: this.state.isNodeHovered,
setIsNodeHovered: this.setIsNodeHovered
});
}
var extensionHandlerResult = this.tryExtensionHandler(undefined);
switch (node.type.name) {
case 'extension':
case 'bodiedExtension':
return /*#__PURE__*/_react.default.createElement(_Extension.default, {
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,
showMacroInteractionDesignUpdates: showMacroInteractionDesignUpdates,
isNodeSelected: selectedNode === node,
isNodeHovered: this.state.isNodeHovered,
setIsNodeHovered: this.setIsNodeHovered
}, extensionHandlerResult);
case 'inlineExtension':
return /*#__PURE__*/_react.default.createElement(_InlineExtension.default, {
node: node,
showMacroInteractionDesignUpdates: showMacroInteractionDesignUpdates,
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.default.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;
}
}]);
return ExtensionComponent;
}(_react.Component);