-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapply-color-mapping.test.ts
84 lines (81 loc) · 3.07 KB
/
apply-color-mapping.test.ts
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import { describe, expect, test } from "vitest"
import {
applyColorMapping,
splitClassName,
} from "../../src/utils/transformers/transform-css-vars"
import baseColor from "../fixtures/colors/slate.json"
describe("split className", () => {
test.each([
{
input: "bg-popover",
output: [null, "bg-popover", null],
},
{
input: "bg-popover/50",
output: [null, "bg-popover", "50"],
},
{
input: "hover:bg-popover/50",
output: ["hover", "bg-popover", "50"],
},
{
input: "hover:bg-popover",
output: ["hover", "bg-popover", null],
},
{
input: "[&_[cmdk-group-heading]]:px-2",
output: ["[&_[cmdk-group-heading]]", "px-2", null],
},
{
input: "[&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0",
output: ["[&_[cmdk-group]:not([hidden])_~[cmdk-group]]", "pt-0", null],
},
{
input: "[&_[cmdk-group]:not([hidden])_~[cmdk-group]]:bg-red-200",
output: [
"[&_[cmdk-group]:not([hidden])_~[cmdk-group]]",
"bg-red-200",
null,
],
},
{
input: "sm:focus:text-accent-foreground/30",
output: ["sm:focus", "text-accent-foreground", "30"],
},
])(`splitClassName($input) -> $output`, ({ input, output }) => {
expect(splitClassName(input)).toStrictEqual(output)
})
})
describe("apply color mapping", async () => {
test.each([
{
input: "bg-background text-foreground",
output: "bg-white text-slate-950 dark:bg-slate-950 dark:text-slate-50",
},
{
input: "rounded-lg border bg-card text-card-foreground shadow-sm",
output:
"rounded-lg border border-slate-200 bg-white text-slate-950 shadow-sm dark:border-slate-800 dark:bg-slate-950 dark:text-slate-50",
},
{
input:
"text-destructive border-destructive/50 dark:border-destructive [&>svg]:text-destructive text-destructive",
output:
"text-red-500 border-red-500/50 dark:border-red-500 [&>svg]:text-red-500 dark:text-red-900 dark:border-red-900/50 dark:dark:border-red-900 dark:[&>svg]:text-red-900",
},
{
input:
"flex h-full w-full items-center justify-center rounded-full bg-muted",
output:
"flex h-full w-full items-center justify-center rounded-full bg-slate-100 dark:bg-slate-800",
},
{
input:
"absolute right-4 top-4 bg-primary rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary",
output:
"absolute right-4 top-4 bg-slate-900 rounded-sm opacity-70 ring-offset-white transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-slate-100 dark:bg-slate-50 dark:ring-offset-slate-950 dark:focus:ring-slate-800 dark:data-[state=open]:bg-slate-800",
},
])(`applyColorMapping($input) -> $output`, ({ input, output }) => {
expect(applyColorMapping(input, baseColor.inlineColors)).toBe(output)
})
})