wix-style-react
Version:
123 lines (100 loc) • 5.24 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _kebabCase = _interopRequireDefault(require("lodash/kebabCase"));
var _ThemeContext = require("./ThemeContext");
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
/** ThemeProvider */
var ThemeProvider = /*#__PURE__*/function (_React$PureComponent) {
(0, _inherits2["default"])(ThemeProvider, _React$PureComponent);
var _super = _createSuper(ThemeProvider);
function ThemeProvider() {
(0, _classCallCheck2["default"])(this, ThemeProvider);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(ThemeProvider, [{
key: "_parseTheme",
value: function _parseTheme(theme) {
var style = {};
for (var _i = 0, _Object$entries = Object.entries(theme); _i < _Object$entries.length; _i++) {
var _Object$entries$_i = (0, _slicedToArray2["default"])(_Object$entries[_i], 2),
key = _Object$entries$_i[0],
value = _Object$entries$_i[1];
if (key !== 'className' && key !== 'icons' && key !== 'componentWrapper') {
style["--wsr-".concat((0, _kebabCase["default"])(key))] = value;
}
}
return style;
}
}, {
key: "render",
value: function render() {
var _this$props = this.props,
dataHook = _this$props.dataHook,
_this$props$theme = _this$props.theme,
theme = _this$props$theme === void 0 ? {} : _this$props$theme,
children = _this$props.children;
return /*#__PURE__*/_react["default"].createElement("div", {
className: theme.className,
style: this._parseTheme(theme),
"data-hook": dataHook
}, /*#__PURE__*/_react["default"].createElement(_ThemeContext.ThemeContext.Provider, {
value: {
icons: theme.icons,
className: theme.className
}
}, theme.componentWrapper ? theme.componentWrapper({
children: children
}) : children));
}
}]);
return ThemeProvider;
}(_react["default"].PureComponent);
ThemeProvider.displayName = 'ThemeProvider';
ThemeProvider.propTypes = {
/** Applied as data-hook HTML attribute that can be used in the tests */
dataHook: _propTypes["default"].string,
/** A theme object */
theme: _propTypes["default"].shape({
className: _propTypes["default"].string,
// Applies a main class on the root element, useful when theming with the stylable approach
icons: _propTypes["default"].object,
// an object of icons mapping per component
componentWrapper: _propTypes["default"].func,
// a function that returns a component to be placed between the theme and the children
color00: _propTypes["default"].string,
color05: _propTypes["default"].string,
color10: _propTypes["default"].string,
color20: _propTypes["default"].string,
color30: _propTypes["default"].string,
color40: _propTypes["default"].string,
color50: _propTypes["default"].string,
color60: _propTypes["default"].string,
textColorPrimary: _propTypes["default"].string,
textColorSecondary: _propTypes["default"].string,
textColorPrimaryLight: _propTypes["default"].string,
textColorSecondaryLight: _propTypes["default"].string,
dividerColor: _propTypes["default"].string,
borderRadius02: _propTypes["default"].string,
borderRadius04: _propTypes["default"].string,
borderRadius06: _propTypes["default"].string,
borderRadius08: _propTypes["default"].string,
// Button
buttonBorderRadius: _propTypes["default"].string
})
};
ThemeProvider.defaultProps = {};
var _default = ThemeProvider;
exports["default"] = _default;