recharts
Version:
React charts
54 lines (51 loc) • 2.77 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.RechartsStoreProvider = RechartsStoreProvider;
var _react = _interopRequireWildcard(require("react"));
var React = _react;
var _reactRedux = require("react-redux");
var _store = require("./store");
var _PanoramaContext = require("../context/PanoramaContext");
var _RechartsReduxContext = require("./RechartsReduxContext");
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
function RechartsStoreProvider(_ref) {
var {
preloadedState,
children,
reduxStoreName
} = _ref;
var isPanorama = (0, _PanoramaContext.useIsPanorama)();
/*
* Why the ref? Redux official documentation recommends to use store as a singleton,
* and reuse that everywhere: https://redux-toolkit.js.org/api/configureStore#basic-example
*
* Which is correct! Except that is considering deploying Redux in an app.
* Recharts as a library supports multiple charts on the same page.
* And each of these charts needs its own store independent of others!
*
* The alternative is to have everything in the store keyed by the chart id.
* Which would make working with everything a little bit more painful because we need the chart id everywhere.
*/
var storeRef = (0, _react.useRef)(null);
/*
* Panorama means that this chart is not its own chart, it's only a "preview"
* being rendered as a child of Brush.
* In such case, it should not have a store on its own - it should implicitly inherit
* whatever data is in the "parent" or "root" chart.
* Which here is represented by not having a Provider at all. All selectors will use the root store by default.
*/
if (isPanorama) {
return children;
}
if (storeRef.current == null) {
storeRef.current = (0, _store.createRechartsStore)(preloadedState, reduxStoreName);
}
// ts-expect-error React-Redux types demand that the context internal value is not null, but we have that as default.
var nonNullContext = _RechartsReduxContext.RechartsReduxContext;
return /*#__PURE__*/React.createElement(_reactRedux.Provider, {
context: nonNullContext,
store: storeRef.current
}, children);
}
;