@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.
- package/dist/_chunks/badge-group.js +299 -0
- package/dist/_chunks/framer.js +1915 -1980
- package/dist/_chunks/keybinding.js +4 -5
- package/dist/_chunks/primitives.js +3198 -3272
- package/dist/_chunks/sonner.js +29 -31
- package/dist/_chunks/stat-row.js +110 -131
- package/dist/_chunks/tiptap.js +42 -78
- package/dist/_chunks/tree-view.js +138 -149
- package/dist/_chunks/typing-indicator.js +565 -0
- package/dist/_chunks/use-calendar.js +416 -439
- package/dist/_chunks/vendor-client.js +977 -814
- package/dist/_chunks/vendor-utils.js +5 -5
- package/dist/ai/block-renderer.js +22 -22
- package/dist/ai/blocks/loading.d.ts.map +1 -1
- package/dist/ai/command-bar.d.ts.map +1 -1
- package/dist/ai/command-bar.js +241 -263
- package/dist/ai/conversation.d.ts.map +1 -1
- package/dist/ai/conversation.js +87 -107
- package/dist/composed/activity-feed.d.ts +2 -0
- package/dist/composed/activity-feed.d.ts.map +1 -1
- package/dist/composed/activity-feed.js +118 -90
- package/dist/composed/avatar-group.d.ts +1 -0
- package/dist/composed/avatar-group.d.ts.map +1 -1
- package/dist/composed/avatar-group.js +91 -67
- package/dist/composed/bulk-action-bar.d.ts.map +1 -1
- package/dist/composed/bulk-action-bar.js +29 -28
- package/dist/composed/command-palette.d.ts.map +1 -1
- package/dist/composed/command-palette.js +99 -113
- package/dist/composed/content-card.js +1 -1
- package/dist/composed/date-picker/calendar-grid.d.ts.map +1 -1
- package/dist/composed/date-picker/date-picker.d.ts.map +1 -1
- package/dist/composed/date-picker/date-range-picker.d.ts.map +1 -1
- package/dist/composed/date-picker/date-time-picker.d.ts.map +1 -1
- package/dist/composed/date-picker/time-picker.d.ts.map +1 -1
- package/dist/composed/deadline-indicator.d.ts.map +1 -1
- package/dist/composed/deadline-indicator.js +29 -28
- package/dist/composed/error-boundary.d.ts.map +1 -1
- package/dist/composed/error-boundary.js +30 -27
- package/dist/composed/extensions/file-attachment.d.ts.map +1 -1
- package/dist/composed/file-preview.d.ts.map +1 -1
- package/dist/composed/file-preview.js +261 -271
- package/dist/composed/filter-bar.d.ts.map +1 -1
- package/dist/composed/filter-bar.js +49 -48
- package/dist/composed/form-section.d.ts.map +1 -1
- package/dist/composed/form-section.js +12 -11
- package/dist/composed/global-loading.js +1 -1
- package/dist/composed/index.js +63 -63
- package/dist/composed/inline-edit.d.ts.map +1 -1
- package/dist/composed/inline-edit.js +55 -54
- package/dist/composed/markdown-viewer.d.ts.map +1 -1
- package/dist/composed/markdown-viewer.js +44 -43
- package/dist/composed/master-detail.d.ts.map +1 -1
- package/dist/composed/master-detail.js +35 -34
- package/dist/composed/multi-select-popover.d.ts.map +1 -1
- package/dist/composed/multi-select-popover.js +64 -64
- package/dist/composed/page-header.d.ts.map +1 -1
- package/dist/composed/page-header.js +31 -37
- package/dist/composed/priority-indicator.d.ts.map +1 -1
- package/dist/composed/priority-indicator.js +37 -36
- package/dist/composed/rich-text-editor.d.ts.map +1 -1
- package/dist/composed/rich-text-editor.js +287 -306
- package/dist/composed/schedule-view.js +62 -62
- package/dist/composed/status-badge.d.ts +4 -2
- package/dist/composed/status-badge.d.ts.map +1 -1
- package/dist/composed/status-badge.js +58 -45
- package/dist/shell/app-command-palette.d.ts.map +1 -1
- package/dist/shell/app-command-palette.js +93 -93
- package/dist/shell/bottom-navbar.d.ts.map +1 -1
- package/dist/shell/bottom-navbar.js +21 -20
- package/dist/shell/index.js +18 -18
- package/dist/shell/notification-center.d.ts.map +1 -1
- package/dist/shell/notification-center.js +96 -95
- package/dist/shell/notification-preferences.d.ts.map +1 -1
- package/dist/shell/notification-preferences.js +82 -85
- package/dist/shell/sidebar.js +59 -60
- package/dist/shell/top-bar.d.ts.map +1 -1
- package/dist/shell/top-bar.js +103 -103
- package/dist/tailwind/index.cjs +37 -4
- package/dist/tailwind/preset.d.ts.map +1 -1
- package/dist/tailwind/preset.js +38 -5
- package/dist/tokens/primitives.css +10 -0
- package/dist/tokens/semantic.css +70 -7
- package/dist/ui/accordion.d.ts +5 -2
- package/dist/ui/accordion.d.ts.map +1 -1
- package/dist/ui/accordion.js +44 -39
- package/dist/ui/alert-dialog.js +57 -57
- package/dist/ui/alert.d.ts +1 -1
- package/dist/ui/alert.d.ts.map +1 -1
- package/dist/ui/alert.js +30 -29
- package/dist/ui/aspect-ratio.js +4 -4
- package/dist/ui/autocomplete.js +56 -56
- package/dist/ui/avatar.js +2 -2
- package/dist/ui/badge-group.d.ts +22 -0
- package/dist/ui/badge-group.d.ts.map +1 -0
- package/dist/ui/badge-group.js +8 -0
- package/dist/ui/badge-indicator.d.ts +32 -0
- package/dist/ui/badge-indicator.d.ts.map +1 -0
- package/dist/ui/badge-indicator.js +54 -0
- package/dist/ui/badge.d.ts +27 -24
- package/dist/ui/badge.d.ts.map +1 -1
- package/dist/ui/badge.js +13 -129
- package/dist/ui/banner.d.ts +1 -1
- package/dist/ui/banner.d.ts.map +1 -1
- package/dist/ui/banner.js +27 -26
- package/dist/ui/breadcrumb.d.ts.map +1 -1
- package/dist/ui/breadcrumb.js +37 -36
- package/dist/ui/button-group.d.ts +12 -6
- package/dist/ui/button-group.d.ts.map +1 -1
- package/dist/ui/button-group.js +18 -18
- package/dist/ui/button-processing.d.ts +15 -0
- package/dist/ui/button-processing.d.ts.map +1 -0
- package/dist/ui/button-processing.js +77 -0
- package/dist/ui/button.d.ts +50 -25
- package/dist/ui/button.d.ts.map +1 -1
- package/dist/ui/button.js +243 -127
- package/dist/ui/card.js +20 -21
- package/dist/ui/charts/index.js +499 -508
- package/dist/ui/chat/date-separator.d.ts +12 -0
- package/dist/ui/chat/date-separator.d.ts.map +1 -0
- package/dist/ui/chat/index.d.ts +9 -0
- package/dist/ui/chat/index.d.ts.map +1 -0
- package/dist/ui/chat/index.js +12 -0
- package/dist/ui/chat/message-input.d.ts +16 -0
- package/dist/ui/chat/message-input.d.ts.map +1 -0
- package/dist/ui/chat/message-list.d.ts +24 -0
- package/dist/ui/chat/message-list.d.ts.map +1 -0
- package/dist/ui/chat/message.d.ts +108 -0
- package/dist/ui/chat/message.d.ts.map +1 -0
- package/dist/ui/chat/system-message.d.ts +11 -0
- package/dist/ui/chat/system-message.d.ts.map +1 -0
- package/dist/ui/chat/typing-indicator.d.ts +14 -0
- package/dist/ui/chat/typing-indicator.d.ts.map +1 -0
- package/dist/ui/chat/unread-separator.d.ts +12 -0
- package/dist/ui/chat/unread-separator.d.ts.map +1 -0
- package/dist/ui/checkbox.js +18 -18
- package/dist/ui/chip.d.ts +13 -62
- package/dist/ui/chip.d.ts.map +1 -1
- package/dist/ui/chip.js +10 -109
- package/dist/ui/collapsible.js +4 -4
- package/dist/ui/color-input.d.ts +19 -5
- package/dist/ui/color-input.d.ts.map +1 -1
- package/dist/ui/color-input.js +371 -79
- package/dist/ui/color-swatch.js +11 -11
- package/dist/ui/combobox.d.ts.map +1 -1
- package/dist/ui/combobox.js +74 -80
- package/dist/ui/context-menu.d.ts.map +1 -1
- package/dist/ui/context-menu.js +86 -85
- package/dist/ui/data-table-toolbar.d.ts.map +1 -1
- package/dist/ui/data-table-toolbar.js +51 -57
- package/dist/ui/data-table.d.ts.map +1 -1
- package/dist/ui/data-table.js +268 -296
- package/dist/ui/devalok-grain.d.ts +81 -0
- package/dist/ui/devalok-grain.d.ts.map +1 -0
- package/dist/ui/devalok-grain.js +69 -0
- package/dist/ui/dialog.d.ts.map +1 -1
- package/dist/ui/dialog.js +73 -72
- package/dist/ui/dropdown-menu.d.ts.map +1 -1
- package/dist/ui/dropdown-menu.js +93 -92
- package/dist/ui/file-upload.d.ts.map +1 -1
- package/dist/ui/file-upload.js +82 -82
- package/dist/ui/hover-card.js +29 -29
- package/dist/ui/icon-button.d.ts +7 -7
- package/dist/ui/icon-button.d.ts.map +1 -1
- package/dist/ui/icon-context.d.ts +15 -0
- package/dist/ui/icon-context.d.ts.map +1 -0
- package/dist/ui/icon-context.js +20 -0
- package/dist/ui/icon-group.d.ts +22 -0
- package/dist/ui/icon-group.d.ts.map +1 -0
- package/dist/ui/icon-group.js +32 -0
- package/dist/ui/icon.d.ts +57 -0
- package/dist/ui/icon.d.ts.map +1 -0
- package/dist/ui/icon.js +122 -0
- package/dist/ui/index.d.ts +8 -1
- package/dist/ui/index.d.ts.map +1 -1
- package/dist/ui/index.js +351 -329
- package/dist/ui/input-otp.d.ts.map +1 -1
- package/dist/ui/input-otp.js +21 -20
- package/dist/ui/input.d.ts +32 -11
- package/dist/ui/input.d.ts.map +1 -1
- package/dist/ui/input.js +149 -44
- package/dist/ui/label.js +1 -1
- package/dist/ui/lib/motion.d.ts +2 -0
- package/dist/ui/lib/motion.d.ts.map +1 -1
- package/dist/ui/lib/motion.js +13 -11
- package/dist/ui/lib/utils.js +1 -1
- package/dist/ui/menubar.d.ts.map +1 -1
- package/dist/ui/menubar.js +87 -86
- package/dist/ui/navigation-menu.d.ts.map +1 -1
- package/dist/ui/navigation-menu.js +23 -28
- package/dist/ui/number-input.d.ts.map +1 -1
- package/dist/ui/number-input.js +54 -53
- package/dist/ui/pagination.d.ts.map +1 -1
- package/dist/ui/pagination.js +45 -44
- package/dist/ui/popover.js +30 -30
- package/dist/ui/progress.d.ts +3 -1
- package/dist/ui/progress.d.ts.map +1 -1
- package/dist/ui/progress.js +43 -39
- package/dist/ui/radio.js +1 -1
- package/dist/ui/search-input.d.ts.map +1 -1
- package/dist/ui/search-input.js +47 -60
- package/dist/ui/segmented-control.js +1 -1
- package/dist/ui/select.d.ts.map +1 -1
- package/dist/ui/select.js +54 -53
- package/dist/ui/separator.js +5 -5
- package/dist/ui/sheet.d.ts.map +1 -1
- package/dist/ui/sheet.js +46 -45
- package/dist/ui/sidebar.d.ts.map +1 -1
- package/dist/ui/sidebar.js +196 -193
- package/dist/ui/skeleton.js +1 -1
- package/dist/ui/slider.js +1 -1
- package/dist/ui/spinner.js +74 -74
- package/dist/ui/stat-card.d.ts.map +1 -1
- package/dist/ui/stat-card.js +85 -86
- package/dist/ui/switch.d.ts +3 -0
- package/dist/ui/switch.d.ts.map +1 -1
- package/dist/ui/switch.js +40 -26
- package/dist/ui/tabs.js +43 -43
- package/dist/ui/text.js +1 -1
- package/dist/ui/textarea.js +10 -10
- package/dist/ui/toast.d.ts.map +1 -1
- package/dist/ui/toast.js +169 -169
- package/dist/ui/toggle-group.js +1 -1
- package/dist/ui/toggle.js +5 -5
- package/dist/ui/tooltip.js +41 -41
- package/dist/ui/tree-view/tree-item.d.ts.map +1 -1
- package/docs/components/_header.md +4 -4
- package/docs/components/composed/activity-feed.md +7 -0
- package/docs/components/composed/avatar-group.md +8 -5
- package/docs/components/composed/status-badge.md +14 -1
- package/docs/components/ui/accordion.md +5 -2
- package/docs/components/ui/badge-group.md +38 -0
- package/docs/components/ui/badge-indicator.md +40 -0
- package/docs/components/ui/badge.md +36 -5
- package/docs/components/ui/button-processing.md +15 -0
- package/docs/components/ui/button.md +40 -11
- package/docs/components/ui/chat.md +214 -0
- package/docs/components/ui/color-input.md +58 -4
- package/docs/components/ui/data-table.md +3 -0
- package/docs/components/ui/devalok-grain.md +55 -0
- package/docs/components/ui/icon-button.md +12 -5
- package/docs/components/ui/icon-context.md +38 -0
- package/docs/components/ui/icon-group.md +36 -0
- package/docs/components/ui/icon.md +47 -0
- package/docs/components/ui/input.md +32 -6
- package/docs/components/ui/progress.md +5 -0
- package/docs/components/ui/spinner.md +3 -0
- package/docs/components/ui/switch.md +13 -0
- package/llms-full.txt +724 -44
- package/llms.txt +38 -19
- 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
|
+
};
|