@devalok/shilp-sutra 0.27.2 → 0.29.0

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 (250) hide show
  1. package/dist/_chunks/badge-group.js +299 -0
  2. package/dist/_chunks/framer.js +1915 -1980
  3. package/dist/_chunks/keybinding.js +4 -5
  4. package/dist/_chunks/primitives.js +3198 -3272
  5. package/dist/_chunks/sonner.js +29 -31
  6. package/dist/_chunks/stat-row.js +110 -131
  7. package/dist/_chunks/tiptap.js +42 -78
  8. package/dist/_chunks/tree-view.js +138 -149
  9. package/dist/_chunks/typing-indicator.js +565 -0
  10. package/dist/_chunks/use-calendar.js +416 -439
  11. package/dist/_chunks/vendor-client.js +977 -814
  12. package/dist/_chunks/vendor-utils.js +5 -5
  13. package/dist/ai/block-renderer.js +22 -22
  14. package/dist/ai/blocks/loading.d.ts.map +1 -1
  15. package/dist/ai/command-bar.d.ts.map +1 -1
  16. package/dist/ai/command-bar.js +241 -263
  17. package/dist/ai/conversation.d.ts.map +1 -1
  18. package/dist/ai/conversation.js +87 -107
  19. package/dist/composed/activity-feed.d.ts +2 -0
  20. package/dist/composed/activity-feed.d.ts.map +1 -1
  21. package/dist/composed/activity-feed.js +118 -90
  22. package/dist/composed/avatar-group.d.ts +1 -0
  23. package/dist/composed/avatar-group.d.ts.map +1 -1
  24. package/dist/composed/avatar-group.js +91 -67
  25. package/dist/composed/bulk-action-bar.d.ts.map +1 -1
  26. package/dist/composed/bulk-action-bar.js +29 -28
  27. package/dist/composed/command-palette.d.ts.map +1 -1
  28. package/dist/composed/command-palette.js +99 -113
  29. package/dist/composed/content-card.js +1 -1
  30. package/dist/composed/date-picker/calendar-grid.d.ts.map +1 -1
  31. package/dist/composed/date-picker/date-picker.d.ts.map +1 -1
  32. package/dist/composed/date-picker/date-range-picker.d.ts.map +1 -1
  33. package/dist/composed/date-picker/date-time-picker.d.ts.map +1 -1
  34. package/dist/composed/date-picker/time-picker.d.ts.map +1 -1
  35. package/dist/composed/deadline-indicator.d.ts.map +1 -1
  36. package/dist/composed/deadline-indicator.js +29 -28
  37. package/dist/composed/error-boundary.d.ts.map +1 -1
  38. package/dist/composed/error-boundary.js +30 -27
  39. package/dist/composed/extensions/file-attachment.d.ts.map +1 -1
  40. package/dist/composed/file-preview.d.ts.map +1 -1
  41. package/dist/composed/file-preview.js +261 -271
  42. package/dist/composed/filter-bar.d.ts.map +1 -1
  43. package/dist/composed/filter-bar.js +49 -48
  44. package/dist/composed/form-section.d.ts.map +1 -1
  45. package/dist/composed/form-section.js +12 -11
  46. package/dist/composed/global-loading.js +1 -1
  47. package/dist/composed/index.js +63 -63
  48. package/dist/composed/inline-edit.d.ts.map +1 -1
  49. package/dist/composed/inline-edit.js +55 -54
  50. package/dist/composed/markdown-viewer.d.ts.map +1 -1
  51. package/dist/composed/markdown-viewer.js +44 -43
  52. package/dist/composed/master-detail.d.ts.map +1 -1
  53. package/dist/composed/master-detail.js +35 -34
  54. package/dist/composed/multi-select-popover.d.ts.map +1 -1
  55. package/dist/composed/multi-select-popover.js +64 -64
  56. package/dist/composed/page-header.d.ts.map +1 -1
  57. package/dist/composed/page-header.js +31 -37
  58. package/dist/composed/priority-indicator.d.ts.map +1 -1
  59. package/dist/composed/priority-indicator.js +37 -36
  60. package/dist/composed/rich-text-editor.d.ts.map +1 -1
  61. package/dist/composed/rich-text-editor.js +287 -306
  62. package/dist/composed/schedule-view.js +62 -62
  63. package/dist/composed/status-badge.d.ts +4 -2
  64. package/dist/composed/status-badge.d.ts.map +1 -1
  65. package/dist/composed/status-badge.js +58 -45
  66. package/dist/shell/app-command-palette.d.ts.map +1 -1
  67. package/dist/shell/app-command-palette.js +93 -93
  68. package/dist/shell/bottom-navbar.d.ts.map +1 -1
  69. package/dist/shell/bottom-navbar.js +21 -20
  70. package/dist/shell/index.js +18 -18
  71. package/dist/shell/notification-center.d.ts.map +1 -1
  72. package/dist/shell/notification-center.js +96 -95
  73. package/dist/shell/notification-preferences.d.ts.map +1 -1
  74. package/dist/shell/notification-preferences.js +82 -85
  75. package/dist/shell/sidebar.js +59 -60
  76. package/dist/shell/top-bar.d.ts.map +1 -1
  77. package/dist/shell/top-bar.js +103 -103
  78. package/dist/tailwind/index.cjs +37 -4
  79. package/dist/tailwind/preset.d.ts.map +1 -1
  80. package/dist/tailwind/preset.js +38 -5
  81. package/dist/tokens/primitives.css +10 -0
  82. package/dist/tokens/semantic.css +70 -7
  83. package/dist/ui/accordion.d.ts +5 -2
  84. package/dist/ui/accordion.d.ts.map +1 -1
  85. package/dist/ui/accordion.js +44 -39
  86. package/dist/ui/alert-dialog.js +57 -57
  87. package/dist/ui/alert.d.ts +1 -1
  88. package/dist/ui/alert.d.ts.map +1 -1
  89. package/dist/ui/alert.js +30 -29
  90. package/dist/ui/aspect-ratio.js +4 -4
  91. package/dist/ui/autocomplete.js +56 -56
  92. package/dist/ui/avatar.js +2 -2
  93. package/dist/ui/badge-group.d.ts +22 -0
  94. package/dist/ui/badge-group.d.ts.map +1 -0
  95. package/dist/ui/badge-group.js +8 -0
  96. package/dist/ui/badge-indicator.d.ts +32 -0
  97. package/dist/ui/badge-indicator.d.ts.map +1 -0
  98. package/dist/ui/badge-indicator.js +54 -0
  99. package/dist/ui/badge.d.ts +27 -24
  100. package/dist/ui/badge.d.ts.map +1 -1
  101. package/dist/ui/badge.js +13 -129
  102. package/dist/ui/banner.d.ts +1 -1
  103. package/dist/ui/banner.d.ts.map +1 -1
  104. package/dist/ui/banner.js +27 -26
  105. package/dist/ui/breadcrumb.d.ts.map +1 -1
  106. package/dist/ui/breadcrumb.js +37 -36
  107. package/dist/ui/button-group.d.ts +12 -6
  108. package/dist/ui/button-group.d.ts.map +1 -1
  109. package/dist/ui/button-group.js +18 -18
  110. package/dist/ui/button-processing.d.ts +15 -0
  111. package/dist/ui/button-processing.d.ts.map +1 -0
  112. package/dist/ui/button-processing.js +77 -0
  113. package/dist/ui/button.d.ts +50 -25
  114. package/dist/ui/button.d.ts.map +1 -1
  115. package/dist/ui/button.js +243 -127
  116. package/dist/ui/card.js +20 -21
  117. package/dist/ui/charts/index.js +499 -508
  118. package/dist/ui/chat/date-separator.d.ts +12 -0
  119. package/dist/ui/chat/date-separator.d.ts.map +1 -0
  120. package/dist/ui/chat/index.d.ts +9 -0
  121. package/dist/ui/chat/index.d.ts.map +1 -0
  122. package/dist/ui/chat/index.js +12 -0
  123. package/dist/ui/chat/message-input.d.ts +16 -0
  124. package/dist/ui/chat/message-input.d.ts.map +1 -0
  125. package/dist/ui/chat/message-list.d.ts +24 -0
  126. package/dist/ui/chat/message-list.d.ts.map +1 -0
  127. package/dist/ui/chat/message.d.ts +108 -0
  128. package/dist/ui/chat/message.d.ts.map +1 -0
  129. package/dist/ui/chat/system-message.d.ts +11 -0
  130. package/dist/ui/chat/system-message.d.ts.map +1 -0
  131. package/dist/ui/chat/typing-indicator.d.ts +14 -0
  132. package/dist/ui/chat/typing-indicator.d.ts.map +1 -0
  133. package/dist/ui/chat/unread-separator.d.ts +12 -0
  134. package/dist/ui/chat/unread-separator.d.ts.map +1 -0
  135. package/dist/ui/checkbox.js +18 -18
  136. package/dist/ui/chip.d.ts +13 -62
  137. package/dist/ui/chip.d.ts.map +1 -1
  138. package/dist/ui/chip.js +10 -109
  139. package/dist/ui/collapsible.js +4 -4
  140. package/dist/ui/color-input.d.ts +19 -5
  141. package/dist/ui/color-input.d.ts.map +1 -1
  142. package/dist/ui/color-input.js +371 -79
  143. package/dist/ui/color-swatch.js +11 -11
  144. package/dist/ui/combobox.d.ts.map +1 -1
  145. package/dist/ui/combobox.js +74 -80
  146. package/dist/ui/context-menu.d.ts.map +1 -1
  147. package/dist/ui/context-menu.js +86 -85
  148. package/dist/ui/data-table-toolbar.d.ts.map +1 -1
  149. package/dist/ui/data-table-toolbar.js +51 -57
  150. package/dist/ui/data-table.d.ts.map +1 -1
  151. package/dist/ui/data-table.js +268 -296
  152. package/dist/ui/devalok-grain.d.ts +81 -0
  153. package/dist/ui/devalok-grain.d.ts.map +1 -0
  154. package/dist/ui/devalok-grain.js +69 -0
  155. package/dist/ui/dialog.d.ts.map +1 -1
  156. package/dist/ui/dialog.js +73 -72
  157. package/dist/ui/dropdown-menu.d.ts.map +1 -1
  158. package/dist/ui/dropdown-menu.js +93 -92
  159. package/dist/ui/file-upload.d.ts.map +1 -1
  160. package/dist/ui/file-upload.js +82 -82
  161. package/dist/ui/hover-card.js +29 -29
  162. package/dist/ui/icon-button.d.ts +7 -7
  163. package/dist/ui/icon-button.d.ts.map +1 -1
  164. package/dist/ui/icon-context.d.ts +15 -0
  165. package/dist/ui/icon-context.d.ts.map +1 -0
  166. package/dist/ui/icon-context.js +20 -0
  167. package/dist/ui/icon-group.d.ts +22 -0
  168. package/dist/ui/icon-group.d.ts.map +1 -0
  169. package/dist/ui/icon-group.js +32 -0
  170. package/dist/ui/icon.d.ts +57 -0
  171. package/dist/ui/icon.d.ts.map +1 -0
  172. package/dist/ui/icon.js +122 -0
  173. package/dist/ui/index.d.ts +8 -1
  174. package/dist/ui/index.d.ts.map +1 -1
  175. package/dist/ui/index.js +351 -329
  176. package/dist/ui/input-otp.d.ts.map +1 -1
  177. package/dist/ui/input-otp.js +21 -20
  178. package/dist/ui/input.d.ts +32 -11
  179. package/dist/ui/input.d.ts.map +1 -1
  180. package/dist/ui/input.js +149 -44
  181. package/dist/ui/label.js +1 -1
  182. package/dist/ui/lib/motion.d.ts +2 -0
  183. package/dist/ui/lib/motion.d.ts.map +1 -1
  184. package/dist/ui/lib/motion.js +13 -11
  185. package/dist/ui/lib/utils.js +1 -1
  186. package/dist/ui/menubar.d.ts.map +1 -1
  187. package/dist/ui/menubar.js +87 -86
  188. package/dist/ui/navigation-menu.d.ts.map +1 -1
  189. package/dist/ui/navigation-menu.js +23 -28
  190. package/dist/ui/number-input.d.ts.map +1 -1
  191. package/dist/ui/number-input.js +54 -53
  192. package/dist/ui/pagination.d.ts.map +1 -1
  193. package/dist/ui/pagination.js +45 -44
  194. package/dist/ui/popover.js +30 -30
  195. package/dist/ui/progress.d.ts +3 -1
  196. package/dist/ui/progress.d.ts.map +1 -1
  197. package/dist/ui/progress.js +43 -39
  198. package/dist/ui/radio.js +1 -1
  199. package/dist/ui/search-input.d.ts.map +1 -1
  200. package/dist/ui/search-input.js +47 -60
  201. package/dist/ui/segmented-control.js +1 -1
  202. package/dist/ui/select.d.ts.map +1 -1
  203. package/dist/ui/select.js +54 -53
  204. package/dist/ui/separator.js +5 -5
  205. package/dist/ui/sheet.d.ts.map +1 -1
  206. package/dist/ui/sheet.js +46 -45
  207. package/dist/ui/sidebar.d.ts.map +1 -1
  208. package/dist/ui/sidebar.js +196 -193
  209. package/dist/ui/skeleton.js +1 -1
  210. package/dist/ui/slider.js +1 -1
  211. package/dist/ui/spinner.js +74 -74
  212. package/dist/ui/stat-card.d.ts.map +1 -1
  213. package/dist/ui/stat-card.js +85 -86
  214. package/dist/ui/switch.d.ts +3 -0
  215. package/dist/ui/switch.d.ts.map +1 -1
  216. package/dist/ui/switch.js +40 -26
  217. package/dist/ui/tabs.js +43 -43
  218. package/dist/ui/text.js +1 -1
  219. package/dist/ui/textarea.js +10 -10
  220. package/dist/ui/toast.d.ts.map +1 -1
  221. package/dist/ui/toast.js +169 -169
  222. package/dist/ui/toggle-group.js +1 -1
  223. package/dist/ui/toggle.js +5 -5
  224. package/dist/ui/tooltip.js +41 -41
  225. package/dist/ui/tree-view/tree-item.d.ts.map +1 -1
  226. package/docs/components/_header.md +4 -4
  227. package/docs/components/composed/activity-feed.md +7 -0
  228. package/docs/components/composed/avatar-group.md +8 -5
  229. package/docs/components/composed/status-badge.md +14 -1
  230. package/docs/components/ui/accordion.md +5 -2
  231. package/docs/components/ui/badge-group.md +38 -0
  232. package/docs/components/ui/badge-indicator.md +40 -0
  233. package/docs/components/ui/badge.md +36 -5
  234. package/docs/components/ui/button-processing.md +15 -0
  235. package/docs/components/ui/button.md +40 -11
  236. package/docs/components/ui/chat.md +214 -0
  237. package/docs/components/ui/color-input.md +58 -4
  238. package/docs/components/ui/data-table.md +3 -0
  239. package/docs/components/ui/devalok-grain.md +55 -0
  240. package/docs/components/ui/icon-button.md +12 -5
  241. package/docs/components/ui/icon-context.md +38 -0
  242. package/docs/components/ui/icon-group.md +36 -0
  243. package/docs/components/ui/icon.md +47 -0
  244. package/docs/components/ui/input.md +32 -6
  245. package/docs/components/ui/progress.md +5 -0
  246. package/docs/components/ui/spinner.md +3 -0
  247. package/docs/components/ui/switch.md +13 -0
  248. package/llms-full.txt +724 -44
  249. package/llms.txt +38 -19
  250. package/package.json +8 -2
@@ -1,88 +1,380 @@
1
1
  "use client";
2
- import { jsxs as d, jsx as t } from "react/jsx-runtime";
3
- import * as m from "react";
4
- import { cn as c } from "./lib/utils.js";
5
- const b = m.forwardRef(
6
- ({ value: s = "#000000", onChange: l, presets: n, disabled: o = !1, className: i, ...u }, f) => {
7
- const a = (r) => {
8
- l == null || l(r);
9
- };
10
- return /* @__PURE__ */ d("div", { className: c("flex flex-col gap-ds-03", i), ...u, children: [
11
- /* @__PURE__ */ d("div", { className: "flex items-center gap-ds-03", children: [
12
- /* @__PURE__ */ d(
13
- "label",
14
- {
15
- "aria-label": "Pick a color",
16
- className: c(
17
- "relative flex h-ds-sm w-ds-sm shrink-0 cursor-pointer items-center justify-center overflow-hidden rounded-ds-md border border-surface-border-strong transition-colors hover:border-surface-border-strong",
18
- o && "cursor-not-allowed opacity-50"
2
+ import { jsx as r, jsxs as f } from "react/jsx-runtime";
3
+ import * as g from "react";
4
+ import { Z as K } from "../_chunks/vendor-client.js";
5
+ import { cn as k } from "./lib/utils.js";
6
+ import { springs as R } from "./lib/motion.js";
7
+ import { Popover as Q, PopoverTrigger as X, PopoverContent as Y } from "./popover.js";
8
+ import { m as x, A as V } from "../_chunks/framer.js";
9
+ function B(l) {
10
+ const a = /^#?([0-9a-f]{6})$/i.exec(l);
11
+ if (!a) return null;
12
+ const o = parseInt(a[1], 16);
13
+ return { r: o >> 16 & 255, g: o >> 8 & 255, b: o & 255 };
14
+ }
15
+ function O(l, a, o) {
16
+ return "#" + [l, a, o].map((t) => Math.max(0, Math.min(255, Math.round(t))).toString(16).padStart(2, "0")).join("");
17
+ }
18
+ function ee(l) {
19
+ const a = B(l);
20
+ if (!a) return null;
21
+ const o = a.r / 255, t = a.g / 255, i = a.b / 255, c = Math.max(o, t, i), s = Math.min(o, t, i), p = (c + s) / 2;
22
+ if (c === s) return { h: 0, s: 0, l: Math.round(p * 100) };
23
+ const h = c - s, N = p > 0.5 ? h / (2 - c - s) : h / (c - s);
24
+ let M = 0;
25
+ return c === o ? M = ((t - i) / h + (t < i ? 6 : 0)) / 6 : c === t ? M = ((i - o) / h + 2) / 6 : M = ((o - t) / h + 4) / 6, { h: Math.round(M * 360), s: Math.round(N * 100), l: Math.round(p * 100) };
26
+ }
27
+ function te(l, a, o) {
28
+ const t = a / 100, i = o / 100, c = t * Math.min(i, 1 - i), s = (p) => {
29
+ const h = (p + l / 30) % 12, N = i - c * Math.max(Math.min(h - 3, 9 - h, 1), -1);
30
+ return Math.round(255 * N);
31
+ };
32
+ return O(s(0), s(8), s(4));
33
+ }
34
+ const re = [
35
+ { hex: "#EF4444", label: "Red" },
36
+ { hex: "#F59E0B", label: "Amber" },
37
+ { hex: "#10B981", label: "Emerald" },
38
+ { hex: "#3B82F6", label: "Blue" },
39
+ { hex: "#8B5CF6", label: "Violet" },
40
+ { hex: "#EC4899", label: "Pink" },
41
+ { hex: "#06B6D4", label: "Cyan" },
42
+ { hex: "#F97316", label: "Orange" },
43
+ { hex: "#84CC16", label: "Lime" },
44
+ { hex: "#6366F1", label: "Indigo" }
45
+ ];
46
+ function ae(l) {
47
+ const a = B(l);
48
+ if (!a) return !1;
49
+ const [o, t, i] = [a.r, a.g, a.b].map((c) => {
50
+ const s = c / 255;
51
+ return s <= 0.03928 ? s / 12.92 : Math.pow((s + 0.055) / 1.055, 2.4);
52
+ });
53
+ return 0.2126 * o + 0.7152 * t + 0.0722 * i > 0.4;
54
+ }
55
+ function w({
56
+ label: l,
57
+ value: a,
58
+ onChange: o,
59
+ onBlur: t,
60
+ disabled: i,
61
+ maxLength: c = 3,
62
+ prefix: s,
63
+ className: p,
64
+ id: h
65
+ }) {
66
+ return /* @__PURE__ */ f("div", { className: k("flex flex-col gap-ds-01", p), children: [
67
+ /* @__PURE__ */ r("label", { htmlFor: h, className: "text-[10px] font-medium uppercase tracking-wider text-surface-fg-muted", children: l }),
68
+ /* @__PURE__ */ f("div", { className: "flex items-center", children: [
69
+ s && /* @__PURE__ */ r("span", { className: "text-ds-sm text-surface-fg-muted", children: s }),
70
+ /* @__PURE__ */ r(
71
+ "input",
72
+ {
73
+ id: h,
74
+ type: "text",
75
+ value: a,
76
+ disabled: i,
77
+ onChange: (N) => o(N.target.value),
78
+ onBlur: t,
79
+ maxLength: c,
80
+ className: k(
81
+ "h-ds-xs-plus w-full rounded-ds-sm border border-surface-border bg-surface-overlay px-ds-02 font-mono text-ds-sm text-surface-fg transition-colors",
82
+ "focus:border-accent-7 focus:outline-none focus:ring-1 focus:ring-accent-9",
83
+ i && "cursor-not-allowed opacity-50"
84
+ )
85
+ }
86
+ )
87
+ ] })
88
+ ] });
89
+ }
90
+ const ne = g.forwardRef(
91
+ ({
92
+ value: l = "#000000",
93
+ onChange: a,
94
+ presets: o,
95
+ disabled: t = !1,
96
+ showPicker: i = !0,
97
+ defaultFormat: c = "hex",
98
+ align: s = "start",
99
+ variant: p = "default",
100
+ className: h,
101
+ ...N
102
+ }, M) => {
103
+ const [$, A] = g.useState(c), [j, D] = g.useState(!1), b = g.useId(), [n, S] = g.useState(l);
104
+ g.useEffect(() => {
105
+ S(l);
106
+ }, [l]);
107
+ const [v, W] = g.useState(l), [I, F] = g.useState([]), H = g.useRef(!1), G = (e) => {
108
+ t || (e && (W(n), F([])), D(e));
109
+ }, P = (e) => {
110
+ if (t) return;
111
+ const d = (e.startsWith("#") ? e : `#${e}`).toLowerCase();
112
+ F((u) => u[u.length - 1] === n ? u : [...u.slice(-19), n]), S(d), a?.(d);
113
+ }, Z = (e) => {
114
+ if (t) return;
115
+ const d = (e.startsWith("#") ? e : `#${e}`).toLowerCase();
116
+ H.current || (H.current = !0, F((u) => u[u.length - 1] === n ? u : [...u.slice(-19), n])), S(d), a?.(d);
117
+ }, E = () => {
118
+ H.current = !1;
119
+ }, _ = () => {
120
+ if (I.length === 0) return;
121
+ const e = I[I.length - 1];
122
+ F((m) => m.slice(0, -1)), S(e), a?.(e);
123
+ }, q = () => {
124
+ S(v), a?.(v), F([]);
125
+ }, z = o === !1 ? [] : o ? o.map(
126
+ (e) => typeof e == "string" ? { hex: e, label: e } : e
127
+ ) : re, y = B(n), C = ee(n), L = (e, m) => {
128
+ if (!y) return;
129
+ const d = parseInt(m, 10);
130
+ if (isNaN(d)) return;
131
+ const u = Math.max(0, Math.min(255, d));
132
+ P(O(
133
+ e === "r" ? u : y.r,
134
+ e === "g" ? u : y.g,
135
+ e === "b" ? u : y.b
136
+ ));
137
+ }, T = (e, m) => {
138
+ if (!C) return;
139
+ const d = parseInt(m, 10);
140
+ if (isNaN(d)) return;
141
+ const U = Math.max(0, Math.min(e === "h" ? 360 : 100, d));
142
+ P(te(
143
+ e === "h" ? U : C.h,
144
+ e === "s" ? U : C.s,
145
+ e === "l" ? U : C.l
146
+ ));
147
+ }, J = ["hex", "rgb", "hsl"];
148
+ return /* @__PURE__ */ r("div", { ref: M, className: k("inline-flex flex-col", h), ...N, children: /* @__PURE__ */ f(Q, { open: j, onOpenChange: G, children: [
149
+ /* @__PURE__ */ r(X, { asChild: !0, children: p === "inline" ? /* @__PURE__ */ r(
150
+ x.button,
151
+ {
152
+ type: "button",
153
+ disabled: t,
154
+ className: k(
155
+ "group flex items-center justify-center rounded-ds-md px-ds-04 py-ds-02 font-mono text-ds-sm font-medium",
156
+ "focus:outline-none focus:ring-2 focus:ring-accent-9 focus:ring-offset-2 focus:ring-offset-surface-base",
157
+ t && "cursor-not-allowed opacity-50"
158
+ ),
159
+ animate: {
160
+ backgroundColor: n,
161
+ color: ae(n) ? "rgba(0,0,0,0.8)" : "rgba(255,255,255,0.95)"
162
+ },
163
+ whileHover: { y: -1, boxShadow: "0 4px 12px rgba(0,0,0,0.12)" },
164
+ whileTap: { scale: 0.97 },
165
+ transition: R.smooth,
166
+ "aria-label": `Color picker: ${n}`,
167
+ children: n.toUpperCase()
168
+ }
169
+ ) : /* @__PURE__ */ f(
170
+ x.button,
171
+ {
172
+ type: "button",
173
+ disabled: t,
174
+ className: k(
175
+ "group relative flex items-center overflow-hidden rounded-ds-md border border-surface-border-strong",
176
+ "hover:border-accent-7 focus:border-accent-7 focus:outline-none focus:ring-1 focus:ring-accent-9",
177
+ t && "cursor-not-allowed opacity-50"
178
+ ),
179
+ whileHover: { scale: 1.02 },
180
+ whileTap: { scale: 0.98 },
181
+ transition: R.snappy,
182
+ "aria-label": `Color picker: ${n}`,
183
+ children: [
184
+ /* @__PURE__ */ r(
185
+ x.span,
186
+ {
187
+ className: "absolute inset-0",
188
+ animate: {
189
+ background: `linear-gradient(to right, ${n} 0%, ${n} 35%, transparent 70%)`
190
+ },
191
+ transition: { duration: 0.3 }
192
+ }
19
193
  ),
20
- children: [
21
- /* @__PURE__ */ t(
22
- "input",
194
+ /* @__PURE__ */ r("span", { className: "absolute inset-0 bg-surface-overlay/60", style: {
195
+ maskImage: "linear-gradient(to right, transparent 0%, black 40%)",
196
+ WebkitMaskImage: "linear-gradient(to right, transparent 0%, black 40%)"
197
+ } }),
198
+ /* @__PURE__ */ r("span", { className: "relative z-10 py-ds-02 pl-6 pr-ds-03 font-mono text-ds-sm text-surface-fg", children: n.toUpperCase() })
199
+ ]
200
+ }
201
+ ) }),
202
+ /* @__PURE__ */ r(
203
+ Y,
204
+ {
205
+ align: s,
206
+ sideOffset: 8,
207
+ className: "w-[272px] rounded-ds-xl border border-surface-border-strong bg-surface-overlay p-0 shadow-floating",
208
+ children: /* @__PURE__ */ f("div", { className: "flex flex-col", children: [
209
+ i && /* @__PURE__ */ r("div", { className: "p-ds-04 pb-ds-03", onPointerUp: E, onPointerLeave: E, children: /* @__PURE__ */ r(
210
+ K,
211
+ {
212
+ color: n,
213
+ onChange: Z,
214
+ className: "!w-full",
215
+ style: { height: 160 }
216
+ }
217
+ ) }),
218
+ /* @__PURE__ */ f("div", { className: "border-t border-surface-border px-ds-04 py-ds-03", children: [
219
+ /* @__PURE__ */ r("div", { className: "mb-ds-03 flex items-center gap-ds-01", children: J.map((e) => /* @__PURE__ */ f(
220
+ "button",
23
221
  {
24
- ref: f,
25
- type: "color",
26
- value: s,
27
- disabled: o,
28
- onChange: (r) => a(r.target.value),
29
- className: "absolute inset-0 h-full w-full cursor-pointer opacity-0"
30
- }
31
- ),
32
- /* @__PURE__ */ t(
33
- "span",
222
+ type: "button",
223
+ onClick: () => A(e),
224
+ className: k(
225
+ "relative rounded-ds-sm px-ds-02 py-px text-[10px] font-semibold uppercase tracking-wider transition-colors",
226
+ $ === e ? "text-accent-11" : "text-surface-fg-muted hover:text-surface-fg"
227
+ ),
228
+ children: [
229
+ $ === e && /* @__PURE__ */ r(
230
+ x.span,
231
+ {
232
+ layoutId: `color-input-format-pill-${b}`,
233
+ className: "absolute inset-0 rounded-ds-sm bg-accent-3",
234
+ transition: R.snappy
235
+ }
236
+ ),
237
+ /* @__PURE__ */ r("span", { className: "relative z-10", children: e })
238
+ ]
239
+ },
240
+ e
241
+ )) }),
242
+ /* @__PURE__ */ f(V, { mode: "wait", children: [
243
+ $ === "hex" && /* @__PURE__ */ r(
244
+ x.div,
245
+ {
246
+ initial: { opacity: 0, y: 4 },
247
+ animate: { opacity: 1, y: 0 },
248
+ exit: { opacity: 0, y: -4 },
249
+ transition: { duration: 0.15 },
250
+ className: "flex gap-ds-02",
251
+ children: /* @__PURE__ */ r(
252
+ w,
253
+ {
254
+ id: `${b}-hex`,
255
+ label: "Hex",
256
+ value: n.replace("#", "").toUpperCase(),
257
+ onChange: (e) => {
258
+ const m = e.replace(/[^0-9a-fA-F]/g, "").slice(0, 6);
259
+ m.length === 6 && P(`#${m}`);
260
+ },
261
+ onBlur: () => {
262
+ n.replace("#", "").toUpperCase().length !== 6 && S(n);
263
+ },
264
+ disabled: t,
265
+ maxLength: 6,
266
+ prefix: "#",
267
+ className: "flex-1"
268
+ }
269
+ )
270
+ },
271
+ "hex"
272
+ ),
273
+ $ === "rgb" && y && /* @__PURE__ */ f(
274
+ x.div,
275
+ {
276
+ initial: { opacity: 0, y: 4 },
277
+ animate: { opacity: 1, y: 0 },
278
+ exit: { opacity: 0, y: -4 },
279
+ transition: { duration: 0.15 },
280
+ className: "flex gap-ds-02",
281
+ children: [
282
+ /* @__PURE__ */ r(w, { id: `${b}-r`, label: "R", value: String(y.r), onChange: (e) => L("r", e), disabled: t, className: "flex-1" }),
283
+ /* @__PURE__ */ r(w, { id: `${b}-g`, label: "G", value: String(y.g), onChange: (e) => L("g", e), disabled: t, className: "flex-1" }),
284
+ /* @__PURE__ */ r(w, { id: `${b}-b`, label: "B", value: String(y.b), onChange: (e) => L("b", e), disabled: t, className: "flex-1" })
285
+ ]
286
+ },
287
+ "rgb"
288
+ ),
289
+ $ === "hsl" && C && /* @__PURE__ */ f(
290
+ x.div,
291
+ {
292
+ initial: { opacity: 0, y: 4 },
293
+ animate: { opacity: 1, y: 0 },
294
+ exit: { opacity: 0, y: -4 },
295
+ transition: { duration: 0.15 },
296
+ className: "flex gap-ds-02",
297
+ children: [
298
+ /* @__PURE__ */ r(w, { id: `${b}-h`, label: "H", value: String(C.h), onChange: (e) => T("h", e), disabled: t, className: "flex-1" }),
299
+ /* @__PURE__ */ r(w, { id: `${b}-s`, label: "S", value: String(C.s), onChange: (e) => T("s", e), disabled: t, className: "flex-1" }),
300
+ /* @__PURE__ */ r(w, { id: `${b}-l`, label: "L", value: String(C.l), onChange: (e) => T("l", e), disabled: t, className: "flex-1" })
301
+ ]
302
+ },
303
+ "hsl"
304
+ )
305
+ ] })
306
+ ] }),
307
+ z.length > 0 && /* @__PURE__ */ r("div", { className: "border-t border-surface-border px-ds-04 py-ds-03", children: /* @__PURE__ */ r("div", { className: "flex flex-wrap gap-ds-02", children: z.map((e, m) => {
308
+ const d = n.toLowerCase() === e.hex.toLowerCase();
309
+ return /* @__PURE__ */ r(
310
+ x.button,
34
311
  {
35
- className: "h-full w-full rounded-[inherit]",
36
- style: { backgroundColor: s }
37
- }
38
- )
39
- ]
40
- }
41
- ),
42
- /* @__PURE__ */ t(
43
- "input",
44
- {
45
- type: "text",
46
- "aria-label": "Hex color value",
47
- value: s,
48
- disabled: o,
49
- onChange: (r) => {
50
- const e = r.target.value;
51
- /^#[0-9a-fA-F]{0,6}$/.test(e) && a(e);
52
- },
53
- onBlur: (r) => {
54
- const e = r.target.value;
55
- /^#[0-9a-fA-F]{6}$/.test(e) && a(e);
56
- },
57
- maxLength: 7,
58
- className: c(
59
- "h-ds-sm w-[90px] rounded-ds-md border border-surface-border-strong bg-surface-overlay px-ds-03 font-mono text-ds-md text-surface-fg transition-colors",
60
- "focus:border-accent-7 focus:outline-none focus:ring-1 focus:ring-accent-9",
61
- o && "cursor-not-allowed opacity-50"
312
+ type: "button",
313
+ disabled: t,
314
+ onClick: () => P(e.hex),
315
+ initial: { opacity: 0, scale: 0.8 },
316
+ animate: { opacity: 1, scale: d ? 1.15 : 1 },
317
+ whileHover: { scale: d ? 1.15 : 1.1 },
318
+ whileTap: { scale: 0.9 },
319
+ transition: { ...R.bouncy, delay: m * 0.02 },
320
+ className: k(
321
+ "h-6 w-6 rounded-ds-sm border",
322
+ d ? "border-accent-7 ring-2 ring-accent-9/30" : "border-surface-border hover:border-surface-border-strong",
323
+ t && "cursor-not-allowed opacity-50"
324
+ ),
325
+ style: { backgroundColor: e.hex },
326
+ title: e.label,
327
+ "aria-label": `${e.label}: ${e.hex}`
328
+ },
329
+ e.hex
330
+ );
331
+ }) }) }),
332
+ (I.length > 0 || n !== v) && /* @__PURE__ */ f(
333
+ x.div,
334
+ {
335
+ initial: { opacity: 0, height: 0 },
336
+ animate: { opacity: 1, height: "auto" },
337
+ exit: { opacity: 0, height: 0 },
338
+ className: "flex items-center gap-ds-02 border-t border-surface-border px-ds-04 py-ds-02",
339
+ children: [
340
+ /* @__PURE__ */ r(
341
+ "span",
342
+ {
343
+ className: "h-4 w-4 shrink-0 rounded-full border border-surface-border",
344
+ style: { backgroundColor: v },
345
+ title: `Original: ${v}`
346
+ }
347
+ ),
348
+ /* @__PURE__ */ r("span", { className: "text-[10px] text-surface-fg-muted", children: v.toUpperCase() }),
349
+ /* @__PURE__ */ r("span", { className: "flex-1" }),
350
+ I.length > 0 && /* @__PURE__ */ r(
351
+ "button",
352
+ {
353
+ type: "button",
354
+ onClick: _,
355
+ className: "rounded-ds-sm px-ds-02 py-px text-[10px] font-medium text-surface-fg-muted transition-colors hover:text-surface-fg",
356
+ children: "Undo"
357
+ }
358
+ ),
359
+ n !== v && /* @__PURE__ */ r(
360
+ "button",
361
+ {
362
+ type: "button",
363
+ onClick: q,
364
+ className: "rounded-ds-sm px-ds-02 py-px text-[10px] font-medium text-surface-fg-muted transition-colors hover:text-error-11",
365
+ children: "Reset"
366
+ }
367
+ )
368
+ ]
369
+ }
62
370
  )
63
- }
64
- )
65
- ] }),
66
- n && n.length > 0 && /* @__PURE__ */ t("div", { className: "flex flex-wrap gap-ds-02", children: n.map((r) => /* @__PURE__ */ t(
67
- "button",
68
- {
69
- type: "button",
70
- disabled: o,
71
- onClick: () => a(r),
72
- className: c(
73
- "h-ds-xs w-ds-xs rounded-ds-sm border transition-colors",
74
- s === r ? "border-accent-7 ring-1 ring-accent-9" : "border-surface-border-strong hover:border-surface-border-strong",
75
- o && "cursor-not-allowed opacity-50"
76
- ),
77
- style: { backgroundColor: r },
78
- "aria-label": `Select color ${r}`
79
- },
80
- r
81
- )) })
82
- ] });
371
+ ] })
372
+ }
373
+ )
374
+ ] }) });
83
375
  }
84
376
  );
85
- b.displayName = "ColorInput";
377
+ ne.displayName = "ColorInput";
86
378
  export {
87
- b as ColorInput
379
+ ne as ColorInput
88
380
  };
@@ -1,8 +1,8 @@
1
1
  "use client";
2
- import { jsxs as h, Fragment as S, jsx as t } from "react/jsx-runtime";
2
+ import { jsxs as h, Fragment as N, jsx as t } from "react/jsx-runtime";
3
3
  import * as s from "react";
4
4
  import { cn as o } from "./lib/utils.js";
5
- const v = {
5
+ const S = {
6
6
  sm: "h-3 w-3",
7
7
  md: "h-4 w-4",
8
8
  lg: "h-6 w-6"
@@ -11,12 +11,12 @@ const v = {
11
11
  square: "rounded-none",
12
12
  rounded: "rounded-ds-sm"
13
13
  }, k = s.forwardRef(
14
- ({ color: a, size: g = "md", shape: n = "circle", ring: y = !1, copyable: i = !1, checkerboard: e = !1, className: w, style: x, ...c }, u) => {
15
- const [b, d] = s.useState(!1), p = s.useRef();
14
+ ({ color: a, size: g = "md", shape: n = "circle", ring: y = !1, copyable: i = !1, checkerboard: e = !1, className: w, style: x, ...c }, d) => {
15
+ const [b, u] = s.useState(!1), p = s.useRef(void 0);
16
16
  s.useEffect(() => () => clearTimeout(p.current), []);
17
17
  const m = o(
18
18
  "inline-block shrink-0 relative",
19
- v[g],
19
+ S[g],
20
20
  l[n],
21
21
  y && "shadow-ring-sm",
22
22
  i && "cursor-pointer",
@@ -28,12 +28,12 @@ const v = {
28
28
  backgroundColor: a,
29
29
  ...x
30
30
  };
31
- function N() {
31
+ function v() {
32
32
  navigator.clipboard.writeText(a).then(() => {
33
- d(!0), p.current = setTimeout(() => d(!1), 1500);
33
+ u(!0), p.current = setTimeout(() => u(!1), 1500);
34
34
  });
35
35
  }
36
- const f = e ? /* @__PURE__ */ h(S, { children: [
36
+ const f = e ? /* @__PURE__ */ h(N, { children: [
37
37
  /* @__PURE__ */ t(
38
38
  "span",
39
39
  {
@@ -54,10 +54,10 @@ const v = {
54
54
  "button",
55
55
  {
56
56
  type: "button",
57
- ref: u,
57
+ ref: d,
58
58
  className: m,
59
59
  style: e ? {} : r,
60
- onClick: N,
60
+ onClick: v,
61
61
  "aria-label": `Copy color ${a}`,
62
62
  ...c,
63
63
  children: [
@@ -75,7 +75,7 @@ const v = {
75
75
  ) : /* @__PURE__ */ t(
76
76
  "span",
77
77
  {
78
- ref: u,
78
+ ref: d,
79
79
  className: m,
80
80
  style: e ? {} : r,
81
81
  role: "presentation",
@@ -1 +1 @@
1
- {"version":3,"file":"combobox.d.ts","sourceRoot":"","sources":["../../src/ui/combobox.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAQ9B;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,UAAU,iBAAkB,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC;IACxF,OAAO,EAAE,cAAc,EAAE,CAAA;IACzB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,kEAAkE;IAClE,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,EAAE,QAAQ,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAA;IAC7E,4FAA4F;IAC5F,eAAe,CAAC,EAAE,MAAM,CAAA;CACzB;AAED,UAAU,mBAAoB,SAAQ,iBAAiB;IACrD,QAAQ,CAAC,EAAE,KAAK,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;CACvC;AAED,UAAU,qBAAsB,SAAQ,iBAAiB;IACvD,QAAQ,EAAE,IAAI,CAAA;IACd,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAA;CACzC;AAED,MAAM,MAAM,aAAa,GAAG,mBAAmB,GAAG,qBAAqB,CAAA;AAQvE,QAAA,MAAM,QAAQ,yFAoYb,CAAA;AAGD,OAAO,EAAE,QAAQ,EAAE,CAAA"}
1
+ {"version":3,"file":"combobox.d.ts","sourceRoot":"","sources":["../../src/ui/combobox.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAS9B;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,UAAU,iBAAkB,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC;IACxF,OAAO,EAAE,cAAc,EAAE,CAAA;IACzB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,kEAAkE;IAClE,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,EAAE,QAAQ,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAA;IAC7E,4FAA4F;IAC5F,eAAe,CAAC,EAAE,MAAM,CAAA;CACzB;AAED,UAAU,mBAAoB,SAAQ,iBAAiB;IACrD,QAAQ,CAAC,EAAE,KAAK,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;CACvC;AAED,UAAU,qBAAsB,SAAQ,iBAAiB;IACvD,QAAQ,EAAE,IAAI,CAAA;IACd,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAA;CACzC;AAED,MAAM,MAAM,aAAa,GAAG,mBAAmB,GAAG,qBAAqB,CAAA;AAQvE,QAAA,MAAM,QAAQ,yFAoYb,CAAA;AAGD,OAAO,EAAE,QAAQ,EAAE,CAAA"}