@chaibuilder/pages 0.16.13 → 0.16.15
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/{2AITGKQY-D1mM4eEh.js → 2AITGKQY-2rt9M99C.js} +5 -5
- package/dist/{2AITGKQY-AK2WgbeT.cjs → 2AITGKQY-Cs6RBSPQ.cjs} +1 -1
- package/dist/{NCMVHL6D-DItDf9IY.cjs → NCMVHL6D-CsC6nsSQ.cjs} +1 -1
- package/dist/{NCMVHL6D-BeRsWdGV.js → NCMVHL6D-vUfYKc6i.js} +2 -2
- package/dist/{ZDWCUMSJ-COSBY-at.cjs → ZDWCUMSJ-B2OZjsr6.cjs} +1 -1
- package/dist/{ZDWCUMSJ-D6caRaY7.js → ZDWCUMSJ-CzEWKlEU.js} +1 -1
- package/dist/active-in-another-tab-B0N5S-Bh.js +34 -0
- package/dist/active-in-another-tab-BK3cZf-x.cjs +1 -0
- package/dist/{add-new-language-page-CQcFi0Tp.cjs → add-new-language-page-Dt1j-8Zg.cjs} +1 -1
- package/dist/{add-new-language-page-nnaUe-qk.js → add-new-language-page-YlqcCdlK.js} +20 -20
- package/dist/{add-new-page-DxObnvo_.cjs → add-new-page-DqhQUQBz.cjs} +1 -1
- package/dist/{add-new-page-Ba1fq6LH.js → add-new-page-aYomeid4.js} +1 -1
- package/dist/ai-panel-content-C6cH9rrC.js +123 -0
- package/dist/ai-panel-content-MOZmNIKP.cjs +1 -0
- package/dist/ai-panel-default-lang-BZHkFsox.js +317 -0
- package/dist/ai-panel-default-lang-DOk_Q0IO.cjs +3 -0
- package/dist/{ai-panel-other-lang-B4euTuod.js → ai-panel-other-lang-D2A46FTg.js} +10 -9
- package/dist/ai-panel-other-lang-qHrdvAMa.cjs +1 -0
- package/dist/ai-prompt-input-BZSjjNJd.cjs +1 -0
- package/dist/ai-prompt-input-C6gDvvLQ.js +1071 -0
- package/dist/{ai-translation-prompt-Ip7w2_Ey.cjs → ai-translation-prompt-BqXo2CLp.cjs} +1 -1
- package/dist/{ai-translation-prompt-CVuPbgXw.js → ai-translation-prompt-DTR0wbGt.js} +1 -1
- package/dist/continue-editing-in-this-client-C3T6Jzhi.cjs +1 -0
- package/dist/continue-editing-in-this-client-D2S1yCOM.js +24 -0
- package/dist/delete-page-BF1k60U2.js +70 -0
- package/dist/delete-page-x0DWKzsR.cjs +1 -0
- package/dist/{digital-asset-manager-CIMo79Di.cjs → digital-asset-manager-BmlFt2T_.cjs} +1 -1
- package/dist/{digital-asset-manager-SAFNO_mx.js → digital-asset-manager-C8udwDBW.js} +1 -1
- package/dist/{duplicate-page-CXK2HcxD.cjs → duplicate-page-Dt_QZkTk.cjs} +1 -1
- package/dist/{duplicate-page-5SwLvmkX.js → duplicate-page-u_6vUVo1.js} +7 -7
- package/dist/{dynamic-page-selector-Crd3y4Hk.cjs → dynamic-page-selector-Cgs_Y_Kl.cjs} +1 -1
- package/dist/{dynamic-page-selector-DfcuTqRN.js → dynamic-page-selector-DxBHmglP.js} +1 -1
- package/dist/index-BeWL6Sj6.cjs +5 -0
- package/dist/index-DI2Rwk5v.js +4820 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -34
- package/dist/index.js +21 -22
- package/dist/{json-diff-viewer-D34kDA_c.cjs → json-diff-viewer-D2g0Yab2.cjs} +1 -1
- package/dist/{json-diff-viewer-CDwpbuag.js → json-diff-viewer-QdUwk7yF.js} +6 -6
- package/dist/{lang-panel-CUIeO5bb.js → lang-panel-B8OD0GiA.js} +24 -24
- package/dist/{lang-panel-CaFrYllL.cjs → lang-panel-M2Zb01lF.cjs} +1 -1
- package/dist/{mark-as-template-D0dLQaIB.js → mark-as-template-CJ1mlxYT.js} +7 -7
- package/dist/{mark-as-template-v182tmN6.cjs → mark-as-template-DONU52b1.cjs} +1 -1
- package/dist/{no-language-page-content-Bk4fEx_p.cjs → no-language-page-content-DD9Ok2Ku.cjs} +1 -1
- package/dist/{no-language-page-content-ByRFD_qA.js → no-language-page-content-Dtm37LTJ.js} +1 -1
- package/dist/no-language-page-dialog-D3dvenZ7.cjs +1 -0
- package/dist/no-language-page-dialog-Dj_z2_hF.js +10 -0
- package/dist/{page-creator-Bh0IUGR3.js → page-creator-DIMFISo4.js} +52 -52
- package/dist/{page-creator-BnvaGZVI.cjs → page-creator-DTC66ujU.cjs} +1 -1
- package/dist/page-lock-CI6BYvF_.cjs +1 -0
- package/dist/page-lock-DUlNr3os.js +30 -0
- package/dist/page-locked-dialog-BKwULMV7.js +133 -0
- package/dist/page-locked-dialog-DorIbva0.cjs +1 -0
- package/dist/page-manager-new-lNVrLOJp.cjs +1 -0
- package/dist/page-manager-new-znvqI9_L.js +354 -0
- package/dist/{page-manager-search-and-filter-BETHSa3y.js → page-manager-search-and-filter-C-_w7N27.js} +1 -1
- package/dist/{page-manager-search-and-filter-hyUIHOD_.cjs → page-manager-search-and-filter-pe0q0qnZ.cjs} +1 -1
- package/dist/{page-revisions-content-BCMjvZRZ.cjs → page-revisions-content-Caaj5TEI.cjs} +1 -1
- package/dist/{page-revisions-content-VWthKL7O.js → page-revisions-content-CyLjyxNU.js} +16 -16
- package/dist/pages.css +1 -1
- package/dist/publish-pages-content-Bih1W9C4.js +178 -0
- package/dist/publish-pages-content-D5beVcQI.cjs +1 -0
- package/dist/{save-to-lib-YYBxY7MV.js → save-to-lib-BwpkJcT2.js} +1 -1
- package/dist/{save-to-lib-CtGpDkC6.cjs → save-to-lib-DPAERsi4.cjs} +1 -1
- package/dist/{selected-block-display-DdW-DWF1.js → selected-block-display-GXSf3y2s.js} +1 -1
- package/dist/{selected-block-display-BEbuJn0l.cjs → selected-block-display-s99Y91qI.cjs} +1 -1
- package/dist/{seo-panel-CqJDhbj-.js → seo-panel-BurZA566.js} +61 -61
- package/dist/{seo-panel-B9P7fXjo.cjs → seo-panel-BxUfalVy.cjs} +1 -1
- package/dist/server.cjs +1 -1
- package/dist/server.js +39 -39
- package/dist/{shared-json-ld-CyxmC9y5.cjs → shared-json-ld-BYAdrPeC.cjs} +1 -1
- package/dist/{shared-json-ld-DxEPILj_.js → shared-json-ld-DHWdJvQd.js} +39 -39
- package/dist/{slug-input-RNiSrU3p.cjs → slug-input-CR2B1kDJ.cjs} +1 -1
- package/dist/{slug-input-j5z5ZQn9.js → slug-input-Z_ny7bgX.js} +1 -1
- package/dist/take-over-request-CnEpToCM.cjs +1 -0
- package/dist/take-over-request-DF2JsIes.js +63 -0
- package/dist/{theme-panel-footer-DD2yalfG.js → theme-panel-footer-5mxFeEua.js} +4 -4
- package/dist/{theme-panel-footer-CCsiDIVl.cjs → theme-panel-footer-C2CjHoBu.cjs} +1 -1
- package/dist/{unmark-as-template-DXjLbqOM.cjs → unmark-as-template-Dn90g1eh.cjs} +1 -1
- package/dist/{unmark-as-template-B2hKhAHn.js → unmark-as-template-JRRUYTOY.js} +1 -1
- package/dist/{unpublish-page-BdJScWMX.cjs → unpublish-page-C3C_rTRd.cjs} +1 -1
- package/dist/{unpublish-page-BvB1PGSz.js → unpublish-page-FZ8rbi7u.js} +9 -9
- package/dist/{web-preview-CwVpkcwU.js → web-preview-CGBKG162.js} +1 -1
- package/dist/{web-preview-BI4jd0O7.cjs → web-preview-NdxC92Fk.cjs} +1 -1
- package/package.json +3 -3
- package/dist/ai-panel-content-B2AgBWqo.cjs +0 -1
- package/dist/ai-panel-content-M1UnzG_f.js +0 -54
- package/dist/ai-panel-default-lang-CHOFEwmV.js +0 -313
- package/dist/ai-panel-default-lang-sy6vkQJh.cjs +0 -3
- package/dist/ai-panel-other-lang-BwjSDD3L.cjs +0 -1
- package/dist/ai-prompt-input-B_NRADBT.js +0 -988
- package/dist/ai-prompt-input-DcyVXcLG.cjs +0 -1
- package/dist/delete-page-CbY8q5M3.cjs +0 -1
- package/dist/delete-page-SX9X35nA.js +0 -40
- package/dist/index-Bz7smSC0.cjs +0 -5
- package/dist/index-EnM7J19_.js +0 -4960
- package/dist/page-lock-request-C2b1kqyA.cjs +0 -1
- package/dist/page-lock-request-CaNqxfD6.js +0 -75
- package/dist/page-locked-by-dialog--WLDdkw9.js +0 -68
- package/dist/page-locked-by-dialog-90ElC8aG.cjs +0 -1
- package/dist/page-manager-new-Bo4-zwfW.js +0 -354
- package/dist/page-manager-new-SNRQn7Az.cjs +0 -1
- package/dist/publish-pages-content-6N7aEcM1.js +0 -178
- package/dist/publish-pages-content-CaBwfekc.cjs +0 -1
|
@@ -0,0 +1,317 @@
|
|
|
1
|
+
import { jsxs as C, Fragment as F, jsx as f } from "react/jsx-runtime";
|
|
2
|
+
import { C as P, a as W, b as O, R as $, c as q, d as V, T as K, M as _, e as j, f as G, h as z, S as Q, i as U } from "./selected-block-display-GXSf3y2s.js";
|
|
3
|
+
import { useAddBlock as J, useReplaceBlock as X, useRemoveBlocks as Y, getBlocksFromHTML as L, useSelectedBlock as Z, useSelectedBlockIds as tt, useBlocksHtmlForAi as et } from "@chaibuilder/sdk";
|
|
4
|
+
import { Bot as nt } from "lucide-react";
|
|
5
|
+
import { useCallback as rt, lazy as st, Fragment as ot, Suspense as it } from "react";
|
|
6
|
+
import { toast as at } from "sonner";
|
|
7
|
+
import { g as ct } from "./ai-panel-content-C6cH9rrC.js";
|
|
8
|
+
import { useQueryClient as lt } from "@tanstack/react-query";
|
|
9
|
+
const ut = () => {
|
|
10
|
+
const { addPredefinedBlock: k } = J(), x = X(), y = Y(), v = lt(), w = async (s, e) => {
|
|
11
|
+
if (!e) return;
|
|
12
|
+
const r = L(e);
|
|
13
|
+
await k(r, s.parentId, s.position);
|
|
14
|
+
}, I = async (s, e) => {
|
|
15
|
+
if (!s.blockId || !e) return;
|
|
16
|
+
const r = L(e);
|
|
17
|
+
await x(s.blockId, r);
|
|
18
|
+
}, S = async (s) => {
|
|
19
|
+
!s.ids || s.ids.length === 0 || await y(s.ids);
|
|
20
|
+
};
|
|
21
|
+
let d = null;
|
|
22
|
+
const T = (s, e) => {
|
|
23
|
+
const r = document.getElementById("canvas-iframe");
|
|
24
|
+
if (!r)
|
|
25
|
+
return null;
|
|
26
|
+
const c = r == null ? void 0 : r.contentDocument;
|
|
27
|
+
if (!c)
|
|
28
|
+
return null;
|
|
29
|
+
c.querySelectorAll("[data-stream-canvas]").forEach((u) => u.remove());
|
|
30
|
+
let n = null;
|
|
31
|
+
if (s && s !== "undefined" && (n = c.querySelector(`[data-block-id="${s}"]`)), n || (n = c.body), !n)
|
|
32
|
+
return null;
|
|
33
|
+
if (d = c.createElement("div"), d.setAttribute("data-stream-canvas", "true"), e !== void 0 && e >= 0 && n.children) {
|
|
34
|
+
const u = Math.min(e, n.children.length);
|
|
35
|
+
u < n.children.length ? n.insertBefore(d, n.children[u]) : n.appendChild(d);
|
|
36
|
+
} else
|
|
37
|
+
n.appendChild(d);
|
|
38
|
+
return d;
|
|
39
|
+
}, N = (s) => {
|
|
40
|
+
var n;
|
|
41
|
+
const e = document.getElementById("canvas-iframe");
|
|
42
|
+
if (!e)
|
|
43
|
+
return null;
|
|
44
|
+
const r = e == null ? void 0 : e.contentDocument;
|
|
45
|
+
if (!r)
|
|
46
|
+
return null;
|
|
47
|
+
r.querySelectorAll("[data-stream-canvas]").forEach((u) => u.remove());
|
|
48
|
+
const l = r.querySelector(`[data-block-id="${s}"]`);
|
|
49
|
+
return l ? (d = r.createElement("div"), d.setAttribute("data-stream-canvas", "true"), (n = l.parentNode) == null || n.insertBefore(d, l.nextSibling), l.style.display = "none", d) : null;
|
|
50
|
+
}, E = (s, e, r) => {
|
|
51
|
+
const c = T(e, r);
|
|
52
|
+
if (c) {
|
|
53
|
+
c.innerHTML = s;
|
|
54
|
+
const l = c.getBoundingClientRect(), n = document.getElementById("canvas-iframe"), u = n == null ? void 0 : n.contentWindow;
|
|
55
|
+
u && (l.top >= 0 && l.bottom <= u.innerHeight || c.scrollIntoView({ behavior: "smooth", block: "nearest" }));
|
|
56
|
+
}
|
|
57
|
+
}, B = (s, e) => {
|
|
58
|
+
const r = N(e);
|
|
59
|
+
r && (r.innerHTML = s);
|
|
60
|
+
}, M = (s) => {
|
|
61
|
+
const e = s.match(/^--ACTION=(.+)--$/);
|
|
62
|
+
if (!e) return null;
|
|
63
|
+
let c = e[1].replace(/--/g, "").split("|");
|
|
64
|
+
const n = { type: c[0] };
|
|
65
|
+
return c.forEach((u) => {
|
|
66
|
+
const t = u.trim();
|
|
67
|
+
if (t.startsWith("PARENT=")) {
|
|
68
|
+
const p = t.substring(7);
|
|
69
|
+
n.parentId = p === "undefined" ? void 0 : p;
|
|
70
|
+
} else t.startsWith("POS=") ? n.position = parseInt(t.substring(4)) : t.startsWith("ID=") ? n.blockId = t.substring(3) : t.startsWith("IDS=") && (n.ids = t.substring(4).split(",").map((p) => p.trim()));
|
|
71
|
+
}), n;
|
|
72
|
+
};
|
|
73
|
+
return rt(
|
|
74
|
+
async (s, e) => {
|
|
75
|
+
const r = new TextDecoder();
|
|
76
|
+
let c = "", l = "", n = !1, u = null;
|
|
77
|
+
const t = {
|
|
78
|
+
isInAction: !1,
|
|
79
|
+
currentAction: null,
|
|
80
|
+
htmlBuffer: "",
|
|
81
|
+
isCapturingHtml: !1
|
|
82
|
+
}, p = async (m) => {
|
|
83
|
+
const o = m.trim();
|
|
84
|
+
if (o === "--START--") {
|
|
85
|
+
n = !0;
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
if (n) {
|
|
89
|
+
if (o === "--END--") {
|
|
90
|
+
t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), d && (d.remove(), d = null);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (o.startsWith("--THINKING=")) {
|
|
94
|
+
const i = o.substring(11);
|
|
95
|
+
e((a) => {
|
|
96
|
+
const g = [...a], h = g[g.length - 1];
|
|
97
|
+
if (h && h.role === "assistant" && h.isReasoning)
|
|
98
|
+
h.content = i, h.isStreaming = !1;
|
|
99
|
+
else {
|
|
100
|
+
const A = {
|
|
101
|
+
id: Date.now().toString(),
|
|
102
|
+
role: "assistant",
|
|
103
|
+
content: i,
|
|
104
|
+
isReasoning: !0,
|
|
105
|
+
isStreaming: !1
|
|
106
|
+
};
|
|
107
|
+
g.push(A);
|
|
108
|
+
}
|
|
109
|
+
return g;
|
|
110
|
+
});
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
if (o.startsWith("--TASK=")) {
|
|
114
|
+
const i = o.substring(7), a = `task-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`, g = {
|
|
115
|
+
id: a,
|
|
116
|
+
role: "assistant",
|
|
117
|
+
content: i.replace(/--$/, ""),
|
|
118
|
+
isTask: !0,
|
|
119
|
+
isTaskLoading: !0,
|
|
120
|
+
isTaskCompleted: !1
|
|
121
|
+
};
|
|
122
|
+
u = a, e((h) => [...h, g]);
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
if (o.startsWith("--MSG=")) {
|
|
126
|
+
const i = o.substring(6), a = {
|
|
127
|
+
id: Date.now().toString(),
|
|
128
|
+
role: "assistant",
|
|
129
|
+
content: i.replace(/--$/g, ""),
|
|
130
|
+
isReasoning: !1,
|
|
131
|
+
isStreaming: !1
|
|
132
|
+
};
|
|
133
|
+
e((g) => [...g, a]);
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
if (o.startsWith("--ACTION=")) {
|
|
137
|
+
t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), t.currentAction = M(o), t.htmlBuffer = "", t.isInAction = !0;
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
if (o === "--ENDACTION--") {
|
|
141
|
+
t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), u && (e((i) => i.map((a) => a.isTask ? { ...a, isTaskCompleted: !0 } : a)), u = null), t.currentAction = null, t.htmlBuffer = "", t.isInAction = !1;
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
if (o === "--HTML--") {
|
|
145
|
+
t.isCapturingHtml = !0;
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
if (o === "--ENDHTML--") {
|
|
149
|
+
t.isCapturingHtml = !1;
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
if (o.startsWith("--HTML--") && o.includes("--ENDHTML--")) {
|
|
153
|
+
const i = o.match(/^--HTML--(.+?)--ENDHTML--$/);
|
|
154
|
+
if (i && t.currentAction) {
|
|
155
|
+
const a = i[1];
|
|
156
|
+
t.htmlBuffer += a, t.currentAction.type === "ADD" ? E(t.htmlBuffer, t.currentAction.parentId, t.currentAction.position) : t.currentAction.type === "EDIT" && t.currentAction.blockId && B(t.htmlBuffer, t.currentAction.blockId);
|
|
157
|
+
}
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
t.isCapturingHtml && t.currentAction && (t.htmlBuffer += m + `
|
|
161
|
+
`, t.currentAction.type === "ADD" ? E(t.htmlBuffer, t.currentAction.parentId, t.currentAction.position) : t.currentAction.type === "EDIT" && t.currentAction.blockId && B(t.htmlBuffer, t.currentAction.blockId));
|
|
162
|
+
}
|
|
163
|
+
}, b = async (m, o) => {
|
|
164
|
+
try {
|
|
165
|
+
switch (m.type) {
|
|
166
|
+
case "ADD":
|
|
167
|
+
await w(m, o);
|
|
168
|
+
break;
|
|
169
|
+
case "EDIT":
|
|
170
|
+
await I(m, o);
|
|
171
|
+
break;
|
|
172
|
+
case "REMOVE":
|
|
173
|
+
await S(m);
|
|
174
|
+
break;
|
|
175
|
+
}
|
|
176
|
+
e((i) => i.filter((a) => !a.isTask));
|
|
177
|
+
} catch (i) {
|
|
178
|
+
console.log(i);
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
try {
|
|
182
|
+
for (; ; ) {
|
|
183
|
+
const { done: m, value: o } = await s.read();
|
|
184
|
+
if (m) break;
|
|
185
|
+
const i = r.decode(o, { stream: !0 });
|
|
186
|
+
c += i, l += i;
|
|
187
|
+
const a = l.split(`
|
|
188
|
+
`);
|
|
189
|
+
l = a.pop() || "";
|
|
190
|
+
for (const g of a)
|
|
191
|
+
await p(g);
|
|
192
|
+
}
|
|
193
|
+
l && await p(l), v.invalidateQueries({
|
|
194
|
+
queryKey: ["AI_USAGE"]
|
|
195
|
+
});
|
|
196
|
+
} catch (m) {
|
|
197
|
+
console.log(m);
|
|
198
|
+
}
|
|
199
|
+
},
|
|
200
|
+
[y]
|
|
201
|
+
);
|
|
202
|
+
}, dt = st(() => import("./ai-prompt-input-C6gDvvLQ.js")), bt = ({
|
|
203
|
+
t: k,
|
|
204
|
+
fetch: x,
|
|
205
|
+
input: y,
|
|
206
|
+
messages: v,
|
|
207
|
+
setInput: w,
|
|
208
|
+
isLoading: I,
|
|
209
|
+
setMessages: S,
|
|
210
|
+
handleStop: d,
|
|
211
|
+
setIsLoading: T,
|
|
212
|
+
currentBlock: N,
|
|
213
|
+
fallbackLang: E,
|
|
214
|
+
setCurrentBlock: B,
|
|
215
|
+
setAbortController: M,
|
|
216
|
+
selectedModel: s = ct().id,
|
|
217
|
+
onModelChange: e
|
|
218
|
+
}) => {
|
|
219
|
+
const r = Z(), [, c] = tt(), l = et(), n = ut(), u = async (t, p, b, m) => {
|
|
220
|
+
var h;
|
|
221
|
+
if (!t || I) return;
|
|
222
|
+
B(r);
|
|
223
|
+
const o = l(r ? { blockId: r._id, additionalCoreBlocks: ["Icon"] } : { additionalCoreBlocks: ["Icon"] });
|
|
224
|
+
if (r && !o) {
|
|
225
|
+
at.error(k("Something went wrong. Please try again."));
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
const i = {
|
|
229
|
+
id: Date.now().toString(),
|
|
230
|
+
role: "user",
|
|
231
|
+
content: U({
|
|
232
|
+
language: E,
|
|
233
|
+
userInput: p || t,
|
|
234
|
+
currentHtml: o
|
|
235
|
+
}),
|
|
236
|
+
userMessage: t
|
|
237
|
+
}, a = {
|
|
238
|
+
id: (Date.now() + 1).toString(),
|
|
239
|
+
role: "assistant",
|
|
240
|
+
content: "",
|
|
241
|
+
isReasoning: !0,
|
|
242
|
+
isStreaming: !0
|
|
243
|
+
};
|
|
244
|
+
S((A) => [...A, i, a]), T(!0);
|
|
245
|
+
const g = new AbortController();
|
|
246
|
+
M(g);
|
|
247
|
+
try {
|
|
248
|
+
const A = {
|
|
249
|
+
messages: [i].map((H) => ({
|
|
250
|
+
role: H.role,
|
|
251
|
+
content: H.content
|
|
252
|
+
})),
|
|
253
|
+
model: m || s
|
|
254
|
+
};
|
|
255
|
+
b && (A.image = b);
|
|
256
|
+
const D = await x({ body: { action: "ASK_AI", data: A }, streamResponse: !0 });
|
|
257
|
+
if (!D.ok)
|
|
258
|
+
throw new Error(k("Failed to get AI response"));
|
|
259
|
+
const R = (h = D.body) == null ? void 0 : h.getReader();
|
|
260
|
+
if (!R) throw new Error(k("Response body is not readable"));
|
|
261
|
+
await n(R, S);
|
|
262
|
+
} catch (A) {
|
|
263
|
+
if (A.name !== "AbortError") {
|
|
264
|
+
const D = {
|
|
265
|
+
id: (Date.now() + 1).toString(),
|
|
266
|
+
role: "assistant",
|
|
267
|
+
content: k("Sorry, I encountered an error. Please try again.")
|
|
268
|
+
};
|
|
269
|
+
S((R) => [...R, D]);
|
|
270
|
+
}
|
|
271
|
+
} finally {
|
|
272
|
+
w(""), T(!1), B(null), M(null);
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
return /* @__PURE__ */ C(F, { children: [
|
|
276
|
+
/* @__PURE__ */ C(P, { className: "no-scrollbar", children: [
|
|
277
|
+
/* @__PURE__ */ C(W, { className: "gap-2 px-0", children: [
|
|
278
|
+
v.length === 0 && /* @__PURE__ */ f(
|
|
279
|
+
O,
|
|
280
|
+
{
|
|
281
|
+
icon: /* @__PURE__ */ f(nt, { size: 48, className: "text-gray-300" }),
|
|
282
|
+
title: "Start a conversation",
|
|
283
|
+
description: k("Start a conversation with the AI assistant to add/edit current page")
|
|
284
|
+
}
|
|
285
|
+
),
|
|
286
|
+
v.map(
|
|
287
|
+
(t) => t.role !== "system" && /* @__PURE__ */ f(ot, { children: t.isReasoning ? /* @__PURE__ */ C($, { isStreaming: t.isStreaming, defaultOpen: !0, children: [
|
|
288
|
+
/* @__PURE__ */ f(q, { className: "text-xs [&_p]:text-muted-foreground" }),
|
|
289
|
+
/* @__PURE__ */ f(V, { className: "p-0 text-xs", children: t.content })
|
|
290
|
+
] }) : t.isTask && !t.isTaskCompleted ? /* @__PURE__ */ f(K, { content: t.content, isLoading: t.isTaskLoading }) : /* @__PURE__ */ f(_, { from: t.role, children: /* @__PURE__ */ f(j, { className: "p-0", children: t.role === "assistant" ? /* @__PURE__ */ f(G, { className: "p-0 text-xs", children: t.content }) : /* @__PURE__ */ f("div", { className: "p-0 text-xs", children: t.userMessage || t.content }) }) }) }, t.id)
|
|
291
|
+
)
|
|
292
|
+
] }),
|
|
293
|
+
/* @__PURE__ */ f(z, {})
|
|
294
|
+
] }),
|
|
295
|
+
/* @__PURE__ */ C("div", { className: "border-gray-200 pb-2", children: [
|
|
296
|
+
/* @__PURE__ */ f(Q, { onRemove: () => c([]), isLoading: I }),
|
|
297
|
+
/* @__PURE__ */ f(it, { fallback: /* @__PURE__ */ f("div", { children: "Loading..." }), children: /* @__PURE__ */ f(
|
|
298
|
+
dt,
|
|
299
|
+
{
|
|
300
|
+
input: y,
|
|
301
|
+
setInput: w,
|
|
302
|
+
onSend: u,
|
|
303
|
+
onStop: d,
|
|
304
|
+
isLoading: I,
|
|
305
|
+
selectedLang: "",
|
|
306
|
+
currentBlock: r || N,
|
|
307
|
+
disabled: (y == null ? void 0 : y.length) === 0,
|
|
308
|
+
selectedModel: s,
|
|
309
|
+
onModelChange: e
|
|
310
|
+
}
|
|
311
|
+
) })
|
|
312
|
+
] })
|
|
313
|
+
] });
|
|
314
|
+
};
|
|
315
|
+
export {
|
|
316
|
+
bt as default
|
|
317
|
+
};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),g=require("./selected-block-display-s99Y91qI.cjs"),y=require("@chaibuilder/sdk"),L=require("lucide-react"),j=require("react"),P=require("sonner"),F=require("./ai-panel-content-MOZmNIKP.cjs"),O=require("@tanstack/react-query"),W=()=>{const{addPredefinedBlock:b}=y.useAddBlock(),H=y.useReplaceBlock(),I=y.useRemoveBlocks(),C=O.useQueryClient(),T=async(s,e)=>{if(!e)return;const r=y.getBlocksFromHTML(e);await b(r,s.parentId,s.position)},B=async(s,e)=>{if(!s.blockId||!e)return;const r=y.getBlocksFromHTML(e);await H(s.blockId,r)},v=async s=>{!s.ids||s.ids.length===0||await I(s.ids)};let f=null;const w=(s,e)=>{const r=document.getElementById("canvas-iframe");if(!r)return null;const l=r==null?void 0:r.contentDocument;if(!l)return null;l.querySelectorAll("[data-stream-canvas]").forEach(d=>d.remove());let n=null;if(s&&s!=="undefined"&&(n=l.querySelector(`[data-block-id="${s}"]`)),n||(n=l.body),!n)return null;if(f=l.createElement("div"),f.setAttribute("data-stream-canvas","true"),e!==void 0&&e>=0&&n.children){const d=Math.min(e,n.children.length);d<n.children.length?n.insertBefore(f,n.children[d]):n.appendChild(f)}else n.appendChild(f);return f},N=s=>{var n;const e=document.getElementById("canvas-iframe");if(!e)return null;const r=e==null?void 0:e.contentDocument;if(!r)return null;r.querySelectorAll("[data-stream-canvas]").forEach(d=>d.remove());const u=r.querySelector(`[data-block-id="${s}"]`);return u?(f=r.createElement("div"),f.setAttribute("data-stream-canvas","true"),(n=u.parentNode)==null||n.insertBefore(f,u.nextSibling),u.style.display="none",f):null},E=(s,e,r)=>{const l=w(e,r);if(l){l.innerHTML=s;const u=l.getBoundingClientRect(),n=document.getElementById("canvas-iframe"),d=n==null?void 0:n.contentWindow;d&&(u.top>=0&&u.bottom<=d.innerHeight||l.scrollIntoView({behavior:"smooth",block:"nearest"}))}},x=(s,e)=>{const r=N(e);r&&(r.innerHTML=s)},M=s=>{const e=s.match(/^--ACTION=(.+)--$/);if(!e)return null;let l=e[1].replace(/--/g,"").split("|");const n={type:l[0]};return l.forEach(d=>{const t=d.trim();if(t.startsWith("PARENT=")){const A=t.substring(7);n.parentId=A==="undefined"?void 0:A}else t.startsWith("POS=")?n.position=parseInt(t.substring(4)):t.startsWith("ID=")?n.blockId=t.substring(3):t.startsWith("IDS=")&&(n.ids=t.substring(4).split(",").map(A=>A.trim()))}),n};return j.useCallback(async(s,e)=>{const r=new TextDecoder;let l="",u="",n=!1,d=null;const t={isInAction:!1,currentAction:null,htmlBuffer:"",isCapturingHtml:!1},A=async m=>{const o=m.trim();if(o==="--START--"){n=!0;return}if(n){if(o==="--END--"){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),f&&(f.remove(),f=null);return}if(o.startsWith("--THINKING=")){const i=o.substring(11);e(c=>{const h=[...c],p=h[h.length-1];if(p&&p.role==="assistant"&&p.isReasoning)p.content=i,p.isStreaming=!1;else{const k={id:Date.now().toString(),role:"assistant",content:i,isReasoning:!0,isStreaming:!1};h.push(k)}return h});return}if(o.startsWith("--TASK=")){const i=o.substring(7),c=`task-${Date.now()}-${Math.random().toString(36).substr(2,9)}`,h={id:c,role:"assistant",content:i.replace(/--$/,""),isTask:!0,isTaskLoading:!0,isTaskCompleted:!1};d=c,e(p=>[...p,h]);return}if(o.startsWith("--MSG=")){const i=o.substring(6),c={id:Date.now().toString(),role:"assistant",content:i.replace(/--$/g,""),isReasoning:!1,isStreaming:!1};e(h=>[...h,c]);return}if(o.startsWith("--ACTION=")){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),t.currentAction=M(o),t.htmlBuffer="",t.isInAction=!0;return}if(o==="--ENDACTION--"){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),d&&(e(i=>i.map(c=>c.isTask?{...c,isTaskCompleted:!0}:c)),d=null),t.currentAction=null,t.htmlBuffer="",t.isInAction=!1;return}if(o==="--HTML--"){t.isCapturingHtml=!0;return}if(o==="--ENDHTML--"){t.isCapturingHtml=!1;return}if(o.startsWith("--HTML--")&&o.includes("--ENDHTML--")){const i=o.match(/^--HTML--(.+?)--ENDHTML--$/);if(i&&t.currentAction){const c=i[1];t.htmlBuffer+=c,t.currentAction.type==="ADD"?E(t.htmlBuffer,t.currentAction.parentId,t.currentAction.position):t.currentAction.type==="EDIT"&&t.currentAction.blockId&&x(t.htmlBuffer,t.currentAction.blockId)}return}t.isCapturingHtml&&t.currentAction&&(t.htmlBuffer+=m+`
|
|
2
|
+
`,t.currentAction.type==="ADD"?E(t.htmlBuffer,t.currentAction.parentId,t.currentAction.position):t.currentAction.type==="EDIT"&&t.currentAction.blockId&&x(t.htmlBuffer,t.currentAction.blockId))}},S=async(m,o)=>{try{switch(m.type){case"ADD":await T(m,o);break;case"EDIT":await B(m,o);break;case"REMOVE":await v(m);break}e(i=>i.filter(c=>!c.isTask))}catch(i){console.log(i)}};try{for(;;){const{done:m,value:o}=await s.read();if(m)break;const i=r.decode(o,{stream:!0});l+=i,u+=i;const c=u.split(`
|
|
3
|
+
`);u=c.pop()||"";for(const h of c)await A(h)}u&&await A(u),C.invalidateQueries({queryKey:["AI_USAGE"]})}catch(m){console.log(m)}},[I])},$=j.lazy(()=>Promise.resolve().then(()=>require("./ai-prompt-input-BZSjjNJd.cjs"))),V=({t:b,fetch:H,input:I,messages:C,setInput:T,isLoading:B,setMessages:v,handleStop:f,setIsLoading:w,currentBlock:N,fallbackLang:E,setCurrentBlock:x,setAbortController:M,selectedModel:s=F.getDefaultModel().id,onModelChange:e})=>{const r=y.useSelectedBlock(),[,l]=y.useSelectedBlockIds(),u=y.useBlocksHtmlForAi(),n=W(),d=async(t,A,S,m)=>{var p;if(!t||B)return;x(r);const o=u(r?{blockId:r._id,additionalCoreBlocks:["Icon"]}:{additionalCoreBlocks:["Icon"]});if(r&&!o){P.toast.error(b("Something went wrong. Please try again."));return}const i={id:Date.now().toString(),role:"user",content:g.getUserPrompt({language:E,userInput:A||t,currentHtml:o}),userMessage:t},c={id:(Date.now()+1).toString(),role:"assistant",content:"",isReasoning:!0,isStreaming:!0};v(k=>[...k,i,c]),w(!0);const h=new AbortController;M(h);try{const k={messages:[i].map(q=>({role:q.role,content:q.content})),model:m||s};S&&(k.image=S);const D=await H({body:{action:"ASK_AI",data:k},streamResponse:!0});if(!D.ok)throw new Error(b("Failed to get AI response"));const R=(p=D.body)==null?void 0:p.getReader();if(!R)throw new Error(b("Response body is not readable"));await n(R,v)}catch(k){if(k.name!=="AbortError"){const D={id:(Date.now()+1).toString(),role:"assistant",content:b("Sorry, I encountered an error. Please try again.")};v(R=>[...R,D])}}finally{T(""),w(!1),x(null),M(null)}};return a.jsxs(a.Fragment,{children:[a.jsxs(g.Conversation,{className:"no-scrollbar",children:[a.jsxs(g.ConversationContent,{className:"gap-2 px-0",children:[C.length===0&&a.jsx(g.ConversationEmptyState,{icon:a.jsx(L.Bot,{size:48,className:"text-gray-300"}),title:"Start a conversation",description:b("Start a conversation with the AI assistant to add/edit current page")}),C.map(t=>t.role!=="system"&&a.jsx(j.Fragment,{children:t.isReasoning?a.jsxs(g.Reasoning,{isStreaming:t.isStreaming,defaultOpen:!0,children:[a.jsx(g.ReasoningTrigger,{className:"text-xs [&_p]:text-muted-foreground"}),a.jsx(g.ReasoningContent,{className:"p-0 text-xs",children:t.content})]}):t.isTask&&!t.isTaskCompleted?a.jsx(g.TaskMessage,{content:t.content,isLoading:t.isTaskLoading}):a.jsx(g.Message,{from:t.role,children:a.jsx(g.MessageContent,{className:"p-0",children:t.role==="assistant"?a.jsx(g.MessageResponse,{className:"p-0 text-xs",children:t.content}):a.jsx("div",{className:"p-0 text-xs",children:t.userMessage||t.content})})})},t.id))]}),a.jsx(g.ConversationScrollButton,{})]}),a.jsxs("div",{className:"border-gray-200 pb-2",children:[a.jsx(g.SelectedBlockDisplay,{onRemove:()=>l([]),isLoading:B}),a.jsx(j.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:a.jsx($,{input:I,setInput:T,onSend:d,onStop:f,isLoading:B,selectedLang:"",currentBlock:r||N,disabled:(I==null?void 0:I.length)===0,selectedModel:s,onModelChange:e})})]})]})};exports.default=V;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { jsxs as i, Fragment as $, jsx as t } from "react/jsx-runtime";
|
|
2
|
-
import { C as G, a as H, b as Q, R as X, c as Y, d as Z, T as L, M as ee, e as te, f as ne, S as oe, g as se } from "./selected-block-display-
|
|
2
|
+
import { C as G, a as H, b as Q, R as X, c as Y, d as Z, T as L, M as ee, e as te, f as ne, S as oe, g as se } from "./selected-block-display-GXSf3y2s.js";
|
|
3
3
|
import { useTranslation as ae, useSelectedBlock as re, useSelectedBlockIds as ce, useI18nBlocks as ie, useStreamMultipleBlocksProps as le } from "@chaibuilder/sdk";
|
|
4
4
|
import { Bot as de } from "lucide-react";
|
|
5
5
|
import { lazy as v, useRef as ue, useEffect as he, Suspense as B, Fragment as ge } from "react";
|
|
6
|
-
|
|
6
|
+
import { g as me } from "./ai-panel-content-C6cH9rrC.js";
|
|
7
|
+
const fe = v(() => import("./ai-translation-prompt-DTR0wbGt.js")), pe = v(() => import("./ai-prompt-input-C6gDvvLQ.js")), be = ({
|
|
7
8
|
fetch: A,
|
|
8
9
|
input: s,
|
|
9
10
|
messages: l,
|
|
@@ -18,12 +19,12 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
|
|
|
18
19
|
abortController: u,
|
|
19
20
|
setAbortController: O,
|
|
20
21
|
setCurrentBlock: f,
|
|
21
|
-
selectedModel: p =
|
|
22
|
+
selectedModel: p = me().id,
|
|
22
23
|
onModelChange: P
|
|
23
24
|
}) => {
|
|
24
|
-
const { t: n } = ae(),
|
|
25
|
+
const { t: n } = ae(), D = ue(null), c = re(), [, I] = ce(), k = ie(), F = le(), j = () => {
|
|
25
26
|
var e;
|
|
26
|
-
(e =
|
|
27
|
+
(e = D.current) == null || e.scrollIntoView({ behavior: "smooth" });
|
|
27
28
|
};
|
|
28
29
|
he(() => {
|
|
29
30
|
j();
|
|
@@ -79,7 +80,7 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
|
|
|
79
80
|
};
|
|
80
81
|
return /* @__PURE__ */ i($, { children: [
|
|
81
82
|
/* @__PURE__ */ t("div", { className: "py-2", children: /* @__PURE__ */ t(B, { fallback: /* @__PURE__ */ t("div", { children: n("Loading...") }), children: /* @__PURE__ */ t(
|
|
82
|
-
|
|
83
|
+
fe,
|
|
83
84
|
{
|
|
84
85
|
isLoading: a,
|
|
85
86
|
selectedBlock: c,
|
|
@@ -106,9 +107,9 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
|
|
|
106
107
|
)
|
|
107
108
|
] }) }),
|
|
108
109
|
/* @__PURE__ */ i("div", { className: "border-gray-200 pb-2", children: [
|
|
109
|
-
/* @__PURE__ */ t(oe, { onRemove: () =>
|
|
110
|
+
/* @__PURE__ */ t(oe, { onRemove: () => I([]), isLoading: a }),
|
|
110
111
|
/* @__PURE__ */ t(B, { fallback: /* @__PURE__ */ t("div", { children: n("Loading...") }), children: /* @__PURE__ */ t(
|
|
111
|
-
|
|
112
|
+
pe,
|
|
112
113
|
{
|
|
113
114
|
input: s,
|
|
114
115
|
setInput: g,
|
|
@@ -126,5 +127,5 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
|
|
|
126
127
|
] });
|
|
127
128
|
};
|
|
128
129
|
export {
|
|
129
|
-
|
|
130
|
+
be as default
|
|
130
131
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),n=require("./selected-block-display-s99Y91qI.cjs"),a=require("@chaibuilder/sdk"),G=require("lucide-react"),o=require("react"),H=require("./ai-panel-content-MOZmNIKP.cjs"),Q=o.lazy(()=>Promise.resolve().then(()=>require("./ai-translation-prompt-BqXo2CLp.cjs"))),X=o.lazy(()=>Promise.resolve().then(()=>require("./ai-prompt-input-BZSjjNJd.cjs"))),Y=({fetch:v,input:c,messages:u,setInput:j,isLoading:i,handleStop:P,setMessages:y,setIsLoading:h,selectedLang:l,currentBlock:q,fallbackLang:A,abortController:x,setAbortController:E,setCurrentBlock:k,selectedModel:S=H.getDefaultModel().id,onModelChange:M})=>{const{t:s}=a.useTranslation(),O=o.useRef(null),d=a.useSelectedBlock(),[,C]=a.useSelectedBlockIds(),T=a.useI18nBlocks(),D=a.useStreamMultipleBlocksProps(),I=()=>{var t;(t=O.current)==null||t.scrollIntoView({behavior:"smooth"})};o.useEffect(()=>{I()},[u,i]);const f=async(t,m,F)=>{var b;d&&k(d);const p=(t==null?void 0:t.toLowerCase())==="translate",R={id:Date.now().toString(),role:"user",content:n.getTranslationUserPrompt({fallbackLang:A,userInput:m||t,language:l,blocks:p?T():T(l)}),userMessage:m||t||s("Translate the content")},_={id:(Date.now()+1).toString(),role:"assistant",content:"Thinking...",isReasoning:!0,isStreaming:!0};h(!0);const z=new AbortController;E(z),y(w=>[...w,R,_]),h(!0);try{const N=await v({body:{action:"ASK_AI",data:{messages:[R],initiator:p?"TRANSLATE_CONTENT":"UPDATE_CONTENT",model:F||S}},streamResponse:!0});if(!N.ok)throw new Error(s("Failed to get AI response"));const B=(b=N.body)==null?void 0:b.getReader(),U=new TextDecoder;let r="";if(!B)throw new Error(s("Response body is not readable"));for(;;){const{done:K,value:V}=await B.read();if(K)break;const W=U.decode(V,{stream:!0});r+=W,y(g=>(g[g.length-1].content=r,[...g]))}const J=JSON.parse(r==null?void 0:r.replace("```json","").replace("```",""));D(J)}catch{x==null||x.abort()}finally{h(!1),j(""),k(null)}};return e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"py-2",children:e.jsx(o.Suspense,{fallback:e.jsx("div",{children:s("Loading...")}),children:e.jsx(Q,{isLoading:i,selectedBlock:d,selectedLang:l,onClick:f})})}),e.jsx(n.Conversation,{children:e.jsxs(n.ConversationContent,{className:"gap-4 px-0",children:[u.length===0&&e.jsx(n.ConversationEmptyState,{icon:e.jsx(G.Bot,{size:48,className:"text-gray-300"}),title:s("Start a conversation with the AI assistant to translate/edit your content"),description:s("Only content can be edited in secondary languages. To edit layout, styles and more, switch to the default language.")}),u.map(t=>t.role!=="system"&&e.jsx(o.Fragment,{children:t.isReasoning?e.jsxs(n.Reasoning,{isStreaming:t.isStreaming,defaultOpen:!0,children:[e.jsx(n.ReasoningTrigger,{className:"text-xs [&_p]:text-muted-foreground"}),e.jsx(n.ReasoningContent,{className:"p-0 text-xs",children:t.content})]}):t.isTask?e.jsx(n.TaskMessage,{content:t.content,isLoading:t.isTaskLoading}):e.jsx(n.Message,{from:t.role,children:e.jsx(n.MessageContent,{className:"p-0",children:t.role==="assistant"?e.jsx(n.MessageResponse,{className:"p-0 text-xs",children:t.content}):e.jsx("div",{className:"p-0 text-xs",children:t.userMessage||t.content})})})},t.id))]})}),e.jsxs("div",{className:"border-gray-200 pb-2",children:[e.jsx(n.SelectedBlockDisplay,{onRemove:()=>C([]),isLoading:i}),e.jsx(o.Suspense,{fallback:e.jsx("div",{children:s("Loading...")}),children:e.jsx(X,{input:c,setInput:j,onSend:f,onStop:P,isLoading:i,selectedLang:l,currentBlock:d||q,disabled:(c==null?void 0:c.length)===0,selectedModel:S,onModelChange:M})})]})]})};exports.default=Y;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),r=require("./selected-block-display-s99Y91qI.cjs"),d=require("react"),R=require("cmdk"),b=require("lucide-react"),ye=require("@radix-ui/react-dialog"),Ne=require("@radix-ui/react-dropdown-menu"),we=require("@radix-ui/react-hover-card"),J=require("class-variance-authority"),Se=require("@radix-ui/react-select"),Ie=require("@chaibuilder/sdk"),U=require("./ai-panel-content-MOZmNIKP.cjs");function q(t){const s=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const a in t)if(a!=="default"){const n=Object.getOwnPropertyDescriptor(t,a);Object.defineProperty(s,a,n.get?n:{enumerable:!0,get:()=>t[a]})}}return s.default=t,Object.freeze(s)}const p=q(d),z=q(ye),w=q(Ne),G=q(we),I=q(Se),Ce=z.Root,ke=z.Trigger,Re=z.Portal,Q=p.forwardRef(({className:t,...s},a)=>e.jsx(z.Overlay,{ref:a,className:r.cn("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...s}));Q.displayName=z.Overlay.displayName;const Z=p.forwardRef(({className:t,children:s,...a},n)=>e.jsxs(Re,{children:[e.jsx(Q,{}),e.jsxs(z.Content,{ref:n,className:r.cn("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",t),...a,children:[s,e.jsxs(z.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[e.jsx(b.X,{className:"h-4 w-4"}),e.jsx("span",{className:"sr-only",children:"Close"})]})]})]}));Z.displayName=z.Content.displayName;const ee=p.forwardRef(({className:t,...s},a)=>e.jsx(z.Title,{ref:a,className:r.cn("text-lg font-semibold leading-none tracking-tight",t),...s}));ee.displayName=z.Title.displayName;const De=p.forwardRef(({className:t,...s},a)=>e.jsx(z.Description,{ref:a,className:r.cn("text-sm text-muted-foreground",t),...s}));De.displayName=z.Description.displayName;const te=p.forwardRef(({className:t,...s},a)=>e.jsx(R.Command,{ref:a,className:r.cn("flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",t),...s}));te.displayName=R.Command.displayName;const se=p.forwardRef(({className:t,...s},a)=>e.jsxs("div",{className:"flex items-center border-b px-3","cmdk-input-wrapper":"",children:[e.jsx(b.Search,{className:"mr-2 h-4 w-4 shrink-0 opacity-50"}),e.jsx(R.Command.Input,{ref:a,className:r.cn("flex h-11 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",t),...s})]}));se.displayName=R.Command.Input.displayName;const ae=p.forwardRef(({className:t,...s},a)=>e.jsx(R.Command.List,{ref:a,className:r.cn("max-h-[300px] overflow-y-auto overflow-x-hidden",t),...s}));ae.displayName=R.Command.List.displayName;const ze=p.forwardRef((t,s)=>e.jsx(R.Command.Empty,{ref:s,className:"py-6 text-center text-sm",...t}));ze.displayName=R.Command.Empty.displayName;const ne=p.forwardRef(({className:t,...s},a)=>e.jsx(R.Command.Group,{ref:a,className:r.cn("overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",t),...s}));ne.displayName=R.Command.Group.displayName;const Pe=p.forwardRef(({className:t,...s},a)=>e.jsx(R.Command.Separator,{ref:a,className:r.cn("-mx-1 h-px bg-border",t),...s}));Pe.displayName=R.Command.Separator.displayName;const oe=p.forwardRef(({className:t,...s},a)=>e.jsx(R.Command.Item,{ref:a,className:r.cn("relative flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected='true']:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",t),...s}));oe.displayName=R.Command.Item.displayName;const Te=w.Root,Le=w.Trigger,Ae=p.forwardRef(({className:t,inset:s,children:a,...n},l)=>e.jsxs(w.SubTrigger,{ref:l,className:r.cn("flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",s&&"pl-8",t),...n,children:[a,e.jsx(b.ChevronRight,{className:"ml-auto"})]}));Ae.displayName=w.SubTrigger.displayName;const Me=p.forwardRef(({className:t,...s},a)=>e.jsx(w.SubContent,{ref:a,className:r.cn("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-dropdown-menu-content-transform-origin]",t),...s}));Me.displayName=w.SubContent.displayName;const re=p.forwardRef(({className:t,sideOffset:s=4,...a},n)=>e.jsx(w.Portal,{children:e.jsx(w.Content,{ref:n,sideOffset:s,className:r.cn("z-50 max-h-[var(--radix-dropdown-menu-content-available-height)] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-dropdown-menu-content-transform-origin]",t),...a})}));re.displayName=w.Content.displayName;const ie=p.forwardRef(({className:t,inset:s,...a},n)=>e.jsx(w.Item,{ref:n,className:r.cn("relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",s&&"pl-8",t),...a}));ie.displayName=w.Item.displayName;const _e=p.forwardRef(({className:t,children:s,checked:a,...n},l)=>e.jsxs(w.CheckboxItem,{ref:l,className:r.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:a,...n,children:[e.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:e.jsx(w.ItemIndicator,{children:e.jsx(b.Check,{className:"h-4 w-4"})})}),s]}));_e.displayName=w.CheckboxItem.displayName;const Oe=p.forwardRef(({className:t,children:s,...a},n)=>e.jsxs(w.RadioItem,{ref:n,className:r.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...a,children:[e.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:e.jsx(w.ItemIndicator,{children:e.jsx(b.Circle,{className:"h-2 w-2 fill-current"})})}),s]}));Oe.displayName=w.RadioItem.displayName;const Ue=p.forwardRef(({className:t,inset:s,...a},n)=>e.jsx(w.Label,{ref:n,className:r.cn("px-2 py-1.5 text-sm font-semibold",s&&"pl-8",t),...a}));Ue.displayName=w.Label.displayName;const qe=p.forwardRef(({className:t,...s},a)=>e.jsx(w.Separator,{ref:a,className:r.cn("-mx-1 my-1 h-px bg-muted",t),...s}));qe.displayName=w.Separator.displayName;const Be=G.Root,Ee=G.Trigger,le=p.forwardRef(({className:t,align:s="center",sideOffset:a=4,...n},l)=>e.jsx(G.Content,{ref:l,align:s,sideOffset:a,className:r.cn("z-50 w-64 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-hover-card-content-transform-origin]",t),...n}));le.displayName=G.Content.displayName;const Fe=p.forwardRef(({className:t,type:s,...a},n)=>e.jsx("input",{type:s,className:r.cn("flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-base ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",t),ref:n,...a}));Fe.displayName="Input";const ce=p.forwardRef(({className:t,...s},a)=>e.jsx("textarea",{className:r.cn("flex min-h-[80px] w-full rounded-md border border-input bg-background px-3 py-2 text-base ring-offset-background placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",t),ref:a,...s}));ce.displayName="Textarea";function Ge({className:t,...s}){return e.jsx("div",{"data-slot":"input-group",role:"group",className:r.cn("group/input-group border-input dark:bg-input/30 shadow-xs relative flex w-full items-center rounded-md border outline-none transition-[color,box-shadow]","h-9 has-[>textarea]:h-auto","has-[>[data-align=inline-start]]:[&>input]:pl-2","has-[>[data-align=inline-end]]:[&>input]:pr-2","has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3","has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3","has-[[data-slot=input-group-control]:focus-visible]:ring-ring has-[[data-slot=input-group-control]:focus-visible]:ring-1","has-[[data-slot][aria-invalid=true]]:ring-destructive/20 has-[[data-slot][aria-invalid=true]]:border-destructive dark:has-[[data-slot][aria-invalid=true]]:ring-destructive/40",t),...s})}const Ve=J.cva("text-muted-foreground flex h-auto cursor-text select-none items-center justify-center gap-2 py-1.5 text-sm font-medium group-data-[disabled=true]/input-group:opacity-50 [&>kbd]:rounded-[calc(var(--radius)-5px)] [&>svg:not([class*='size-'])]:size-4",{variants:{align:{"inline-start":"order-first pl-3 has-[>button]:ml-[-0.45rem] has-[>kbd]:ml-[-0.35rem]","inline-end":"order-last pr-3 has-[>button]:mr-[-0.4rem] has-[>kbd]:mr-[-0.35rem]","block-start":"[.border-b]:pb-3 order-first w-full justify-start px-3 pt-3 group-has-[>input]/input-group:pt-2.5","block-end":"[.border-t]:pt-3 order-last w-full justify-start px-3 pb-3 group-has-[>input]/input-group:pb-2.5"}},defaultVariants:{align:"inline-start"}});function de({className:t,align:s="inline-start",...a}){return e.jsx("div",{role:"group","data-slot":"input-group-addon","data-align":s,className:r.cn(Ve({align:s}),t),onClick:n=>{var l,g;n.target.closest("button")||(g=(l=n.currentTarget.parentElement)==null?void 0:l.querySelector("input"))==null||g.focus()},...a})}const He=J.cva("flex items-center gap-2 text-sm shadow-none",{variants:{size:{xs:"h-6 gap-1 rounded-[calc(var(--radius)-5px)] px-2 has-[>svg]:px-2 [&>svg:not([class*='size-'])]:size-3.5",sm:"h-8 gap-1.5 rounded-md px-2.5 has-[>svg]:px-2.5","icon-xs":"size-6 rounded-[calc(var(--radius)-5px)] p-0 has-[>svg]:p-0","icon-sm":"size-8 p-0 has-[>svg]:p-0"}},defaultVariants:{size:"xs"}});function ue({className:t,type:s="button",variant:a="ghost",size:n="xs",...l}){return e.jsx(r.Button,{type:s,"data-size":n,variant:a,className:r.cn(He({size:n}),t),...l})}function We({className:t,...s}){return e.jsx(ce,{"data-slot":"input-group-control",className:r.cn("flex-1 resize-none rounded-none border-0 bg-transparent py-3 shadow-none focus-visible:ring-0 dark:bg-transparent",t),...s})}const Ke=p.forwardRef(({className:t,children:s,...a},n)=>e.jsxs(I.Trigger,{ref:n,className:r.cn("flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background data-[placeholder]:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1",t),...a,children:[s,e.jsx(I.Icon,{asChild:!0,children:e.jsx(b.ChevronDown,{className:"h-4 w-4 opacity-50"})})]}));Ke.displayName=I.Trigger.displayName;const me=p.forwardRef(({className:t,...s},a)=>e.jsx(I.ScrollUpButton,{ref:a,className:r.cn("flex cursor-default items-center justify-center py-1",t),...s,children:e.jsx(b.ChevronUp,{className:"h-4 w-4"})}));me.displayName=I.ScrollUpButton.displayName;const pe=p.forwardRef(({className:t,...s},a)=>e.jsx(I.ScrollDownButton,{ref:a,className:r.cn("flex cursor-default items-center justify-center py-1",t),...s,children:e.jsx(b.ChevronDown,{className:"h-4 w-4"})}));pe.displayName=I.ScrollDownButton.displayName;const Xe=p.forwardRef(({className:t,children:s,position:a="popper",...n},l)=>e.jsx(I.Portal,{children:e.jsxs(I.Content,{ref:l,className:r.cn("relative z-50 max-h-[--radix-select-content-available-height] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-select-content-transform-origin]",a==="popper"&&"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",t),position:a,...n,children:[e.jsx(me,{}),e.jsx(I.Viewport,{className:r.cn("p-1",a==="popper"&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"),children:s}),e.jsx(pe,{})]})}));Xe.displayName=I.Content.displayName;const Ye=p.forwardRef(({className:t,...s},a)=>e.jsx(I.Label,{ref:a,className:r.cn("py-1.5 pl-8 pr-2 text-sm font-semibold",t),...s}));Ye.displayName=I.Label.displayName;const $e=p.forwardRef(({className:t,children:s,...a},n)=>e.jsxs(I.Item,{ref:n,className:r.cn("relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...a,children:[e.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:e.jsx(I.ItemIndicator,{children:e.jsx(b.Check,{className:"h-4 w-4"})})}),e.jsx(I.ItemText,{children:s})]}));$e.displayName=I.Item.displayName;const Je=p.forwardRef(({className:t,...s},a)=>e.jsx(I.Separator,{ref:a,className:r.cn("-mx-1 my-1 h-px bg-muted",t),...s}));Je.displayName=I.Separator.displayName;const Qe="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";let Ze=(t=21)=>{let s="",a=crypto.getRandomValues(new Uint8Array(t|=0));for(;t--;)s+=Qe[a[t]&63];return s};const et=d.createContext(null),tt=d.createContext(null),fe=()=>d.useContext(et),st=()=>d.useContext(tt),xe=d.createContext(null),V=()=>{const t=st(),s=d.useContext(xe),a=t??s;if(!a)throw new Error("usePromptInputAttachments must be used within a PromptInput or PromptInputProvider");return a};function at({data:t,className:s,...a}){var v;const n=V(),l=t.filename||"",u=((v=t.mediaType)!=null&&v.startsWith("image/")&&t.url?"image":"file")==="image",y=l||(u?"Image":"Attachment");return e.jsxs(gt,{children:[e.jsx(Ee,{asChild:!0,children:e.jsxs("div",{className:r.cn("group relative flex h-8 cursor-default select-none items-center gap-1.5 rounded-md border border-border px-1.5 text-sm font-medium transition-all hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",s),...a,children:[e.jsxs("div",{className:"relative size-5 shrink-0",children:[e.jsx("div",{className:"absolute inset-0 flex size-5 items-center justify-center overflow-hidden rounded bg-background transition-opacity group-hover:opacity-0",children:u?e.jsx("img",{alt:l||"attachment",className:"size-5 object-cover",height:20,src:t.url,width:20}):e.jsx("div",{className:"flex size-5 items-center justify-center text-muted-foreground",children:e.jsx(b.PaperclipIcon,{className:"size-3"})})}),e.jsxs(r.Button,{"aria-label":"Remove attachment",className:"absolute inset-0 size-5 cursor-pointer rounded p-0 opacity-0 transition-opacity group-hover:pointer-events-auto group-hover:opacity-100 [&>svg]:size-2.5",onClick:k=>{k.stopPropagation(),n.remove(t.id)},type:"button",variant:"ghost",children:[e.jsx(b.XIcon,{}),e.jsx("span",{className:"sr-only",children:"Remove"})]})]}),e.jsx("span",{className:"flex-1 truncate",children:y})]},t.id)}),e.jsx(ht,{className:"w-auto p-2",children:e.jsxs("div",{className:"w-auto space-y-3",children:[u&&e.jsx("div",{className:"flex max-h-96 w-96 items-center justify-center overflow-hidden rounded-md border",children:e.jsx("img",{alt:l||"attachment preview",className:"max-h-full max-w-full object-contain",height:384,src:t.url,width:448})}),e.jsx("div",{className:"flex items-center gap-2.5",children:e.jsxs("div",{className:"min-w-0 flex-1 space-y-1 px-0.5",children:[e.jsx("h4",{className:"truncate text-sm font-semibold leading-none",children:l||(u?"Image":"Attachment")}),t.mediaType&&e.jsx("p",{className:"truncate font-mono text-xs text-muted-foreground",children:t.mediaType})]})})]})})]})}function nt({children:t,className:s,...a}){const n=V();return n.files.length?e.jsx("div",{className:r.cn("flex flex-wrap items-center gap-2 p-3",s),...a,children:n.files.map(l=>e.jsx(d.Fragment,{children:t(l)},l.id))}):null}const ot=({label:t="Add photos or files",...s})=>{const a=V();return e.jsxs(ie,{...s,onSelect:n=>{n.preventDefault(),a.openFileDialog()},children:[e.jsx(b.ImageIcon,{className:"mr-2 size-4"})," ",t]})},rt=({className:t,accept:s,multiple:a,globalDrop:n,syncHiddenInput:l,maxFiles:g,maxFileSize:u,onError:y,onSubmit:v,children:k,...T})=>{const o=fe(),c=!!o,m=d.useRef(null),P=d.useRef(null),C=d.useRef(null);d.useEffect(()=>{var N;const i=(N=P.current)==null?void 0:N.closest("form");i instanceof HTMLFormElement&&(C.current=i)},[]);const[D,A]=d.useState([]),j=c?o.attachments.files:D,M=d.useCallback(()=>{var i;(i=m.current)==null||i.click()},[]),B=d.useCallback(i=>!s||s.trim()===""?!0:s.includes("image/*")?i.type.startsWith("image/"):!0,[s]),E=d.useCallback(i=>{const N=Array.from(i),h=N.filter(S=>B(S));if(N.length&&h.length===0){y==null||y({code:"accept",message:"No files match the accepted types."});return}const x=S=>u?S.size<=u:!0,f=h.filter(x);if(h.length>0&&f.length===0){y==null||y({code:"max_file_size",message:"All files exceed the maximum size."});return}A(S=>{const _=typeof g=="number"?Math.max(0,g-S.length):void 0,je=typeof _=="number"?f.slice(0,_):f;typeof _=="number"&&f.length>_&&(y==null||y({code:"max_files",message:"Too many files. Some were not added."}));const Y=[];for(const H of je)Y.push({id:Ze(),type:"file",url:URL.createObjectURL(H),mediaType:H.type,filename:H.name});return S.concat(Y)})},[B,g,u,y]),L=c?i=>o.attachments.add(i):E,O=c?i=>o.attachments.remove(i):i=>A(N=>{const h=N.find(x=>x.id===i);return h!=null&&h.url&&URL.revokeObjectURL(h.url),N.filter(x=>x.id!==i)}),F=c?()=>o.attachments.clear():()=>A(i=>{for(const N of i)N.url&&URL.revokeObjectURL(N.url);return[]}),K=c?()=>o.attachments.openFileDialog():M;d.useEffect(()=>{c&&o.__registerFileInput(m,()=>{var i;return(i=m.current)==null?void 0:i.click()})},[c,o]),d.useEffect(()=>{l&&m.current&&j.length===0&&(m.current.value="")},[j,l]),d.useEffect(()=>{const i=C.current;if(!i)return;const N=x=>{var f,S;(S=(f=x.dataTransfer)==null?void 0:f.types)!=null&&S.includes("Files")&&x.preventDefault()},h=x=>{var f,S,_;(S=(f=x.dataTransfer)==null?void 0:f.types)!=null&&S.includes("Files")&&x.preventDefault(),(_=x.dataTransfer)!=null&&_.files&&x.dataTransfer.files.length>0&&L(x.dataTransfer.files)};return i.addEventListener("dragover",N),i.addEventListener("drop",h),()=>{i.removeEventListener("dragover",N),i.removeEventListener("drop",h)}},[L]),d.useEffect(()=>{if(!n)return;const i=h=>{var x,f;(f=(x=h.dataTransfer)==null?void 0:x.types)!=null&&f.includes("Files")&&h.preventDefault()},N=h=>{var x,f,S;(f=(x=h.dataTransfer)==null?void 0:x.types)!=null&&f.includes("Files")&&h.preventDefault(),(S=h.dataTransfer)!=null&&S.files&&h.dataTransfer.files.length>0&&L(h.dataTransfer.files)};return document.addEventListener("dragover",i),document.addEventListener("drop",N),()=>{document.removeEventListener("dragover",i),document.removeEventListener("drop",N)}},[L,n]),d.useEffect(()=>()=>{if(!c)for(const i of j)i.url&&URL.revokeObjectURL(i.url)},[c,j]);const ge=i=>{i.currentTarget.files&&L(i.currentTarget.files)},he=async i=>{const h=await(await fetch(i)).blob();return new Promise((x,f)=>{const S=new FileReader;S.onloadend=()=>x(S.result),S.onerror=f,S.readAsDataURL(h)})},be=d.useMemo(()=>({files:j.map(i=>({...i,id:i.id})),add:L,remove:O,clear:F,openFileDialog:K,fileInputRef:m}),[j,L,O,F,K]),ve=i=>{i.preventDefault();const N=i.currentTarget,h=c?o.textInput.value:new FormData(N).get("message")||"";c||N.reset(),Promise.all(j.map(async({id:x,...f})=>f.url&&f.url.startsWith("blob:")?{...f,url:await he(f.url)}:f)).then(x=>{try{const f=v({text:h,files:x},i);f instanceof Promise?f.then(()=>{F(),c&&o.textInput.clear()}).catch(()=>{}):(F(),c&&o.textInput.clear())}catch{}})},X=e.jsxs(e.Fragment,{children:[e.jsx("span",{"aria-hidden":"true",className:"hidden",ref:P}),e.jsx("input",{accept:s,"aria-label":"Upload files",className:"hidden",multiple:a,onChange:ge,ref:m,title:"Upload files",type:"file"}),e.jsx("form",{className:r.cn("w-full",t),onSubmit:ve,...T,children:e.jsx(Ge,{className:"overflow-hidden",children:k})})]});return c?X:e.jsx(xe.Provider,{value:be,children:X})},it=({onChange:t,className:s,placeholder:a="What would you like to know?",...n})=>{const l=fe(),g=V(),[u,y]=d.useState(!1),v=o=>{if(o.key==="Enter"){if(u||o.nativeEvent.isComposing||o.shiftKey)return;o.preventDefault();const c=o.currentTarget.form,m=c==null?void 0:c.querySelector('button[type="submit"]');if(m!=null&&m.disabled)return;c==null||c.requestSubmit()}if(o.key==="Backspace"&&o.currentTarget.value===""&&g.files.length>0){o.preventDefault();const c=g.files.at(-1);c&&g.remove(c.id)}},k=o=>{var P;const c=(P=o.clipboardData)==null?void 0:P.items;if(!c)return;const m=[];for(const C of c)if(C.kind==="file"){const D=C.getAsFile();D&&m.push(D)}m.length>0&&(o.preventDefault(),g.add(m))},T=l?{value:l.textInput.value,onChange:o=>{l.textInput.setInput(o.currentTarget.value),t==null||t(o)}}:{onChange:t};return e.jsx(We,{className:r.cn("field-sizing-content max-h-48 min-h-16",s),name:"message",onCompositionEnd:()=>y(!1),onCompositionStart:()=>y(!0),onKeyDown:v,onPaste:k,placeholder:a,...n,...T})},lt=({className:t,...s})=>e.jsx(de,{align:"block-end",className:r.cn("order-first flex-wrap gap-1",t),...s}),ct=({className:t,...s})=>e.jsx(de,{align:"block-end",className:r.cn("justify-between gap-1",t),...s}),dt=({className:t,...s})=>e.jsx("div",{className:r.cn("flex items-center gap-1",t),...s}),W=({variant:t="ghost",className:s,size:a,...n})=>{const l=a??(d.Children.count(n.children)>1?"sm":"icon-sm");return e.jsx(ue,{className:r.cn(s),size:l,type:"button",variant:t,...n})},ut=t=>e.jsx(Te,{...t}),mt=({className:t,children:s,...a})=>e.jsx(Le,{asChild:!0,children:e.jsx(W,{className:t,...a,children:s??e.jsx(b.PlusIcon,{className:"size-4"})})}),pt=({className:t,...s})=>e.jsx(re,{align:"start",className:r.cn(t),...s}),ft=({className:t,variant:s="default",size:a="icon-sm",status:n,children:l,...g})=>{let u=e.jsx(b.CornerDownLeftIcon,{className:"size-4"});return n==="submitted"?u=e.jsx(b.Loader2Icon,{className:"size-4 animate-spin"}):n==="streaming"?u=e.jsx(b.SquareIcon,{className:"size-4"}):n==="error"&&(u=e.jsx(b.XIcon,{className:"size-4"})),e.jsx(ue,{"aria-label":"Submit",className:r.cn(t),size:a,type:"submit",variant:s,...g,children:l??u})},xt=({className:t,textareaRef:s,onTranscriptionChange:a,...n})=>{const[l,g]=d.useState(!1),[u,y]=d.useState(null),v=d.useRef(null);d.useEffect(()=>{if(typeof window<"u"&&("SpeechRecognition"in window||"webkitSpeechRecognition"in window)){const T=window.SpeechRecognition||window.webkitSpeechRecognition,o=new T;o.continuous=!0,o.interimResults=!0,o.lang="en-US",o.onstart=()=>{g(!0)},o.onend=()=>{g(!1)},o.onresult=c=>{var P;let m="";for(let C=c.resultIndex;C<c.results.length;C++){const D=c.results[C];D.isFinal&&(m+=((P=D[0])==null?void 0:P.transcript)??"")}if(m&&(s!=null&&s.current)){const C=s.current,D=C.value,A=D+(D?" ":"")+m;C.value=A,C.dispatchEvent(new Event("input",{bubbles:!0})),a==null||a(A)}},o.onerror=c=>{console.error("Speech recognition error:",c.error),g(!1)},v.current=o,y(o)}return()=>{v.current&&v.current.stop()}},[s,a]);const k=d.useCallback(()=>{u&&(l?u.stop():u.start())},[u,l]);return e.jsx(W,{className:r.cn("relative transition-all duration-200",l&&"animate-pulse bg-accent text-accent-foreground",t),disabled:!u,onClick:k,...n,children:e.jsx(b.MicIcon,{className:"size-4"})})},gt=({openDelay:t=0,closeDelay:s=0,...a})=>e.jsx(Be,{closeDelay:s,openDelay:t,...a}),ht=({align:t="start",...s})=>e.jsx(le,{align:t,...s}),bt=t=>e.jsx(Ce,{...t}),vt=t=>e.jsx(ke,{...t}),jt=({className:t,children:s,title:a="Model Selector",...n})=>e.jsxs(Z,{className:r.cn("p-0",t),...n,children:[e.jsx(ee,{className:"sr-only",children:a}),e.jsx(te,{className:"**:data-[slot=command-input-wrapper]:h-auto",children:s})]}),yt=({className:t,...s})=>e.jsx(se,{className:r.cn("h-auto py-3.5",t),...s}),Nt=t=>e.jsx(ae,{...t}),wt=t=>e.jsx(ne,{...t}),St=t=>e.jsx(oe,{...t}),It=({provider:t,className:s,...a})=>e.jsx("img",{...a,alt:`${t} logo`,className:r.cn("size-3 dark:invert",s),height:12,src:`https://models.dev/logos/${t}.svg`,width:12}),Ct=({className:t,...s})=>e.jsx("span",{className:r.cn("flex-1 truncate text-left",t),...s}),kt=({selectedModel:t,onModelChange:s,disabled:a=!1})=>{const[n,l]=d.useState(!1),[g,u]=d.useState(""),y=U.getModelById(t)||U.getDefaultModel(),k=U.AI_MODELS.filter(o=>o.name.toLowerCase().includes(g.toLowerCase())||o.provider.toLowerCase().includes(g.toLowerCase())).reduce((o,c)=>(o[c.provider]||(o[c.provider]=[]),o[c.provider].push(c),o),{}),T=o=>{s(o),l(!1),u("")};return e.jsxs(bt,{open:n,onOpenChange:l,children:[e.jsx(vt,{asChild:!0,children:e.jsxs(r.Button,{variant:"outline",size:"sm",disabled:a,className:"h-8 gap-1 px-2 text-xs",children:[e.jsx(b.Cpu,{size:14}),e.jsx("span",{className:"max-w-20 truncate",children:y.name})]})}),e.jsxs(jt,{className:"w-96 p-0",children:[e.jsx(yt,{placeholder:"Search models...",value:g,onValueChange:u}),e.jsx(Nt,{children:Object.entries(k).map(([o,c])=>e.jsx(wt,{heading:o.charAt(0).toUpperCase()+o.slice(1),children:c.map(m=>e.jsxs(St,{value:m.id,onSelect:()=>T(m.id),className:"flex cursor-pointer items-center gap-2 p-2",children:[e.jsx(It,{provider:m.provider}),e.jsxs("div",{className:"flex flex-1 flex-col",children:[e.jsx(Ct,{children:m.name}),e.jsx("span",{className:"text-xs text-muted-foreground",children:m.description})]}),t===m.id&&e.jsx("div",{className:"h-2 w-2 rounded-full bg-blue-500"})]},m.id))},o))})]})]})},$="chai-ai-selected-model",Rt=({input:t,setInput:s,onSend:a,onStop:n,isLoading:l,disabled:g,selectedLang:u,selectedModel:y=U.getDefaultModel().id,onModelChange:v})=>{const{t:k}=Ie.useTranslation(),[T,o]=d.useState(y),[c,m]=d.useState(null),P=d.useRef(null),[C,D]=d.useState(!1);d.useEffect(()=>{if(!u){const j=localStorage.getItem($);if(j)o(j),v==null||v(j);else{const M=U.getDefaultModel().id;o(M),v==null||v(M)}}},[u,v]);const A=j=>{var E;const M=j.files.find(L=>{var O;return(O=L.mediaType)==null?void 0:O.startsWith("image/")}),B=(M==null?void 0:M.url)||c;a((E=j.text)==null?void 0:E.trim(),void 0,B,T),m(null)};return e.jsx("div",{className:"relative",children:e.jsx("div",{className:"border-gray-20 rounded-lg border",children:e.jsxs(rt,{onSubmit:A,accept:"image/*",className:"flex h-auto w-full flex-col",children:[e.jsx(lt,{className:"p-0",children:e.jsx(nt,{className:"pb-0",children:j=>e.jsx(at,{className:"text-xs",data:j})})}),e.jsx(it,{ref:P,value:t,onChange:j=>s(j.target.value),placeholder:k(u?"Ask to update content":"Ask me anything..."),disabled:l,className:"max-h-[200px] min-h-[60px] w-full",rows:3}),e.jsxs(ct,{children:[u?e.jsx("div",{}):e.jsxs(dt,{children:[e.jsxs(ut,{children:[e.jsx(mt,{disabled:l,children:e.jsx(b.Paperclip,{size:16})}),e.jsx(pt,{children:e.jsx(ot,{})})]}),e.jsx(xt,{textareaRef:P,onTranscriptionChange:s,disabled:l}),e.jsx(kt,{selectedModel:T,onModelChange:j=>{o(j),v==null||v(j),localStorage.setItem($,j)},disabled:l}),e.jsxs(W,{className:"hidden",size:"sm",onClick:()=>D(!C),variant:C?"default":"ghost",children:[e.jsx(b.GlobeIcon,{size:16}),e.jsx("span",{children:"Search"})]})]}),l?e.jsxs("button",{onClick:n,className:"z-50 flex items-center gap-x-1 rounded-md bg-red-500 p-1.5 text-white transition-colors hover:bg-red-600",title:k("Stop generation"),children:[e.jsx(b.Square,{size:16})," ",e.jsx("span",{className:"text-xs",children:k("Stop")})]}):e.jsx(ft,{disabled:!t.trim()||g,children:e.jsx(b.Send,{size:16})})]})]})})})};exports.default=Rt;
|