@zentauri-ui/zentauri-components 2.1.7 → 2.1.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (110) hide show
  1. package/README.md +8 -5
  2. package/cli/props.json +350 -3
  3. package/cli/registry.json +11 -0
  4. package/dist/{chunk-DBNGLT5U.mjs → chunk-3HBC34NF.mjs} +4 -4
  5. package/dist/{chunk-DBNGLT5U.mjs.map → chunk-3HBC34NF.mjs.map} +1 -1
  6. package/dist/{chunk-FUCW5GPE.mjs → chunk-3RC5IG6O.mjs} +55 -8
  7. package/dist/chunk-3RC5IG6O.mjs.map +1 -0
  8. package/dist/chunk-4SLVTSHM.js +241 -0
  9. package/dist/chunk-4SLVTSHM.js.map +1 -0
  10. package/dist/{chunk-TJ2EWPER.js → chunk-4TPE5DEG.js} +63 -7
  11. package/dist/chunk-4TPE5DEG.js.map +1 -0
  12. package/dist/{chunk-G7FVHZRB.js → chunk-7CZDJTPD.js} +12 -12
  13. package/dist/{chunk-G7FVHZRB.js.map → chunk-7CZDJTPD.js.map} +1 -1
  14. package/dist/{chunk-5ELR6MIN.js → chunk-7DGPRPWM.js} +6 -6
  15. package/dist/{chunk-5ELR6MIN.js.map → chunk-7DGPRPWM.js.map} +1 -1
  16. package/dist/chunk-GP3FUS2H.mjs +26 -0
  17. package/dist/chunk-GP3FUS2H.mjs.map +1 -0
  18. package/dist/chunk-IHDM7AHY.mjs +233 -0
  19. package/dist/chunk-IHDM7AHY.mjs.map +1 -0
  20. package/dist/chunk-MWG7LHAK.js +19 -0
  21. package/dist/{chunk-5FU57ZVQ.js.map → chunk-MWG7LHAK.js.map} +1 -1
  22. package/dist/{chunk-7UXPXCKV.mjs → chunk-OLT7P7JO.mjs} +3 -3
  23. package/dist/{chunk-7UXPXCKV.mjs.map → chunk-OLT7P7JO.mjs.map} +1 -1
  24. package/dist/chunk-PAISX7YL.js +38 -0
  25. package/dist/chunk-PAISX7YL.js.map +1 -0
  26. package/dist/{chunk-KVSRUAXP.mjs → chunk-VN7FE5RR.mjs} +3 -3
  27. package/dist/{chunk-KVSRUAXP.mjs.map → chunk-VN7FE5RR.mjs.map} +1 -1
  28. package/dist/design-system/code-diff.d.ts +18 -0
  29. package/dist/design-system/code-diff.d.ts.map +1 -0
  30. package/dist/design-system/facade.js +8 -7
  31. package/dist/design-system/facade.js.map +1 -1
  32. package/dist/design-system/facade.mjs +7 -6
  33. package/dist/design-system/facade.mjs.map +1 -1
  34. package/dist/design-system/index.d.ts +2 -0
  35. package/dist/design-system/index.d.ts.map +1 -1
  36. package/dist/design-system/split-button.d.ts +25 -0
  37. package/dist/design-system/split-button.d.ts.map +1 -0
  38. package/dist/ui/buttons/animated.js +10 -9
  39. package/dist/ui/buttons/animated.js.map +1 -1
  40. package/dist/ui/buttons/animated.mjs +8 -7
  41. package/dist/ui/buttons/animated.mjs.map +1 -1
  42. package/dist/ui/buttons.js +11 -10
  43. package/dist/ui/buttons.mjs +9 -8
  44. package/dist/ui/code-diff/code-diff-base.d.ts +6 -0
  45. package/dist/ui/code-diff/code-diff-base.d.ts.map +1 -0
  46. package/dist/ui/code-diff/code-diff.d.ts +6 -0
  47. package/dist/ui/code-diff/code-diff.d.ts.map +1 -0
  48. package/dist/ui/code-diff/index.d.ts +4 -0
  49. package/dist/ui/code-diff/index.d.ts.map +1 -0
  50. package/dist/ui/code-diff/types.d.ts +26 -0
  51. package/dist/ui/code-diff/types.d.ts.map +1 -0
  52. package/dist/ui/code-diff/variants.d.ts +11 -0
  53. package/dist/ui/code-diff/variants.d.ts.map +1 -0
  54. package/dist/ui/code-diff.js +302 -0
  55. package/dist/ui/code-diff.js.map +1 -0
  56. package/dist/ui/code-diff.mjs +297 -0
  57. package/dist/ui/code-diff.mjs.map +1 -0
  58. package/dist/ui/data-table.js +22 -21
  59. package/dist/ui/data-table.js.map +1 -1
  60. package/dist/ui/data-table.mjs +12 -11
  61. package/dist/ui/data-table.mjs.map +1 -1
  62. package/dist/ui/dropdown/dropdown.d.ts +1 -1
  63. package/dist/ui/dropdown/dropdown.d.ts.map +1 -1
  64. package/dist/ui/dropdown/types.d.ts +2 -2
  65. package/dist/ui/dropdown/types.d.ts.map +1 -1
  66. package/dist/ui/dropdown.js +31 -231
  67. package/dist/ui/dropdown.js.map +1 -1
  68. package/dist/ui/dropdown.mjs +4 -229
  69. package/dist/ui/dropdown.mjs.map +1 -1
  70. package/dist/ui/dynamic-stepper.js +20 -19
  71. package/dist/ui/dynamic-stepper.js.map +1 -1
  72. package/dist/ui/dynamic-stepper.mjs +9 -8
  73. package/dist/ui/dynamic-stepper.mjs.map +1 -1
  74. package/dist/ui/pagination.js +12 -11
  75. package/dist/ui/pagination.mjs +9 -8
  76. package/dist/ui/split-button/index.d.ts +4 -0
  77. package/dist/ui/split-button/index.d.ts.map +1 -0
  78. package/dist/ui/split-button/split-button-base.d.ts +6 -0
  79. package/dist/ui/split-button/split-button-base.d.ts.map +1 -0
  80. package/dist/ui/split-button/split-button.d.ts +6 -0
  81. package/dist/ui/split-button/split-button.d.ts.map +1 -0
  82. package/dist/ui/split-button/types.d.ts +30 -0
  83. package/dist/ui/split-button/types.d.ts.map +1 -0
  84. package/dist/ui/split-button/variants.d.ts +16 -0
  85. package/dist/ui/split-button/variants.d.ts.map +1 -0
  86. package/dist/ui/split-button.js +288 -0
  87. package/dist/ui/split-button.js.map +1 -0
  88. package/dist/ui/split-button.mjs +279 -0
  89. package/dist/ui/split-button.mjs.map +1 -0
  90. package/package.json +4 -1
  91. package/src/design-system/code-diff.ts +37 -0
  92. package/src/design-system/index.ts +2 -0
  93. package/src/design-system/split-button.ts +38 -0
  94. package/src/ui/code-diff/code-diff-base.tsx +284 -0
  95. package/src/ui/code-diff/code-diff.test.tsx +50 -0
  96. package/src/ui/code-diff/code-diff.tsx +8 -0
  97. package/src/ui/code-diff/index.ts +15 -0
  98. package/src/ui/code-diff/types.ts +31 -0
  99. package/src/ui/code-diff/variants.ts +49 -0
  100. package/src/ui/dropdown/dropdown.tsx +7 -3
  101. package/src/ui/dropdown/types.ts +2 -2
  102. package/src/ui/split-button/index.ts +19 -0
  103. package/src/ui/split-button/split-button-base.tsx +232 -0
  104. package/src/ui/split-button/split-button.test.tsx +208 -0
  105. package/src/ui/split-button/split-button.tsx +9 -0
  106. package/src/ui/split-button/types.ts +46 -0
  107. package/src/ui/split-button/variants.ts +46 -0
  108. package/dist/chunk-5FU57ZVQ.js +0 -19
  109. package/dist/chunk-FUCW5GPE.mjs.map +0 -1
  110. package/dist/chunk-TJ2EWPER.js.map +0 -1
@@ -0,0 +1,26 @@
1
+ // src/design-system/code-diff.ts
2
+ var zuiCodeDiffBase = [
3
+ "relative overflow-auto rounded-lg border border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))]",
4
+ "bg-[var(--zui-code-diff-bg,var(--zui-surface,oklch(98.4%_0.003_247.858)))] dark:bg-[var(--zui-code-diff-bg-dark,var(--zui-surface-dark,oklch(12.9%_0.042_264.695)))]",
5
+ "text-[color:var(--zui-code-diff-fg,var(--zui-fg,oklch(20.8%_0.042_265.755)))] dark:text-[color:var(--zui-code-diff-fg-dark,var(--zui-fg-dark,oklch(98.4%_0.003_247.858)))]"
6
+ ];
7
+ var zuiCodeDiffSizes = {
8
+ sm: "text-xs leading-5",
9
+ md: "text-sm leading-6",
10
+ lg: "text-base leading-7"
11
+ };
12
+ var zuiCodeDiffHeaderBase = "sticky top-0 z-10 flex items-center justify-between border-b border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] bg-[var(--zui-code-diff-header-bg,var(--zui-surface-muted,oklch(92.9%_0.013_255.508)))] dark:bg-[var(--zui-code-diff-header-bg-dark,var(--zui-surface-muted-dark,oklch(27.9%_0.041_260.031)))] px-4 py-2";
13
+ var zuiCodeDiffTableBase = "w-full border-collapse table-fixed";
14
+ var zuiCodeDiffLineNumberBase = "select-none text-right align-top whitespace-nowrap border-r border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] px-3 text-[color:var(--zui-code-diff-line-number-fg,var(--zui-fg-muted,oklch(55.2%_0.046_257.417)))] dark:text-[color:var(--zui-code-diff-line-number-fg-dark,var(--zui-fg-muted-dark,oklch(70.8%_0.015_256.243)))]";
15
+ var zuiCodeDiffLineContentBase = "whitespace-pre-wrap break-all px-4 align-top";
16
+ var zuiCodeDiffLineAdded = "bg-[var(--zui-code-diff-added-bg,oklch(92.8%_0.109_150.96))] dark:bg-[var(--zui-code-diff-added-bg-dark,oklch(26.8%_0.077_146.44))] text-[color:var(--zui-code-diff-added-fg,oklch(29.1%_0.065_148.99))] dark:text-[color:var(--zui-code-diff-added-fg-dark,oklch(74%_0.131_149.02))]";
17
+ var zuiCodeDiffLineRemoved = "bg-[var(--zui-code-diff-removed-bg,oklch(93.1%_0.08_22.4))] dark:bg-[var(--zui-code-diff-removed-bg-dark,oklch(26.9%_0.07_22.54))] text-[color:var(--zui-code-diff-removed-fg,oklch(30.7%_0.06_28.07))] dark:text-[color:var(--zui-code-diff-removed-fg-dark,oklch(74.2%_0.127_24.75))]";
18
+ var zuiCodeDiffLineUnchanged = "";
19
+ var zuiCodeDiffGutterMarker = "inline-block w-4 text-center select-none";
20
+ var zuiCodeDiffAppearances = {
21
+ default: ""
22
+ };
23
+
24
+ export { zuiCodeDiffAppearances, zuiCodeDiffBase, zuiCodeDiffGutterMarker, zuiCodeDiffHeaderBase, zuiCodeDiffLineAdded, zuiCodeDiffLineContentBase, zuiCodeDiffLineNumberBase, zuiCodeDiffLineRemoved, zuiCodeDiffLineUnchanged, zuiCodeDiffSizes, zuiCodeDiffTableBase };
25
+ //# sourceMappingURL=chunk-GP3FUS2H.mjs.map
26
+ //# sourceMappingURL=chunk-GP3FUS2H.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/design-system/code-diff.ts"],"names":[],"mappings":";AAAO,IAAM,eAAA,GAAkB;AAAA,EAC7B,uMAAA;AAAA,EACA,sKAAA;AAAA,EACA;AACF;AAEO,IAAM,gBAAA,GAAmB;AAAA,EAC9B,EAAA,EAAI,mBAAA;AAAA,EACJ,EAAA,EAAI,mBAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,qBAAA,GACX;AAEK,IAAM,oBAAA,GAAuB;AAE7B,IAAM,yBAAA,GACX;AAEK,IAAM,0BAAA,GACX;AAEK,IAAM,oBAAA,GACX;AAEK,IAAM,sBAAA,GACX;AAEK,IAAM,wBAAA,GAA2B;AAEjC,IAAM,uBAAA,GACX;AAEK,IAAM,sBAAA,GAAyB;AAAA,EACpC,OAAA,EAAS;AACX","file":"chunk-GP3FUS2H.mjs","sourcesContent":["export const zuiCodeDiffBase = [\n \"relative overflow-auto rounded-lg border border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))]\",\n \"bg-[var(--zui-code-diff-bg,var(--zui-surface,oklch(98.4%_0.003_247.858)))] dark:bg-[var(--zui-code-diff-bg-dark,var(--zui-surface-dark,oklch(12.9%_0.042_264.695)))]\",\n \"text-[color:var(--zui-code-diff-fg,var(--zui-fg,oklch(20.8%_0.042_265.755)))] dark:text-[color:var(--zui-code-diff-fg-dark,var(--zui-fg-dark,oklch(98.4%_0.003_247.858)))]\",\n] as const;\n\nexport const zuiCodeDiffSizes = {\n sm: \"text-xs leading-5\",\n md: \"text-sm leading-6\",\n lg: \"text-base leading-7\",\n} as const;\n\nexport const zuiCodeDiffHeaderBase =\n \"sticky top-0 z-10 flex items-center justify-between border-b border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] bg-[var(--zui-code-diff-header-bg,var(--zui-surface-muted,oklch(92.9%_0.013_255.508)))] dark:bg-[var(--zui-code-diff-header-bg-dark,var(--zui-surface-muted-dark,oklch(27.9%_0.041_260.031)))] px-4 py-2\";\n\nexport const zuiCodeDiffTableBase = \"w-full border-collapse table-fixed\";\n\nexport const zuiCodeDiffLineNumberBase =\n \"select-none text-right align-top whitespace-nowrap border-r border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] px-3 text-[color:var(--zui-code-diff-line-number-fg,var(--zui-fg-muted,oklch(55.2%_0.046_257.417)))] dark:text-[color:var(--zui-code-diff-line-number-fg-dark,var(--zui-fg-muted-dark,oklch(70.8%_0.015_256.243)))]\";\n\nexport const zuiCodeDiffLineContentBase =\n \"whitespace-pre-wrap break-all px-4 align-top\";\n\nexport const zuiCodeDiffLineAdded =\n \"bg-[var(--zui-code-diff-added-bg,oklch(92.8%_0.109_150.96))] dark:bg-[var(--zui-code-diff-added-bg-dark,oklch(26.8%_0.077_146.44))] text-[color:var(--zui-code-diff-added-fg,oklch(29.1%_0.065_148.99))] dark:text-[color:var(--zui-code-diff-added-fg-dark,oklch(74%_0.131_149.02))]\";\n\nexport const zuiCodeDiffLineRemoved =\n \"bg-[var(--zui-code-diff-removed-bg,oklch(93.1%_0.08_22.4))] dark:bg-[var(--zui-code-diff-removed-bg-dark,oklch(26.9%_0.07_22.54))] text-[color:var(--zui-code-diff-removed-fg,oklch(30.7%_0.06_28.07))] dark:text-[color:var(--zui-code-diff-removed-fg-dark,oklch(74.2%_0.127_24.75))]\";\n\nexport const zuiCodeDiffLineUnchanged = \"\";\n\nexport const zuiCodeDiffGutterMarker =\n \"inline-block w-4 text-center select-none\";\n\nexport const zuiCodeDiffAppearances = {\n default: \"\",\n} as const;\n"]}
@@ -0,0 +1,233 @@
1
+ import { useClickOutside } from './chunk-VXDEPZKH.mjs';
2
+ import { zuiDropdownTriggerBase, zuiDropdownTriggerSizes, zuiDropdownTriggerVariants, zuiDropdownContentBase, zuiDropdownSpacing, zuiDropdownPlacements, zuiDropdownItemBase, zuiDropdownItemVariants } from './chunk-QX6PPTWL.mjs';
3
+ import { cn } from './chunk-4D54YOL6.mjs';
4
+ import { createContext, useId, useState, useRef, useEffect, useContext } from 'react';
5
+ import { FiCheck } from 'react-icons/fi';
6
+ import { cva } from 'class-variance-authority';
7
+ import { jsx, jsxs } from 'react/jsx-runtime';
8
+
9
+ var triggerVariants = cva(zuiDropdownTriggerBase, {
10
+ variants: {
11
+ variant: zuiDropdownTriggerVariants,
12
+ size: zuiDropdownTriggerSizes
13
+ },
14
+ defaultVariants: {
15
+ variant: "default",
16
+ size: "md"
17
+ }
18
+ });
19
+ var contentVariants = cva(zuiDropdownContentBase, {
20
+ variants: {
21
+ placement: zuiDropdownPlacements,
22
+ spacing: zuiDropdownSpacing
23
+ },
24
+ defaultVariants: {
25
+ placement: "bottom",
26
+ spacing: "default"
27
+ }
28
+ });
29
+ var itemVariants = cva(zuiDropdownItemBase, {
30
+ variants: {
31
+ variant: zuiDropdownItemVariants
32
+ },
33
+ defaultVariants: {
34
+ variant: "default"
35
+ }
36
+ });
37
+ var DropdownContext = createContext(null);
38
+ var useDropdown = () => {
39
+ const ctx = useContext(DropdownContext);
40
+ if (!ctx) throw new Error("Use inside Dropdown");
41
+ return ctx;
42
+ };
43
+ var Dropdown = ({
44
+ children,
45
+ className,
46
+ defaultOpen = false,
47
+ open: controlledOpen,
48
+ onOpenChange,
49
+ multiSelect = false,
50
+ ...props
51
+ }) => {
52
+ const menuId = `${useId()}-menu`;
53
+ const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);
54
+ const [selectedValues, setSelectedValues] = useState([]);
55
+ const open = controlledOpen ?? uncontrolledOpen;
56
+ const setOpen = (val) => {
57
+ if (controlledOpen !== void 0) {
58
+ onOpenChange?.(val);
59
+ } else {
60
+ setUncontrolledOpen(val);
61
+ }
62
+ };
63
+ const toggle = () => setOpen(!open);
64
+ const toggleSelect = (value) => {
65
+ if (!multiSelect) {
66
+ setSelectedValues([value]);
67
+ setOpen(false);
68
+ return;
69
+ }
70
+ setSelectedValues(
71
+ (prev) => prev.includes(value) ? prev.filter((v) => v !== value) : [...prev, value]
72
+ );
73
+ };
74
+ return /* @__PURE__ */ jsx(
75
+ DropdownContext.Provider,
76
+ {
77
+ value: {
78
+ open,
79
+ setOpen,
80
+ toggle,
81
+ selectedValues,
82
+ toggleSelect,
83
+ multiSelect,
84
+ menuId
85
+ },
86
+ children: /* @__PURE__ */ jsx("div", { className: cn("relative inline-block", className), ...props, children })
87
+ }
88
+ );
89
+ };
90
+ var DropdownTrigger = ({
91
+ children,
92
+ className,
93
+ variant,
94
+ size,
95
+ onClick,
96
+ ...props
97
+ }) => {
98
+ const { toggle, open, menuId } = useDropdown();
99
+ return /* @__PURE__ */ jsx(
100
+ "button",
101
+ {
102
+ type: "button",
103
+ "aria-expanded": open,
104
+ "aria-haspopup": "menu",
105
+ "aria-controls": menuId,
106
+ className: cn(triggerVariants({ variant, size }), className),
107
+ ...props,
108
+ onClick: (event) => {
109
+ onClick?.(event);
110
+ if (!event.defaultPrevented) {
111
+ toggle();
112
+ }
113
+ },
114
+ children
115
+ }
116
+ );
117
+ };
118
+ var DropdownContent = ({
119
+ children,
120
+ className,
121
+ placement = "bottom",
122
+ spacing = "default",
123
+ divider,
124
+ ...props
125
+ }) => {
126
+ const { open, setOpen, menuId } = useDropdown();
127
+ const ref = useRef(null);
128
+ useClickOutside({ ref, setOpen });
129
+ useEffect(() => {
130
+ if (!open) {
131
+ return;
132
+ }
133
+ ref.current?.querySelector('[role="menuitem"]')?.focus();
134
+ }, [open]);
135
+ if (!open) return null;
136
+ return /* @__PURE__ */ jsx(
137
+ "div",
138
+ {
139
+ ref,
140
+ id: menuId,
141
+ role: "menu",
142
+ className: cn(
143
+ contentVariants({ placement, spacing }),
144
+ className,
145
+ divider && "divide-y divide-current"
146
+ ),
147
+ ...props,
148
+ children
149
+ }
150
+ );
151
+ };
152
+ var DropdownItem = ({
153
+ children,
154
+ value,
155
+ className,
156
+ variant,
157
+ onClick,
158
+ onKeyDown,
159
+ onSelect,
160
+ leftIcon,
161
+ rightIcon,
162
+ ...props
163
+ }) => {
164
+ const { toggleSelect, selectedValues } = useDropdown();
165
+ const isSelected = value !== void 0 && selectedValues.includes(value);
166
+ const handleClick = () => {
167
+ if (value !== void 0) toggleSelect(value);
168
+ onSelect?.();
169
+ };
170
+ const focusSiblingItem = (event, direction) => {
171
+ const menu = event.currentTarget.closest('[role="menu"]');
172
+ const items = Array.from(
173
+ menu?.querySelectorAll('[role="menuitem"]') ?? []
174
+ );
175
+ const currentIndex = items.indexOf(event.currentTarget);
176
+ if (currentIndex === -1 || items.length === 0) {
177
+ return;
178
+ }
179
+ const nextIndex = direction === "first" ? 0 : direction === "last" ? items.length - 1 : (currentIndex + (direction === "next" ? 1 : -1) + items.length) % items.length;
180
+ items[nextIndex]?.focus();
181
+ };
182
+ return /* @__PURE__ */ jsxs(
183
+ "div",
184
+ {
185
+ role: "menuitem",
186
+ tabIndex: -1,
187
+ onClick: (event) => {
188
+ onClick?.(event);
189
+ if (!event.defaultPrevented) {
190
+ handleClick();
191
+ }
192
+ },
193
+ onKeyDown: (e) => {
194
+ onKeyDown?.(e);
195
+ if (e.defaultPrevented) {
196
+ return;
197
+ }
198
+ if (e.key === "Enter" || e.key === " ") {
199
+ e.preventDefault();
200
+ handleClick();
201
+ } else if (e.key === "ArrowDown") {
202
+ e.preventDefault();
203
+ focusSiblingItem(e, "next");
204
+ } else if (e.key === "ArrowUp") {
205
+ e.preventDefault();
206
+ focusSiblingItem(e, "previous");
207
+ } else if (e.key === "Home") {
208
+ e.preventDefault();
209
+ focusSiblingItem(e, "first");
210
+ } else if (e.key === "End") {
211
+ e.preventDefault();
212
+ focusSiblingItem(e, "last");
213
+ }
214
+ },
215
+ className: cn(itemVariants({ variant }), className),
216
+ ...props,
217
+ children: [
218
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
219
+ leftIcon,
220
+ children
221
+ ] }),
222
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
223
+ isSelected && /* @__PURE__ */ jsx(FiCheck, {}),
224
+ rightIcon
225
+ ] })
226
+ ]
227
+ }
228
+ );
229
+ };
230
+
231
+ export { Dropdown, DropdownContent, DropdownItem, DropdownTrigger, contentVariants, itemVariants, triggerVariants };
232
+ //# sourceMappingURL=chunk-IHDM7AHY.mjs.map
233
+ //# sourceMappingURL=chunk-IHDM7AHY.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ui/dropdown/variants.ts","../src/ui/dropdown/dropdown.tsx"],"names":[],"mappings":"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","file":"chunk-IHDM7AHY.mjs","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nimport {\n zuiDropdownContentBase,\n zuiDropdownItemBase,\n zuiDropdownItemVariants,\n zuiDropdownPlacements,\n zuiDropdownSpacing,\n zuiDropdownTriggerBase,\n zuiDropdownTriggerSizes,\n zuiDropdownTriggerVariants,\n} from \"../../design-system/dropdown\";\n\nexport const triggerVariants = cva(zuiDropdownTriggerBase, {\n variants: {\n variant: zuiDropdownTriggerVariants,\n size: zuiDropdownTriggerSizes,\n },\n defaultVariants: {\n variant: \"default\",\n size: \"md\",\n },\n});\n\nexport const contentVariants = cva(zuiDropdownContentBase, {\n variants: {\n placement: zuiDropdownPlacements,\n spacing: zuiDropdownSpacing,\n },\n defaultVariants: {\n placement: \"bottom\",\n spacing: \"default\",\n },\n});\n\nexport const itemVariants = cva(zuiDropdownItemBase, {\n variants: {\n variant: zuiDropdownItemVariants,\n },\n defaultVariants: {\n variant: \"default\",\n },\n});\n","\"use client\";\n\nimport {\n createContext,\n useContext,\n useState,\n useRef,\n useEffect,\n useId,\n type KeyboardEvent,\n} from \"react\";\nimport { FiCheck } from \"react-icons/fi\";\nimport { cn } from \"../../lib/utils\";\nimport type {\n DropdownContextType,\n DropdownProps,\n DropdownTriggerProps,\n DropdownContentProps,\n DropdownItemProps,\n} from \"./types\";\nimport { triggerVariants, contentVariants, itemVariants } from \"./variants\";\nimport { useClickOutside } from \"../../hooks/useClickOutside\";\n\n/* =========================\n Context\n========================= */\nconst DropdownContext = createContext<DropdownContextType | null>(null);\n\nconst useDropdown = () => {\n const ctx = useContext(DropdownContext);\n if (!ctx) throw new Error(\"Use inside Dropdown\");\n return ctx;\n};\n\n/* =========================\n Root\n========================= */\nexport const Dropdown = ({\n children,\n className,\n defaultOpen = false,\n open: controlledOpen,\n onOpenChange,\n multiSelect = false,\n ...props\n}: DropdownProps) => {\n const menuId = `${useId()}-menu`;\n const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);\n const [selectedValues, setSelectedValues] = useState<string[]>([]);\n\n const open = controlledOpen ?? uncontrolledOpen;\n\n const setOpen = (val: boolean) => {\n if (controlledOpen !== undefined) {\n onOpenChange?.(val);\n } else {\n setUncontrolledOpen(val);\n }\n };\n\n const toggle = () => setOpen(!open);\n\n const toggleSelect = (value: string) => {\n if (!multiSelect) {\n setSelectedValues([value]);\n setOpen(false);\n return;\n }\n\n setSelectedValues((prev) =>\n prev.includes(value) ? prev.filter((v) => v !== value) : [...prev, value],\n );\n };\n\n return (\n <DropdownContext.Provider\n value={{\n open,\n setOpen,\n toggle,\n selectedValues,\n toggleSelect,\n multiSelect,\n menuId,\n }}\n >\n <div className={cn(\"relative inline-block\", className)} {...props}>\n {children}\n </div>\n </DropdownContext.Provider>\n );\n};\n\n/* =========================\n Trigger\n========================= */\nexport const DropdownTrigger = ({\n children,\n className,\n variant,\n size,\n onClick,\n ...props\n}: DropdownTriggerProps) => {\n const { toggle, open, menuId } = useDropdown();\n\n return (\n <button\n type=\"button\"\n aria-expanded={open}\n aria-haspopup=\"menu\"\n aria-controls={menuId}\n className={cn(triggerVariants({ variant, size }), className)}\n {...props}\n onClick={(event) => {\n onClick?.(event);\n if (!event.defaultPrevented) {\n toggle();\n }\n }}\n >\n {children}\n </button>\n );\n};\n\n/* =========================\n Content\n========================= */\nexport const DropdownContent = ({\n children,\n className,\n placement = \"bottom\",\n spacing = \"default\",\n divider,\n ...props\n}: DropdownContentProps) => {\n const { open, setOpen, menuId } = useDropdown();\n const ref = useRef<HTMLDivElement>(null);\n\n // click outside\n useClickOutside({ ref, setOpen });\n\n useEffect(() => {\n if (!open) {\n return;\n }\n\n ref.current?.querySelector<HTMLElement>('[role=\"menuitem\"]')?.focus();\n }, [open]);\n\n if (!open) return null;\n\n return (\n <div\n ref={ref}\n id={menuId}\n role=\"menu\"\n className={cn(\n contentVariants({ placement, spacing }),\n className,\n divider && \"divide-y divide-current\",\n )}\n {...props}\n >\n {children}\n </div>\n );\n};\n\n/* =========================\n Item\n========================= */\nexport const DropdownItem = ({\n children,\n value,\n className,\n variant,\n onClick,\n onKeyDown,\n onSelect,\n leftIcon,\n rightIcon,\n ...props\n}: DropdownItemProps) => {\n const { toggleSelect, selectedValues } = useDropdown();\n const isSelected = value !== undefined && selectedValues.includes(value);\n\n const handleClick = () => {\n if (value !== undefined) toggleSelect(value);\n onSelect?.();\n };\n\n const focusSiblingItem = (\n event: KeyboardEvent<HTMLDivElement>,\n direction: \"next\" | \"previous\" | \"first\" | \"last\",\n ) => {\n const menu = event.currentTarget.closest('[role=\"menu\"]');\n const items = Array.from(\n menu?.querySelectorAll<HTMLElement>('[role=\"menuitem\"]') ?? [],\n );\n const currentIndex = items.indexOf(event.currentTarget);\n\n if (currentIndex === -1 || items.length === 0) {\n return;\n }\n\n const nextIndex =\n direction === \"first\"\n ? 0\n : direction === \"last\"\n ? items.length - 1\n : (currentIndex + (direction === \"next\" ? 1 : -1) + items.length) %\n items.length;\n\n items[nextIndex]?.focus();\n };\n\n return (\n <div\n role=\"menuitem\"\n tabIndex={-1}\n onClick={(event) => {\n onClick?.(event);\n if (!event.defaultPrevented) {\n handleClick();\n }\n }}\n onKeyDown={(e) => {\n onKeyDown?.(e);\n if (e.defaultPrevented) {\n return;\n }\n if (e.key === \"Enter\" || e.key === \" \") {\n e.preventDefault();\n handleClick();\n } else if (e.key === \"ArrowDown\") {\n e.preventDefault();\n focusSiblingItem(e, \"next\");\n } else if (e.key === \"ArrowUp\") {\n e.preventDefault();\n focusSiblingItem(e, \"previous\");\n } else if (e.key === \"Home\") {\n e.preventDefault();\n focusSiblingItem(e, \"first\");\n } else if (e.key === \"End\") {\n e.preventDefault();\n focusSiblingItem(e, \"last\");\n }\n }}\n className={cn(itemVariants({ variant }), className)}\n {...props}\n >\n <div className=\"flex items-center gap-2\">\n {leftIcon}\n {children}\n </div>\n\n <div className=\"flex items-center gap-2\">\n {isSelected && <FiCheck />}\n {rightIcon}\n </div>\n </div>\n );\n};\n"]}
@@ -0,0 +1,19 @@
1
+ 'use strict';
2
+
3
+ var chunk4TPE5DEG_js = require('./chunk-4TPE5DEG.js');
4
+ var classVarianceAuthority = require('class-variance-authority');
5
+
6
+ var buttonVariants = classVarianceAuthority.cva(chunk4TPE5DEG_js.zuiButtonBase, {
7
+ variants: {
8
+ appearance: chunk4TPE5DEG_js.zuiButtonAppearances,
9
+ size: chunk4TPE5DEG_js.zuiButtonSizes
10
+ },
11
+ defaultVariants: {
12
+ appearance: "default",
13
+ size: "md"
14
+ }
15
+ });
16
+
17
+ exports.buttonVariants = buttonVariants;
18
+ //# sourceMappingURL=chunk-MWG7LHAK.js.map
19
+ //# sourceMappingURL=chunk-MWG7LHAK.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/ui/buttons/variants.ts"],"names":["cva","zuiButtonBase","zuiButtonAppearances","zuiButtonSizes"],"mappings":";;;;;AAQO,IAAM,cAAA,GAAiBA,2BAAIC,8BAAA,EAAe;AAAA,EAC/C,QAAA,EAAU;AAAA,IACR,UAAA,EAAYC,qCAAA;AAAA,IACZ,IAAA,EAAMC;AAAA,GACR;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,UAAA,EAAY,SAAA;AAAA,IACZ,IAAA,EAAM;AAAA;AAEV,CAAC","file":"chunk-5FU57ZVQ.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nimport {\n zuiButtonAppearances,\n zuiButtonBase,\n zuiButtonSizes,\n} from \"../../design-system\";\n\nexport const buttonVariants = cva(zuiButtonBase, {\n variants: {\n appearance: zuiButtonAppearances,\n size: zuiButtonSizes,\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n },\n});\n"]}
1
+ {"version":3,"sources":["../src/ui/buttons/variants.ts"],"names":["cva","zuiButtonBase","zuiButtonAppearances","zuiButtonSizes"],"mappings":";;;;;AAQO,IAAM,cAAA,GAAiBA,2BAAIC,8BAAA,EAAe;AAAA,EAC/C,QAAA,EAAU;AAAA,IACR,UAAA,EAAYC,qCAAA;AAAA,IACZ,IAAA,EAAMC;AAAA,GACR;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,UAAA,EAAY,SAAA;AAAA,IACZ,IAAA,EAAM;AAAA;AAEV,CAAC","file":"chunk-MWG7LHAK.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nimport {\n zuiButtonAppearances,\n zuiButtonBase,\n zuiButtonSizes,\n} from \"../../design-system\";\n\nexport const buttonVariants = cva(zuiButtonBase, {\n variants: {\n appearance: zuiButtonAppearances,\n size: zuiButtonSizes,\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n },\n});\n"]}
@@ -1,4 +1,4 @@
1
- import { buttonVariants } from './chunk-KVSRUAXP.mjs';
1
+ import { buttonVariants } from './chunk-VN7FE5RR.mjs';
2
2
  import { cn } from './chunk-4D54YOL6.mjs';
3
3
  import { isValidElement, cloneElement } from 'react';
4
4
  import { jsx } from 'react/jsx-runtime';
@@ -97,5 +97,5 @@ var Button = (props) => {
97
97
  Button.displayName = "Button";
98
98
 
99
99
  export { Button };
100
- //# sourceMappingURL=chunk-7UXPXCKV.mjs.map
101
- //# sourceMappingURL=chunk-7UXPXCKV.mjs.map
100
+ //# sourceMappingURL=chunk-OLT7P7JO.mjs.map
101
+ //# sourceMappingURL=chunk-OLT7P7JO.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/ui/buttons/button-base.tsx","../src/ui/buttons/button.tsx"],"names":["className","appearance","size","children","rest","ref","jsx"],"mappings":"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","file":"chunk-7UXPXCKV.mjs","sourcesContent":["\"use client\";\n\nimport { cloneElement, isValidElement, type MouseEventHandler } from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type { ButtonProps } from \"./types\";\nimport { buttonVariants } from \"./variants\";\n\nexport const ButtonBase = (props: ButtonProps) => {\n if (\"asChild\" in props && props.asChild) {\n const {\n className,\n appearance,\n size,\n children,\n asChild: _asChild,\n disabled,\n onClick,\n ...rest\n } = props;\n\n if (!isValidElement<{ className?: string }>(children)) {\n return null;\n }\n\n const isNativeButton = children.type === \"button\";\n const childOnClick = children.props.onClick as\n | MouseEventHandler<HTMLElement>\n | undefined;\n const handleClick: MouseEventHandler<HTMLElement> = (event) => {\n if (disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n onClick?.(event);\n if (!event.defaultPrevented) {\n childOnClick?.(event);\n }\n };\n\n return cloneElement(children, {\n ...rest,\n ...children.props,\n ...(disabled\n ? isNativeButton\n ? { disabled: true }\n : { \"aria-disabled\": true, tabIndex: -1 }\n : null),\n \"data-slot\": \"button\",\n onClick: handleClick,\n className: cn(\n buttonVariants({ appearance, size }),\n children.props.className,\n className,\n ),\n });\n }\n\n if (props.as === \"link\") {\n const {\n className,\n appearance,\n size,\n children,\n ref,\n href,\n target,\n ...rest\n } = props;\n\n return (\n <a\n ref={ref}\n href={href}\n target={target}\n rel={target === \"_blank\" ? \"noopener noreferrer\" : undefined}\n data-slot=\"button\"\n className={cn(buttonVariants({ appearance, size }), className)}\n {...rest}\n >\n {children}\n </a>\n );\n }\n\n const {\n className,\n appearance,\n size,\n type = \"button\",\n children,\n ref,\n ...rest\n } = props;\n\n return (\n <button\n ref={ref}\n type={type}\n data-slot=\"button\"\n className={cn(buttonVariants({ appearance, size }), className)}\n {...rest}\n >\n {children}\n </button>\n );\n};\n\nButtonBase.displayName = \"Button\";\n","// button.tsx — default static entry (no framer-motion)\nimport { ButtonBase } from \"./button-base\";\nimport type { ButtonProps } from \"./types\";\n\nexport const Button = (props: ButtonProps) => {\n return <ButtonBase {...props} />;\n};\n\nButton.displayName = \"Button\";\n"]}
1
+ {"version":3,"sources":["../src/ui/buttons/button-base.tsx","../src/ui/buttons/button.tsx"],"names":["className","appearance","size","children","rest","ref","jsx"],"mappings":"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","file":"chunk-OLT7P7JO.mjs","sourcesContent":["\"use client\";\n\nimport { cloneElement, isValidElement, type MouseEventHandler } from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type { ButtonProps } from \"./types\";\nimport { buttonVariants } from \"./variants\";\n\nexport const ButtonBase = (props: ButtonProps) => {\n if (\"asChild\" in props && props.asChild) {\n const {\n className,\n appearance,\n size,\n children,\n asChild: _asChild,\n disabled,\n onClick,\n ...rest\n } = props;\n\n if (!isValidElement<{ className?: string }>(children)) {\n return null;\n }\n\n const isNativeButton = children.type === \"button\";\n const childOnClick = children.props.onClick as\n | MouseEventHandler<HTMLElement>\n | undefined;\n const handleClick: MouseEventHandler<HTMLElement> = (event) => {\n if (disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n onClick?.(event);\n if (!event.defaultPrevented) {\n childOnClick?.(event);\n }\n };\n\n return cloneElement(children, {\n ...rest,\n ...children.props,\n ...(disabled\n ? isNativeButton\n ? { disabled: true }\n : { \"aria-disabled\": true, tabIndex: -1 }\n : null),\n \"data-slot\": \"button\",\n onClick: handleClick,\n className: cn(\n buttonVariants({ appearance, size }),\n children.props.className,\n className,\n ),\n });\n }\n\n if (props.as === \"link\") {\n const {\n className,\n appearance,\n size,\n children,\n ref,\n href,\n target,\n ...rest\n } = props;\n\n return (\n <a\n ref={ref}\n href={href}\n target={target}\n rel={target === \"_blank\" ? \"noopener noreferrer\" : undefined}\n data-slot=\"button\"\n className={cn(buttonVariants({ appearance, size }), className)}\n {...rest}\n >\n {children}\n </a>\n );\n }\n\n const {\n className,\n appearance,\n size,\n type = \"button\",\n children,\n ref,\n ...rest\n } = props;\n\n return (\n <button\n ref={ref}\n type={type}\n data-slot=\"button\"\n className={cn(buttonVariants({ appearance, size }), className)}\n {...rest}\n >\n {children}\n </button>\n );\n};\n\nButtonBase.displayName = \"Button\";\n","// button.tsx — default static entry (no framer-motion)\nimport { ButtonBase } from \"./button-base\";\nimport type { ButtonProps } from \"./types\";\n\nexport const Button = (props: ButtonProps) => {\n return <ButtonBase {...props} />;\n};\n\nButton.displayName = \"Button\";\n"]}
@@ -0,0 +1,38 @@
1
+ 'use strict';
2
+
3
+ // src/design-system/code-diff.ts
4
+ var zuiCodeDiffBase = [
5
+ "relative overflow-auto rounded-lg border border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))]",
6
+ "bg-[var(--zui-code-diff-bg,var(--zui-surface,oklch(98.4%_0.003_247.858)))] dark:bg-[var(--zui-code-diff-bg-dark,var(--zui-surface-dark,oklch(12.9%_0.042_264.695)))]",
7
+ "text-[color:var(--zui-code-diff-fg,var(--zui-fg,oklch(20.8%_0.042_265.755)))] dark:text-[color:var(--zui-code-diff-fg-dark,var(--zui-fg-dark,oklch(98.4%_0.003_247.858)))]"
8
+ ];
9
+ var zuiCodeDiffSizes = {
10
+ sm: "text-xs leading-5",
11
+ md: "text-sm leading-6",
12
+ lg: "text-base leading-7"
13
+ };
14
+ var zuiCodeDiffHeaderBase = "sticky top-0 z-10 flex items-center justify-between border-b border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] bg-[var(--zui-code-diff-header-bg,var(--zui-surface-muted,oklch(92.9%_0.013_255.508)))] dark:bg-[var(--zui-code-diff-header-bg-dark,var(--zui-surface-muted-dark,oklch(27.9%_0.041_260.031)))] px-4 py-2";
15
+ var zuiCodeDiffTableBase = "w-full border-collapse table-fixed";
16
+ var zuiCodeDiffLineNumberBase = "select-none text-right align-top whitespace-nowrap border-r border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] px-3 text-[color:var(--zui-code-diff-line-number-fg,var(--zui-fg-muted,oklch(55.2%_0.046_257.417)))] dark:text-[color:var(--zui-code-diff-line-number-fg-dark,var(--zui-fg-muted-dark,oklch(70.8%_0.015_256.243)))]";
17
+ var zuiCodeDiffLineContentBase = "whitespace-pre-wrap break-all px-4 align-top";
18
+ var zuiCodeDiffLineAdded = "bg-[var(--zui-code-diff-added-bg,oklch(92.8%_0.109_150.96))] dark:bg-[var(--zui-code-diff-added-bg-dark,oklch(26.8%_0.077_146.44))] text-[color:var(--zui-code-diff-added-fg,oklch(29.1%_0.065_148.99))] dark:text-[color:var(--zui-code-diff-added-fg-dark,oklch(74%_0.131_149.02))]";
19
+ var zuiCodeDiffLineRemoved = "bg-[var(--zui-code-diff-removed-bg,oklch(93.1%_0.08_22.4))] dark:bg-[var(--zui-code-diff-removed-bg-dark,oklch(26.9%_0.07_22.54))] text-[color:var(--zui-code-diff-removed-fg,oklch(30.7%_0.06_28.07))] dark:text-[color:var(--zui-code-diff-removed-fg-dark,oklch(74.2%_0.127_24.75))]";
20
+ var zuiCodeDiffLineUnchanged = "";
21
+ var zuiCodeDiffGutterMarker = "inline-block w-4 text-center select-none";
22
+ var zuiCodeDiffAppearances = {
23
+ default: ""
24
+ };
25
+
26
+ exports.zuiCodeDiffAppearances = zuiCodeDiffAppearances;
27
+ exports.zuiCodeDiffBase = zuiCodeDiffBase;
28
+ exports.zuiCodeDiffGutterMarker = zuiCodeDiffGutterMarker;
29
+ exports.zuiCodeDiffHeaderBase = zuiCodeDiffHeaderBase;
30
+ exports.zuiCodeDiffLineAdded = zuiCodeDiffLineAdded;
31
+ exports.zuiCodeDiffLineContentBase = zuiCodeDiffLineContentBase;
32
+ exports.zuiCodeDiffLineNumberBase = zuiCodeDiffLineNumberBase;
33
+ exports.zuiCodeDiffLineRemoved = zuiCodeDiffLineRemoved;
34
+ exports.zuiCodeDiffLineUnchanged = zuiCodeDiffLineUnchanged;
35
+ exports.zuiCodeDiffSizes = zuiCodeDiffSizes;
36
+ exports.zuiCodeDiffTableBase = zuiCodeDiffTableBase;
37
+ //# sourceMappingURL=chunk-PAISX7YL.js.map
38
+ //# sourceMappingURL=chunk-PAISX7YL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/design-system/code-diff.ts"],"names":[],"mappings":";;;AAAO,IAAM,eAAA,GAAkB;AAAA,EAC7B,uMAAA;AAAA,EACA,sKAAA;AAAA,EACA;AACF;AAEO,IAAM,gBAAA,GAAmB;AAAA,EAC9B,EAAA,EAAI,mBAAA;AAAA,EACJ,EAAA,EAAI,mBAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,qBAAA,GACX;AAEK,IAAM,oBAAA,GAAuB;AAE7B,IAAM,yBAAA,GACX;AAEK,IAAM,0BAAA,GACX;AAEK,IAAM,oBAAA,GACX;AAEK,IAAM,sBAAA,GACX;AAEK,IAAM,wBAAA,GAA2B;AAEjC,IAAM,uBAAA,GACX;AAEK,IAAM,sBAAA,GAAyB;AAAA,EACpC,OAAA,EAAS;AACX","file":"chunk-PAISX7YL.js","sourcesContent":["export const zuiCodeDiffBase = [\n \"relative overflow-auto rounded-lg border border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))]\",\n \"bg-[var(--zui-code-diff-bg,var(--zui-surface,oklch(98.4%_0.003_247.858)))] dark:bg-[var(--zui-code-diff-bg-dark,var(--zui-surface-dark,oklch(12.9%_0.042_264.695)))]\",\n \"text-[color:var(--zui-code-diff-fg,var(--zui-fg,oklch(20.8%_0.042_265.755)))] dark:text-[color:var(--zui-code-diff-fg-dark,var(--zui-fg-dark,oklch(98.4%_0.003_247.858)))]\",\n] as const;\n\nexport const zuiCodeDiffSizes = {\n sm: \"text-xs leading-5\",\n md: \"text-sm leading-6\",\n lg: \"text-base leading-7\",\n} as const;\n\nexport const zuiCodeDiffHeaderBase =\n \"sticky top-0 z-10 flex items-center justify-between border-b border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] bg-[var(--zui-code-diff-header-bg,var(--zui-surface-muted,oklch(92.9%_0.013_255.508)))] dark:bg-[var(--zui-code-diff-header-bg-dark,var(--zui-surface-muted-dark,oklch(27.9%_0.041_260.031)))] px-4 py-2\";\n\nexport const zuiCodeDiffTableBase = \"w-full border-collapse table-fixed\";\n\nexport const zuiCodeDiffLineNumberBase =\n \"select-none text-right align-top whitespace-nowrap border-r border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] px-3 text-[color:var(--zui-code-diff-line-number-fg,var(--zui-fg-muted,oklch(55.2%_0.046_257.417)))] dark:text-[color:var(--zui-code-diff-line-number-fg-dark,var(--zui-fg-muted-dark,oklch(70.8%_0.015_256.243)))]\";\n\nexport const zuiCodeDiffLineContentBase =\n \"whitespace-pre-wrap break-all px-4 align-top\";\n\nexport const zuiCodeDiffLineAdded =\n \"bg-[var(--zui-code-diff-added-bg,oklch(92.8%_0.109_150.96))] dark:bg-[var(--zui-code-diff-added-bg-dark,oklch(26.8%_0.077_146.44))] text-[color:var(--zui-code-diff-added-fg,oklch(29.1%_0.065_148.99))] dark:text-[color:var(--zui-code-diff-added-fg-dark,oklch(74%_0.131_149.02))]\";\n\nexport const zuiCodeDiffLineRemoved =\n \"bg-[var(--zui-code-diff-removed-bg,oklch(93.1%_0.08_22.4))] dark:bg-[var(--zui-code-diff-removed-bg-dark,oklch(26.9%_0.07_22.54))] text-[color:var(--zui-code-diff-removed-fg,oklch(30.7%_0.06_28.07))] dark:text-[color:var(--zui-code-diff-removed-fg-dark,oklch(74.2%_0.127_24.75))]\";\n\nexport const zuiCodeDiffLineUnchanged = \"\";\n\nexport const zuiCodeDiffGutterMarker =\n \"inline-block w-4 text-center select-none\";\n\nexport const zuiCodeDiffAppearances = {\n default: \"\",\n} as const;\n"]}
@@ -1,4 +1,4 @@
1
- import { zuiButtonBase, zuiButtonSizes, zuiButtonAppearances } from './chunk-FUCW5GPE.mjs';
1
+ import { zuiButtonBase, zuiButtonSizes, zuiButtonAppearances } from './chunk-3RC5IG6O.mjs';
2
2
  import { cva } from 'class-variance-authority';
3
3
 
4
4
  var buttonVariants = cva(zuiButtonBase, {
@@ -13,5 +13,5 @@ var buttonVariants = cva(zuiButtonBase, {
13
13
  });
14
14
 
15
15
  export { buttonVariants };
16
- //# sourceMappingURL=chunk-KVSRUAXP.mjs.map
17
- //# sourceMappingURL=chunk-KVSRUAXP.mjs.map
16
+ //# sourceMappingURL=chunk-VN7FE5RR.mjs.map
17
+ //# sourceMappingURL=chunk-VN7FE5RR.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/ui/buttons/variants.ts"],"names":[],"mappings":";;;AAQO,IAAM,cAAA,GAAiB,IAAI,aAAA,EAAe;AAAA,EAC/C,QAAA,EAAU;AAAA,IACR,UAAA,EAAY,oBAAA;AAAA,IACZ,IAAA,EAAM;AAAA,GACR;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,UAAA,EAAY,SAAA;AAAA,IACZ,IAAA,EAAM;AAAA;AAEV,CAAC","file":"chunk-KVSRUAXP.mjs","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nimport {\n zuiButtonAppearances,\n zuiButtonBase,\n zuiButtonSizes,\n} from \"../../design-system\";\n\nexport const buttonVariants = cva(zuiButtonBase, {\n variants: {\n appearance: zuiButtonAppearances,\n size: zuiButtonSizes,\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n },\n});\n"]}
1
+ {"version":3,"sources":["../src/ui/buttons/variants.ts"],"names":[],"mappings":";;;AAQO,IAAM,cAAA,GAAiB,IAAI,aAAA,EAAe;AAAA,EAC/C,QAAA,EAAU;AAAA,IACR,UAAA,EAAY,oBAAA;AAAA,IACZ,IAAA,EAAM;AAAA,GACR;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,UAAA,EAAY,SAAA;AAAA,IACZ,IAAA,EAAM;AAAA;AAEV,CAAC","file":"chunk-VN7FE5RR.mjs","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nimport {\n zuiButtonAppearances,\n zuiButtonBase,\n zuiButtonSizes,\n} from \"../../design-system\";\n\nexport const buttonVariants = cva(zuiButtonBase, {\n variants: {\n appearance: zuiButtonAppearances,\n size: zuiButtonSizes,\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n },\n});\n"]}
@@ -0,0 +1,18 @@
1
+ export declare const zuiCodeDiffBase: readonly ["relative overflow-auto rounded-lg border border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))]", "bg-[var(--zui-code-diff-bg,var(--zui-surface,oklch(98.4%_0.003_247.858)))] dark:bg-[var(--zui-code-diff-bg-dark,var(--zui-surface-dark,oklch(12.9%_0.042_264.695)))]", "text-[color:var(--zui-code-diff-fg,var(--zui-fg,oklch(20.8%_0.042_265.755)))] dark:text-[color:var(--zui-code-diff-fg-dark,var(--zui-fg-dark,oklch(98.4%_0.003_247.858)))]"];
2
+ export declare const zuiCodeDiffSizes: {
3
+ readonly sm: "text-xs leading-5";
4
+ readonly md: "text-sm leading-6";
5
+ readonly lg: "text-base leading-7";
6
+ };
7
+ export declare const zuiCodeDiffHeaderBase = "sticky top-0 z-10 flex items-center justify-between border-b border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] bg-[var(--zui-code-diff-header-bg,var(--zui-surface-muted,oklch(92.9%_0.013_255.508)))] dark:bg-[var(--zui-code-diff-header-bg-dark,var(--zui-surface-muted-dark,oklch(27.9%_0.041_260.031)))] px-4 py-2";
8
+ export declare const zuiCodeDiffTableBase = "w-full border-collapse table-fixed";
9
+ export declare const zuiCodeDiffLineNumberBase = "select-none text-right align-top whitespace-nowrap border-r border-[color:var(--zui-code-diff-border,var(--zui-border,#0000001a))] dark:border-[color:var(--zui-code-diff-border-dark,var(--zui-border-dark,#ffffff1a))] px-3 text-[color:var(--zui-code-diff-line-number-fg,var(--zui-fg-muted,oklch(55.2%_0.046_257.417)))] dark:text-[color:var(--zui-code-diff-line-number-fg-dark,var(--zui-fg-muted-dark,oklch(70.8%_0.015_256.243)))]";
10
+ export declare const zuiCodeDiffLineContentBase = "whitespace-pre-wrap break-all px-4 align-top";
11
+ export declare const zuiCodeDiffLineAdded = "bg-[var(--zui-code-diff-added-bg,oklch(92.8%_0.109_150.96))] dark:bg-[var(--zui-code-diff-added-bg-dark,oklch(26.8%_0.077_146.44))] text-[color:var(--zui-code-diff-added-fg,oklch(29.1%_0.065_148.99))] dark:text-[color:var(--zui-code-diff-added-fg-dark,oklch(74%_0.131_149.02))]";
12
+ export declare const zuiCodeDiffLineRemoved = "bg-[var(--zui-code-diff-removed-bg,oklch(93.1%_0.08_22.4))] dark:bg-[var(--zui-code-diff-removed-bg-dark,oklch(26.9%_0.07_22.54))] text-[color:var(--zui-code-diff-removed-fg,oklch(30.7%_0.06_28.07))] dark:text-[color:var(--zui-code-diff-removed-fg-dark,oklch(74.2%_0.127_24.75))]";
13
+ export declare const zuiCodeDiffLineUnchanged = "";
14
+ export declare const zuiCodeDiffGutterMarker = "inline-block w-4 text-center select-none";
15
+ export declare const zuiCodeDiffAppearances: {
16
+ readonly default: "";
17
+ };
18
+ //# sourceMappingURL=code-diff.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-diff.d.ts","sourceRoot":"","sources":["../../src/design-system/code-diff.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,0iBAIlB,CAAC;AAEX,eAAO,MAAM,gBAAgB;;;;CAInB,CAAC;AAEX,eAAO,MAAM,qBAAqB,uaACoY,CAAC;AAEva,eAAO,MAAM,oBAAoB,uCAAuC,CAAC;AAEzE,eAAO,MAAM,yBAAyB,ibAC0Y,CAAC;AAEjb,eAAO,MAAM,0BAA0B,iDACS,CAAC;AAEjD,eAAO,MAAM,oBAAoB,0RACwP,CAAC;AAE1R,eAAO,MAAM,sBAAsB,4RACwP,CAAC;AAE5R,eAAO,MAAM,wBAAwB,KAAK,CAAC;AAE3C,eAAO,MAAM,uBAAuB,6CACQ,CAAC;AAE7C,eAAO,MAAM,sBAAsB;;CAEzB,CAAC"}
@@ -1,32 +1,34 @@
1
1
  'use strict';
2
2
 
3
- var chunkTJ2EWPER_js = require('../chunk-TJ2EWPER.js');
3
+ var chunk4TPE5DEG_js = require('../chunk-4TPE5DEG.js');
4
4
  require('../chunk-FBUY6K6S.js');
5
+ require('../chunk-KWBGLH7G.js');
6
+ require('../chunk-OH5VOGNW.js');
5
7
  require('../chunk-Y7BU5RC4.js');
6
8
  require('../chunk-NDF3HORF.js');
7
9
  require('../chunk-USLNTKVQ.js');
8
10
  require('../chunk-D7ATXPVI.js');
9
11
  require('../chunk-IEHY6KNM.js');
10
12
  require('../chunk-3MK7CWEX.js');
13
+ require('../chunk-CJCOURVM.js');
11
14
  require('../chunk-22FJROCI.js');
12
15
  require('../chunk-UJXFD4SK.js');
13
16
  require('../chunk-3EJCQXGV.js');
14
17
  require('../chunk-6KVTKYTB.js');
15
18
  require('../chunk-L7W4NRK6.js');
16
- require('../chunk-KWBGLH7G.js');
17
- require('../chunk-OH5VOGNW.js');
19
+ require('../chunk-A7MU6SFI.js');
18
20
  require('../chunk-WGN2CBG6.js');
19
21
  require('../chunk-SRSRY5K2.js');
20
22
  require('../chunk-UG3GF2BD.js');
21
23
  require('../chunk-BZTAA3MK.js');
22
24
  require('../chunk-PZ25OHJE.js');
23
25
  require('../chunk-HOOZYA4N.js');
24
- require('../chunk-CJCOURVM.js');
26
+ require('../chunk-7DVECOO7.js');
25
27
  require('../chunk-KJMW7S5X.js');
26
28
  require('../chunk-3CYJQ6KF.js');
27
29
  require('../chunk-3453DQNL.js');
28
30
  require('../chunk-DYSXCJGL.js');
29
- require('../chunk-A7MU6SFI.js');
31
+ require('../chunk-PAISX7YL.js');
30
32
  require('../chunk-NYO3W5GY.js');
31
33
  require('../chunk-HNRCPZCK.js');
32
34
  require('../chunk-J2SUGU3X.js');
@@ -34,7 +36,6 @@ require('../chunk-J5NTJVKX.js');
34
36
  require('../chunk-UQQHB3OI.js');
35
37
  require('../chunk-BBM4BKSN.js');
36
38
  require('../chunk-Y5JAQEBF.js');
37
- require('../chunk-7DVECOO7.js');
38
39
  require('../chunk-YPYPWALR.js');
39
40
  require('../chunk-PP3L6M62.js');
40
41
  require('../chunk-BJDT7P2I.js');
@@ -242,7 +243,7 @@ function classifyVariables(raw) {
242
243
  };
243
244
  });
244
245
  }
245
- var tokenEntries = Object.entries(chunkTJ2EWPER_js.design_system_exports);
246
+ var tokenEntries = Object.entries(chunk4TPE5DEG_js.design_system_exports);
246
247
  function flattenClassStrings(value) {
247
248
  if (typeof value === "string") {
248
249
  return [value];