@inkeep/agents-ui 0.0.0-dev-20260506222442 → 0.0.0-dev-20260506225821
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/primitives/atoms/icons/built-in-icons.cjs +1 -1
- package/dist/primitives/atoms/icons/built-in-icons.d.ts +4 -1
- package/dist/primitives/atoms/icons/built-in-icons.js +94 -91
- package/dist/primitives/atoms/icons/collections/pi.cjs +1 -1
- package/dist/primitives/atoms/icons/collections/pi.d.ts +3 -0
- package/dist/primitives/atoms/icons/collections/pi.js +82 -37
- package/dist/primitives/atoms/icons/inkeep-default-icons.cjs +1 -1
- package/dist/primitives/atoms/icons/inkeep-default-icons.js +4 -1
- package/dist/primitives/components/embedded-chat/file-upload-input.cjs +1 -1
- package/dist/primitives/components/embedded-chat/file-upload-input.d.ts +0 -1
- package/dist/primitives/components/embedded-chat/file-upload-input.js +346 -207
- package/dist/primitives/components/embedded-chat.js +6 -1
- package/dist/primitives/components/tagline-logo-icon.js +50 -9
- package/dist/primitives/hooks/use-initial-conversation.js +4 -1
- package/dist/primitives/hooks/use-input-notification.js +9 -9
- package/dist/styled/components/embedded-chat/image-preview-modal.js +9 -2
- package/dist/styled/components/embedded-chat.js +14 -2
- package/dist/styled/components/embedded-search.js +7 -1
- package/dist/types/icons/built-in.d.ts +1 -1
- package/dist/types/icons/custom.d.ts +3 -0
- package/package.json +1 -1
|
@@ -1,65 +1,205 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import { jsx as a, jsxs as
|
|
3
|
-
import
|
|
4
|
-
import { CustomIcon as
|
|
5
|
-
import { useImagePreview as
|
|
6
|
-
import { useMessage as
|
|
7
|
-
import { useChat as
|
|
8
|
-
import { useFileUploadApi as
|
|
9
|
-
import { dataAttr as
|
|
10
|
-
import { composeEventHandlers as
|
|
2
|
+
import { jsx as a, jsxs as j } from "react/jsx-runtime";
|
|
3
|
+
import C, { useState as h, useEffect as E, useMemo as w } from "react";
|
|
4
|
+
import { CustomIcon as v } from "../../atoms/icons/custom-icon.js";
|
|
5
|
+
import { useImagePreview as I } from "../../providers/image-preview-provider.js";
|
|
6
|
+
import { useMessage as k } from "../../providers/message-provider.js";
|
|
7
|
+
import { useChat as c } from "./chat-provider.js";
|
|
8
|
+
import { useFileUploadApi as d, FileUploadRoot as N } from "../../atoms/file-upload.js";
|
|
9
|
+
import { dataAttr as g } from "../../utils/misc.js";
|
|
10
|
+
import { composeEventHandlers as r } from "../../utils/compose-event-handlers.js";
|
|
11
11
|
import { ikp as o } from "../factory.js";
|
|
12
|
-
import { useInkeepConfig as
|
|
13
|
-
const
|
|
12
|
+
import { useInkeepConfig as T } from "../../providers/config-provider.js";
|
|
13
|
+
const L = {
|
|
14
14
|
"application/pdf": "filePdf",
|
|
15
15
|
"text/plain": "fileText",
|
|
16
16
|
"text/markdown": "fileMarkdown",
|
|
17
17
|
"text/html": "fileHtml",
|
|
18
18
|
"text/csv": "fileCsv",
|
|
19
19
|
"text/x-log": "fileLog",
|
|
20
|
-
"application/json": "fileJson"
|
|
20
|
+
"application/json": "fileJson",
|
|
21
|
+
"text/x-sql": "fileSql",
|
|
22
|
+
"application/x-sql": "fileSql",
|
|
23
|
+
"text/x-script.python": "filePy",
|
|
24
|
+
"text/x-python": "filePy",
|
|
25
|
+
"text/x-python-script": "filePy"
|
|
21
26
|
};
|
|
22
|
-
function
|
|
23
|
-
return
|
|
27
|
+
function F(t) {
|
|
28
|
+
return t.startsWith("image/");
|
|
24
29
|
}
|
|
25
|
-
const
|
|
30
|
+
const _ = {
|
|
31
|
+
// Images
|
|
26
32
|
"image/png": [".png"],
|
|
27
33
|
"image/jpeg": [".jpg", ".jpeg"],
|
|
28
34
|
"image/webp": [".webp"],
|
|
35
|
+
// PDF
|
|
29
36
|
"application/pdf": [".pdf"],
|
|
30
|
-
|
|
31
|
-
"text/
|
|
32
|
-
"text/html": [".html"],
|
|
33
|
-
"text/csv": [".csv"],
|
|
37
|
+
// Plain text & logs
|
|
38
|
+
"text/plain": [".txt", ".text", ".bat", ".cfg", ".conf", ".def", ".dic", ".in", ".list"],
|
|
34
39
|
"text/x-log": [".log"],
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
+
// Markup & web
|
|
41
|
+
"text/markdown": [".md", ".markdown"],
|
|
42
|
+
"text/html": [".html", ".htm"],
|
|
43
|
+
"text/csv": [".csv"],
|
|
44
|
+
"text/xml": [".xml"],
|
|
45
|
+
"text/css": [".css"],
|
|
46
|
+
// Data formats
|
|
47
|
+
"application/json": [".json"],
|
|
48
|
+
"application/yaml": [".yaml", ".yml"],
|
|
49
|
+
"application/x-yaml": [".yaml", ".yml"],
|
|
50
|
+
"text/x-yaml": [".yaml", ".yml"],
|
|
51
|
+
"application/toml": [".toml"],
|
|
52
|
+
"application/x-toml": [".toml"],
|
|
53
|
+
"application/graphql": [".graphql", ".gql"],
|
|
54
|
+
"application/x-graphql": [".graphql", ".gql"],
|
|
55
|
+
"text/x-graphql": [".graphql", ".gql"],
|
|
56
|
+
"application/x-ndjson": [".ndjson"],
|
|
57
|
+
"application/json5": [".json5"],
|
|
58
|
+
"application/x-json5": [".json5"],
|
|
59
|
+
// JavaScript & TypeScript
|
|
60
|
+
"application/javascript": [".js", ".mjs"],
|
|
61
|
+
"text/javascript": [".js", ".mjs"],
|
|
62
|
+
"application/typescript": [".ts"],
|
|
63
|
+
"text/x-typescript": [".ts"],
|
|
64
|
+
"text/jsx": [".jsx"],
|
|
65
|
+
"text/tsx": [".tsx"],
|
|
66
|
+
// Shell & scripting
|
|
67
|
+
"text/x-sh": [".sh"],
|
|
68
|
+
"text/x-bash": [".bash"],
|
|
69
|
+
"application/x-bash": [".bash"],
|
|
70
|
+
"text/x-zsh": [".zsh"],
|
|
71
|
+
"text/x-shellscript": [".sh", ".ksh"],
|
|
72
|
+
"application/x-powershell": [".ps1"],
|
|
73
|
+
"text/vbscript": [".vbs"],
|
|
74
|
+
"text/x-awk": [".awk"],
|
|
75
|
+
"application/x-awk": [".awk"],
|
|
76
|
+
// C-family
|
|
77
|
+
"text/x-c": [".c", ".h"],
|
|
78
|
+
"text/x-c++": [".cpp", ".cc", ".cxx", ".hh"],
|
|
79
|
+
"text/x-csharp": [".cs"],
|
|
80
|
+
"text/x-objectivec": [".m"],
|
|
81
|
+
"text/x-objectivec++": [".mm"],
|
|
82
|
+
// JVM
|
|
83
|
+
"text/x-java": [".java"],
|
|
84
|
+
"text/x-scala": [".scala"],
|
|
85
|
+
"application/x-scala": [".scala"],
|
|
86
|
+
"text/x-kotlin": [".kt"],
|
|
87
|
+
"text/x-groovy": [".groovy"],
|
|
88
|
+
"text/x-clojure": [".clj"],
|
|
89
|
+
// Systems & compiled
|
|
90
|
+
"text/x-go": [".go"],
|
|
91
|
+
"text/x-golang": [".go"],
|
|
92
|
+
"text/x-rust": [".rs"],
|
|
93
|
+
"application/x-rust": [".rs"],
|
|
94
|
+
"text/x-swift": [".swift"],
|
|
95
|
+
"text/x-dart": [".dart"],
|
|
96
|
+
// Scripting languages
|
|
97
|
+
"text/x-python": [".py"],
|
|
98
|
+
"text/x-script.python": [".py"],
|
|
99
|
+
"text/x-python-script": [".py"],
|
|
100
|
+
"text/x-ruby": [".rb"],
|
|
101
|
+
"text/x-perl": [".pl"],
|
|
102
|
+
"text/x-lua": [".lua"],
|
|
103
|
+
"text/x-r": [".r"],
|
|
104
|
+
"text/x-R": [".r"],
|
|
105
|
+
"text/x-julia": [".jl"],
|
|
106
|
+
"text/x-elixir": [".ex"],
|
|
107
|
+
"text/x-erlang": [".erl"],
|
|
108
|
+
"text/x-haskell": [".hs"],
|
|
109
|
+
"text/x-lisp": [".lisp"],
|
|
110
|
+
// PHP
|
|
111
|
+
"text/x-php": [".php"],
|
|
112
|
+
"application/x-php": [".php"],
|
|
113
|
+
"application/x-httpd-php": [".php"],
|
|
114
|
+
"application/x-httpd-php-source": [".php"],
|
|
115
|
+
// Markup & templating
|
|
116
|
+
"text/x-tex": [".tex"],
|
|
117
|
+
"text/x-rst": [".rst"],
|
|
118
|
+
"text/x-handlebars": [".hbs"],
|
|
119
|
+
"text/x-mustache": [".mustache"],
|
|
120
|
+
"text/x-ejs": [".ejs"],
|
|
121
|
+
"text/x-jinja2": [".jinja", ".jinja2"],
|
|
122
|
+
"text/x-liquid": [".liquid"],
|
|
123
|
+
"text/x-erb": [".erb"],
|
|
124
|
+
"text/x-twig": [".twig"],
|
|
125
|
+
"text/x-pug": [".pug"],
|
|
126
|
+
"text/x-jade": [".jade"],
|
|
127
|
+
"text/x-tmpl": [".tmpl"],
|
|
128
|
+
"text/x-astro": [".astro"],
|
|
129
|
+
// Style
|
|
130
|
+
"text/x-sass": [".sass"],
|
|
131
|
+
"text/x-scss": [".scss"],
|
|
132
|
+
"text/x-less": [".less"],
|
|
133
|
+
// SQL
|
|
134
|
+
"text/x-sql": [".sql"],
|
|
135
|
+
"application/x-sql": [".sql"],
|
|
136
|
+
// Config & build
|
|
137
|
+
"text/x-makefile": [".makefile", ".mk"],
|
|
138
|
+
"text/x-cmake": [".cmake"],
|
|
139
|
+
"text/x-dockerfile": [".dockerfile"],
|
|
140
|
+
"text/x-gradle": [".gradle"],
|
|
141
|
+
"text/x-ini": [".ini"],
|
|
142
|
+
"text/x-properties": [".properties"],
|
|
143
|
+
"text/x-protobuf": [".proto"],
|
|
144
|
+
"application/x-protobuf": [".proto"],
|
|
145
|
+
"text/x-hcl": [".hcl"],
|
|
146
|
+
"text/x-terraform": [".tf"],
|
|
147
|
+
"application/x-terraform": [".tf"],
|
|
148
|
+
// Diff & patch
|
|
149
|
+
"text/x-diff": [".diff"],
|
|
150
|
+
"text/x-patch": [".patch"],
|
|
151
|
+
"application/x-patch": [".patch"],
|
|
152
|
+
// Assembly
|
|
153
|
+
"text/x-asm": [".asm", ".s"],
|
|
154
|
+
// Email
|
|
155
|
+
"message/rfc822": [".eml", ".mht", ".mhtml", ".mime", ".nws"],
|
|
156
|
+
// Subtitles & calendar
|
|
157
|
+
"text/srt": [".srt"],
|
|
158
|
+
"application/x-subrip": [".srt"],
|
|
159
|
+
"text/x-subrip": [".srt"],
|
|
160
|
+
"text/vtt": [".vtt"],
|
|
161
|
+
"text/x-vcard": [".vcf"],
|
|
162
|
+
"text/calendar": [".ics", ".ifb"],
|
|
163
|
+
// Office documents
|
|
164
|
+
"application/vnd.openxmlformats-officedocument.wordprocessingml.document": [".docx"],
|
|
165
|
+
"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": [".xlsx"],
|
|
166
|
+
"application/vnd.openxmlformats-officedocument.presentationml.presentation": [".pptx"],
|
|
167
|
+
"application/vnd.oasis.opendocument.text": [".odt"],
|
|
168
|
+
"application/vnd.oasis.opendocument.spreadsheet": [".ods"],
|
|
169
|
+
"application/vnd.oasis.opendocument.presentation": [".odp"],
|
|
170
|
+
"application/vnd.apple.pages": [".pages"],
|
|
171
|
+
"application/vnd.apple.numbers": [".numbers"],
|
|
172
|
+
"application/vnd.apple.keynote": [".key"],
|
|
173
|
+
"application/x-iwork-pages-sffpages": [".pages"],
|
|
174
|
+
"application/x-iwork-numbers-sffnumbers": [".numbers"],
|
|
175
|
+
"application/x-iwork-keynote-sffkey": [".key"]
|
|
176
|
+
}, M = new Set(Object.keys(_)), P = 10, y = 1024 * 1024 * 10, q = Object.entries(_).reduce(
|
|
177
|
+
(t, [e, i]) => {
|
|
178
|
+
for (const n of i) t[n] = e;
|
|
179
|
+
return t;
|
|
40
180
|
},
|
|
41
181
|
{}
|
|
42
182
|
);
|
|
43
|
-
function
|
|
44
|
-
if (
|
|
45
|
-
const
|
|
46
|
-
return i ? new File([
|
|
183
|
+
function R(t) {
|
|
184
|
+
if (t.type) return t;
|
|
185
|
+
const e = `.${t.name.split(".").pop()?.toLowerCase()}`, i = q[e];
|
|
186
|
+
return i ? new File([t], t.name, { type: i }) : t;
|
|
47
187
|
}
|
|
48
|
-
function
|
|
49
|
-
if (!
|
|
50
|
-
const
|
|
51
|
-
return
|
|
188
|
+
function U(t) {
|
|
189
|
+
if (!t.length) return null;
|
|
190
|
+
const e = (i) => t.some((n) => n.errors.includes(i));
|
|
191
|
+
return e("TOO_MANY_FILES") ? {
|
|
52
192
|
title: "Attachment limit reached",
|
|
53
|
-
message: `You can only attach up to ${
|
|
54
|
-
} :
|
|
193
|
+
message: `You can only attach up to ${P} files per message.`
|
|
194
|
+
} : e("FILE_INVALID_TYPE") ? {
|
|
55
195
|
title: "Unsupported file type",
|
|
56
|
-
message:
|
|
57
|
-
} :
|
|
196
|
+
message: "Supported formats include images, PDFs, text, code, and document files."
|
|
197
|
+
} : e("FILE_TOO_LARGE") ? {
|
|
58
198
|
title: "File too large",
|
|
59
|
-
message: `Files must be smaller than ${
|
|
60
|
-
} :
|
|
199
|
+
message: `Files must be smaller than ${y / 1024 / 1024}MB.`
|
|
200
|
+
} : e("FILE_EXISTS") ? {
|
|
61
201
|
title: "File already exists",
|
|
62
|
-
message: `The file "${
|
|
202
|
+
message: `The file "${t.find((n) => n.errors.includes("FILE_EXISTS"))?.file.name ?? "file"}" is already attached to this message.`
|
|
63
203
|
} : {
|
|
64
204
|
title: "File rejected",
|
|
65
205
|
message: "This file could not be added."
|
|
@@ -67,265 +207,264 @@ function O(e) {
|
|
|
67
207
|
}
|
|
68
208
|
const S = o("div", {
|
|
69
209
|
_id: "aiChatMessage__Files"
|
|
70
|
-
}),
|
|
71
|
-
const { message: i } =
|
|
210
|
+
}), dt = ({ children: t, ...e }) => {
|
|
211
|
+
const { message: i } = k();
|
|
72
212
|
if (i.role !== "user") return null;
|
|
73
|
-
const n = (i.parts ?? []).filter((
|
|
74
|
-
if (
|
|
75
|
-
const
|
|
76
|
-
return
|
|
213
|
+
const n = (i.parts ?? []).filter((s) => {
|
|
214
|
+
if (s.type !== "file") return !1;
|
|
215
|
+
const l = s.mediaType;
|
|
216
|
+
return M.has(l ?? "");
|
|
77
217
|
});
|
|
78
|
-
return n.length ? /* @__PURE__ */ a(S, { ...
|
|
79
|
-
},
|
|
218
|
+
return n.length ? /* @__PURE__ */ a(S, { ...e, children: t(n) }) : null;
|
|
219
|
+
}, A = o("button", {
|
|
80
220
|
_id: "aiChatMessage__File"
|
|
81
|
-
}),
|
|
82
|
-
url:
|
|
83
|
-
name:
|
|
221
|
+
}), xt = ({
|
|
222
|
+
url: t,
|
|
223
|
+
name: e,
|
|
84
224
|
mediaType: i,
|
|
85
225
|
onClick: n,
|
|
86
|
-
...
|
|
226
|
+
...s
|
|
87
227
|
}) => {
|
|
88
|
-
const { openImagePreview:
|
|
89
|
-
() => new File([],
|
|
90
|
-
[
|
|
228
|
+
const { openImagePreview: l } = I(), [p, m] = h(!0), u = w(
|
|
229
|
+
() => new File([], e ?? "file", { type: i }),
|
|
230
|
+
[e, i]
|
|
91
231
|
);
|
|
92
232
|
return /* @__PURE__ */ a(
|
|
93
|
-
|
|
233
|
+
b.Provider,
|
|
94
234
|
{
|
|
95
|
-
value: { file:
|
|
235
|
+
value: { file: u, objectUrl: t, isLoading: p, setIsLoading: m, onRemove: () => {
|
|
96
236
|
} },
|
|
97
237
|
children: /* @__PURE__ */ a(
|
|
98
|
-
|
|
238
|
+
A,
|
|
99
239
|
{
|
|
100
240
|
type: "button",
|
|
101
|
-
"aria-label":
|
|
102
|
-
"data-loading":
|
|
103
|
-
onClick:
|
|
104
|
-
if (
|
|
105
|
-
|
|
106
|
-
else if (
|
|
107
|
-
if (
|
|
108
|
-
const
|
|
109
|
-
|
|
241
|
+
"aria-label": F(i ?? "") ? `Preview ${e ?? "file"}` : `Open ${e ?? "file"} in new tab`,
|
|
242
|
+
"data-loading": g(p),
|
|
243
|
+
onClick: r(n, () => {
|
|
244
|
+
if (F(i ?? ""))
|
|
245
|
+
l({ url: t, name: e ?? "file" });
|
|
246
|
+
else if (t)
|
|
247
|
+
if (t.startsWith("data:")) {
|
|
248
|
+
const f = document.createElement("a");
|
|
249
|
+
f.href = t, f.download = e ?? "file", f.click();
|
|
110
250
|
} else
|
|
111
|
-
window.open(
|
|
251
|
+
window.open(t, "_blank", "noopener,noreferrer");
|
|
112
252
|
}),
|
|
113
|
-
...
|
|
253
|
+
...s
|
|
114
254
|
}
|
|
115
255
|
)
|
|
116
256
|
}
|
|
117
257
|
);
|
|
118
|
-
},
|
|
258
|
+
}, O = o("div", {
|
|
119
259
|
_id: "aiChatInput__Fieldset"
|
|
120
|
-
}),
|
|
121
|
-
const
|
|
260
|
+
}), D = (t) => {
|
|
261
|
+
const e = d();
|
|
122
262
|
return /* @__PURE__ */ a(
|
|
123
|
-
|
|
263
|
+
O,
|
|
124
264
|
{
|
|
125
|
-
...
|
|
126
|
-
"data-drag-over":
|
|
127
|
-
...
|
|
265
|
+
...e.getDropzoneProps({ disableClick: !0 }),
|
|
266
|
+
"data-drag-over": g(e.dragging),
|
|
267
|
+
...t
|
|
128
268
|
}
|
|
129
269
|
);
|
|
130
|
-
},
|
|
131
|
-
...
|
|
270
|
+
}, mt = ({
|
|
271
|
+
...t
|
|
132
272
|
}) => {
|
|
133
|
-
const { files:
|
|
273
|
+
const { files: e, setFiles: i, showInputNotification: n } = c();
|
|
134
274
|
return /* @__PURE__ */ a(
|
|
135
|
-
|
|
275
|
+
N,
|
|
136
276
|
{
|
|
137
|
-
accept:
|
|
138
|
-
maxFiles:
|
|
139
|
-
maxFileSize:
|
|
277
|
+
accept: _,
|
|
278
|
+
maxFiles: P,
|
|
279
|
+
maxFileSize: y,
|
|
140
280
|
preventDocumentDrop: !0,
|
|
141
|
-
acceptedFiles:
|
|
142
|
-
onFileAccept: (
|
|
143
|
-
onFileReject: (
|
|
144
|
-
const
|
|
145
|
-
|
|
281
|
+
acceptedFiles: e,
|
|
282
|
+
onFileAccept: (s) => i(s.files),
|
|
283
|
+
onFileReject: (s) => {
|
|
284
|
+
const l = U(s.files);
|
|
285
|
+
l && n(l);
|
|
146
286
|
},
|
|
147
|
-
children: /* @__PURE__ */ a(
|
|
287
|
+
children: /* @__PURE__ */ a(D, { ...t })
|
|
148
288
|
}
|
|
149
289
|
);
|
|
150
|
-
},
|
|
290
|
+
}, ut = o("div", {
|
|
151
291
|
_id: "aiChatInput__DropZone"
|
|
152
|
-
}),
|
|
292
|
+
}), $ = o("div", {
|
|
153
293
|
_id: "aiChatInput__Notification"
|
|
154
|
-
}),
|
|
155
|
-
const { inputNotification:
|
|
156
|
-
return
|
|
157
|
-
},
|
|
294
|
+
}), ft = (t) => {
|
|
295
|
+
const { inputNotification: e } = c();
|
|
296
|
+
return e ? /* @__PURE__ */ a($, { role: "alert", ...t }) : null;
|
|
297
|
+
}, B = o("p", {
|
|
158
298
|
_id: "aiChatInput__NotificationTitle"
|
|
159
|
-
}),
|
|
160
|
-
children:
|
|
161
|
-
...
|
|
299
|
+
}), ht = ({
|
|
300
|
+
children: t,
|
|
301
|
+
...e
|
|
162
302
|
}) => {
|
|
163
|
-
const { inputNotification: i } =
|
|
164
|
-
return i?.title ? /* @__PURE__ */
|
|
165
|
-
|
|
303
|
+
const { inputNotification: i } = c();
|
|
304
|
+
return i?.title ? /* @__PURE__ */ j(B, { ...e, children: [
|
|
305
|
+
t,
|
|
166
306
|
i.title
|
|
167
307
|
] }) : null;
|
|
168
|
-
},
|
|
308
|
+
}, z = o("p", {
|
|
169
309
|
_id: "aiChatInput__NotificationMessage"
|
|
170
|
-
}),
|
|
171
|
-
const { inputNotification:
|
|
172
|
-
return /* @__PURE__ */ a(
|
|
173
|
-
},
|
|
310
|
+
}), vt = (t) => {
|
|
311
|
+
const { inputNotification: e } = c();
|
|
312
|
+
return /* @__PURE__ */ a(z, { ...t, children: e?.message });
|
|
313
|
+
}, H = o("button", {
|
|
174
314
|
_id: "aiChatInput__NotificationClose"
|
|
175
|
-
}),
|
|
176
|
-
onClick:
|
|
177
|
-
...
|
|
315
|
+
}), gt = ({
|
|
316
|
+
onClick: t,
|
|
317
|
+
...e
|
|
178
318
|
}) => {
|
|
179
|
-
const { clearInputNotification: i } =
|
|
319
|
+
const { clearInputNotification: i } = c();
|
|
180
320
|
return /* @__PURE__ */ a(
|
|
181
|
-
|
|
321
|
+
H,
|
|
182
322
|
{
|
|
183
323
|
type: "button",
|
|
184
324
|
"aria-label": "Dismiss",
|
|
185
|
-
onClick:
|
|
186
|
-
...
|
|
325
|
+
onClick: r(t, i),
|
|
326
|
+
...e
|
|
187
327
|
}
|
|
188
328
|
);
|
|
189
|
-
},
|
|
329
|
+
}, _t = o("div", {
|
|
190
330
|
_id: "aiChatInput__NotificationContent"
|
|
191
|
-
}),
|
|
331
|
+
}), bt = o("div", {
|
|
192
332
|
_id: "aiChatInput__NotificationHeader"
|
|
193
|
-
}),
|
|
333
|
+
}), Ft = o(v, {
|
|
194
334
|
_id: "aiChatInput__FileUploadButtonIcon",
|
|
195
335
|
iconKey: "fileUpload"
|
|
196
|
-
}),
|
|
336
|
+
}), X = o("button", {
|
|
197
337
|
_id: "aiChatInput__FileUploadButton"
|
|
198
|
-
}),
|
|
199
|
-
const { aiChatSettings:
|
|
338
|
+
}), Ct = (t) => {
|
|
339
|
+
const { aiChatSettings: e } = T(), i = d(), { onClick: n, ...s } = t;
|
|
200
340
|
return /* @__PURE__ */ a(
|
|
201
|
-
|
|
341
|
+
X,
|
|
202
342
|
{
|
|
203
343
|
type: "button",
|
|
204
344
|
"aria-label": "Upload file",
|
|
205
|
-
disabled:
|
|
206
|
-
onClick:
|
|
207
|
-
...
|
|
345
|
+
disabled: e.isViewOnly,
|
|
346
|
+
onClick: r(n, () => i.openFilePicker()),
|
|
347
|
+
...s
|
|
208
348
|
}
|
|
209
349
|
);
|
|
210
|
-
},
|
|
350
|
+
}, Y = o("input", {
|
|
211
351
|
_id: "aiChatInput__FileInput"
|
|
212
|
-
}),
|
|
213
|
-
const
|
|
214
|
-
return /* @__PURE__ */ a(
|
|
215
|
-
},
|
|
352
|
+
}), It = (t) => {
|
|
353
|
+
const e = d();
|
|
354
|
+
return /* @__PURE__ */ a(Y, { ...t, ...e.getHiddenInputProps() });
|
|
355
|
+
}, K = o("div", {
|
|
216
356
|
_id: "aiChatInput__FileList"
|
|
217
|
-
}),
|
|
218
|
-
const n =
|
|
219
|
-
return n.length ? /* @__PURE__ */ a(
|
|
220
|
-
},
|
|
221
|
-
function
|
|
222
|
-
const
|
|
223
|
-
if (!
|
|
224
|
-
return
|
|
357
|
+
}), Pt = ({ children: t, ...e }) => {
|
|
358
|
+
const n = d().acceptedFiles;
|
|
359
|
+
return n.length ? /* @__PURE__ */ a(K, { ...e, children: t(n) }) : null;
|
|
360
|
+
}, b = C.createContext(null);
|
|
361
|
+
function x() {
|
|
362
|
+
const t = C.useContext(b);
|
|
363
|
+
if (!t) throw new Error("useFileContext must be used within EmbeddedChatPrimitiveFileItem");
|
|
364
|
+
return t;
|
|
225
365
|
}
|
|
226
|
-
const
|
|
366
|
+
const Z = o("div", {
|
|
227
367
|
_id: "aiChatInput__FileItem"
|
|
228
|
-
}),
|
|
229
|
-
const i =
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
}), [
|
|
233
|
-
const
|
|
234
|
-
return /* @__PURE__ */ a(
|
|
235
|
-
},
|
|
368
|
+
}), yt = ({ file: t, ...e }) => {
|
|
369
|
+
const i = d(), [n, s] = h(void 0), [l, p] = h(!0);
|
|
370
|
+
E(() => i.createFileUrl(t, (u) => {
|
|
371
|
+
s(u), p(!0);
|
|
372
|
+
}), [t]);
|
|
373
|
+
const m = () => i.deleteFile(t);
|
|
374
|
+
return /* @__PURE__ */ a(b.Provider, { value: { file: t, objectUrl: n, isLoading: l, setIsLoading: p, onRemove: m }, children: /* @__PURE__ */ a(Z, { "data-loading": g(l), ...e }) });
|
|
375
|
+
}, V = o("button", {
|
|
236
376
|
_id: "aiChatInput__FilePreviewTrigger"
|
|
237
|
-
}),
|
|
238
|
-
onClick:
|
|
239
|
-
...
|
|
377
|
+
}), jt = ({
|
|
378
|
+
onClick: t,
|
|
379
|
+
...e
|
|
240
380
|
}) => {
|
|
241
|
-
const { objectUrl: i, file: n } =
|
|
381
|
+
const { objectUrl: i, file: n } = x(), { openImagePreview: s } = I();
|
|
242
382
|
return /* @__PURE__ */ a(
|
|
243
|
-
|
|
383
|
+
V,
|
|
244
384
|
{
|
|
245
385
|
type: "button",
|
|
246
386
|
"aria-label": `Preview ${n.name}`,
|
|
247
387
|
disabled: !i,
|
|
248
|
-
onClick:
|
|
249
|
-
i &&
|
|
388
|
+
onClick: r(t, () => {
|
|
389
|
+
i && s({ url: i, name: n.name });
|
|
250
390
|
}),
|
|
251
|
-
...
|
|
391
|
+
...e
|
|
252
392
|
}
|
|
253
393
|
);
|
|
254
|
-
},
|
|
394
|
+
}, W = o("span", {
|
|
255
395
|
_id: "aiChatInput__FileContent"
|
|
256
|
-
}),
|
|
396
|
+
}), Et = (t) => /* @__PURE__ */ a(W, { ...t }), G = o("img", {
|
|
257
397
|
_id: "aiChatInput__FileThumbnail"
|
|
258
|
-
}),
|
|
259
|
-
onLoad:
|
|
260
|
-
...
|
|
398
|
+
}), wt = ({
|
|
399
|
+
onLoad: t,
|
|
400
|
+
...e
|
|
261
401
|
}) => {
|
|
262
|
-
const { objectUrl: i, file: n, setIsLoading:
|
|
402
|
+
const { objectUrl: i, file: n, setIsLoading: s } = x();
|
|
263
403
|
return /* @__PURE__ */ a(
|
|
264
|
-
|
|
404
|
+
G,
|
|
265
405
|
{
|
|
266
406
|
src: i,
|
|
267
407
|
alt: n.name,
|
|
268
|
-
onLoad:
|
|
269
|
-
...
|
|
408
|
+
onLoad: r(t, () => s(!1)),
|
|
409
|
+
...e
|
|
270
410
|
}
|
|
271
411
|
);
|
|
272
|
-
},
|
|
273
|
-
const { file:
|
|
274
|
-
return /* @__PURE__ */ a(
|
|
275
|
-
},
|
|
412
|
+
}, kt = ({ className: t }) => {
|
|
413
|
+
const { file: e } = x(), i = L[R(e).type] ?? "file";
|
|
414
|
+
return /* @__PURE__ */ a(v, { iconKey: i, className: t });
|
|
415
|
+
}, J = o("span", {
|
|
276
416
|
_id: "aiChatInput__FileName"
|
|
277
|
-
}),
|
|
278
|
-
const { file:
|
|
279
|
-
return /* @__PURE__ */ a(
|
|
280
|
-
},
|
|
417
|
+
}), Nt = (t) => {
|
|
418
|
+
const { file: e } = x();
|
|
419
|
+
return /* @__PURE__ */ a(J, { ...t, children: e.name });
|
|
420
|
+
}, Q = o("button", {
|
|
281
421
|
_id: "aiChatInput__FileRemove"
|
|
282
|
-
}),
|
|
422
|
+
}), Tt = o(v, {
|
|
283
423
|
_id: "aiChatInput__FileRemoveIcon",
|
|
284
424
|
iconKey: "close"
|
|
285
|
-
}),
|
|
286
|
-
onClick:
|
|
287
|
-
...
|
|
425
|
+
}), Lt = ({
|
|
426
|
+
onClick: t,
|
|
427
|
+
...e
|
|
288
428
|
}) => {
|
|
289
|
-
const { onRemove: i } =
|
|
429
|
+
const { onRemove: i } = x();
|
|
290
430
|
return /* @__PURE__ */ a(
|
|
291
|
-
|
|
431
|
+
Q,
|
|
292
432
|
{
|
|
293
433
|
type: "button",
|
|
294
434
|
"aria-label": "Remove file",
|
|
295
|
-
onClick:
|
|
296
|
-
...
|
|
435
|
+
onClick: r(t, i),
|
|
436
|
+
...e
|
|
297
437
|
}
|
|
298
438
|
);
|
|
299
439
|
};
|
|
300
440
|
export {
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
A as normalizeFileType
|
|
441
|
+
M as ACCEPTED_FILE_MIME_TYPES,
|
|
442
|
+
ut as EmbeddedChatPrimitiveDropZone,
|
|
443
|
+
Et as EmbeddedChatPrimitiveFileContent,
|
|
444
|
+
It as EmbeddedChatPrimitiveFileInput,
|
|
445
|
+
yt as EmbeddedChatPrimitiveFileItem,
|
|
446
|
+
Pt as EmbeddedChatPrimitiveFileList,
|
|
447
|
+
Nt as EmbeddedChatPrimitiveFileName,
|
|
448
|
+
jt as EmbeddedChatPrimitiveFilePreviewTrigger,
|
|
449
|
+
Lt as EmbeddedChatPrimitiveFileRemove,
|
|
450
|
+
Tt as EmbeddedChatPrimitiveFileRemoveIcon,
|
|
451
|
+
wt as EmbeddedChatPrimitiveFileThumbnail,
|
|
452
|
+
kt as EmbeddedChatPrimitiveFileTypeIcon,
|
|
453
|
+
Ct as EmbeddedChatPrimitiveFileUploadButton,
|
|
454
|
+
Ft as EmbeddedChatPrimitiveFileUploadButtonIcon,
|
|
455
|
+
mt as EmbeddedChatPrimitiveInputFieldset,
|
|
456
|
+
ft as EmbeddedChatPrimitiveInputNotification,
|
|
457
|
+
gt as EmbeddedChatPrimitiveInputNotificationClose,
|
|
458
|
+
_t as EmbeddedChatPrimitiveInputNotificationContent,
|
|
459
|
+
bt as EmbeddedChatPrimitiveInputNotificationHeader,
|
|
460
|
+
vt as EmbeddedChatPrimitiveInputNotificationMessage,
|
|
461
|
+
ht as EmbeddedChatPrimitiveInputNotificationTitle,
|
|
462
|
+
xt as EmbeddedChatPrimitiveMessageFile,
|
|
463
|
+
dt as EmbeddedChatPrimitiveMessageFiles,
|
|
464
|
+
_ as FILE_ACCEPT_MAP,
|
|
465
|
+
L as FILE_TYPE_ICON_MAP,
|
|
466
|
+
P as MAX_FILES,
|
|
467
|
+
y as MAX_FILE_SIZE,
|
|
468
|
+
F as isImageMimeType,
|
|
469
|
+
R as normalizeFileType
|
|
331
470
|
};
|