@alicloudfe/components
Version:
A react component library for aliyun
44 lines (43 loc) • 1.9 kB
JavaScript
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;
;