UNPKG

wix-style-react

Version:
123 lines (100 loc) 5.24 kB
"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;