Conditions | 4 |
Total Lines | 31 |
Code Lines | 26 |
Lines | 0 |
Ratio | 0 % |
Changes | 0 |
1 | import { |
||
30 | |||
31 | function mapping< |
||
32 | Source extends CssModule, |
||
33 | Target extends AnyObject, |
||
34 | Mapping extends ClassNamesMap<OmitIndexed<GetProps<Target>>, Source> |
||
35 | >( |
||
36 | source: Source, |
||
37 | _: Target, |
||
38 | map: Mapping |
||
39 | ): {[M in keyof Mapping]: string} { |
||
40 | // TODO change to for-in https://jsbench.me/prkm3gn4ji |
||
41 | const keys = $keys(map) as (keyof Mapping)[] |
||
42 | // TODO = {...keys} + reassign or delete? |
||
43 | , classnames = {} as {[M in keyof Mapping]: string} |
||
44 | |||
45 | for (let i = keys.length; i--;) { |
||
46 | const key = keys[i] |
||
47 | , val = map[key] |
||
48 | |||
49 | if (val === undefined) |
||
50 | continue |
||
51 | |||
52 | classnames[key] = typeof val === "function" |
||
53 | ? `${val}` |
||
54 | : resolver(source, |
||
55 | //@ts-expect-error #27 TS doesn't understand that ClassNaming is first of all function |
||
56 | val |
||
57 | ).join(" ") |
||
58 | } |
||
59 | |||
60 | return classnames |
||
61 | } |
||
62 |