@talend/react-cmf
Version:
A framework built on top of best react libraries
92 lines (90 loc) • 2.86 kB
JavaScript
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
import PropTypes from 'prop-types';
import { Component } from 'react';
import { Provider } from 'react-redux';
import { RegistryProvider } from '../RegistryProvider';
import mock from './store';
import { jsx as _jsx } from "react/jsx-runtime";
class ErrorBoundary extends Component {
componentDidCatch(error, errorInfo) {
if (this.props.onError) {
this.props.onError(error, errorInfo);
}
this.setState({
hasError: true
});
}
render() {
if (this.state && this.state.hasError) {
return /*#__PURE__*/_jsx("div", {
className: "error",
children: "Error"
});
}
return this.props.children;
}
}
_defineProperty(ErrorBoundary, "propTypes", {
children: PropTypes.any,
onError: PropTypes.func
});
const store = mock.store();
/**
* This component help you to mock the provider.
* If you want to write a pure component that use an other which
* is connected on CMF, you will need to provide a CMF store.
* @example
import React from 'react';
import { render, screen } from '@testing-library/react';
import { Provider } from 'react-cmf/lib/mock';
import AppMenu from './AppMenu.component';
describe('AppMenu', () => {
it('should render', () => {
render(
<Provider>
<AppMenu />
</Provider>
);
expect(screen.getByRole('button')).toBeDefined();
});
});
*/
function MockProvider(props) {
let st = props.store;
if (!st) {
st = store;
}
if (props.state) {
st.state = props.state;
st.getState = () => props.state;
}
const context = {
store: st,
registry: props.registry || {}
};
return /*#__PURE__*/_jsx("div", {
className: "mock-provider",
children: /*#__PURE__*/_jsx(Provider, {
store: context.store,
children: /*#__PURE__*/_jsx(RegistryProvider, {
value: context.registry,
children: props.children
})
})
});
}
MockProvider.propTypes = {
children: PropTypes.node.isRequired,
store: PropTypes.object,
state: PropTypes.object,
registry: PropTypes.object
};
MockProvider.getEnzymeOption = context => ({
wrappingComponent: MockProvider,
wrappingComponentProps: context
});
MockProvider.ErrorBoundary = ErrorBoundary;
export default MockProvider;
//# sourceMappingURL=provider.js.map