@qn-pandora/pandora-visualization
Version:
Pandora 通用可视化库
38 lines (37 loc) • 1.27 kB
JavaScript
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
import * as React from 'react';
import hoistNonReactStatics from 'hoist-non-react-statics';
var useContext = React.useContext;
function contextWrapper(Comp) {
// tslint:disable-next-line
var contextTypes = [];
for (
// tslint:disable-next-line
var _i = 1;
// tslint:disable-next-line
_i < arguments.length;
// tslint:disable-next-line
_i++) {
// tslint:disable-next-line
contextTypes[_i - 1] = arguments[_i];
}
function WrappedComponents(props) {
var ctx = contextTypes.reduce(function (res, ctxType) {
// eslint-disable-next-line react-hooks/rules-of-hooks
return __assign(__assign({}, res), useContext(ctxType));
}, {});
return React.createElement(Comp, __assign({}, props, ctx));
}
return hoistNonReactStatics(WrappedComponents, Comp);
}
export default contextWrapper;