@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
@@ -0,0 +1,565 @@
1
+ "use client";
2
+ import { jsxs as m, jsx as t } from "react/jsx-runtime";
3
+ import * as n from "react";
4
+ import { cn as d } from "../ui/lib/utils.js";
5
+ import { tweens as O, springs as A, motionProps as R } from "../ui/lib/motion.js";
6
+ import { Spinner as G } from "../ui/spinner.js";
7
+ import { A as E, m as C } from "./framer.js";
8
+ import { IconTrash as J, IconAlertCircle as Q, IconSquare as V, IconSend as X } from "@tabler/icons-react";
9
+ import { Icon as M } from "../ui/icon.js";
10
+ import { Avatar as Z, AvatarImage as _, AvatarFallback as ee } from "../ui/avatar.js";
11
+ import { Tooltip as te, TooltipTrigger as se, TooltipContent as re } from "../ui/tooltip.js";
12
+ import { Button as B } from "../ui/button.js";
13
+ const ae = n.forwardRef(
14
+ ({
15
+ children: e,
16
+ autoScroll: s = !0,
17
+ newMessageCount: r = 0,
18
+ onScrollToBottom: a,
19
+ onLoadMore: i,
20
+ isLoadingMore: o = !1,
21
+ emptySlot: l,
22
+ scrollToBottomSlot: u,
23
+ headerSlot: h,
24
+ className: g,
25
+ ...y
26
+ }, b) => {
27
+ const x = n.useRef(null), v = n.useRef(!0), [c, T] = n.useState(!0), N = n.useRef(!1), w = n.useRef(0), S = n.Children.count(e) === 0 && !o, D = n.useCallback(() => {
28
+ const f = x.current;
29
+ if (!f) return;
30
+ const k = f.scrollHeight - f.scrollTop - f.clientHeight < 40;
31
+ v.current = k, T(k), f.scrollTop < 100 && i && !N.current && (N.current = !0, w.current = f.scrollHeight, i());
32
+ }, [i]);
33
+ n.useLayoutEffect(() => {
34
+ const f = x.current;
35
+ if (f) {
36
+ if (N.current) {
37
+ const k = f.scrollHeight;
38
+ f.scrollTop = k - w.current, N.current = !1;
39
+ return;
40
+ }
41
+ s && v.current && f.scrollTo({ top: f.scrollHeight, behavior: "smooth" });
42
+ }
43
+ }, [e, s]), n.useEffect(() => {
44
+ o || (N.current = !1);
45
+ }, [o]);
46
+ const p = r > 0 && !c, q = n.useCallback(() => {
47
+ const f = x.current;
48
+ f && f.scrollTo({ top: f.scrollHeight, behavior: "smooth" }), a?.();
49
+ }, [a]);
50
+ return /* @__PURE__ */ m(
51
+ "div",
52
+ {
53
+ ref: b,
54
+ className: d("relative flex flex-1 flex-col overflow-hidden", g),
55
+ ...y,
56
+ children: [
57
+ h,
58
+ /* @__PURE__ */ m(
59
+ "div",
60
+ {
61
+ ref: x,
62
+ role: "log",
63
+ "aria-live": "polite",
64
+ "aria-relevant": "additions",
65
+ className: "flex-1 overflow-y-auto px-ds-05 py-ds-04",
66
+ style: {
67
+ scrollbarWidth: "thin",
68
+ scrollbarColor: "var(--color-surface-border) transparent"
69
+ },
70
+ onScroll: D,
71
+ children: [
72
+ o && /* @__PURE__ */ t("div", { className: "flex justify-center py-ds-03", children: /* @__PURE__ */ t(G, { size: "sm" }) }),
73
+ S ? l : /* @__PURE__ */ t("div", { className: "flex flex-col gap-ds-04", children: /* @__PURE__ */ t(E, { initial: !1, children: e }) })
74
+ ]
75
+ }
76
+ ),
77
+ /* @__PURE__ */ t(E, { children: p && /* @__PURE__ */ m(
78
+ C.button,
79
+ {
80
+ initial: { opacity: 0, y: 10 },
81
+ animate: { opacity: 1, y: 0 },
82
+ exit: { opacity: 0, y: 10 },
83
+ transition: O.fade,
84
+ onClick: q,
85
+ className: "absolute bottom-ds-04 left-1/2 z-10 -translate-x-1/2 rounded-full bg-accent-9 px-ds-04 py-ds-02 text-ds-xs font-medium text-accent-fg shadow-raised transition-colors hover:bg-accent-10",
86
+ children: [
87
+ r,
88
+ " new"
89
+ ]
90
+ }
91
+ ) })
92
+ ]
93
+ }
94
+ );
95
+ }
96
+ );
97
+ ae.displayName = "MessageList";
98
+ const I = n.createContext({
99
+ variant: "flat",
100
+ placement: "start",
101
+ grouped: !1
102
+ });
103
+ function $() {
104
+ return n.useContext(I);
105
+ }
106
+ const j = n.forwardRef(
107
+ ({
108
+ children: e,
109
+ variant: s = "flat",
110
+ placement: r = "start",
111
+ highlight: a,
112
+ grouped: i = !1,
113
+ deleted: o = !1,
114
+ deletedText: l = "This message was deleted",
115
+ className: u,
116
+ ...h
117
+ }, g) => {
118
+ const y = n.useMemo(
119
+ () => ({ variant: s, placement: r, grouped: i, highlight: a }),
120
+ [s, r, i, a]
121
+ );
122
+ return o ? /* @__PURE__ */ m(
123
+ C.div,
124
+ {
125
+ ref: g,
126
+ initial: { opacity: 0, y: 8 },
127
+ animate: { opacity: 1, y: 0 },
128
+ transition: A.snappy,
129
+ className: d(
130
+ "flex items-center gap-ds-02 py-ds-02 text-ds-xs text-surface-fg-subtle/50 italic",
131
+ u
132
+ ),
133
+ ...R(h),
134
+ children: [
135
+ /* @__PURE__ */ t(M, { icon: J, size: "xs" }),
136
+ l
137
+ ]
138
+ }
139
+ ) : s === "bubble" ? /* @__PURE__ */ t(I.Provider, { value: y, children: /* @__PURE__ */ t(
140
+ C.div,
141
+ {
142
+ ref: g,
143
+ initial: { opacity: 0, y: 8 },
144
+ animate: { opacity: 1, y: 0 },
145
+ transition: A.snappy,
146
+ className: d(
147
+ "group/message relative flex",
148
+ r === "end" ? "justify-end" : "justify-start",
149
+ a === "mention" && "border-l-2 border-l-accent-9 bg-accent-2 pl-ds-03 rounded-ds-sm",
150
+ a === "internal" && "bg-warning-2/50 rounded-ds-sm",
151
+ u
152
+ ),
153
+ ...R(h),
154
+ children: /* @__PURE__ */ t(
155
+ "div",
156
+ {
157
+ className: d(
158
+ "max-w-[85%] rounded-ds-2xl px-ds-04 py-ds-03",
159
+ r === "end" ? "bg-accent-3 text-surface-fg" : "bg-surface-raised text-surface-fg"
160
+ ),
161
+ children: e
162
+ }
163
+ )
164
+ }
165
+ ) }) : /* @__PURE__ */ t(I.Provider, { value: y, children: /* @__PURE__ */ t(
166
+ C.div,
167
+ {
168
+ ref: g,
169
+ initial: { opacity: 0, y: 8 },
170
+ animate: { opacity: 1, y: 0 },
171
+ transition: A.snappy,
172
+ className: d(
173
+ "group/message relative flex gap-ds-04",
174
+ i && "-mt-ds-01",
175
+ a === "mention" && "border-l-2 border-l-accent-9 bg-accent-2 pl-ds-03 rounded-ds-sm",
176
+ a === "internal" && "bg-warning-2/50 rounded-ds-sm",
177
+ u
178
+ ),
179
+ ...R(h),
180
+ children: e
181
+ }
182
+ ) });
183
+ }
184
+ );
185
+ j.displayName = "Message";
186
+ function H({
187
+ src: e,
188
+ fallback: s,
189
+ icon: r,
190
+ size: a = "md",
191
+ children: i
192
+ }) {
193
+ const { grouped: o } = $(), l = a === "sm" ? "w-5" : "w-6", u = a === "sm" ? "h-5" : "h-6";
194
+ return o ? /* @__PURE__ */ t("div", { className: d(l, u, "shrink-0") }) : i ? /* @__PURE__ */ t("div", { className: d(l, "shrink-0 flex items-start"), children: i }) : r ? /* @__PURE__ */ t(
195
+ "div",
196
+ {
197
+ className: d(
198
+ l,
199
+ a === "sm" ? "h-5" : "h-6",
200
+ "shrink-0 flex items-center justify-center rounded-ds-full bg-surface-raised-hover"
201
+ ),
202
+ children: r
203
+ }
204
+ ) : /* @__PURE__ */ t("div", { className: d(l, "shrink-0"), children: /* @__PURE__ */ m(Z, { size: a === "sm" ? "xs" : "sm", children: [
205
+ e && /* @__PURE__ */ t(_, { src: e, alt: s ?? "" }),
206
+ /* @__PURE__ */ t(ee, { children: s ?? "" })
207
+ ] }) });
208
+ }
209
+ H.displayName = "Message.Avatar";
210
+ function F({ children: e, className: s, ...r }) {
211
+ return /* @__PURE__ */ t("div", { className: d("min-w-0 flex-1 flex flex-col gap-ds-02", s), ...r, children: e });
212
+ }
213
+ F.displayName = "Message.Content";
214
+ function ne(e) {
215
+ return e.toLocaleTimeString("en-US", { hour: "numeric", minute: "2-digit" });
216
+ }
217
+ function K({
218
+ name: e,
219
+ badge: s,
220
+ timestamp: r,
221
+ formattedTimestamp: a,
222
+ timestampFormat: i = ne
223
+ }) {
224
+ const { grouped: o } = $();
225
+ if (o) return null;
226
+ const l = a ?? (r ? i(r) : void 0);
227
+ return /* @__PURE__ */ m("div", { className: "flex items-baseline gap-ds-02", children: [
228
+ /* @__PURE__ */ t("span", { className: "font-semibold text-[13px] text-surface-fg", children: e }),
229
+ s,
230
+ l && /* @__PURE__ */ t("span", { className: "text-[11px] text-surface-fg-subtle/50", children: l })
231
+ ] });
232
+ }
233
+ K.displayName = "Message.Author";
234
+ function U({ children: e, className: s, ...r }) {
235
+ return /* @__PURE__ */ t(
236
+ "div",
237
+ {
238
+ className: d(
239
+ "text-[13px] leading-relaxed text-surface-fg whitespace-pre-wrap",
240
+ s
241
+ ),
242
+ ...r,
243
+ children: e
244
+ }
245
+ );
246
+ }
247
+ U.displayName = "Message.Body";
248
+ function Y({
249
+ content: e,
250
+ onSave: s,
251
+ onCancel: r,
252
+ canEdit: a = !1,
253
+ renderContent: i
254
+ }) {
255
+ const [o, l] = n.useState(!1), [u, h] = n.useState(e), g = n.useRef(null);
256
+ n.useEffect(() => {
257
+ o && g.current && (g.current.focus(), g.current.select());
258
+ }, [o]);
259
+ const y = n.useCallback(() => {
260
+ a && (h(e), l(!0));
261
+ }, [a, e]), b = n.useCallback(() => {
262
+ const c = u.trim();
263
+ c && c !== e && s(c), l(!1);
264
+ }, [u, e, s]), x = n.useCallback(() => {
265
+ l(!1), h(e), r?.();
266
+ }, [e, r]), v = n.useCallback(
267
+ (c) => {
268
+ c.key === "Enter" && !c.shiftKey ? (c.preventDefault(), b()) : c.key === "Escape" && (c.preventDefault(), x());
269
+ },
270
+ [b, x]
271
+ );
272
+ return o ? /* @__PURE__ */ m("div", { className: "text-[13px] leading-relaxed", children: [
273
+ /* @__PURE__ */ t(
274
+ "textarea",
275
+ {
276
+ ref: g,
277
+ value: u,
278
+ onChange: (c) => h(c.target.value),
279
+ onKeyDown: v,
280
+ onBlur: b,
281
+ className: "w-full resize-none rounded-ds-sm border border-surface-border-strong bg-surface-raised-hover px-ds-02 py-ds-01 text-[13px] leading-relaxed text-surface-fg focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent-9",
282
+ rows: 2
283
+ }
284
+ ),
285
+ /* @__PURE__ */ t("div", { className: "mt-ds-01 text-ds-xs text-surface-fg-subtle/50", children: "Enter to save · Escape to cancel" })
286
+ ] }) : /* @__PURE__ */ t(
287
+ "div",
288
+ {
289
+ className: d(
290
+ "text-[13px] leading-relaxed text-surface-fg whitespace-pre-wrap",
291
+ a && "cursor-pointer hover:bg-surface-raised-hover rounded-ds-sm transition-colors"
292
+ ),
293
+ onClick: y,
294
+ role: a ? "button" : void 0,
295
+ tabIndex: a ? 0 : void 0,
296
+ onKeyDown: a ? (c) => {
297
+ (c.key === "Enter" || c.key === " ") && (c.preventDefault(), y());
298
+ } : void 0,
299
+ children: i ? i(e) : e
300
+ }
301
+ );
302
+ }
303
+ Y.displayName = "Message.EditableBody";
304
+ function P({ reactions: e, onReact: s }) {
305
+ return e.length === 0 ? null : /* @__PURE__ */ t("div", { className: "flex flex-wrap gap-ds-02 mt-ds-03", children: e.map((r) => /* @__PURE__ */ m(
306
+ "button",
307
+ {
308
+ type: "button",
309
+ onClick: () => s(r.emoji),
310
+ className: d(
311
+ "inline-flex items-center gap-ds-01 rounded-full px-ds-02 py-ds-01 text-ds-xs transition-colors",
312
+ r.reacted ? "bg-accent-3 ring-1 ring-accent-6" : "bg-surface-raised-hover hover:bg-surface-raised-active"
313
+ ),
314
+ children: [
315
+ /* @__PURE__ */ t("span", { children: r.emoji }),
316
+ /* @__PURE__ */ t("span", { children: r.count })
317
+ ]
318
+ },
319
+ r.emoji
320
+ )) });
321
+ }
322
+ P.displayName = "Message.Reactions";
323
+ function L({ children: e, delay: s = 100 }) {
324
+ return /* @__PURE__ */ t(
325
+ "div",
326
+ {
327
+ className: d(
328
+ "absolute -top-2 right-0 z-10",
329
+ "flex items-center gap-ds-01 rounded-ds-md border border-surface-border bg-surface-raised px-ds-01 py-ds-01 shadow-raised",
330
+ "opacity-0 group-hover/message:opacity-100 transition-opacity duration-150"
331
+ ),
332
+ style: { transitionDelay: `${s}ms` },
333
+ children: e
334
+ }
335
+ );
336
+ }
337
+ L.displayName = "Message.Actions";
338
+ function W({
339
+ icon: e,
340
+ label: s,
341
+ onClick: r,
342
+ variant: a = "default"
343
+ }) {
344
+ return /* @__PURE__ */ m(te, { children: [
345
+ /* @__PURE__ */ t(se, { asChild: !0, children: /* @__PURE__ */ t(
346
+ "button",
347
+ {
348
+ type: "button",
349
+ onClick: r,
350
+ "aria-label": s,
351
+ className: d(
352
+ "p-ds-02 rounded-ds-sm transition-colors",
353
+ a === "default" && "text-surface-fg-subtle hover:text-surface-fg hover:bg-surface-raised-hover",
354
+ a === "danger" && "text-surface-fg-subtle hover:text-error-11 hover:bg-surface-raised-hover"
355
+ ),
356
+ children: /* @__PURE__ */ t(M, { icon: e, size: "xs" })
357
+ }
358
+ ) }),
359
+ /* @__PURE__ */ t(re, { children: s })
360
+ ] });
361
+ }
362
+ W.displayName = "Message.Action";
363
+ const Ce = Object.assign(j, {
364
+ Avatar: H,
365
+ Content: F,
366
+ Author: K,
367
+ Body: U,
368
+ EditableBody: Y,
369
+ Reactions: P,
370
+ Actions: L,
371
+ Action: W
372
+ });
373
+ function z(e) {
374
+ return new Date(e).toLocaleTimeString("en-US", {
375
+ hour: "numeric",
376
+ minute: "2-digit"
377
+ });
378
+ }
379
+ const ie = n.forwardRef(
380
+ ({ icon: e, timestamp: s, variant: r = "event", children: a, className: i, ...o }, l) => r === "alert" ? /* @__PURE__ */ t(
381
+ "div",
382
+ {
383
+ ref: l,
384
+ className: d("flex justify-center", i),
385
+ ...o,
386
+ children: /* @__PURE__ */ m("div", { className: "flex items-center gap-ds-03 rounded-ds-lg bg-error-3 px-ds-04 py-ds-03", children: [
387
+ e ?? /* @__PURE__ */ t(M, { icon: Q, size: "sm" }),
388
+ /* @__PURE__ */ t("span", { className: "text-ds-sm text-error-11", children: a }),
389
+ s && /* @__PURE__ */ t("span", { className: "text-ds-sm text-error-11/60", children: z(s) })
390
+ ] })
391
+ }
392
+ ) : /* @__PURE__ */ m(
393
+ "div",
394
+ {
395
+ ref: l,
396
+ className: d(
397
+ "flex items-center gap-ds-02 rounded-ds-sm bg-surface-raised-hover/30 px-ds-02 py-ds-01 -mx-ds-02 text-ds-sm text-surface-fg-subtle/60",
398
+ i
399
+ ),
400
+ ...o,
401
+ children: [
402
+ e,
403
+ /* @__PURE__ */ t("span", { className: "flex-1", children: a }),
404
+ s && /* @__PURE__ */ t("span", { children: z(s) })
405
+ ]
406
+ }
407
+ )
408
+ );
409
+ ie.displayName = "SystemMessage";
410
+ function le(e) {
411
+ const s = /* @__PURE__ */ new Date(), r = new Date(s.getFullYear(), s.getMonth(), s.getDate()), a = new Date(e.getFullYear(), e.getMonth(), e.getDate()), i = r.getTime() - a.getTime(), o = Math.round(i / (1e3 * 60 * 60 * 24));
412
+ if (o === 0) return "Today";
413
+ if (o === 1) return "Yesterday";
414
+ const l = e.toLocaleString("en-US", { month: "short" }), u = e.getDate();
415
+ return e.getFullYear() !== s.getFullYear() ? `${l} ${u}, ${e.getFullYear()}` : `${l} ${u}`;
416
+ }
417
+ function oe({ date: e, format: s, className: r }) {
418
+ const a = typeof e == "string" ? new Date(e) : e, i = s ? s(a) : le(a);
419
+ return /* @__PURE__ */ m("div", { className: d("flex items-center gap-ds-03 py-ds-03", r), children: [
420
+ /* @__PURE__ */ t("div", { className: "flex-1 border-t border-surface-border-subtle" }),
421
+ /* @__PURE__ */ t("span", { className: "text-ds-xs font-medium text-surface-fg-subtle/50 uppercase tracking-wider", children: i }),
422
+ /* @__PURE__ */ t("div", { className: "flex-1 border-t border-surface-border-subtle" })
423
+ ] });
424
+ }
425
+ oe.displayName = "DateSeparator";
426
+ function ce({
427
+ label: e = "NEW",
428
+ count: s,
429
+ className: r
430
+ }) {
431
+ return /* @__PURE__ */ m("div", { className: d("relative flex items-center py-ds-02", r), children: [
432
+ /* @__PURE__ */ t("div", { className: "flex-1 border-t-2 border-accent-7" }),
433
+ /* @__PURE__ */ t("span", { className: "px-ds-03 text-ds-xs font-semibold text-accent-11", children: s ? `${s} ${e}` : e }),
434
+ /* @__PURE__ */ t("div", { className: "flex-1 border-t-2 border-accent-7" })
435
+ ] });
436
+ }
437
+ ce.displayName = "UnreadSeparator";
438
+ const de = n.forwardRef(
439
+ ({
440
+ onSubmit: e,
441
+ placeholder: s = "Type a message...",
442
+ disabled: r = !1,
443
+ isStreaming: a = !1,
444
+ onCancel: i,
445
+ leadingSlot: o,
446
+ trailingSlot: l,
447
+ disclaimer: u,
448
+ sendIcon: h,
449
+ className: g,
450
+ ...y
451
+ }, b) => {
452
+ const [x, v] = n.useState(""), c = n.useRef(null), T = n.useCallback(() => {
453
+ const p = c.current;
454
+ p && (p.style.height = "auto", p.style.height = `${Math.min(p.scrollHeight, 160)}px`);
455
+ }, []), N = n.useCallback(
456
+ (p) => {
457
+ v(p.target.value), T();
458
+ },
459
+ [T]
460
+ ), w = n.useCallback(() => {
461
+ const p = x.trim();
462
+ !p || a || (e(p), v(""), c.current && (c.current.style.height = "auto"));
463
+ }, [x, a, e]), S = n.useCallback(
464
+ (p) => {
465
+ p.key === "Enter" && !p.shiftKey && (p.preventDefault(), a || w());
466
+ },
467
+ [a, w]
468
+ ), D = x.trim().length === 0;
469
+ return /* @__PURE__ */ m(
470
+ "div",
471
+ {
472
+ ref: b,
473
+ className: d(
474
+ "border-t border-surface-border-subtle px-ds-05 py-ds-04",
475
+ g
476
+ ),
477
+ ...y,
478
+ children: [
479
+ /* @__PURE__ */ m("div", { className: "flex items-end gap-ds-02 rounded-ds-xl border border-surface-border bg-surface-base p-ds-03", children: [
480
+ o,
481
+ /* @__PURE__ */ t(
482
+ "textarea",
483
+ {
484
+ ref: c,
485
+ value: x,
486
+ onChange: N,
487
+ onKeyDown: S,
488
+ placeholder: s,
489
+ disabled: r,
490
+ rows: 1,
491
+ className: "flex-1 resize-none bg-transparent px-ds-02 py-ds-01 text-ds-sm text-surface-fg placeholder:text-surface-fg-subtle/50 focus:outline-none disabled:opacity-50",
492
+ style: { maxHeight: 160 }
493
+ }
494
+ ),
495
+ a ? /* @__PURE__ */ t(
496
+ B,
497
+ {
498
+ variant: "ghost",
499
+ size: "icon-sm",
500
+ color: "error",
501
+ onClick: i,
502
+ "aria-label": "Stop",
503
+ children: /* @__PURE__ */ t(M, { icon: V, size: "sm" })
504
+ }
505
+ ) : /* @__PURE__ */ t(
506
+ B,
507
+ {
508
+ variant: "ghost",
509
+ size: "icon-sm",
510
+ onClick: w,
511
+ disabled: D || r,
512
+ "aria-label": "Send",
513
+ children: h ?? /* @__PURE__ */ t(M, { icon: X, size: "sm" })
514
+ }
515
+ ),
516
+ l
517
+ ] }),
518
+ u && /* @__PURE__ */ t("p", { className: "mt-ds-02 text-center text-ds-xs text-surface-fg-subtle/50", children: u })
519
+ ]
520
+ }
521
+ );
522
+ }
523
+ );
524
+ de.displayName = "MessageInput";
525
+ function ue(e) {
526
+ return e.length === 1 ? `${e[0].name} is typing...` : e.length === 2 ? `${e[0].name} and ${e[1].name} are typing...` : "Several people are typing...";
527
+ }
528
+ function fe({ users: e, className: s }) {
529
+ return /* @__PURE__ */ t("div", { className: d("min-h-[24px] px-ds-05", s), children: /* @__PURE__ */ t(E, { children: e.length > 0 && /* @__PURE__ */ m(
530
+ C.div,
531
+ {
532
+ initial: { opacity: 0 },
533
+ animate: { opacity: 1 },
534
+ exit: { opacity: 0 },
535
+ className: "flex items-center gap-ds-02 text-ds-xs text-surface-fg-subtle",
536
+ children: [
537
+ /* @__PURE__ */ t("span", { className: "flex items-center gap-ds-01", children: [0, 1, 2].map((r) => /* @__PURE__ */ t(
538
+ C.span,
539
+ {
540
+ className: "h-1 w-1 rounded-full bg-surface-fg-subtle",
541
+ animate: { y: [0, -3, 0] },
542
+ transition: {
543
+ duration: 0.5,
544
+ repeat: 1 / 0,
545
+ delay: r * 0.15
546
+ }
547
+ },
548
+ r
549
+ )) }),
550
+ /* @__PURE__ */ t("span", { children: ue(e) })
551
+ ]
552
+ }
553
+ ) }) });
554
+ }
555
+ fe.displayName = "TypingIndicator";
556
+ export {
557
+ oe as D,
558
+ Ce as M,
559
+ ie as S,
560
+ fe as T,
561
+ ce as U,
562
+ de as a,
563
+ ae as b,
564
+ $ as u
565
+ };