UNPKG

react-palm

Version:

Elm-like architecture for React apps

1,106 lines (906 loc) 37.2 kB
"use strict"; var _react = _interopRequireDefault(require("react")); var _reactDom = _interopRequireDefault(require("../react-dom")); var _server = _interopRequireDefault(require("../react-dom/server")); var _shallow = _interopRequireDefault(require("react-test-renderer/shallow")); var _package = require("react-test-renderer/package.json"); var _testUtils = _interopRequireDefault(require("../react-dom/test-utils")); var _semver = _interopRequireDefault(require("semver")); var _checkPropTypes2 = _interopRequireDefault(require("prop-types/checkPropTypes")); var _has = _interopRequireDefault(require("has")); var _reactIs = require("react-is"); var _enzyme = require("enzyme"); var _Utils = require("enzyme/build/Utils"); var _enzymeShallowEqual = _interopRequireDefault(require("enzyme-shallow-equal")); var _enzymeAdapterUtils = require("enzyme-adapter-utils"); var _findCurrentFiberUsingSlowPath = _interopRequireDefault(require("./findCurrentFiberUsingSlowPath")); var _detectFiberTags = _interopRequireDefault(require("./detectFiberTags")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } var is164 = !!_testUtils.default.Simulate.touchStart; // 16.4+ var is165 = !!_testUtils.default.Simulate.auxClick; // 16.5+ var is166 = is165 && !_react.default.unstable_AsyncMode; // 16.6+ var is168 = is166 && typeof _testUtils.default.act === 'function'; var hasShouldComponentUpdateBug = _semver.default.satisfies(_package.version, '< 16.8'); // Lazily populated if DOM is available. var FiberTags = null; function nodeAndSiblingsArray(nodeWithSibling) { var array = []; var node = nodeWithSibling; while (node != null) { array.push(node); node = node.sibling; } return array; } function flatten(arr) { var result = []; var stack = [{ i: 0, array: arr }]; while (stack.length) { var n = stack.pop(); while (n.i < n.array.length) { var el = n.array[n.i]; n.i += 1; if (Array.isArray(el)) { stack.push(n); stack.push({ i: 0, array: el }); break; } result.push(el); } } return result; } function nodeTypeFromType(type) { if (type === _reactIs.Portal) { return 'portal'; } return (0, _enzymeAdapterUtils.nodeTypeFromType)(type); } function isMemo(type) { return (0, _enzymeAdapterUtils.compareNodeTypeOf)(type, _reactIs.Memo); } function isLazy(type) { return (0, _enzymeAdapterUtils.compareNodeTypeOf)(type, _reactIs.Lazy); } function unmemoType(type) { return isMemo(type) ? type.type : type; } function elementToTree(el) { if (!(0, _reactIs.isPortal)(el)) { return (0, _enzymeAdapterUtils.elementToTree)(el, elementToTree); } var children = el.children, containerInfo = el.containerInfo; var props = { children: children, containerInfo: containerInfo }; return { nodeType: 'portal', type: _reactIs.Portal, props: props, key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(el.key), ref: el.ref || null, instance: null, rendered: elementToTree(el.children) }; } function _toTree(vnode) { if (vnode == null) { return null; } // TODO(lmr): I'm not really sure I understand whether or not this is what // i should be doing, or if this is a hack for something i'm doing wrong // somewhere else. Should talk to sebastian about this perhaps var node = (0, _findCurrentFiberUsingSlowPath.default)(vnode); switch (node.tag) { case FiberTags.HostRoot: return childrenToTree(node.child); case FiberTags.HostPortal: { var containerInfo = node.stateNode.containerInfo, children = node.memoizedProps; var props = { containerInfo: containerInfo, children: children }; return { nodeType: 'portal', type: _reactIs.Portal, props: props, key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: null, rendered: childrenToTree(node.child) }; } case FiberTags.ClassComponent: return { nodeType: 'class', type: node.type, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: node.stateNode, rendered: childrenToTree(node.child) }; case FiberTags.FunctionalComponent: return { nodeType: 'function', type: node.type, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: null, rendered: childrenToTree(node.child) }; case FiberTags.MemoClass: return { nodeType: 'class', type: node.elementType.type, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: node.stateNode, rendered: childrenToTree(node.child.child) }; case FiberTags.MemoSFC: { var renderedNodes = flatten(nodeAndSiblingsArray(node.child).map(_toTree)); if (renderedNodes.length === 0) { renderedNodes = [node.memoizedProps.children]; } return { nodeType: 'function', type: node.elementType, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: null, rendered: renderedNodes }; } case FiberTags.HostComponent: { var _renderedNodes = flatten(nodeAndSiblingsArray(node.child).map(_toTree)); if (_renderedNodes.length === 0) { _renderedNodes = [node.memoizedProps.children]; } return { nodeType: 'host', type: node.type, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: node.stateNode, rendered: _renderedNodes }; } case FiberTags.HostText: return node.memoizedProps; case FiberTags.Fragment: case FiberTags.Mode: case FiberTags.ContextProvider: case FiberTags.ContextConsumer: return childrenToTree(node.child); case FiberTags.Profiler: case FiberTags.ForwardRef: { return { nodeType: 'function', type: node.type, props: _objectSpread({}, node.pendingProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: null, rendered: childrenToTree(node.child) }; } case FiberTags.Suspense: { return { nodeType: 'function', type: _reactIs.Suspense, props: _objectSpread({}, node.memoizedProps), key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key), ref: node.ref, instance: null, rendered: childrenToTree(node.child) }; } case FiberTags.Lazy: return childrenToTree(node.child); default: throw new Error("Enzyme Internal Error: unknown node with tag ".concat(node.tag)); } } function childrenToTree(node) { if (!node) { return null; } var children = nodeAndSiblingsArray(node); if (children.length === 0) { return null; } if (children.length === 1) { return _toTree(children[0]); } return flatten(children.map(_toTree)); } function _nodeToHostNode(_node) { // NOTE(lmr): node could be a function component // which wont have an instance prop, but we can get the // host node associated with its return value at that point. // Although this breaks down if the return value is an array, // as is possible with React 16. var node = _node; while (node && !Array.isArray(node) && node.instance === null) { node = node.rendered; } // if the SFC returned null effectively, there is no host node. if (!node) { return null; } var mapper = function mapper(item) { if (item && item.instance) return _reactDom.default.findDOMNode(item.instance); return null; }; if (Array.isArray(node)) { return node.map(mapper); } if (Array.isArray(node.rendered) && node.nodeType === 'class') { return node.rendered.map(mapper); } return mapper(node); } function replaceLazyWithFallback(node, fallback) { if (!node) { return null; } if (Array.isArray(node)) { return node.map(function (el) { return replaceLazyWithFallback(el, fallback); }); } if (isLazy(node.type)) { return fallback; } return _objectSpread({}, node, { props: _objectSpread({}, node.props, { children: replaceLazyWithFallback(node.props.children, fallback) }) }); } var eventOptions = { animation: true, pointerEvents: is164, auxClick: is165 }; function getEmptyStateValue() { // this handles a bug in React 16.0 - 16.2 // see https://github.com/facebook/react/commit/39be83565c65f9c522150e52375167568a2a1459 // also see https://github.com/facebook/react/pull/11965 // eslint-disable-next-line react/prefer-stateless-function var EmptyState = /*#__PURE__*/ function (_React$Component) { _inherits(EmptyState, _React$Component); function EmptyState() { _classCallCheck(this, EmptyState); return _possibleConstructorReturn(this, _getPrototypeOf(EmptyState).apply(this, arguments)); } _createClass(EmptyState, [{ key: "render", value: function render() { return null; } }]); return EmptyState; }(_react.default.Component); var testRenderer = new _shallow.default(); testRenderer.render(_react.default.createElement(EmptyState)); return testRenderer._instance.state; } function wrapAct(fn) { if (!is168) { return fn(); } var returnVal; _testUtils.default.act(function () { returnVal = fn(); }); return returnVal; } function getProviderDefaultValue(Provider) { // React stores references to the Provider's defaultValue differently across versions. if ('_defaultValue' in Provider._context) { return Provider._context._defaultValue; } if ('_currentValue' in Provider._context) { return Provider._context._currentValue; } throw new Error('Enzyme Internal Error: can’t figure out how to get Provider’s default value'); } function makeFakeElement(type) { return { $$typeof: _reactIs.Element, type: type }; } function isStateful(Component) { return Component.prototype && (Component.prototype.isReactComponent || Array.isArray(Component.__reactAutoBindPairs) // fallback for createClass components ); } var ReactSixteenAdapter = /*#__PURE__*/ function (_EnzymeAdapter) { _inherits(ReactSixteenAdapter, _EnzymeAdapter); function ReactSixteenAdapter() { var _this; _classCallCheck(this, ReactSixteenAdapter); _this = _possibleConstructorReturn(this, _getPrototypeOf(ReactSixteenAdapter).call(this)); var lifecycles = _this.options.lifecycles; _this.options = _objectSpread({}, _this.options, { enableComponentDidUpdateOnSetState: true, // TODO: remove, semver-major legacyContextMode: 'parent', lifecycles: _objectSpread({}, lifecycles, { componentDidUpdate: { onSetState: true }, getDerivedStateFromProps: { hasShouldComponentUpdateBug: hasShouldComponentUpdateBug }, getSnapshotBeforeUpdate: true, setState: { skipsComponentDidUpdateOnNullish: true }, getChildContext: { calledByRenderer: false }, getDerivedStateFromError: is166 }) }); return _this; } _createClass(ReactSixteenAdapter, [{ key: "createMountRenderer", value: function createMountRenderer(options) { (0, _enzymeAdapterUtils.assertDomAvailable)('mount'); if ((0, _has.default)(options, 'suspenseFallback')) { throw new TypeError('`suspenseFallback` is not supported by the `mount` renderer'); } if (FiberTags === null) { // Requires DOM. FiberTags = (0, _detectFiberTags.default)(); } var attachTo = options.attachTo, hydrateIn = options.hydrateIn, wrappingComponentProps = options.wrappingComponentProps; var domNode = hydrateIn || attachTo || global.document.createElement('div'); var instance = null; var adapter = this; return _objectSpread({ render: function render(el, context, callback) { return wrapAct(function () { if (instance === null) { var type = el.type, props = el.props, ref = el.ref; var wrapperProps = _objectSpread({ Component: type, props: props, wrappingComponentProps: wrappingComponentProps, context: context }, ref && { refProp: ref }); var ReactWrapperComponent = (0, _enzymeAdapterUtils.createMountWrapper)(el, _objectSpread({}, options, { adapter: adapter })); var wrappedEl = _react.default.createElement(ReactWrapperComponent, wrapperProps); instance = hydrateIn ? _reactDom.default.hydrate(wrappedEl, domNode) : _reactDom.default.render(wrappedEl, domNode); if (typeof callback === 'function') { callback(); } } else { instance.setChildProps(el.props, context, callback); } }); }, unmount: function unmount() { _reactDom.default.unmountComponentAtNode(domNode); instance = null; }, getNode: function getNode() { if (!instance) { return null; } return (0, _enzymeAdapterUtils.getNodeFromRootFinder)(adapter.isCustomComponent, _toTree(instance._reactInternalFiber), options); }, simulateError: function simulateError(nodeHierarchy, rootNode, error) { var isErrorBoundary = function isErrorBoundary(_ref) { var elInstance = _ref.instance, type = _ref.type; if (is166 && type && type.getDerivedStateFromError) { return true; } return elInstance && elInstance.componentDidCatch; }; var _ref2 = nodeHierarchy.find(isErrorBoundary) || {}, catchingInstance = _ref2.instance, catchingType = _ref2.type; (0, _enzymeAdapterUtils.simulateError)(error, catchingInstance, rootNode, nodeHierarchy, nodeTypeFromType, adapter.displayNameOfNode, is166 ? catchingType : undefined); }, simulateEvent: function simulateEvent(node, event, mock) { var mappedEvent = (0, _enzymeAdapterUtils.mapNativeEventNames)(event, eventOptions); var eventFn = _testUtils.default.Simulate[mappedEvent]; if (!eventFn) { throw new TypeError("ReactWrapper::simulate() event '".concat(event, "' does not exist")); } wrapAct(function () { eventFn(adapter.nodeToHostNode(node), mock); }); }, batchedUpdates: function batchedUpdates(fn) { return fn(); // return ReactDOM.unstable_batchedUpdates(fn); }, getWrappingComponentRenderer: function getWrappingComponentRenderer() { return _objectSpread({}, this, (0, _enzymeAdapterUtils.getWrappingComponentMountRenderer)({ toTree: function toTree(inst) { return _toTree(inst._reactInternalFiber); }, getMountWrapperInstance: function getMountWrapperInstance() { return instance; } })); } }, is168 && { wrapInvoke: wrapAct }); } }, { key: "createShallowRenderer", value: function createShallowRenderer() { var _this2 = this; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var adapter = this; var renderer = new _shallow.default(); var suspenseFallback = options.suspenseFallback; if (typeof suspenseFallback !== 'undefined' && typeof suspenseFallback !== 'boolean') { throw TypeError('`options.suspenseFallback` should be boolean or undefined'); } var isDOM = false; var cachedNode = null; var lastComponent = null; var wrappedComponent = null; var sentinel = {}; // wrap memo components with a PureComponent, or a class component with sCU var wrapPureComponent = function wrapPureComponent(Component, compare) { if (!is166) { throw new RangeError('this function should not be called in React < 16.6. Please report this!'); } if (lastComponent !== Component) { if (isStateful(Component)) { wrappedComponent = /*#__PURE__*/ function (_Component) { _inherits(wrappedComponent, _Component); function wrappedComponent() { _classCallCheck(this, wrappedComponent); return _possibleConstructorReturn(this, _getPrototypeOf(wrappedComponent).apply(this, arguments)); } return wrappedComponent; }(Component); // eslint-disable-line react/prefer-stateless-function if (compare) { wrappedComponent.prototype.shouldComponentUpdate = function (nextProps) { return !compare(_this2.props, nextProps); }; } else { wrappedComponent.prototype.isPureReactComponent = true; } } else { var memoized = sentinel; var prevProps; wrappedComponent = function wrappedComponent(props) { var shouldUpdate = memoized === sentinel || (compare ? !compare(prevProps, props) : !(0, _enzymeShallowEqual.default)(prevProps, props)); if (shouldUpdate) { for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } memoized = Component.apply(void 0, [_objectSpread({}, Component.defaultProps, props)].concat(args)); prevProps = props; } return memoized; }; } Object.assign(wrappedComponent, Component, { displayName: adapter.displayNameOfNode({ type: Component }) }); lastComponent = Component; } return wrappedComponent; }; // Wrap functional components on versions prior to 16.5, // to avoid inadvertently pass a `this` instance to it. var wrapFunctionalComponent = function wrapFunctionalComponent(Component) { if (is166 && (0, _has.default)(Component, 'defaultProps')) { if (lastComponent !== Component) { wrappedComponent = Object.assign( // eslint-disable-next-line new-cap function (props) { for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { args[_key2 - 1] = arguments[_key2]; } return Component.apply(void 0, [_objectSpread({}, Component.defaultProps, props)].concat(args)); }, Component, { displayName: adapter.displayNameOfNode({ type: Component }) }); lastComponent = Component; } return wrappedComponent; } if (is165) { return Component; } if (lastComponent !== Component) { wrappedComponent = Object.assign(function () { return Component.apply(void 0, arguments); }, // eslint-disable-line new-cap Component); lastComponent = Component; } return wrappedComponent; }; return { render: function render(el, unmaskedContext) { var _ref3 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}, _ref3$providerValues = _ref3.providerValues, providerValues = _ref3$providerValues === void 0 ? new Map() : _ref3$providerValues; cachedNode = el; /* eslint consistent-return: 0 */ if (typeof el.type === 'string') { isDOM = true; } else if ((0, _reactIs.isContextProvider)(el)) { providerValues.set(el.type, el.props.value); var MockProvider = Object.assign(function (props) { return props.children; }, el.type); return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { return renderer.render(_objectSpread({}, el, { type: MockProvider })); }); } else if ((0, _reactIs.isContextConsumer)(el)) { var Provider = adapter.getProviderFromConsumer(el.type); var value = providerValues.has(Provider) ? providerValues.get(Provider) : getProviderDefaultValue(Provider); var MockConsumer = Object.assign(function (props) { return props.children(value); }, el.type); return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { return renderer.render(_objectSpread({}, el, { type: MockConsumer })); }); } else { isDOM = false; var renderedEl = el; if (isLazy(renderedEl)) { throw TypeError('`React.lazy` is not supported by shallow rendering.'); } if ((0, _reactIs.isSuspense)(renderedEl)) { var children = renderedEl.props.children; if (suspenseFallback) { var fallback = renderedEl.props.fallback; children = replaceLazyWithFallback(children, fallback); } var FakeSuspenseWrapper = function FakeSuspenseWrapper() { return children; }; renderedEl = _react.default.createElement(FakeSuspenseWrapper, null, children); } var _renderedEl = renderedEl, Component = _renderedEl.type; var context = (0, _enzymeAdapterUtils.getMaskedContext)(Component.contextTypes, unmaskedContext); if (isMemo(el.type)) { var _el$type = el.type, InnerComp = _el$type.type, compare = _el$type.compare; return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { return renderer.render(_objectSpread({}, el, { type: wrapPureComponent(InnerComp, compare) }), context); }); } if (!isStateful(Component) && typeof Component === 'function') { return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { return renderer.render(_objectSpread({}, renderedEl, { type: wrapFunctionalComponent(Component) }), context); }); } if (isStateful) { // fix react bug; see implementation of `getEmptyStateValue` var emptyStateValue = getEmptyStateValue(); if (emptyStateValue) { Object.defineProperty(Component.prototype, 'state', { configurable: true, enumerable: true, get: function get() { return null; }, set: function set(value) { if (value !== emptyStateValue) { Object.defineProperty(this, 'state', { configurable: true, enumerable: true, value: value, writable: true }); } return true; } }); } } return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { return renderer.render(renderedEl, context); }); } }, unmount: function unmount() { renderer.unmount(); }, getNode: function getNode() { if (isDOM) { return elementToTree(cachedNode); } var output = renderer.getRenderOutput(); return { nodeType: nodeTypeFromType(cachedNode.type), type: cachedNode.type, props: cachedNode.props, key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(cachedNode.key), ref: cachedNode.ref, instance: renderer._instance, rendered: Array.isArray(output) ? flatten(output).map(function (el) { return elementToTree(el); }) : elementToTree(output) }; }, simulateError: function simulateError(nodeHierarchy, rootNode, error) { (0, _enzymeAdapterUtils.simulateError)(error, renderer._instance, cachedNode, nodeHierarchy.concat(cachedNode), nodeTypeFromType, adapter.displayNameOfNode, is166 ? cachedNode.type : undefined); }, simulateEvent: function simulateEvent(node, event) { for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) { args[_key3 - 2] = arguments[_key3]; } var handler = node.props[(0, _enzymeAdapterUtils.propFromEvent)(event, eventOptions)]; if (handler) { (0, _enzymeAdapterUtils.withSetStateAllowed)(function () { // TODO(lmr): create/use synthetic events // TODO(lmr): emulate React's event propagation // ReactDOM.unstable_batchedUpdates(() => { handler.apply(void 0, args); // }); }); } }, batchedUpdates: function batchedUpdates(fn) { return fn(); // return ReactDOM.unstable_batchedUpdates(fn); }, checkPropTypes: function checkPropTypes(typeSpecs, values, location, hierarchy) { return (0, _checkPropTypes2.default)(typeSpecs, values, location, (0, _enzymeAdapterUtils.displayNameOfNode)(cachedNode), function () { return (0, _enzymeAdapterUtils.getComponentStack)(hierarchy.concat([cachedNode])); }); } }; } }, { key: "createStringRenderer", value: function createStringRenderer(options) { if ((0, _has.default)(options, 'suspenseFallback')) { throw new TypeError('`suspenseFallback` should not be specified in options of string renderer'); } return { render: function render(el, context) { if (options.context && (el.type.contextTypes || options.childContextTypes)) { var childContextTypes = _objectSpread({}, el.type.contextTypes || {}, options.childContextTypes); var ContextWrapper = (0, _enzymeAdapterUtils.createRenderWrapper)(el, context, childContextTypes); return _server.default.renderToStaticMarkup(_react.default.createElement(ContextWrapper)); } return _server.default.renderToStaticMarkup(el); } }; } // Provided a bag of options, return an `EnzymeRenderer`. Some options can be implementation // specific, like `attach` etc. for React, but not part of this interface explicitly. // eslint-disable-next-line class-methods-use-this }, { key: "createRenderer", value: function createRenderer(options) { switch (options.mode) { case _enzyme.EnzymeAdapter.MODES.MOUNT: return this.createMountRenderer(options); case _enzyme.EnzymeAdapter.MODES.SHALLOW: return this.createShallowRenderer(options); case _enzyme.EnzymeAdapter.MODES.STRING: return this.createStringRenderer(options); default: throw new Error("Enzyme Internal Error: Unrecognized mode: ".concat(options.mode)); } } }, { key: "wrap", value: function wrap(element) { return (0, _enzymeAdapterUtils.wrap)(element); } // converts an RSTNode to the corresponding JSX Pragma Element. This will be needed // in order to implement the `Wrapper.mount()` and `Wrapper.shallow()` methods, but should // be pretty straightforward for people to implement. // eslint-disable-next-line class-methods-use-this }, { key: "nodeToElement", value: function nodeToElement(node) { if (!node || _typeof(node) !== 'object') return null; var type = node.type; return _react.default.createElement(unmemoType(type), (0, _enzymeAdapterUtils.propsWithKeysAndRef)(node)); } // eslint-disable-next-line class-methods-use-this }, { key: "matchesElementType", value: function matchesElementType(node, matchingType) { if (!node) { return node; } var type = node.type; return unmemoType(type) === unmemoType(matchingType); } }, { key: "elementToNode", value: function elementToNode(element) { return elementToTree(element); } }, { key: "nodeToHostNode", value: function nodeToHostNode(node) { var supportsArray = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var nodes = _nodeToHostNode(node); if (Array.isArray(nodes) && !supportsArray) { return nodes[0]; } return nodes; } }, { key: "displayNameOfNode", value: function displayNameOfNode(node) { if (!node) return null; var type = node.type, $$typeof = node.$$typeof; var nodeType = type || $$typeof; // newer node types may be undefined, so only test if the nodeType exists if (nodeType) { switch (nodeType) { case (is166 ? _reactIs.ConcurrentMode : _reactIs.AsyncMode) || NaN: return is166 ? 'ConcurrentMode' : 'AsyncMode'; case _reactIs.Fragment || NaN: return 'Fragment'; case _reactIs.StrictMode || NaN: return 'StrictMode'; case _reactIs.Profiler || NaN: return 'Profiler'; case _reactIs.Portal || NaN: return 'Portal'; case _reactIs.Suspense || NaN: return 'Suspense'; default: } } var $$typeofType = type && type.$$typeof; switch ($$typeofType) { case _reactIs.ContextConsumer || NaN: return 'ContextConsumer'; case _reactIs.ContextProvider || NaN: return 'ContextProvider'; case _reactIs.Memo || NaN: { var nodeName = (0, _enzymeAdapterUtils.displayNameOfNode)(node); return typeof nodeName === 'string' ? nodeName : "Memo(".concat((0, _enzymeAdapterUtils.displayNameOfNode)(type), ")"); } case _reactIs.ForwardRef || NaN: { if (type.displayName) { return type.displayName; } var name = (0, _enzymeAdapterUtils.displayNameOfNode)({ type: type.render }); return name ? "ForwardRef(".concat(name, ")") : 'ForwardRef'; } case _reactIs.Lazy || NaN: { return 'lazy'; } default: return (0, _enzymeAdapterUtils.displayNameOfNode)(node); } } }, { key: "isValidElement", value: function isValidElement(element) { return (0, _reactIs.isElement)(element); } }, { key: "isValidElementType", value: function isValidElementType(object) { return !!object && (0, _reactIs.isValidElementType)(object); } }, { key: "isFragment", value: function isFragment(fragment) { return (0, _Utils.typeOfNode)(fragment) === _reactIs.Fragment; } }, { key: "isCustomComponent", value: function isCustomComponent(type) { var fakeElement = makeFakeElement(type); return !!type && (typeof type === 'function' || (0, _reactIs.isForwardRef)(fakeElement) || (0, _reactIs.isContextProvider)(fakeElement) || (0, _reactIs.isContextConsumer)(fakeElement) || (0, _reactIs.isSuspense)(fakeElement)); } }, { key: "isContextConsumer", value: function isContextConsumer(type) { return !!type && (0, _reactIs.isContextConsumer)(makeFakeElement(type)); } }, { key: "isCustomComponentElement", value: function isCustomComponentElement(inst) { if (!inst || !this.isValidElement(inst)) { return false; } return this.isCustomComponent(inst.type); } }, { key: "getProviderFromConsumer", value: function getProviderFromConsumer(Consumer) { // React stores references to the Provider on a Consumer differently across versions. if (Consumer) { var Provider; if (Consumer._context) { // check this first, to avoid a deprecation warning Provider = Consumer._context.Provider; } else if (Consumer.Provider) { Provider = Consumer.Provider; } if (Provider) { return Provider; } } throw new Error('Enzyme Internal Error: can’t figure out how to get Provider from Consumer'); } }, { key: "createElement", value: function createElement() { return _react.default.createElement.apply(_react.default, arguments); } }, { key: "wrapWithWrappingComponent", value: function wrapWithWrappingComponent(node, options) { return { RootFinder: _enzymeAdapterUtils.RootFinder, node: (0, _enzymeAdapterUtils.wrapWithWrappingComponent)(_react.default.createElement, node, options) }; } }]); return ReactSixteenAdapter; }(_enzyme.EnzymeAdapter); module.exports = ReactSixteenAdapter;