UNPKG

@alicloudfe/components

Version:

A react component library for aliyun

44 lines (43 loc) 1.9 kB
"use strict"; 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); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.withThemeClass = void 0; var react_1 = __importDefault(require("react")); var hoist_non_react_statics_1 = __importDefault(require("hoist-non-react-statics")); var classnames_1 = __importDefault(require("classnames")); var useCssVar_1 = require("./useCssVar"); var config_provider_1 = __importDefault(require("../config-provider")); function withThemeClass(Comp) { // 使用useCssVar为它动态添加类名 var Wrapped = config_provider_1.default.config(react_1.default.forwardRef(function (props, ref) { var _a; var theme = useCssVar_1.useCssVar('--alicloudfe-components-theme'); // 判断属于哪个类型主题 var isWind = theme.trim() === 'wind'; var isHybridcloud = theme.trim().startsWith('hybridcloud'); var isYunxiao = theme.trim().startsWith('yunxiao'); return ( // @ts-ignore react_1.default.createElement(Comp, __assign({}, props, { ref: ref, className: classnames_1.default(props.className, (_a = {}, _a['is-wind'] = isWind, _a['is-hybridcloud'] = isHybridcloud, _a['is-yunxiao'] = isYunxiao, _a)) }))); })); hoist_non_react_statics_1.default(Wrapped, Comp); return Wrapped; } exports.withThemeClass = withThemeClass;