12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- import { prefixCls } from '/@/settings/designSetting';
- type Mod = string | { [key: string]: any };
- type Mods = Mod | Mod[];
- export type BEM = ReturnType<typeof createBEM>;
- function genBem(name: string, mods?: Mods): string {
- if (!mods) {
- return '';
- }
- if (typeof mods === 'string') {
- return ` ${name}--${mods}`;
- }
- if (Array.isArray(mods)) {
- return mods.reduce<string>((ret, item) => ret + genBem(name, item), '');
- }
- return Object.keys(mods).reduce((ret, key) => ret + (mods[key] ? genBem(name, key) : ''), '');
- }
- /**
- * bem helper
- * b() // 'button'
- * b('text') // 'button__text'
- * b({ disabled }) // 'button button--disabled'
- * b('text', { disabled }) // 'button__text button__text--disabled'
- * b(['disabled', 'primary']) // 'button button--disabled button--primary'
- */
- export function buildBEM(name: string) {
- return (el?: Mods, mods?: Mods): Mods => {
- if (el && typeof el !== 'string') {
- mods = el;
- el = '';
- }
- el = el ? `${name}__${el}` : name;
- return `${el}${genBem(el, mods)}`;
- };
- }
- export function createBEM(name: string) {
- return [buildBEM(`${prefixCls}-${name}`)];
- }
- export function createNamespace(name: string) {
- const prefixedName = `${prefixCls}-${name}`;
- return [prefixedName, buildBEM(prefixedName)] as const;
- }
|