UNPKG

5.17 kBJavaScriptView Raw
1"use strict";
2
3exports.__esModule = true;
4exports.default = void 0;
5
6var React = _interopRequireWildcard(require("react"));
7
8var _deepmerge = _interopRequireDefault(require("deepmerge"));
9
10var _hoistNonReactStatics = _interopRequireDefault(require("hoist-non-react-statics"));
11
12var _utils = require("./utils");
13
14function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
16function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
17
18function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
19
20function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
21
22function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
23
24function _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; }
25
26var isClassComponent = function isClassComponent(Component) {
27 return Boolean(Component.prototype && Component.prototype.isReactComponent);
28};
29
30var createWithTheme = function createWithTheme(ThemeProvider, ThemeContext) {
31 return function withTheme(Comp) {
32 var ThemedComponent =
33 /*#__PURE__*/
34 function (_React$Component) {
35 _inheritsLoose(ThemedComponent, _React$Component);
36
37 function ThemedComponent() {
38 var _this;
39
40 for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
41 args[_key] = arguments[_key];
42 }
43
44 _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;
45
46 _defineProperty(_assertThisInitialized(_this), "_previous", void 0);
47
48 _defineProperty(_assertThisInitialized(_this), "_merge", function (a, b) {
49 var previous = _this._previous;
50
51 if (previous && previous.a === a && previous.b === b) {
52 return previous.result;
53 }
54
55 var result = a && b ? (0, _deepmerge.default)(a, b) : a || b;
56 _this._previous = {
57 a: a,
58 b: b,
59 result: result
60 };
61 return result;
62 });
63
64 _defineProperty(_assertThisInitialized(_this), "_root", void 0);
65
66 return _this;
67 }
68
69 var _proto = ThemedComponent.prototype;
70
71 _proto.render = function render() {
72 var _this2 = this;
73
74 return React.createElement(ThemeContext.Consumer, null, function (theme) {
75 var merged = _this2._merge(theme, _this2.props.theme);
76
77 var element;
78
79 if (isClassComponent(Comp)) {
80 // Only add refs for class components as function components don't support them
81 // It's needed to support use cases which need access to the underlying node
82 element = React.createElement(Comp, _extends({}, _this2.props, {
83 ref: function ref(c) {
84 _this2._root = c;
85 },
86 theme: merged
87 }));
88 } else {
89 element = React.createElement(Comp, _extends({}, _this2.props, {
90 theme: merged
91 }));
92 }
93
94 if (merged !== _this2.props.theme) {
95 // If a theme prop was passed, expose it to the children
96 return React.createElement(ThemeProvider, {
97 theme: merged
98 }, element);
99 }
100
101 return element;
102 });
103 };
104
105 return ThemedComponent;
106 }(React.Component);
107
108 _defineProperty(ThemedComponent, "displayName", "withTheme(" + (Comp.displayName || Comp.name) + ")");
109
110 if (isClassComponent(Comp)) {
111 // getWrappedInstance is exposed by some HOCs like react-redux's connect
112 // Use it to get the ref to the underlying element
113 // Also expose it to access the underlying element after wrapping
114 // $FlowFixMe
115 ThemedComponent.prototype.getWrappedInstance = function getWrappedInstance() {
116 return this._root && this._root.getWrappedInstance ? this._root.getWrappedInstance() : this._root;
117 };
118
119 ThemedComponent = (0, _utils.copyRefs)(ThemedComponent, Comp);
120 }
121
122 (0, _hoistNonReactStatics.default)(ThemedComponent, Comp);
123 return ThemedComponent;
124 };
125};
126
127var _default = createWithTheme;
128exports.default = _default;
129//# sourceMappingURL=createWithTheme.js.map
\No newline at end of file