Sanakey
2024-08-29 45b43f4ff4bea965638166ff619db1ef5afcad70
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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}`;
  }
 
  // ArrayConstructor.isArray(arg: any): arg is any[]
  if (Array.isArray(mods)) {
    return (mods as Mod[]).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;
}