ant-design-vue/components/_util/classNames.ts

46 lines
916 B
TypeScript

import { isArray, isString, isObject } from './util';
export type ClassArray = ClassValue[];
export interface ClassDictionary {
[id: string]: any;
}
export type ClassValue =
| string
| number
| ClassDictionary
| ClassArray
| undefined
| null
| boolean;
function classNames(...args: ClassValue[]): string {
const classes = [];
for (let i = 0; i < args.length; i++) {
const value = args[i];
if (!value) {
continue;
}
if (isString(value)) {
classes.push(value);
} else if (isArray(value)) {
for (let i = 0; i < value.length; i++) {
const inner = classNames(value[i]);
if (inner) {
classes.push(inner);
}
}
} else if (isObject(value)) {
for (const name in value) {
if (value[name]) {
classes.push(name);
}
}
}
}
return classes.join(' ');
}
export default classNames;