UNPKG

@wix/design-system

Version:

@wix/design-system

76 lines (75 loc) 3.68 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _react = _interopRequireDefault(require("react")); var _kebabCase = _interopRequireDefault(require("lodash/kebabCase")); var _ThemeContext = require("./ThemeContext"); var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/cjs/ThemeProvider/ThemeProvider.jsx"; function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /** ThemeProvider */ var ThemeProvider = /*#__PURE__*/function (_React$PureComponent) { function ThemeProvider() { (0, _classCallCheck2["default"])(this, ThemeProvider); return _callSuper(this, ThemeProvider, arguments); } (0, _inherits2["default"])(ThemeProvider, _React$PureComponent); return (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, __self: this, __source: { fileName: _jsxFileName, lineNumber: 25, columnNumber: 7 } }, /*#__PURE__*/_react["default"].createElement(_ThemeContext.ThemeContext.Provider, { value: { icons: theme.icons, className: theme.className }, __self: this, __source: { fileName: _jsxFileName, lineNumber: 30, columnNumber: 9 } }, theme.componentWrapper ? theme.componentWrapper({ children: children }) : children)); } }]); }(_react["default"].PureComponent); ThemeProvider.displayName = 'ThemeProvider'; ThemeProvider.defaultProps = {}; var _default = exports["default"] = ThemeProvider;