@orion-ds/react 4.0.5 → 4.2.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/contexts/ThemeContext.d.ts.map +1 -1
- package/dist/index.d.ts +2 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index10.cjs +1 -1
- package/dist/index10.mjs +1 -1
- package/dist/index100.cjs +1 -1
- package/dist/index100.mjs +20 -40
- package/dist/index100.mjs.map +1 -1
- package/dist/index101.cjs +1 -1
- package/dist/index101.mjs +28 -40
- package/dist/index101.mjs.map +1 -1
- package/dist/index102.cjs +1 -1
- package/dist/index102.mjs +46 -33
- package/dist/index102.mjs.map +1 -1
- package/dist/index103.cjs +1 -1
- package/dist/index103.mjs +42 -27
- package/dist/index103.mjs.map +1 -1
- package/dist/index104.cjs +1 -1
- package/dist/index104.mjs +56 -30
- package/dist/index104.mjs.map +1 -1
- package/dist/index105.cjs +1 -1
- package/dist/index105.mjs +25 -15
- package/dist/index105.mjs.map +1 -1
- package/dist/index106.cjs +1 -1
- package/dist/index106.mjs +64 -52
- package/dist/index106.mjs.map +1 -1
- package/dist/index107.cjs +1 -1
- package/dist/index107.mjs +20 -20
- package/dist/index108.cjs +1 -1
- package/dist/index108.mjs +45 -36
- package/dist/index108.mjs.map +1 -1
- package/dist/index109.cjs +1 -1
- package/dist/index109.mjs +24 -42
- package/dist/index109.mjs.map +1 -1
- package/dist/index11.cjs +1 -1
- package/dist/index11.mjs +1 -1
- package/dist/index110.cjs +1 -1
- package/dist/index110.mjs +40 -18
- package/dist/index110.mjs.map +1 -1
- package/dist/index111.cjs +1 -1
- package/dist/index111.mjs +18 -28
- package/dist/index111.mjs.map +1 -1
- package/dist/index112.cjs +1 -1
- package/dist/index112.mjs +55 -12
- package/dist/index112.mjs.map +1 -1
- package/dist/index114.cjs +1 -1
- package/dist/index114.mjs +62 -28
- package/dist/index114.mjs.map +1 -1
- package/dist/index115.cjs +1 -1
- package/dist/index115.mjs +65 -45
- package/dist/index115.mjs.map +1 -1
- package/dist/index116.cjs +1 -1
- package/dist/index116.mjs +234 -18
- package/dist/index116.mjs.map +1 -1
- package/dist/index117.cjs +1 -1
- package/dist/index117.cjs.map +1 -1
- package/dist/index117.mjs +34 -29
- package/dist/index117.mjs.map +1 -1
- package/dist/index118.cjs +1 -1
- package/dist/index118.cjs.map +1 -1
- package/dist/index118.mjs +44 -31
- package/dist/index118.mjs.map +1 -1
- package/dist/index119.cjs +1 -1
- package/dist/index119.cjs.map +1 -1
- package/dist/index119.mjs +170 -22
- package/dist/index119.mjs.map +1 -1
- package/dist/index12.cjs +1 -1
- package/dist/index12.mjs +1 -1
- package/dist/index120.cjs +1 -1
- package/dist/index120.cjs.map +1 -1
- package/dist/index120.mjs +186 -39
- package/dist/index120.mjs.map +1 -1
- package/dist/index121.cjs +1 -1
- package/dist/index121.cjs.map +1 -1
- package/dist/index121.mjs +29 -66
- package/dist/index121.mjs.map +1 -1
- package/dist/index122.cjs +1 -1
- package/dist/index122.cjs.map +1 -1
- package/dist/index122.mjs +90 -18
- package/dist/index122.mjs.map +1 -1
- package/dist/index123.cjs +1 -1
- package/dist/index123.cjs.map +1 -1
- package/dist/index123.mjs +53 -54
- package/dist/index123.mjs.map +1 -1
- package/dist/index124.cjs +1 -1
- package/dist/index124.cjs.map +1 -1
- package/dist/index124.mjs +66 -30
- package/dist/index124.mjs.map +1 -1
- package/dist/index125.cjs +1 -1
- package/dist/index125.cjs.map +1 -1
- package/dist/index125.mjs +124 -62
- package/dist/index125.mjs.map +1 -1
- package/dist/index126.cjs +1 -1
- package/dist/index126.cjs.map +1 -1
- package/dist/index126.mjs +108 -55
- package/dist/index126.mjs.map +1 -1
- package/dist/index127.cjs +1 -1
- package/dist/index127.cjs.map +1 -1
- package/dist/index127.mjs +111 -44
- package/dist/index127.mjs.map +1 -1
- package/dist/index128.cjs +1 -1
- package/dist/index128.cjs.map +1 -1
- package/dist/index128.mjs +122 -14
- package/dist/index128.mjs.map +1 -1
- package/dist/index129.cjs +1 -1
- package/dist/index129.cjs.map +1 -1
- package/dist/index129.mjs +214 -33
- package/dist/index129.mjs.map +1 -1
- package/dist/index13.cjs +1 -1
- package/dist/index13.mjs +1 -1
- package/dist/index130.cjs +1 -1
- package/dist/index130.mjs +42 -28
- package/dist/index130.mjs.map +1 -1
- package/dist/index131.cjs +1 -1
- package/dist/index131.mjs +40 -22
- package/dist/index131.mjs.map +1 -1
- package/dist/index132.cjs +1 -1
- package/dist/index132.mjs +106 -64
- package/dist/index132.mjs.map +1 -1
- package/dist/index133.cjs +1 -1
- package/dist/index133.mjs +20 -44
- package/dist/index133.mjs.map +1 -1
- package/dist/index134.cjs +1 -1
- package/dist/index134.mjs +30 -57
- package/dist/index134.mjs.map +1 -1
- package/dist/index135.cjs +1 -1
- package/dist/index135.mjs +46 -44
- package/dist/index135.mjs.map +1 -1
- package/dist/index136.cjs +1 -1
- package/dist/index136.mjs +12 -38
- package/dist/index136.mjs.map +1 -1
- package/dist/index137.cjs +1 -1
- package/dist/index137.mjs +32 -28
- package/dist/index137.mjs.map +1 -1
- package/dist/index138.cjs +1 -1
- package/dist/index138.mjs +27 -24
- package/dist/index138.mjs.map +1 -1
- package/dist/index139.cjs +1 -1
- package/dist/index139.mjs +33 -67
- package/dist/index139.mjs.map +1 -1
- package/dist/index14.cjs +1 -1
- package/dist/index14.mjs +1 -1
- package/dist/index140.cjs +1 -1
- package/dist/index140.mjs +57 -76
- package/dist/index140.mjs.map +1 -1
- package/dist/index141.cjs +1 -1
- package/dist/index141.mjs +30 -46
- package/dist/index141.mjs.map +1 -1
- package/dist/index142.cjs +1 -1
- package/dist/index142.mjs +32 -234
- package/dist/index142.mjs.map +1 -1
- package/dist/index143.cjs +1 -1
- package/dist/index143.cjs.map +1 -1
- package/dist/index143.mjs +51 -34
- package/dist/index143.mjs.map +1 -1
- package/dist/index144.cjs +1 -1
- package/dist/index144.cjs.map +1 -1
- package/dist/index144.mjs +17 -44
- package/dist/index144.mjs.map +1 -1
- package/dist/index145.cjs +1 -1
- package/dist/index145.cjs.map +1 -1
- package/dist/index145.mjs +30 -170
- package/dist/index145.mjs.map +1 -1
- package/dist/index146.cjs +1 -1
- package/dist/index146.cjs.map +1 -1
- package/dist/index146.mjs +47 -186
- package/dist/index146.mjs.map +1 -1
- package/dist/index147.cjs +1 -1
- package/dist/index147.cjs.map +1 -1
- package/dist/index147.mjs +43 -29
- package/dist/index147.mjs.map +1 -1
- package/dist/index148.cjs +1 -1
- package/dist/index148.cjs.map +1 -1
- package/dist/index148.mjs +28 -90
- package/dist/index148.mjs.map +1 -1
- package/dist/index149.cjs +1 -1
- package/dist/index149.cjs.map +1 -1
- package/dist/index149.mjs +29 -53
- package/dist/index149.mjs.map +1 -1
- package/dist/index15.cjs +1 -1
- package/dist/index15.mjs +1 -1
- package/dist/index150.cjs +1 -1
- package/dist/index150.cjs.map +1 -1
- package/dist/index150.mjs +30 -66
- package/dist/index150.mjs.map +1 -1
- package/dist/index151.cjs +1 -1
- package/dist/index151.cjs.map +1 -1
- package/dist/index151.mjs +24 -124
- package/dist/index151.mjs.map +1 -1
- package/dist/index152.cjs +1 -1
- package/dist/index152.cjs.map +1 -1
- package/dist/index152.mjs +22 -108
- package/dist/index152.mjs.map +1 -1
- package/dist/index153.cjs +1 -1
- package/dist/index153.cjs.map +1 -1
- package/dist/index153.mjs +36 -111
- package/dist/index153.mjs.map +1 -1
- package/dist/index154.cjs +1 -1
- package/dist/index154.cjs.map +1 -1
- package/dist/index154.mjs +38 -122
- package/dist/index154.mjs.map +1 -1
- package/dist/index155.cjs +1 -1
- package/dist/index155.cjs.map +1 -1
- package/dist/index155.mjs +12 -214
- package/dist/index155.mjs.map +1 -1
- package/dist/index156.cjs +1 -1
- package/dist/index156.mjs +27 -49
- package/dist/index156.mjs.map +1 -1
- package/dist/index157.cjs +1 -1
- package/dist/index157.mjs +38 -24
- package/dist/index157.mjs.map +1 -1
- package/dist/index158.cjs +1 -1
- package/dist/index158.mjs +33 -32
- package/dist/index158.mjs.map +1 -1
- package/dist/index159.cjs +1 -1
- package/dist/index159.mjs +30 -18
- package/dist/index159.mjs.map +1 -1
- package/dist/index16.cjs +1 -1
- package/dist/index16.mjs +1 -1
- package/dist/index160.cjs +1 -1
- package/dist/index160.mjs +14 -26
- package/dist/index160.mjs.map +1 -1
- package/dist/index161.cjs +1 -1
- package/dist/index161.mjs +18 -46
- package/dist/index161.mjs.map +1 -1
- package/dist/index162.cjs +1 -1
- package/dist/index162.mjs +28 -24
- package/dist/index162.mjs.map +1 -1
- package/dist/index163.cjs +1 -1
- package/dist/index163.mjs +18 -56
- package/dist/index163.mjs.map +1 -1
- package/dist/index164.cjs +1 -1
- package/dist/index164.mjs +65 -40
- package/dist/index164.mjs.map +1 -1
- package/dist/index165.cjs +1 -1
- package/dist/index165.mjs +30 -62
- package/dist/index165.mjs.map +1 -1
- package/dist/index166.cjs +1 -1
- package/dist/index166.mjs +44 -20
- package/dist/index166.mjs.map +1 -1
- package/dist/index167.cjs +1 -1
- package/dist/index167.mjs +52 -106
- package/dist/index167.mjs.map +1 -1
- package/dist/index168.cjs +1 -1
- package/dist/index168.cjs.map +1 -1
- package/dist/index168.mjs +37 -21
- package/dist/index168.mjs.map +1 -1
- package/dist/index169.cjs +1 -1
- package/dist/index169.mjs +28 -30
- package/dist/index169.mjs.map +1 -1
- package/dist/index17.cjs +1 -1
- package/dist/index17.mjs +1 -1
- package/dist/index170.cjs +1 -1
- package/dist/index170.mjs +18 -12
- package/dist/index170.mjs.map +1 -1
- package/dist/index171.cjs +1 -1
- package/dist/index171.mjs +33 -32
- package/dist/index171.mjs.map +1 -1
- package/dist/index172.cjs +1 -1
- package/dist/index172.mjs +20 -40
- package/dist/index172.mjs.map +1 -1
- package/dist/index173.cjs +1 -1
- package/dist/index173.cjs.map +1 -1
- package/dist/index173.mjs +25 -37
- package/dist/index173.mjs.map +1 -1
- package/dist/index174.cjs +1 -1
- package/dist/index174.mjs +64 -28
- package/dist/index174.mjs.map +1 -1
- package/dist/index175.cjs +1 -1
- package/dist/index175.mjs +76 -33
- package/dist/index175.mjs.map +1 -1
- package/dist/index176.cjs +1 -1
- package/dist/index176.mjs +40 -52
- package/dist/index176.mjs.map +1 -1
- package/dist/index177.cjs +1 -1
- package/dist/index177.mjs +52 -18
- package/dist/index177.mjs.map +1 -1
- package/dist/index178.cjs +1 -1
- package/dist/index178.mjs +53 -42
- package/dist/index178.mjs.map +1 -1
- package/dist/index179.cjs +1 -1
- package/dist/index179.mjs +18 -28
- package/dist/index179.mjs.map +1 -1
- package/dist/index18.cjs +1 -1
- package/dist/index18.mjs +1 -1
- package/dist/index180.cjs +1 -1
- package/dist/index180.mjs +42 -28
- package/dist/index180.mjs.map +1 -1
- package/dist/index181.cjs +1 -1
- package/dist/index181.mjs +28 -64
- package/dist/index181.mjs.map +1 -1
- package/dist/index182.cjs +1 -1
- package/dist/index182.mjs +17 -17
- package/dist/index182.mjs.map +1 -1
- package/dist/index183.cjs +1 -1
- package/dist/index183.mjs +17 -17
- package/dist/index183.mjs.map +1 -1
- package/dist/index185.cjs +1 -1
- package/dist/index185.mjs +1 -1
- package/dist/index19.cjs +1 -1
- package/dist/index19.mjs +2 -2
- package/dist/index20.cjs +1 -1
- package/dist/index20.mjs +14 -14
- package/dist/index21.cjs +1 -1
- package/dist/index21.cjs.map +1 -1
- package/dist/index21.mjs +1 -1
- package/dist/index22.cjs +1 -1
- package/dist/index22.mjs +1 -1
- package/dist/index23.cjs +1 -1
- package/dist/index23.mjs +1 -1
- package/dist/index24.cjs +1 -1
- package/dist/index24.mjs +1 -1
- package/dist/index25.cjs +1 -1
- package/dist/index25.mjs +1 -1
- package/dist/index26.cjs +1 -1
- package/dist/index26.cjs.map +1 -1
- package/dist/index26.mjs +1 -1
- package/dist/index27.cjs +1 -1
- package/dist/index27.mjs +1 -1
- package/dist/index28.cjs +1 -1
- package/dist/index28.mjs +1 -1
- package/dist/index29.cjs +1 -1
- package/dist/index29.mjs +1 -1
- package/dist/index30.cjs +1 -1
- package/dist/index30.mjs +1 -1
- package/dist/index31.cjs +1 -1
- package/dist/index31.mjs +1 -1
- package/dist/index32.cjs +1 -1
- package/dist/index32.mjs +1 -1
- package/dist/index33.cjs +1 -1
- package/dist/index33.mjs +1 -1
- package/dist/index34.cjs +1 -1
- package/dist/index34.mjs +1 -1
- package/dist/index35.cjs +1 -1
- package/dist/index35.mjs +1 -1
- package/dist/index36.cjs +1 -1
- package/dist/index36.mjs +1 -1
- package/dist/index37.cjs +1 -1
- package/dist/index37.mjs +1 -1
- package/dist/index38.cjs +1 -1
- package/dist/index38.mjs +1 -1
- package/dist/index39.cjs +1 -1
- package/dist/index39.mjs +1 -1
- package/dist/index40.cjs +1 -1
- package/dist/index40.mjs +1 -1
- package/dist/index42.cjs +1 -1
- package/dist/index42.mjs +1 -1
- package/dist/index43.cjs +1 -1
- package/dist/index43.mjs +1 -1
- package/dist/index46.cjs +1 -1
- package/dist/index46.mjs +1 -1
- package/dist/index47.cjs +1 -1
- package/dist/index47.mjs +1 -1
- package/dist/index49.cjs +1 -1
- package/dist/index49.mjs +1 -1
- package/dist/index5.cjs +1 -1
- package/dist/index5.mjs +1 -1
- package/dist/index50.cjs +1 -1
- package/dist/index50.mjs +1 -1
- package/dist/index51.cjs +1 -1
- package/dist/index51.mjs +1 -1
- package/dist/index52.cjs +1 -1
- package/dist/index52.mjs +1 -1
- package/dist/index53.cjs +1 -1
- package/dist/index53.mjs +1 -1
- package/dist/index54.cjs +1 -1
- package/dist/index54.mjs +1 -1
- package/dist/index55.cjs +1 -1
- package/dist/index55.mjs +1 -1
- package/dist/index56.cjs +1 -1
- package/dist/index56.mjs +1 -1
- package/dist/index57.cjs +1 -1
- package/dist/index57.mjs +1 -1
- package/dist/index58.cjs +1 -1
- package/dist/index58.mjs +1 -1
- package/dist/index59.cjs +1 -1
- package/dist/index59.mjs +1 -1
- package/dist/index6.cjs +1 -1
- package/dist/index6.mjs +1 -1
- package/dist/index60.cjs +1 -1
- package/dist/index60.mjs +1 -1
- package/dist/index61.cjs +1 -1
- package/dist/index61.mjs +1 -1
- package/dist/index62.cjs +1 -1
- package/dist/index62.mjs +1 -1
- package/dist/index63.cjs +1 -1
- package/dist/index63.mjs +1 -1
- package/dist/index64.cjs +1 -1
- package/dist/index64.mjs +1 -1
- package/dist/index65.cjs +1 -1
- package/dist/index65.mjs +1 -1
- package/dist/index66.cjs +1 -1
- package/dist/index66.mjs +1 -1
- package/dist/index67.cjs +1 -1
- package/dist/index67.mjs +1 -1
- package/dist/index68.cjs +1 -1
- package/dist/index68.mjs +1 -1
- package/dist/index69.cjs +1 -1
- package/dist/index69.mjs +1 -1
- package/dist/index7.cjs +1 -1
- package/dist/index7.mjs +1 -1
- package/dist/index70.cjs +1 -1
- package/dist/index70.mjs +1 -1
- package/dist/index71.cjs +1 -1
- package/dist/index71.mjs +1 -1
- package/dist/index72.cjs +1 -1
- package/dist/index72.mjs +1 -1
- package/dist/index73.cjs +1 -1
- package/dist/index73.mjs +1 -1
- package/dist/index75.cjs +7 -10
- package/dist/index75.cjs.map +1 -1
- package/dist/index75.mjs +18 -21
- package/dist/index75.mjs.map +1 -1
- package/dist/index76.cjs +1 -1
- package/dist/index76.mjs +1 -1
- package/dist/index77.cjs +1 -1
- package/dist/index77.mjs +1 -1
- package/dist/index78.cjs +1 -1
- package/dist/index78.mjs +1 -1
- package/dist/index79.cjs +1 -1
- package/dist/index79.mjs +1 -1
- package/dist/index8.cjs +1 -1
- package/dist/index8.mjs +1 -1
- package/dist/index80.cjs +1 -1
- package/dist/index80.mjs +1 -1
- package/dist/index81.cjs +1 -1
- package/dist/index81.mjs +1 -1
- package/dist/index82.cjs +1 -1
- package/dist/index82.mjs +2 -2
- package/dist/index9.cjs +1 -1
- package/dist/index9.mjs +1 -1
- package/dist/index97.cjs +1 -1
- package/dist/index97.cjs.map +1 -1
- package/dist/index97.mjs +62 -154
- package/dist/index97.mjs.map +1 -1
- package/dist/index98.cjs +1 -1
- package/dist/index98.cjs.map +1 -1
- package/dist/index98.mjs +138 -202
- package/dist/index98.mjs.map +1 -1
- package/dist/index99.cjs +1 -1
- package/dist/index99.cjs.map +1 -1
- package/dist/index99.mjs +218 -30
- package/dist/index99.mjs.map +1 -1
- package/package.json +1 -5
package/dist/index117.mjs
CHANGED
|
@@ -1,32 +1,37 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
1
|
+
import { jsxs as i, jsx as a, Fragment as c } from "react/jsx-runtime";
|
|
2
|
+
import { Bot as m } from "lucide-react";
|
|
3
|
+
import e from "./index116.mjs";
|
|
4
|
+
const o = ({
|
|
5
|
+
title: d = "AI Assistant",
|
|
6
|
+
subtitle: r,
|
|
7
|
+
avatar: l,
|
|
8
|
+
actions: s,
|
|
9
|
+
children: t,
|
|
10
|
+
className: h,
|
|
11
|
+
...n
|
|
12
|
+
}) => /* @__PURE__ */ i(
|
|
13
|
+
"div",
|
|
14
|
+
{
|
|
15
|
+
className: [e.header, h].filter(Boolean).join(" "),
|
|
16
|
+
...n,
|
|
17
|
+
children: [
|
|
18
|
+
/* @__PURE__ */ a("div", { className: e.headerAvatar, children: l || /* @__PURE__ */ a(
|
|
19
|
+
"div",
|
|
20
|
+
{
|
|
21
|
+
className: [e.messageAvatar, e.headerAvatarDefault].filter(Boolean).join(" "),
|
|
22
|
+
children: /* @__PURE__ */ a(m, { size: 20 })
|
|
23
|
+
}
|
|
24
|
+
) }),
|
|
25
|
+
/* @__PURE__ */ a("div", { className: e.headerContent, children: t || /* @__PURE__ */ i(c, { children: [
|
|
26
|
+
/* @__PURE__ */ a("h2", { className: e.headerTitle, children: d }),
|
|
27
|
+
r && /* @__PURE__ */ a("p", { className: e.headerSubtitle, children: r })
|
|
28
|
+
] }) }),
|
|
29
|
+
s && /* @__PURE__ */ a("div", { className: e.headerActions, children: s })
|
|
30
|
+
]
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
o.displayName = "ChatHeader";
|
|
16
34
|
export {
|
|
17
|
-
|
|
18
|
-
m as default,
|
|
19
|
-
i as inverse,
|
|
20
|
-
p as label,
|
|
21
|
-
o as lg,
|
|
22
|
-
r as md,
|
|
23
|
-
l as neutral,
|
|
24
|
-
x as primary,
|
|
25
|
-
a as secondary,
|
|
26
|
-
t as sm,
|
|
27
|
-
n as spin,
|
|
28
|
-
_ as spinner,
|
|
29
|
-
c as xl,
|
|
30
|
-
e as xs
|
|
35
|
+
o as ChatHeader
|
|
31
36
|
};
|
|
32
37
|
//# sourceMappingURL=index117.mjs.map
|
package/dist/index117.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index117.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index117.mjs","sources":["../src/components/Chat/components/ChatHeader.tsx"],"sourcesContent":["/**\n * ChatHeader Component\n *\n * Header bar with title, avatar, and action buttons.\n */\n\nimport React from \"react\";\nimport { Bot } from \"lucide-react\";\nimport type { ChatHeaderProps } from \"../Chat.types\";\nimport styles from \"../Chat.module.css\";\n\nexport const ChatHeader: React.FC<ChatHeaderProps> = ({\n title = \"AI Assistant\",\n subtitle,\n avatar,\n actions,\n children,\n className,\n ...rest\n}) => {\n return (\n <div\n className={[styles.header, className].filter(Boolean).join(\" \")}\n {...rest}\n >\n {/* Avatar */}\n <div className={styles.headerAvatar}>\n {avatar || (\n <div\n className={[styles.messageAvatar, styles.headerAvatarDefault]\n .filter(Boolean)\n .join(\" \")}\n >\n <Bot size={20} />\n </div>\n )}\n </div>\n\n {/* Title/Subtitle */}\n <div className={styles.headerContent}>\n {children || (\n <>\n <h2 className={styles.headerTitle}>{title}</h2>\n {subtitle && <p className={styles.headerSubtitle}>{subtitle}</p>}\n </>\n )}\n </div>\n\n {/* Actions */}\n {actions && <div className={styles.headerActions}>{actions}</div>}\n </div>\n );\n};\n\nChatHeader.displayName = \"ChatHeader\";\n"],"names":["ChatHeader","title","subtitle","avatar","actions","children","className","rest","jsxs","styles","jsx","Bot","Fragment"],"mappings":";;;AAWO,MAAMA,IAAwC,CAAC;AAAA,EACpD,OAAAC,IAAQ;AAAA,EACR,UAAAC;AAAA,EACA,QAAAC;AAAA,EACA,SAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,GAAGC;AACL,MAEI,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,WAAW,CAACC,EAAO,QAAQH,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,IAC7D,GAAGC;AAAA,IAGJ,UAAA;AAAA,MAAA,gBAAAG,EAAC,OAAA,EAAI,WAAWD,EAAO,cACpB,UAAAN,KACC,gBAAAO;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAW,CAACD,EAAO,eAAeA,EAAO,mBAAmB,EACzD,OAAO,OAAO,EACd,KAAK,GAAG;AAAA,UAEX,UAAA,gBAAAC,EAACC,GAAA,EAAI,MAAM,GAAA,CAAI;AAAA,QAAA;AAAA,MAAA,GAGrB;AAAA,wBAGC,OAAA,EAAI,WAAWF,EAAO,eACpB,eACC,gBAAAD,EAAAI,GAAA,EACE,UAAA;AAAA,QAAA,gBAAAF,EAAC,MAAA,EAAG,WAAWD,EAAO,aAAc,UAAAR,GAAM;AAAA,QACzCC,KAAY,gBAAAQ,EAAC,KAAA,EAAE,WAAWD,EAAO,gBAAiB,UAAAP,EAAA,CAAS;AAAA,MAAA,EAAA,CAC9D,EAAA,CAEJ;AAAA,MAGCE,KAAW,gBAAAM,EAAC,OAAA,EAAI,WAAWD,EAAO,eAAgB,UAAAL,EAAA,CAAQ;AAAA,IAAA;AAAA,EAAA;AAAA;AAKjEJ,EAAW,cAAc;"}
|
package/dist/index118.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),g=require("react"),f=require("lucide-react"),h=require("./index84.cjs"),t=require("./index116.cjs"),j=require("./index14.cjs"),a=g.forwardRef(({children:l,autoScroll:r=!0,className:i,...n},s)=>{const{scrollRef:c,isAtBottom:u,scrollToBottom:m}=h.useAutoScroll({enabled:r}),d=o=>{c.current=o,typeof s=="function"?s(o):s&&(s.current=o)};return e.jsxs("div",{ref:d,className:[t.default.messages,i].filter(Boolean).join(" "),role:"log","aria-live":"polite","aria-label":"Chat messages","aria-relevant":"additions",...n,children:[e.jsx("div",{className:t.default.messagesInner,children:l}),!u&&e.jsx("div",{className:t.default.scrollToBottomWrapper,children:e.jsx(j.Button,{variant:"secondary",size:"sm",iconOnly:!0,icon:e.jsx(f.ArrowDown,{size:18}),onClick:m,"aria-label":"Scroll to latest messages",className:t.default.scrollToBottomButton})})]})});a.displayName="ChatMessages";exports.ChatMessages=a;
|
|
2
2
|
//# sourceMappingURL=index118.cjs.map
|
package/dist/index118.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index118.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index118.cjs","sources":["../src/components/Chat/components/ChatMessages.tsx"],"sourcesContent":["/**\n * ChatMessages Component\n *\n * Scrollable container for chat messages with auto-scroll support\n * and accessibility features.\n */\n\nimport React, { forwardRef } from \"react\";\nimport { ArrowDown } from \"lucide-react\";\nimport type { ChatMessagesProps } from \"../Chat.types\";\nimport { useAutoScroll } from \"../hooks/useAutoScroll\";\nimport { Button } from \"../../Button\";\nimport styles from \"../Chat.module.css\";\n\nexport const ChatMessages = forwardRef<HTMLDivElement, ChatMessagesProps>(\n ({ children, autoScroll = true, className, ...rest }, forwardedRef) => {\n const { scrollRef, isAtBottom, scrollToBottom } = useAutoScroll({\n enabled: autoScroll,\n });\n\n // Combine refs\n const handleRef = (node: HTMLDivElement | null) => {\n // Set internal ref\n (scrollRef as React.MutableRefObject<HTMLDivElement | null>).current =\n node;\n\n // Forward ref\n if (typeof forwardedRef === \"function\") {\n forwardedRef(node);\n } else if (forwardedRef) {\n forwardedRef.current = node;\n }\n };\n\n return (\n <div\n ref={handleRef}\n className={[styles.messages, className].filter(Boolean).join(\" \")}\n role=\"log\"\n aria-live=\"polite\"\n aria-label=\"Chat messages\"\n aria-relevant=\"additions\"\n {...rest}\n >\n <div className={styles.messagesInner}>{children}</div>\n\n {/* Scroll to bottom button (shown when not at bottom) */}\n {!isAtBottom && (\n <div className={styles.scrollToBottomWrapper}>\n <Button\n variant=\"secondary\"\n size=\"sm\"\n iconOnly\n icon={<ArrowDown size={18} />}\n onClick={scrollToBottom}\n aria-label=\"Scroll to latest messages\"\n className={styles.scrollToBottomButton}\n />\n </div>\n )}\n </div>\n );\n },\n);\n\nChatMessages.displayName = \"ChatMessages\";\n"],"names":["ChatMessages","forwardRef","children","autoScroll","className","rest","forwardedRef","scrollRef","isAtBottom","scrollToBottom","useAutoScroll","handleRef","node","jsxs","styles","jsx","Button","ArrowDown"],"mappings":"oPAcaA,EAAeC,EAAAA,WAC1B,CAAC,CAAE,SAAAC,EAAU,WAAAC,EAAa,GAAM,UAAAC,EAAW,GAAGC,CAAA,EAAQC,IAAiB,CACrE,KAAM,CAAE,UAAAC,EAAW,WAAAC,EAAY,eAAAC,CAAA,EAAmBC,EAAAA,cAAc,CAC9D,QAASP,CAAA,CACV,EAGKQ,EAAaC,GAAgC,CAEhDL,EAA4D,QAC3DK,EAGE,OAAON,GAAiB,WAC1BA,EAAaM,CAAI,EACRN,IACTA,EAAa,QAAUM,EAE3B,EAEA,OACEC,EAAAA,KAAC,MAAA,CACC,IAAKF,EACL,UAAW,CAACG,UAAO,SAAUV,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,EAChE,KAAK,MACL,YAAU,SACV,aAAW,gBACX,gBAAc,YACb,GAAGC,EAEJ,SAAA,CAAAU,EAAAA,IAAC,MAAA,CAAI,UAAWD,EAAAA,QAAO,cAAgB,SAAAZ,EAAS,EAG/C,CAACM,GACAO,EAAAA,IAAC,MAAA,CAAI,UAAWD,UAAO,sBACrB,SAAAC,EAAAA,IAACC,EAAAA,OAAA,CACC,QAAQ,YACR,KAAK,KACL,SAAQ,GACR,KAAMD,EAAAA,IAACE,EAAAA,UAAA,CAAU,KAAM,EAAA,CAAI,EAC3B,QAASR,EACT,aAAW,4BACX,UAAWK,EAAAA,QAAO,oBAAA,CAAA,CACpB,CACF,CAAA,CAAA,CAAA,CAIR,CACF,EAEAd,EAAa,YAAc"}
|
package/dist/index118.mjs
CHANGED
|
@@ -1,34 +1,47 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
1
|
+
import { jsxs as p, jsx as s } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as f } from "react";
|
|
3
|
+
import { ArrowDown as u } from "lucide-react";
|
|
4
|
+
import { useAutoScroll as g } from "./index84.mjs";
|
|
5
|
+
import e from "./index116.mjs";
|
|
6
|
+
import { Button as h } from "./index14.mjs";
|
|
7
|
+
const B = f(
|
|
8
|
+
({ children: r, autoScroll: a = !0, className: l, ...i }, o) => {
|
|
9
|
+
const { scrollRef: m, isAtBottom: n, scrollToBottom: c } = g({
|
|
10
|
+
enabled: a
|
|
11
|
+
});
|
|
12
|
+
return /* @__PURE__ */ p(
|
|
13
|
+
"div",
|
|
14
|
+
{
|
|
15
|
+
ref: (t) => {
|
|
16
|
+
m.current = t, typeof o == "function" ? o(t) : o && (o.current = t);
|
|
17
|
+
},
|
|
18
|
+
className: [e.messages, l].filter(Boolean).join(" "),
|
|
19
|
+
role: "log",
|
|
20
|
+
"aria-live": "polite",
|
|
21
|
+
"aria-label": "Chat messages",
|
|
22
|
+
"aria-relevant": "additions",
|
|
23
|
+
...i,
|
|
24
|
+
children: [
|
|
25
|
+
/* @__PURE__ */ s("div", { className: e.messagesInner, children: r }),
|
|
26
|
+
!n && /* @__PURE__ */ s("div", { className: e.scrollToBottomWrapper, children: /* @__PURE__ */ s(
|
|
27
|
+
h,
|
|
28
|
+
{
|
|
29
|
+
variant: "secondary",
|
|
30
|
+
size: "sm",
|
|
31
|
+
iconOnly: !0,
|
|
32
|
+
icon: /* @__PURE__ */ s(u, { size: 18 }),
|
|
33
|
+
onClick: c,
|
|
34
|
+
"aria-label": "Scroll to latest messages",
|
|
35
|
+
className: e.scrollToBottomButton
|
|
36
|
+
}
|
|
37
|
+
) })
|
|
38
|
+
]
|
|
39
|
+
}
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
);
|
|
43
|
+
B.displayName = "ChatMessages";
|
|
17
44
|
export {
|
|
18
|
-
|
|
19
|
-
e as container,
|
|
20
|
-
d as default,
|
|
21
|
-
m as error,
|
|
22
|
-
g as indeterminate,
|
|
23
|
-
l as info,
|
|
24
|
-
c as labelWrapper,
|
|
25
|
-
a as lg,
|
|
26
|
-
s as md,
|
|
27
|
-
_ as percentage,
|
|
28
|
-
p as primary,
|
|
29
|
-
t as sm,
|
|
30
|
-
o as success,
|
|
31
|
-
r as track,
|
|
32
|
-
i as warning
|
|
45
|
+
B as ChatMessages
|
|
33
46
|
};
|
|
34
47
|
//# sourceMappingURL=index118.mjs.map
|
package/dist/index118.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index118.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index118.mjs","sources":["../src/components/Chat/components/ChatMessages.tsx"],"sourcesContent":["/**\n * ChatMessages Component\n *\n * Scrollable container for chat messages with auto-scroll support\n * and accessibility features.\n */\n\nimport React, { forwardRef } from \"react\";\nimport { ArrowDown } from \"lucide-react\";\nimport type { ChatMessagesProps } from \"../Chat.types\";\nimport { useAutoScroll } from \"../hooks/useAutoScroll\";\nimport { Button } from \"../../Button\";\nimport styles from \"../Chat.module.css\";\n\nexport const ChatMessages = forwardRef<HTMLDivElement, ChatMessagesProps>(\n ({ children, autoScroll = true, className, ...rest }, forwardedRef) => {\n const { scrollRef, isAtBottom, scrollToBottom } = useAutoScroll({\n enabled: autoScroll,\n });\n\n // Combine refs\n const handleRef = (node: HTMLDivElement | null) => {\n // Set internal ref\n (scrollRef as React.MutableRefObject<HTMLDivElement | null>).current =\n node;\n\n // Forward ref\n if (typeof forwardedRef === \"function\") {\n forwardedRef(node);\n } else if (forwardedRef) {\n forwardedRef.current = node;\n }\n };\n\n return (\n <div\n ref={handleRef}\n className={[styles.messages, className].filter(Boolean).join(\" \")}\n role=\"log\"\n aria-live=\"polite\"\n aria-label=\"Chat messages\"\n aria-relevant=\"additions\"\n {...rest}\n >\n <div className={styles.messagesInner}>{children}</div>\n\n {/* Scroll to bottom button (shown when not at bottom) */}\n {!isAtBottom && (\n <div className={styles.scrollToBottomWrapper}>\n <Button\n variant=\"secondary\"\n size=\"sm\"\n iconOnly\n icon={<ArrowDown size={18} />}\n onClick={scrollToBottom}\n aria-label=\"Scroll to latest messages\"\n className={styles.scrollToBottomButton}\n />\n </div>\n )}\n </div>\n );\n },\n);\n\nChatMessages.displayName = \"ChatMessages\";\n"],"names":["ChatMessages","forwardRef","children","autoScroll","className","rest","forwardedRef","scrollRef","isAtBottom","scrollToBottom","useAutoScroll","jsxs","node","styles","jsx","Button","ArrowDown"],"mappings":";;;;;;AAcO,MAAMA,IAAeC;AAAA,EAC1B,CAAC,EAAE,UAAAC,GAAU,YAAAC,IAAa,IAAM,WAAAC,GAAW,GAAGC,EAAA,GAAQC,MAAiB;AACrE,UAAM,EAAE,WAAAC,GAAW,YAAAC,GAAY,gBAAAC,EAAA,IAAmBC,EAAc;AAAA,MAC9D,SAASP;AAAA,IAAA,CACV;AAgBD,WACE,gBAAAQ;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAfc,CAACC,MAAgC;AAEhD,UAAAL,EAA4D,UAC3DK,GAGE,OAAON,KAAiB,aAC1BA,EAAaM,CAAI,IACRN,MACTA,EAAa,UAAUM;AAAA,QAE3B;AAAA,QAKI,WAAW,CAACC,EAAO,UAAUT,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,QAChE,MAAK;AAAA,QACL,aAAU;AAAA,QACV,cAAW;AAAA,QACX,iBAAc;AAAA,QACb,GAAGC;AAAA,QAEJ,UAAA;AAAA,UAAA,gBAAAS,EAAC,OAAA,EAAI,WAAWD,EAAO,eAAgB,UAAAX,GAAS;AAAA,UAG/C,CAACM,KACA,gBAAAM,EAAC,OAAA,EAAI,WAAWD,EAAO,uBACrB,UAAA,gBAAAC;AAAA,YAACC;AAAA,YAAA;AAAA,cACC,SAAQ;AAAA,cACR,MAAK;AAAA,cACL,UAAQ;AAAA,cACR,MAAM,gBAAAD,EAACE,GAAA,EAAU,MAAM,GAAA,CAAI;AAAA,cAC3B,SAASP;AAAA,cACT,cAAW;AAAA,cACX,WAAWI,EAAO;AAAA,YAAA;AAAA,UAAA,EACpB,CACF;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AACF;AAEAb,EAAa,cAAc;"}
|
package/dist/index119.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("react/jsx-runtime"),t=require("lucide-react"),p=require("./index123.cjs"),y=require("./index128.cjs"),e=require("./index116.cjs"),R=a=>a?new Intl.DateTimeFormat("en-US",{hour:"numeric",minute:"2-digit",hour12:!0}).format(a):"",S=a=>{switch(a){case"sending":return s.jsx(t.Clock,{size:12});case"sent":return s.jsx(t.Check,{size:12});case"error":return s.jsx(t.AlertCircle,{size:12});default:return null}},b=({role:a,content:u,timestamp:m,status:i,attachments:d,avatar:C,showAvatar:N,actions:c,isStreaming:k,onImageClick:f,onRetry:g,reaction:l,onReaction:o,children:j,className:h,...x})=>{const r=a==="user",A=a==="system",v=a==="assistant",B=N??!1;return A?s.jsx("div",{className:[e.default.message,h].filter(Boolean).join(" "),role:"listitem",...x,children:s.jsx("div",{className:e.default.messageContent,children:s.jsx("div",{className:e.default.messageBubbleSystem,children:j||u})})}):s.jsxs("div",{className:[e.default.message,r&&e.default.messageUser,v&&e.default.messageAssistant,h].filter(Boolean).join(" "),role:"listitem",...x,children:[B&&s.jsx("div",{className:[e.default.messageAvatar,r?e.default.messageAvatarUser:e.default.messageAvatarAssistant].filter(Boolean).join(" "),"aria-hidden":"true",children:C||(r?s.jsx(t.User,{size:18}):s.jsx(t.Bot,{size:18}))}),s.jsxs("div",{className:e.default.messageContent,children:[s.jsxs("div",{className:[e.default.messageBubble,r?e.default.messageBubbleUser:e.default.messageBubbleAssistant].filter(Boolean).join(" "),children:[j||s.jsx(p.ChatMarkdown,{content:u,className:r?e.default.markdownUser:void 0}),k&&s.jsx("span",{className:e.default.streamingCursor})]}),d&&d.length>0&&s.jsx("div",{className:e.default.messageAttachments,children:d.map(n=>s.jsx(y.ChatAttachment,{attachment:n,onClick:n.type==="image"&&f?()=>f(n):void 0},n.id))}),s.jsxs("div",{className:e.default.messageFooter,children:[m&&s.jsx("span",{className:e.default.messageTimestamp,children:R(m)}),i&&s.jsxs("span",{className:[e.default.messageStatus,i==="error"&&e.default.messageStatusError].filter(Boolean).join(" "),children:[S(i),i==="error"&&"Failed to send"]}),i==="error"&&g&&s.jsxs("button",{className:e.default.messageRetry,onClick:g,"aria-label":"Retry sending message",children:[s.jsx(t.RotateCcw,{size:12}),"Retry"]}),c&&s.jsx("div",{className:e.default.messageActions,children:c}),v&&o&&s.jsxs("div",{className:[e.default.messageReactions,l&&e.default.messageReactionsVisible].filter(Boolean).join(" "),children:[s.jsx("button",{className:[e.default.messageReactionButton,l==="like"&&e.default.messageReactionActive].filter(Boolean).join(" "),onClick:()=>o("like"),"aria-label":"Like this response","aria-pressed":l==="like",children:s.jsx(t.ThumbsUp,{size:14})}),s.jsx("button",{className:[e.default.messageReactionButton,l==="dislike"&&e.default.messageReactionActive].filter(Boolean).join(" "),onClick:()=>o("dislike"),"aria-label":"Dislike this response","aria-pressed":l==="dislike",children:s.jsx(t.ThumbsDown,{size:14})})]})]})]})]})};b.displayName="ChatMessage";exports.ChatMessage=b;
|
|
2
2
|
//# sourceMappingURL=index119.cjs.map
|
package/dist/index119.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index119.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index119.cjs","sources":["../src/components/Chat/components/ChatMessage.tsx"],"sourcesContent":["/**\n * ChatMessage Component\n *\n * Individual message bubble with support for text, markdown,\n * attachments, reactions, retry, and various states.\n */\n\nimport React from \"react\";\nimport {\n User,\n Bot,\n AlertCircle,\n Check,\n Clock,\n RotateCcw,\n ThumbsUp,\n ThumbsDown,\n} from \"lucide-react\";\nimport type { ChatMessageProps } from \"../Chat.types\";\nimport { ChatMarkdown } from \"./ChatMarkdown\";\nimport { ChatAttachment } from \"./ChatAttachment\";\nimport styles from \"../Chat.module.css\";\n\n// Format timestamp\nconst formatTimestamp = (date?: Date): string => {\n if (!date) return \"\";\n return new Intl.DateTimeFormat(\"en-US\", {\n hour: \"numeric\",\n minute: \"2-digit\",\n hour12: true,\n }).format(date);\n};\n\n// Get status icon\nconst getStatusIcon = (status?: string) => {\n switch (status) {\n case \"sending\":\n return <Clock size={12} />;\n case \"sent\":\n return <Check size={12} />;\n case \"error\":\n return <AlertCircle size={12} />;\n default:\n return null;\n }\n};\n\nexport const ChatMessage: React.FC<ChatMessageProps> = ({\n role,\n content,\n timestamp,\n status,\n attachments,\n avatar,\n showAvatar,\n actions,\n isStreaming,\n onImageClick,\n onRetry,\n reaction,\n onReaction,\n children,\n className,\n ...rest\n}) => {\n const isUser = role === \"user\";\n const isSystem = role === \"system\";\n const isAssistant = role === \"assistant\";\n const shouldShowAvatar = showAvatar ?? false;\n\n // System messages have a different layout\n if (isSystem) {\n return (\n <div\n className={[styles.message, className].filter(Boolean).join(\" \")}\n role=\"listitem\"\n {...rest}\n >\n <div className={styles.messageContent}>\n <div className={styles.messageBubbleSystem}>\n {children || content}\n </div>\n </div>\n </div>\n );\n }\n\n return (\n <div\n className={[\n styles.message,\n isUser && styles.messageUser,\n isAssistant && styles.messageAssistant,\n className,\n ]\n .filter(Boolean)\n .join(\" \")}\n role=\"listitem\"\n {...rest}\n >\n {/* Avatar */}\n {shouldShowAvatar && (\n <div\n className={[\n styles.messageAvatar,\n isUser ? styles.messageAvatarUser : styles.messageAvatarAssistant,\n ]\n .filter(Boolean)\n .join(\" \")}\n aria-hidden=\"true\"\n >\n {avatar || (isUser ? <User size={18} /> : <Bot size={18} />)}\n </div>\n )}\n\n {/* Content */}\n <div className={styles.messageContent}>\n {/* Message bubble */}\n <div\n className={[\n styles.messageBubble,\n isUser ? styles.messageBubbleUser : styles.messageBubbleAssistant,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n {children || (\n <ChatMarkdown\n content={content}\n className={isUser ? styles.markdownUser : undefined}\n />\n )}\n\n {/* Streaming cursor */}\n {isStreaming && <span className={styles.streamingCursor} />}\n </div>\n\n {/* Attachments */}\n {attachments && attachments.length > 0 && (\n <div className={styles.messageAttachments}>\n {attachments.map((attachment) => (\n <ChatAttachment\n key={attachment.id}\n attachment={attachment}\n onClick={\n attachment.type === \"image\" && onImageClick\n ? () => onImageClick(attachment)\n : undefined\n }\n />\n ))}\n </div>\n )}\n\n {/* Footer (timestamp, status, actions, reactions) */}\n <div className={styles.messageFooter}>\n {timestamp && (\n <span className={styles.messageTimestamp}>\n {formatTimestamp(timestamp)}\n </span>\n )}\n\n {status && (\n <span\n className={[\n styles.messageStatus,\n status === \"error\" && styles.messageStatusError,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n {getStatusIcon(status)}\n {status === \"error\" && \"Failed to send\"}\n </span>\n )}\n\n {/* Retry button for failed messages */}\n {status === \"error\" && onRetry && (\n <button\n className={styles.messageRetry}\n onClick={onRetry}\n aria-label=\"Retry sending message\"\n >\n <RotateCcw size={12} />\n Retry\n </button>\n )}\n\n {actions && <div className={styles.messageActions}>{actions}</div>}\n\n {/* Reactions for assistant messages */}\n {isAssistant && onReaction && (\n <div\n className={[\n styles.messageReactions,\n reaction && styles.messageReactionsVisible,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n <button\n className={[\n styles.messageReactionButton,\n reaction === \"like\" && styles.messageReactionActive,\n ]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => onReaction(\"like\")}\n aria-label=\"Like this response\"\n aria-pressed={reaction === \"like\"}\n >\n <ThumbsUp size={14} />\n </button>\n <button\n className={[\n styles.messageReactionButton,\n reaction === \"dislike\" && styles.messageReactionActive,\n ]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => onReaction(\"dislike\")}\n aria-label=\"Dislike this response\"\n aria-pressed={reaction === \"dislike\"}\n >\n <ThumbsDown size={14} />\n </button>\n </div>\n )}\n </div>\n </div>\n </div>\n );\n};\n\nChatMessage.displayName = \"ChatMessage\";\n"],"names":["formatTimestamp","date","getStatusIcon","status","jsx","Clock","Check","AlertCircle","ChatMessage","role","content","timestamp","attachments","avatar","showAvatar","actions","isStreaming","onImageClick","onRetry","reaction","onReaction","children","className","rest","isUser","isSystem","isAssistant","shouldShowAvatar","styles","jsxs","User","Bot","ChatMarkdown","attachment","ChatAttachment","RotateCcw","ThumbsUp","ThumbsDown"],"mappings":"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"}
|
package/dist/index119.mjs
CHANGED
|
@@ -1,26 +1,174 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
1
|
+
import { jsx as s, jsxs as i } from "react/jsx-runtime";
|
|
2
|
+
import { User as j, Bot as y, RotateCcw as z, ThumbsUp as U, ThumbsDown as w, AlertCircle as R, Check as S, Clock as T } from "lucide-react";
|
|
3
|
+
import { ChatMarkdown as x } from "./index123.mjs";
|
|
4
|
+
import { ChatAttachment as D } from "./index128.mjs";
|
|
5
|
+
import e from "./index116.mjs";
|
|
6
|
+
const F = (a) => a ? new Intl.DateTimeFormat("en-US", {
|
|
7
|
+
hour: "numeric",
|
|
8
|
+
minute: "2-digit",
|
|
9
|
+
hour12: !0
|
|
10
|
+
}).format(a) : "", M = (a) => {
|
|
11
|
+
switch (a) {
|
|
12
|
+
case "sending":
|
|
13
|
+
return /* @__PURE__ */ s(T, { size: 12 });
|
|
14
|
+
case "sent":
|
|
15
|
+
return /* @__PURE__ */ s(S, { size: 12 });
|
|
16
|
+
case "error":
|
|
17
|
+
return /* @__PURE__ */ s(R, { size: 12 });
|
|
18
|
+
default:
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
}, E = ({
|
|
22
|
+
role: a,
|
|
23
|
+
content: c,
|
|
24
|
+
timestamp: d,
|
|
25
|
+
status: r,
|
|
26
|
+
attachments: o,
|
|
27
|
+
avatar: b,
|
|
28
|
+
showAvatar: k,
|
|
29
|
+
actions: g,
|
|
30
|
+
isStreaming: B,
|
|
31
|
+
onImageClick: u,
|
|
32
|
+
onRetry: h,
|
|
33
|
+
reaction: l,
|
|
34
|
+
onReaction: m,
|
|
35
|
+
children: f,
|
|
36
|
+
className: v,
|
|
37
|
+
...p
|
|
38
|
+
}) => {
|
|
39
|
+
const t = a === "user", A = a === "system", N = a === "assistant", C = k ?? !1;
|
|
40
|
+
return A ? /* @__PURE__ */ s(
|
|
41
|
+
"div",
|
|
42
|
+
{
|
|
43
|
+
className: [e.message, v].filter(Boolean).join(" "),
|
|
44
|
+
role: "listitem",
|
|
45
|
+
...p,
|
|
46
|
+
children: /* @__PURE__ */ s("div", { className: e.messageContent, children: /* @__PURE__ */ s("div", { className: e.messageBubbleSystem, children: f || c }) })
|
|
47
|
+
}
|
|
48
|
+
) : /* @__PURE__ */ i(
|
|
49
|
+
"div",
|
|
50
|
+
{
|
|
51
|
+
className: [
|
|
52
|
+
e.message,
|
|
53
|
+
t && e.messageUser,
|
|
54
|
+
N && e.messageAssistant,
|
|
55
|
+
v
|
|
56
|
+
].filter(Boolean).join(" "),
|
|
57
|
+
role: "listitem",
|
|
58
|
+
...p,
|
|
59
|
+
children: [
|
|
60
|
+
C && /* @__PURE__ */ s(
|
|
61
|
+
"div",
|
|
62
|
+
{
|
|
63
|
+
className: [
|
|
64
|
+
e.messageAvatar,
|
|
65
|
+
t ? e.messageAvatarUser : e.messageAvatarAssistant
|
|
66
|
+
].filter(Boolean).join(" "),
|
|
67
|
+
"aria-hidden": "true",
|
|
68
|
+
children: b || (t ? /* @__PURE__ */ s(j, { size: 18 }) : /* @__PURE__ */ s(y, { size: 18 }))
|
|
69
|
+
}
|
|
70
|
+
),
|
|
71
|
+
/* @__PURE__ */ i("div", { className: e.messageContent, children: [
|
|
72
|
+
/* @__PURE__ */ i(
|
|
73
|
+
"div",
|
|
74
|
+
{
|
|
75
|
+
className: [
|
|
76
|
+
e.messageBubble,
|
|
77
|
+
t ? e.messageBubbleUser : e.messageBubbleAssistant
|
|
78
|
+
].filter(Boolean).join(" "),
|
|
79
|
+
children: [
|
|
80
|
+
f || /* @__PURE__ */ s(
|
|
81
|
+
x,
|
|
82
|
+
{
|
|
83
|
+
content: c,
|
|
84
|
+
className: t ? e.markdownUser : void 0
|
|
85
|
+
}
|
|
86
|
+
),
|
|
87
|
+
B && /* @__PURE__ */ s("span", { className: e.streamingCursor })
|
|
88
|
+
]
|
|
89
|
+
}
|
|
90
|
+
),
|
|
91
|
+
o && o.length > 0 && /* @__PURE__ */ s("div", { className: e.messageAttachments, children: o.map((n) => /* @__PURE__ */ s(
|
|
92
|
+
D,
|
|
93
|
+
{
|
|
94
|
+
attachment: n,
|
|
95
|
+
onClick: n.type === "image" && u ? () => u(n) : void 0
|
|
96
|
+
},
|
|
97
|
+
n.id
|
|
98
|
+
)) }),
|
|
99
|
+
/* @__PURE__ */ i("div", { className: e.messageFooter, children: [
|
|
100
|
+
d && /* @__PURE__ */ s("span", { className: e.messageTimestamp, children: F(d) }),
|
|
101
|
+
r && /* @__PURE__ */ i(
|
|
102
|
+
"span",
|
|
103
|
+
{
|
|
104
|
+
className: [
|
|
105
|
+
e.messageStatus,
|
|
106
|
+
r === "error" && e.messageStatusError
|
|
107
|
+
].filter(Boolean).join(" "),
|
|
108
|
+
children: [
|
|
109
|
+
M(r),
|
|
110
|
+
r === "error" && "Failed to send"
|
|
111
|
+
]
|
|
112
|
+
}
|
|
113
|
+
),
|
|
114
|
+
r === "error" && h && /* @__PURE__ */ i(
|
|
115
|
+
"button",
|
|
116
|
+
{
|
|
117
|
+
className: e.messageRetry,
|
|
118
|
+
onClick: h,
|
|
119
|
+
"aria-label": "Retry sending message",
|
|
120
|
+
children: [
|
|
121
|
+
/* @__PURE__ */ s(z, { size: 12 }),
|
|
122
|
+
"Retry"
|
|
123
|
+
]
|
|
124
|
+
}
|
|
125
|
+
),
|
|
126
|
+
g && /* @__PURE__ */ s("div", { className: e.messageActions, children: g }),
|
|
127
|
+
N && m && /* @__PURE__ */ i(
|
|
128
|
+
"div",
|
|
129
|
+
{
|
|
130
|
+
className: [
|
|
131
|
+
e.messageReactions,
|
|
132
|
+
l && e.messageReactionsVisible
|
|
133
|
+
].filter(Boolean).join(" "),
|
|
134
|
+
children: [
|
|
135
|
+
/* @__PURE__ */ s(
|
|
136
|
+
"button",
|
|
137
|
+
{
|
|
138
|
+
className: [
|
|
139
|
+
e.messageReactionButton,
|
|
140
|
+
l === "like" && e.messageReactionActive
|
|
141
|
+
].filter(Boolean).join(" "),
|
|
142
|
+
onClick: () => m("like"),
|
|
143
|
+
"aria-label": "Like this response",
|
|
144
|
+
"aria-pressed": l === "like",
|
|
145
|
+
children: /* @__PURE__ */ s(U, { size: 14 })
|
|
146
|
+
}
|
|
147
|
+
),
|
|
148
|
+
/* @__PURE__ */ s(
|
|
149
|
+
"button",
|
|
150
|
+
{
|
|
151
|
+
className: [
|
|
152
|
+
e.messageReactionButton,
|
|
153
|
+
l === "dislike" && e.messageReactionActive
|
|
154
|
+
].filter(Boolean).join(" "),
|
|
155
|
+
onClick: () => m("dislike"),
|
|
156
|
+
"aria-label": "Dislike this response",
|
|
157
|
+
"aria-pressed": l === "dislike",
|
|
158
|
+
children: /* @__PURE__ */ s(w, { size: 14 })
|
|
159
|
+
}
|
|
160
|
+
)
|
|
161
|
+
]
|
|
162
|
+
}
|
|
163
|
+
)
|
|
164
|
+
] })
|
|
165
|
+
] })
|
|
166
|
+
]
|
|
167
|
+
}
|
|
168
|
+
);
|
|
12
169
|
};
|
|
170
|
+
E.displayName = "ChatMessage";
|
|
13
171
|
export {
|
|
14
|
-
|
|
15
|
-
e as closeButton,
|
|
16
|
-
n as content,
|
|
17
|
-
i as default,
|
|
18
|
-
a as error,
|
|
19
|
-
t as icon,
|
|
20
|
-
r as info,
|
|
21
|
-
_ as message,
|
|
22
|
-
c as success,
|
|
23
|
-
o as title,
|
|
24
|
-
y as warning
|
|
172
|
+
E as ChatMessage
|
|
25
173
|
};
|
|
26
174
|
//# sourceMappingURL=index119.mjs.map
|
package/dist/index119.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index119.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"index119.mjs","sources":["../src/components/Chat/components/ChatMessage.tsx"],"sourcesContent":["/**\n * ChatMessage Component\n *\n * Individual message bubble with support for text, markdown,\n * attachments, reactions, retry, and various states.\n */\n\nimport React from \"react\";\nimport {\n User,\n Bot,\n AlertCircle,\n Check,\n Clock,\n RotateCcw,\n ThumbsUp,\n ThumbsDown,\n} from \"lucide-react\";\nimport type { ChatMessageProps } from \"../Chat.types\";\nimport { ChatMarkdown } from \"./ChatMarkdown\";\nimport { ChatAttachment } from \"./ChatAttachment\";\nimport styles from \"../Chat.module.css\";\n\n// Format timestamp\nconst formatTimestamp = (date?: Date): string => {\n if (!date) return \"\";\n return new Intl.DateTimeFormat(\"en-US\", {\n hour: \"numeric\",\n minute: \"2-digit\",\n hour12: true,\n }).format(date);\n};\n\n// Get status icon\nconst getStatusIcon = (status?: string) => {\n switch (status) {\n case \"sending\":\n return <Clock size={12} />;\n case \"sent\":\n return <Check size={12} />;\n case \"error\":\n return <AlertCircle size={12} />;\n default:\n return null;\n }\n};\n\nexport const ChatMessage: React.FC<ChatMessageProps> = ({\n role,\n content,\n timestamp,\n status,\n attachments,\n avatar,\n showAvatar,\n actions,\n isStreaming,\n onImageClick,\n onRetry,\n reaction,\n onReaction,\n children,\n className,\n ...rest\n}) => {\n const isUser = role === \"user\";\n const isSystem = role === \"system\";\n const isAssistant = role === \"assistant\";\n const shouldShowAvatar = showAvatar ?? false;\n\n // System messages have a different layout\n if (isSystem) {\n return (\n <div\n className={[styles.message, className].filter(Boolean).join(\" \")}\n role=\"listitem\"\n {...rest}\n >\n <div className={styles.messageContent}>\n <div className={styles.messageBubbleSystem}>\n {children || content}\n </div>\n </div>\n </div>\n );\n }\n\n return (\n <div\n className={[\n styles.message,\n isUser && styles.messageUser,\n isAssistant && styles.messageAssistant,\n className,\n ]\n .filter(Boolean)\n .join(\" \")}\n role=\"listitem\"\n {...rest}\n >\n {/* Avatar */}\n {shouldShowAvatar && (\n <div\n className={[\n styles.messageAvatar,\n isUser ? styles.messageAvatarUser : styles.messageAvatarAssistant,\n ]\n .filter(Boolean)\n .join(\" \")}\n aria-hidden=\"true\"\n >\n {avatar || (isUser ? <User size={18} /> : <Bot size={18} />)}\n </div>\n )}\n\n {/* Content */}\n <div className={styles.messageContent}>\n {/* Message bubble */}\n <div\n className={[\n styles.messageBubble,\n isUser ? styles.messageBubbleUser : styles.messageBubbleAssistant,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n {children || (\n <ChatMarkdown\n content={content}\n className={isUser ? styles.markdownUser : undefined}\n />\n )}\n\n {/* Streaming cursor */}\n {isStreaming && <span className={styles.streamingCursor} />}\n </div>\n\n {/* Attachments */}\n {attachments && attachments.length > 0 && (\n <div className={styles.messageAttachments}>\n {attachments.map((attachment) => (\n <ChatAttachment\n key={attachment.id}\n attachment={attachment}\n onClick={\n attachment.type === \"image\" && onImageClick\n ? () => onImageClick(attachment)\n : undefined\n }\n />\n ))}\n </div>\n )}\n\n {/* Footer (timestamp, status, actions, reactions) */}\n <div className={styles.messageFooter}>\n {timestamp && (\n <span className={styles.messageTimestamp}>\n {formatTimestamp(timestamp)}\n </span>\n )}\n\n {status && (\n <span\n className={[\n styles.messageStatus,\n status === \"error\" && styles.messageStatusError,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n {getStatusIcon(status)}\n {status === \"error\" && \"Failed to send\"}\n </span>\n )}\n\n {/* Retry button for failed messages */}\n {status === \"error\" && onRetry && (\n <button\n className={styles.messageRetry}\n onClick={onRetry}\n aria-label=\"Retry sending message\"\n >\n <RotateCcw size={12} />\n Retry\n </button>\n )}\n\n {actions && <div className={styles.messageActions}>{actions}</div>}\n\n {/* Reactions for assistant messages */}\n {isAssistant && onReaction && (\n <div\n className={[\n styles.messageReactions,\n reaction && styles.messageReactionsVisible,\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n <button\n className={[\n styles.messageReactionButton,\n reaction === \"like\" && styles.messageReactionActive,\n ]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => onReaction(\"like\")}\n aria-label=\"Like this response\"\n aria-pressed={reaction === \"like\"}\n >\n <ThumbsUp size={14} />\n </button>\n <button\n className={[\n styles.messageReactionButton,\n reaction === \"dislike\" && styles.messageReactionActive,\n ]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => onReaction(\"dislike\")}\n aria-label=\"Dislike this response\"\n aria-pressed={reaction === \"dislike\"}\n >\n <ThumbsDown size={14} />\n </button>\n </div>\n )}\n </div>\n </div>\n </div>\n );\n};\n\nChatMessage.displayName = \"ChatMessage\";\n"],"names":["formatTimestamp","date","getStatusIcon","status","jsx","Clock","Check","AlertCircle","ChatMessage","role","content","timestamp","attachments","avatar","showAvatar","actions","isStreaming","onImageClick","onRetry","reaction","onReaction","children","className","rest","isUser","isSystem","isAssistant","shouldShowAvatar","styles","jsxs","User","Bot","ChatMarkdown","attachment","ChatAttachment","RotateCcw","ThumbsUp","ThumbsDown"],"mappings":"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"}
|
package/dist/index12.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),$=require("lucide-react"),s=require("./
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),$=require("lucide-react"),s=require("./index173.cjs"),l=require("./index14.cjs"),j=({eyebrow:a,title:x,description:c,ctaLabel:i,ctaHref:d,secondaryCtaLabel:n,secondaryCtaHref:r,variant:t="default",backgroundImage:o,sideImage:u,imagePosition:p="right",backgroundColor:m,gradient:h,dismissible:N=!1,onDismiss:B,fullWidth:g=!1,compact:v=!1,centered:y=!0,className:w,style:q,...k})=>{const S={...q,...o&&t==="image"&&{backgroundImage:`url(${o})`},...m&&{backgroundColor:m},...h&&t==="gradient"&&{background:h}},f=()=>e.jsxs("div",{className:s.default.content,children:[a&&e.jsx("span",{className:s.default.eyebrow,children:a}),e.jsx("h2",{className:s.default.title,children:x}),c&&e.jsx("p",{className:s.default.description,children:c}),(i||n)&&e.jsxs("div",{className:s.default.actions,children:[i&&d&&e.jsx(l.Button,{variant:t==="split"?"primary":"inverse",onClick:()=>window.location.href=d,children:i}),n&&r&&e.jsx(l.Button,{variant:t==="split"?"secondary":"ghost",onClick:()=>window.location.href=r,children:n})]})]});return e.jsxs("section",{className:`${s.default.banner} ${w||""}`,"data-variant":t,"data-compact":v,"data-centered":y&&t!=="split","data-full-width":g,style:S,...k,children:[e.jsx("div",{className:s.default.container,children:t==="split"&&u?e.jsxs("div",{className:s.default.splitLayout,"data-image-position":p,children:[e.jsx("div",{className:s.default.splitContent,children:f()}),e.jsx("img",{src:u,alt:"",className:s.default.splitImage,"aria-hidden":"true"})]}):f()}),N&&e.jsx("div",{className:s.default.dismissButton,children:e.jsx(l.Button,{iconOnly:!0,icon:e.jsx($.X,{size:20}),variant:"ghost",onClick:B,"aria-label":"Dismiss banner"})})]})};j.displayName="Banner";exports.Banner=j;
|
|
2
2
|
//# sourceMappingURL=index12.cjs.map
|
package/dist/index12.mjs
CHANGED
package/dist/index120.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),l=require("react"),o=require("lucide-react"),_=require("./index85.cjs"),$=require("./index126.cjs"),E=require("./index184.cjs"),a=require("./index116.cjs"),X=m=>m.type.startsWith("image/")?e.jsx(o.Image,{size:14}):e.jsx(o.File,{size:14}),y=l.forwardRef(({onSend:m,placeholder:R="Type a message...",allowAttachments:N=!0,allowVoiceRecording:S=!0,allowAudioUpload:G=!0,disabled:i=!1,maxLength:f,acceptedFileTypes:k=["image/*","audio/*",".pdf",".doc",".docx",".txt"],isLoading:s=!1,pendingAttachments:z,onRemoveAttachment:I,className:q,...w},r)=>{const[j,h]=l.useState(!1),u=l.useRef(null),{value:x,setValue:B,attachments:D,addAttachments:c,removeAttachment:F,handleSubmit:g,handleKeyDown:V,textareaRef:C,isEmpty:P}=_.useChatInput({maxLength:f,onSend:m,disabled:i||s}),d=z||D,M=I||F,T=l.useCallback(t=>{C.current=t,typeof r=="function"?r(t):r&&(r.current=t)},[r,C]),W=l.useCallback(t=>{const n=t.target.files;n&&n.length>0&&c(Array.from(n)),u.current&&(u.current.value="")},[c]),K=l.useCallback(t=>{const n=t.clipboardData.items,p=[];for(const v of n)if(v.type.startsWith("image/")){const A=v.getAsFile();A&&p.push(A)}p.length>0&&(t.preventDefault(),c(p))},[c]),O=l.useCallback(t=>{const n=Object.assign(t,{name:`voice-${Date.now()}.webm`,lastModified:Date.now()});c([n]),h(!1)},[c]),U=l.useCallback(()=>{i||s||g()},[i,s,g]),b=!P||d.length>0;return e.jsx("div",{className:[a.default.inputContainer,q].filter(Boolean).join(" "),children:e.jsxs("div",{className:a.default.inputWrapper,children:[d.length>0&&e.jsx("div",{className:a.default.pendingAttachments,children:d.map((t,n)=>e.jsxs("div",{className:a.default.pendingAttachment,children:[X(t),e.jsx("span",{children:t.name}),e.jsxs("span",{className:a.default.pendingAttachmentSize,children:["(",E.formatFileSize(t.size),")"]}),e.jsx("button",{className:a.default.pendingAttachmentRemove,onClick:()=>M(n),"aria-label":`Remove ${t.name}`,children:e.jsx(o.X,{size:14})})]},n))}),j&&e.jsx($.ChatVoiceRecorder,{onRecordingComplete:O,onCancel:()=>h(!1)}),!j&&e.jsxs("div",{className:a.default.inputBox,children:[N&&e.jsxs("div",{className:a.default.inputActions,children:[e.jsx("input",{ref:u,type:"file",accept:k.join(","),multiple:!0,onChange:W,style:{display:"none"},"aria-hidden":"true"}),e.jsx("button",{className:a.default.inputButton,onClick:()=>u.current?.click(),disabled:i||s,"aria-label":"Attach file",title:"Attach file",children:e.jsx(o.Paperclip,{size:20})})]}),e.jsx("textarea",{ref:T,className:a.default.inputTextarea,value:x,onChange:t=>B(t.target.value),onKeyDown:V,onPaste:K,placeholder:R,disabled:i||s,maxLength:f,rows:1,"aria-label":"Message input",...w}),e.jsxs("div",{className:a.default.inputActions,children:[S&&!x&&d.length===0&&e.jsx("button",{className:a.default.inputButton,onClick:()=>h(!0),disabled:i||s,"aria-label":"Record voice message",title:"Record voice message",children:e.jsx(o.Mic,{size:20})}),e.jsx("button",{className:[a.default.inputButton,b&&a.default.inputButtonPrimary].filter(Boolean).join(" "),onClick:U,disabled:i||s||!b,"aria-label":"Send message",title:"Send message",children:s?e.jsx("span",{className:a.default.inputSpinner}):e.jsx(o.Send,{size:20})})]})]})]})})});y.displayName="ChatInput";exports.ChatInput=y;
|
|
2
2
|
//# sourceMappingURL=index120.cjs.map
|
package/dist/index120.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index120.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index120.cjs","sources":["../src/components/Chat/components/ChatInput.tsx"],"sourcesContent":["/**\n * ChatInput Component\n *\n * Multi-line input with attachment support, voice recording,\n * and send functionality.\n */\n\nimport React, { forwardRef, useCallback, useState, useRef } from \"react\";\nimport { Send, Paperclip, Mic, X, Image, File } from \"lucide-react\";\nimport type { ChatInputProps } from \"../Chat.types\";\nimport { useChatInput } from \"../hooks/useChatInput\";\nimport { ChatVoiceRecorder } from \"./ChatVoiceRecorder\";\nimport { formatFileSize } from \"../utils\";\nimport styles from \"../Chat.module.css\";\n\n// Get file icon\nconst getFileIcon = (file: File) => {\n if (file.type.startsWith(\"image/\")) {\n return <Image size={14} />;\n }\n return <File size={14} />;\n};\n\nexport const ChatInput = forwardRef<HTMLTextAreaElement, ChatInputProps>(\n (\n {\n onSend,\n placeholder = \"Type a message...\",\n allowAttachments = true,\n allowVoiceRecording = true,\n allowAudioUpload: _allowAudioUpload = true,\n disabled = false,\n maxLength,\n acceptedFileTypes = [\n \"image/*\",\n \"audio/*\",\n \".pdf\",\n \".doc\",\n \".docx\",\n \".txt\",\n ],\n isLoading = false,\n pendingAttachments: externalAttachments,\n onRemoveAttachment: externalOnRemove,\n className,\n ...rest\n },\n forwardedRef,\n ) => {\n const [showVoiceRecorder, setShowVoiceRecorder] = useState(false);\n const fileInputRef = useRef<HTMLInputElement>(null);\n\n const {\n value,\n setValue,\n attachments,\n addAttachments,\n removeAttachment,\n handleSubmit: internalSubmit,\n handleKeyDown,\n textareaRef,\n isEmpty,\n } = useChatInput({\n maxLength,\n onSend,\n disabled: disabled || isLoading,\n });\n\n // Use external attachments if provided, otherwise internal\n const displayAttachments = externalAttachments || attachments;\n const handleRemoveAttachment = externalOnRemove || removeAttachment;\n\n // Combine refs via callback ref\n const combinedRef = useCallback(\n (node: HTMLTextAreaElement | null) => {\n // Set internal ref\n (\n textareaRef as React.MutableRefObject<HTMLTextAreaElement | null>\n ).current = node;\n // Forward ref\n if (typeof forwardedRef === \"function\") {\n forwardedRef(node);\n } else if (forwardedRef) {\n forwardedRef.current = node;\n }\n },\n [forwardedRef, textareaRef],\n );\n\n // Handle file selection\n const handleFileSelect = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n const files = e.target.files;\n if (files && files.length > 0) {\n addAttachments(Array.from(files));\n }\n // Reset input\n if (fileInputRef.current) {\n fileInputRef.current.value = \"\";\n }\n },\n [addAttachments],\n );\n\n // Handle paste for images\n const handlePaste = useCallback(\n (e: React.ClipboardEvent) => {\n const items = e.clipboardData.items;\n const imageFiles: File[] = [];\n\n for (const item of items) {\n if (item.type.startsWith(\"image/\")) {\n const file = item.getAsFile();\n if (file) {\n imageFiles.push(file);\n }\n }\n }\n\n if (imageFiles.length > 0) {\n e.preventDefault();\n addAttachments(imageFiles);\n }\n },\n [addAttachments],\n );\n\n // Handle voice recording complete\n const handleVoiceRecordingComplete = useCallback(\n (blob: Blob) => {\n // Create a file-like object from the blob\n const file = Object.assign(blob, {\n name: `voice-${Date.now()}.webm`,\n lastModified: Date.now(),\n }) as File;\n addAttachments([file]);\n setShowVoiceRecorder(false);\n },\n [addAttachments],\n );\n\n // Handle submit\n const handleSubmit = useCallback(() => {\n if (disabled || isLoading) return;\n internalSubmit();\n }, [disabled, isLoading, internalSubmit]);\n\n const canSend = !isEmpty || displayAttachments.length > 0;\n\n return (\n <div\n className={[styles.inputContainer, className].filter(Boolean).join(\" \")}\n >\n <div className={styles.inputWrapper}>\n {/* Pending attachments */}\n {displayAttachments.length > 0 && (\n <div className={styles.pendingAttachments}>\n {displayAttachments.map((file, index) => (\n <div key={index} className={styles.pendingAttachment}>\n {getFileIcon(file)}\n <span>{file.name}</span>\n <span className={styles.pendingAttachmentSize}>\n ({formatFileSize(file.size)})\n </span>\n <button\n className={styles.pendingAttachmentRemove}\n onClick={() => handleRemoveAttachment(index)}\n aria-label={`Remove ${file.name}`}\n >\n <X size={14} />\n </button>\n </div>\n ))}\n </div>\n )}\n\n {/* Voice recorder overlay */}\n {showVoiceRecorder && (\n <ChatVoiceRecorder\n onRecordingComplete={handleVoiceRecordingComplete}\n onCancel={() => setShowVoiceRecorder(false)}\n />\n )}\n\n {/* Main input box */}\n {!showVoiceRecorder && (\n <div className={styles.inputBox}>\n {/* Left actions (attachments) */}\n {allowAttachments && (\n <div className={styles.inputActions}>\n <input\n ref={fileInputRef}\n type=\"file\"\n accept={acceptedFileTypes.join(\",\")}\n multiple\n onChange={handleFileSelect}\n style={{ display: \"none\" }}\n aria-hidden=\"true\"\n />\n <button\n className={styles.inputButton}\n onClick={() => fileInputRef.current?.click()}\n disabled={disabled || isLoading}\n aria-label=\"Attach file\"\n title=\"Attach file\"\n >\n <Paperclip size={20} />\n </button>\n </div>\n )}\n\n {/* Textarea */}\n <textarea\n ref={combinedRef}\n className={styles.inputTextarea}\n value={value}\n onChange={(e) => setValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onPaste={handlePaste}\n placeholder={placeholder}\n disabled={disabled || isLoading}\n maxLength={maxLength}\n rows={1}\n aria-label=\"Message input\"\n {...rest}\n />\n\n {/* Right actions (voice, send) */}\n <div className={styles.inputActions}>\n {/* Voice recording button */}\n {allowVoiceRecording &&\n !value &&\n displayAttachments.length === 0 && (\n <button\n className={styles.inputButton}\n onClick={() => setShowVoiceRecorder(true)}\n disabled={disabled || isLoading}\n aria-label=\"Record voice message\"\n title=\"Record voice message\"\n >\n <Mic size={20} />\n </button>\n )}\n\n {/* Send button */}\n <button\n className={[\n styles.inputButton,\n canSend && styles.inputButtonPrimary,\n ]\n .filter(Boolean)\n .join(\" \")}\n onClick={handleSubmit}\n disabled={disabled || isLoading || !canSend}\n aria-label=\"Send message\"\n title=\"Send message\"\n >\n {isLoading ? (\n <span className={styles.inputSpinner} />\n ) : (\n <Send size={20} />\n )}\n </button>\n </div>\n </div>\n )}\n </div>\n </div>\n );\n },\n);\n\nChatInput.displayName = \"ChatInput\";\n"],"names":["getFileIcon","file","jsx","Image","File","ChatInput","forwardRef","onSend","placeholder","allowAttachments","allowVoiceRecording","_allowAudioUpload","disabled","maxLength","acceptedFileTypes","isLoading","externalAttachments","externalOnRemove","className","rest","forwardedRef","showVoiceRecorder","setShowVoiceRecorder","useState","fileInputRef","useRef","value","setValue","attachments","addAttachments","removeAttachment","internalSubmit","handleKeyDown","textareaRef","isEmpty","useChatInput","displayAttachments","handleRemoveAttachment","combinedRef","useCallback","node","handleFileSelect","e","files","handlePaste","items","imageFiles","item","handleVoiceRecordingComplete","blob","handleSubmit","canSend","styles","jsxs","index","formatFileSize","X","ChatVoiceRecorder","Paperclip","Mic","Send"],"mappings":"iRAgBMA,EAAeC,GACfA,EAAK,KAAK,WAAW,QAAQ,EACxBC,EAAAA,IAACC,EAAAA,MAAA,CAAM,KAAM,EAAA,CAAI,EAEnBD,EAAAA,IAACE,EAAAA,KAAA,CAAK,KAAM,EAAA,CAAI,EAGZC,EAAYC,EAAAA,WACvB,CACE,CACE,OAAAC,EACA,YAAAC,EAAc,oBACd,iBAAAC,EAAmB,GACnB,oBAAAC,EAAsB,GACtB,iBAAkBC,EAAoB,GACtC,SAAAC,EAAW,GACX,UAAAC,EACA,kBAAAC,EAAoB,CAClB,UACA,UACA,OACA,OACA,QACA,MAAA,EAEF,UAAAC,EAAY,GACZ,mBAAoBC,EACpB,mBAAoBC,EACpB,UAAAC,EACA,GAAGC,CAAA,EAELC,IACG,CACH,KAAM,CAACC,EAAmBC,CAAoB,EAAIC,EAAAA,SAAS,EAAK,EAC1DC,EAAeC,EAAAA,OAAyB,IAAI,EAE5C,CACJ,MAAAC,EACA,SAAAC,EACA,YAAAC,EACA,eAAAC,EACA,iBAAAC,EACA,aAAcC,EACd,cAAAC,EACA,YAAAC,EACA,QAAAC,CAAA,EACEC,eAAa,CACf,UAAAtB,EACA,OAAAN,EACA,SAAUK,GAAYG,CAAA,CACvB,EAGKqB,EAAqBpB,GAAuBY,EAC5CS,EAAyBpB,GAAoBa,EAG7CQ,EAAcC,EAAAA,YACjBC,GAAqC,CAGlCP,EACA,QAAUO,EAER,OAAOpB,GAAiB,WAC1BA,EAAaoB,CAAI,EACRpB,IACTA,EAAa,QAAUoB,EAE3B,EACA,CAACpB,EAAca,CAAW,CAAA,EAItBQ,EAAmBF,EAAAA,YACtBG,GAA2C,CAC1C,MAAMC,EAAQD,EAAE,OAAO,MACnBC,GAASA,EAAM,OAAS,GAC1Bd,EAAe,MAAM,KAAKc,CAAK,CAAC,EAG9BnB,EAAa,UACfA,EAAa,QAAQ,MAAQ,GAEjC,EACA,CAACK,CAAc,CAAA,EAIXe,EAAcL,EAAAA,YACjBG,GAA4B,CAC3B,MAAMG,EAAQH,EAAE,cAAc,MACxBI,EAAqB,CAAA,EAE3B,UAAWC,KAAQF,EACjB,GAAIE,EAAK,KAAK,WAAW,QAAQ,EAAG,CAClC,MAAM9C,EAAO8C,EAAK,UAAA,EACd9C,GACF6C,EAAW,KAAK7C,CAAI,CAExB,CAGE6C,EAAW,OAAS,IACtBJ,EAAE,eAAA,EACFb,EAAeiB,CAAU,EAE7B,EACA,CAACjB,CAAc,CAAA,EAIXmB,EAA+BT,EAAAA,YAClCU,GAAe,CAEd,MAAMhD,EAAO,OAAO,OAAOgD,EAAM,CAC/B,KAAM,SAAS,KAAK,IAAA,CAAK,QACzB,aAAc,KAAK,IAAA,CAAI,CACxB,EACDpB,EAAe,CAAC5B,CAAI,CAAC,EACrBqB,EAAqB,EAAK,CAC5B,EACA,CAACO,CAAc,CAAA,EAIXqB,EAAeX,EAAAA,YAAY,IAAM,CACjC3B,GAAYG,GAChBgB,EAAA,CACF,EAAG,CAACnB,EAAUG,EAAWgB,CAAc,CAAC,EAElCoB,EAAU,CAACjB,GAAWE,EAAmB,OAAS,EAExD,OACElC,EAAAA,IAAC,MAAA,CACC,UAAW,CAACkD,UAAO,eAAgBlC,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,EAEtE,SAAAmC,EAAAA,KAAC,MAAA,CAAI,UAAWD,EAAAA,QAAO,aAEpB,SAAA,CAAAhB,EAAmB,OAAS,GAC3BlC,MAAC,MAAA,CAAI,UAAWkD,EAAAA,QAAO,mBACpB,SAAAhB,EAAmB,IAAI,CAACnC,EAAMqD,IAC7BD,OAAC,MAAA,CAAgB,UAAWD,EAAAA,QAAO,kBAChC,SAAA,CAAApD,EAAYC,CAAI,EACjBC,EAAAA,IAAC,OAAA,CAAM,SAAAD,EAAK,IAAA,CAAK,EACjBoD,EAAAA,KAAC,OAAA,CAAK,UAAWD,EAAAA,QAAO,sBAAuB,SAAA,CAAA,IAC3CG,EAAAA,eAAetD,EAAK,IAAI,EAAE,GAAA,EAC9B,EACAC,EAAAA,IAAC,SAAA,CACC,UAAWkD,EAAAA,QAAO,wBAClB,QAAS,IAAMf,EAAuBiB,CAAK,EAC3C,aAAY,UAAUrD,EAAK,IAAI,GAE/B,SAAAC,EAAAA,IAACsD,EAAAA,EAAA,CAAE,KAAM,EAAA,CAAI,CAAA,CAAA,CACf,GAZQF,CAaV,CACD,EACH,EAIDjC,GACCnB,EAAAA,IAACuD,EAAAA,kBAAA,CACC,oBAAqBT,EACrB,SAAU,IAAM1B,EAAqB,EAAK,CAAA,CAAA,EAK7C,CAACD,GACAgC,EAAAA,KAAC,MAAA,CAAI,UAAWD,EAAAA,QAAO,SAEpB,SAAA,CAAA3C,GACC4C,EAAAA,KAAC,MAAA,CAAI,UAAWD,EAAAA,QAAO,aACrB,SAAA,CAAAlD,EAAAA,IAAC,QAAA,CACC,IAAKsB,EACL,KAAK,OACL,OAAQV,EAAkB,KAAK,GAAG,EAClC,SAAQ,GACR,SAAU2B,EACV,MAAO,CAAE,QAAS,MAAA,EAClB,cAAY,MAAA,CAAA,EAEdvC,EAAAA,IAAC,SAAA,CACC,UAAWkD,EAAAA,QAAO,YAClB,QAAS,IAAM5B,EAAa,SAAS,MAAA,EACrC,SAAUZ,GAAYG,EACtB,aAAW,cACX,MAAM,cAEN,SAAAb,EAAAA,IAACwD,EAAAA,UAAA,CAAU,KAAM,EAAA,CAAI,CAAA,CAAA,CACvB,EACF,EAIFxD,EAAAA,IAAC,WAAA,CACC,IAAKoC,EACL,UAAWc,EAAAA,QAAO,cAClB,MAAA1B,EACA,SAAWgB,GAAMf,EAASe,EAAE,OAAO,KAAK,EACxC,UAAWV,EACX,QAASY,EACT,YAAApC,EACA,SAAUI,GAAYG,EACtB,UAAAF,EACA,KAAM,EACN,aAAW,gBACV,GAAGM,CAAA,CAAA,EAINkC,EAAAA,KAAC,MAAA,CAAI,UAAWD,EAAAA,QAAO,aAEpB,SAAA,CAAA1C,GACC,CAACgB,GACDU,EAAmB,SAAW,GAC5BlC,EAAAA,IAAC,SAAA,CACC,UAAWkD,EAAAA,QAAO,YAClB,QAAS,IAAM9B,EAAqB,EAAI,EACxC,SAAUV,GAAYG,EACtB,aAAW,uBACX,MAAM,uBAEN,SAAAb,EAAAA,IAACyD,EAAAA,IAAA,CAAI,KAAM,EAAA,CAAI,CAAA,CAAA,EAKrBzD,EAAAA,IAAC,SAAA,CACC,UAAW,CACTkD,EAAAA,QAAO,YACPD,GAAWC,EAAAA,QAAO,kBAAA,EAEjB,OAAO,OAAO,EACd,KAAK,GAAG,EACX,QAASF,EACT,SAAUtC,GAAYG,GAAa,CAACoC,EACpC,aAAW,eACX,MAAM,eAEL,SAAApC,EACCb,EAAAA,IAAC,OAAA,CAAK,UAAWkD,EAAAA,QAAO,aAAc,EAEtClD,EAAAA,IAAC0D,EAAAA,KAAA,CAAK,KAAM,EAAA,CAAI,CAAA,CAAA,CAEpB,CAAA,CACF,CAAA,CAAA,CACF,CAAA,CAAA,CAEJ,CAAA,CAAA,CAGN,CACF,EAEAvD,EAAU,YAAc"}
|