@orion-ds/react 4.2.11 → 4.2.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/dist/index10.cjs +1 -1
  2. package/dist/index10.mjs +1 -1
  3. package/dist/index100.cjs +1 -1
  4. package/dist/index100.mjs +46 -14
  5. package/dist/index101.cjs +1 -1
  6. package/dist/index101.mjs +14 -28
  7. package/dist/index102.cjs +1 -1
  8. package/dist/index102.mjs +28 -27
  9. package/dist/index103.cjs +1 -1
  10. package/dist/index103.mjs +29 -29
  11. package/dist/index104.cjs +1 -1
  12. package/dist/index104.mjs +44 -20
  13. package/dist/index105.cjs +1 -1
  14. package/dist/index105.mjs +52 -44
  15. package/dist/index106.cjs +1 -1
  16. package/dist/index106.mjs +42 -54
  17. package/dist/index107.cjs +1 -1
  18. package/dist/index107.mjs +18 -40
  19. package/dist/index108.cjs +1 -1
  20. package/dist/index108.mjs +50 -36
  21. package/dist/index109.cjs +1 -1
  22. package/dist/index109.mjs +20 -64
  23. package/dist/index11.cjs +1 -1
  24. package/dist/index11.mjs +1 -1
  25. package/dist/index110.cjs +1 -1
  26. package/dist/index110.mjs +36 -24
  27. package/dist/index111.cjs +1 -1
  28. package/dist/index111.mjs +20 -52
  29. package/dist/index112.cjs +1 -1
  30. package/dist/index112.mjs +29 -37
  31. package/dist/index113.cjs +1 -1
  32. package/dist/index113.mjs +18 -28
  33. package/dist/index114.cjs +1 -1
  34. package/dist/index114.mjs +62 -44
  35. package/dist/index116.cjs +1 -1
  36. package/dist/index116.mjs +12 -36
  37. package/dist/index117.cjs +1 -1
  38. package/dist/index117.mjs +35 -28
  39. package/dist/index118.cjs +1 -1
  40. package/dist/index118.mjs +49 -19
  41. package/dist/index119.cjs +1 -1
  42. package/dist/index119.mjs +36 -38
  43. package/dist/index12.cjs +1 -1
  44. package/dist/index12.mjs +1 -1
  45. package/dist/index120.cjs +1 -1
  46. package/dist/index120.mjs +32 -40
  47. package/dist/index121.cjs +1 -1
  48. package/dist/index121.mjs +27 -28
  49. package/dist/index122.cjs +1 -1
  50. package/dist/index122.mjs +12 -52
  51. package/dist/index123.cjs +1 -1
  52. package/dist/index123.mjs +40 -32
  53. package/dist/index125.cjs +1 -1
  54. package/dist/index125.mjs +42 -35
  55. package/dist/index126.cjs +1 -1
  56. package/dist/index126.mjs +27 -27
  57. package/dist/index127.cjs +1 -1
  58. package/dist/index127.mjs +37 -21
  59. package/dist/index128.cjs +1 -1
  60. package/dist/index128.mjs +26 -44
  61. package/dist/index129.cjs +1 -1
  62. package/dist/index129.mjs +55 -51
  63. package/dist/index13.cjs +1 -1
  64. package/dist/index13.mjs +1 -1
  65. package/dist/index130.cjs +1 -1
  66. package/dist/index130.mjs +20 -64
  67. package/dist/index131.cjs +1 -1
  68. package/dist/index131.mjs +26 -44
  69. package/dist/index132.cjs +1 -1
  70. package/dist/index132.mjs +52 -42
  71. package/dist/index133.cjs +1 -1
  72. package/dist/index133.mjs +106 -28
  73. package/dist/index134.cjs +1 -1
  74. package/dist/index134.mjs +55 -12
  75. package/dist/index135.cjs +1 -1
  76. package/dist/index135.mjs +18 -20
  77. package/dist/index136.cjs +1 -1
  78. package/dist/index136.mjs +65 -24
  79. package/dist/index137.cjs +1 -1
  80. package/dist/index137.mjs +64 -16
  81. package/dist/index138.cjs +1 -1
  82. package/dist/index138.mjs +28 -50
  83. package/dist/index139.cjs +1 -1
  84. package/dist/index139.mjs +24 -40
  85. package/dist/index14.cjs +1 -1
  86. package/dist/index14.mjs +1 -1
  87. package/dist/index140.cjs +1 -1
  88. package/dist/index140.mjs +18 -42
  89. package/dist/index141.cjs +1 -1
  90. package/dist/index141.mjs +24 -18
  91. package/dist/index142.cjs +1 -1
  92. package/dist/index142.mjs +40 -55
  93. package/dist/index143.cjs +1 -1
  94. package/dist/index143.mjs +22 -65
  95. package/dist/index144.cjs +1 -1
  96. package/dist/index144.mjs +46 -33
  97. package/dist/index145.cjs +1 -1
  98. package/dist/index145.mjs +20 -18
  99. package/dist/index146.cjs +1 -1
  100. package/dist/index146.mjs +33 -67
  101. package/dist/index147.cjs +1 -1
  102. package/dist/index147.mjs +24 -56
  103. package/dist/index148.cjs +1 -1
  104. package/dist/index148.mjs +67 -18
  105. package/dist/index149.cjs +1 -1
  106. package/dist/index149.mjs +46 -62
  107. package/dist/index15.cjs +1 -1
  108. package/dist/index15.mjs +1 -1
  109. package/dist/index150.cjs +1 -1
  110. package/dist/index150.mjs +24 -76
  111. package/dist/index151.cjs +1 -1
  112. package/dist/index151.mjs +45 -24
  113. package/dist/index152.cjs +1 -1
  114. package/dist/index152.mjs +42 -32
  115. package/dist/index154.cjs +1 -1
  116. package/dist/index154.mjs +64 -30
  117. package/dist/index155.cjs +1 -1
  118. package/dist/index155.mjs +53 -106
  119. package/dist/index156.cjs +1 -1
  120. package/dist/index156.mjs +76 -45
  121. package/dist/index157.cjs +1 -1
  122. package/dist/index157.mjs +38 -234
  123. package/dist/index158.cjs +1 -1
  124. package/dist/index158.mjs +235 -34
  125. package/dist/index159.cjs +1 -1
  126. package/dist/index159.mjs +32 -42
  127. package/dist/index16.cjs +1 -1
  128. package/dist/index16.mjs +1 -1
  129. package/dist/index160.cjs +1 -1
  130. package/dist/index160.mjs +42 -169
  131. package/dist/index161.cjs +1 -1
  132. package/dist/index161.mjs +162 -177
  133. package/dist/index162.cjs +1 -1
  134. package/dist/index162.mjs +181 -24
  135. package/dist/index163.cjs +1 -1
  136. package/dist/index163.mjs +28 -90
  137. package/dist/index164.cjs +1 -1
  138. package/dist/index164.mjs +89 -51
  139. package/dist/index165.cjs +1 -1
  140. package/dist/index165.mjs +49 -63
  141. package/dist/index166.cjs +1 -1
  142. package/dist/index166.mjs +60 -118
  143. package/dist/index167.cjs +1 -1
  144. package/dist/index167.mjs +109 -93
  145. package/dist/index168.cjs +1 -1
  146. package/dist/index168.mjs +97 -100
  147. package/dist/index169.cjs +1 -1
  148. package/dist/index169.mjs +101 -112
  149. package/dist/index17.cjs +1 -1
  150. package/dist/index17.mjs +1 -1
  151. package/dist/index170.cjs +1 -1
  152. package/dist/index170.mjs +118 -210
  153. package/dist/index171.cjs +1 -1
  154. package/dist/index171.mjs +214 -33
  155. package/dist/index172.cjs +1 -1
  156. package/dist/index172.mjs +44 -26
  157. package/dist/index173.cjs +1 -1
  158. package/dist/index173.mjs +30 -20
  159. package/dist/index174.cjs +1 -1
  160. package/dist/index174.mjs +36 -46
  161. package/dist/index175.cjs +1 -1
  162. package/dist/index175.mjs +56 -28
  163. package/dist/index176.cjs +1 -1
  164. package/dist/index176.mjs +30 -57
  165. package/dist/index177.cjs +1 -1
  166. package/dist/index177.mjs +32 -24
  167. package/dist/index178.cjs +1 -1
  168. package/dist/index178.mjs +28 -12
  169. package/dist/index179.cjs +1 -1
  170. package/dist/index179.mjs +28 -18
  171. package/dist/index18.cjs +1 -1
  172. package/dist/index18.mjs +1 -1
  173. package/dist/index180.cjs +1 -1
  174. package/dist/index180.mjs +16 -38
  175. package/dist/index181.cjs +1 -1
  176. package/dist/index181.mjs +33 -30
  177. package/dist/index185.cjs +1 -1
  178. package/dist/index185.mjs +1 -1
  179. package/dist/index19.cjs +1 -1
  180. package/dist/index19.mjs +2 -2
  181. package/dist/index20.cjs +1 -1
  182. package/dist/index20.mjs +14 -14
  183. package/dist/index22.cjs +1 -1
  184. package/dist/index22.mjs +1 -1
  185. package/dist/index23.cjs +1 -1
  186. package/dist/index23.mjs +1 -1
  187. package/dist/index24.cjs +1 -1
  188. package/dist/index24.mjs +1 -1
  189. package/dist/index25.cjs +1 -1
  190. package/dist/index25.mjs +1 -1
  191. package/dist/index27.cjs +1 -1
  192. package/dist/index27.mjs +1 -1
  193. package/dist/index28.cjs +1 -1
  194. package/dist/index28.mjs +1 -1
  195. package/dist/index30.cjs +1 -1
  196. package/dist/index30.mjs +1 -1
  197. package/dist/index31.cjs +1 -1
  198. package/dist/index31.mjs +1 -1
  199. package/dist/index32.cjs +1 -1
  200. package/dist/index32.mjs +1 -1
  201. package/dist/index33.cjs +1 -1
  202. package/dist/index33.mjs +1 -1
  203. package/dist/index34.cjs +1 -1
  204. package/dist/index34.mjs +1 -1
  205. package/dist/index35.cjs +1 -1
  206. package/dist/index35.mjs +1 -1
  207. package/dist/index36.cjs +1 -1
  208. package/dist/index36.mjs +1 -1
  209. package/dist/index37.cjs +1 -1
  210. package/dist/index37.mjs +1 -1
  211. package/dist/index38.cjs +1 -1
  212. package/dist/index38.mjs +1 -1
  213. package/dist/index39.cjs +1 -1
  214. package/dist/index39.mjs +1 -1
  215. package/dist/index40.cjs +1 -1
  216. package/dist/index40.mjs +1 -1
  217. package/dist/index42.cjs +1 -1
  218. package/dist/index42.mjs +1 -1
  219. package/dist/index43.cjs +1 -1
  220. package/dist/index43.mjs +1 -1
  221. package/dist/index44.cjs +1 -1
  222. package/dist/index44.mjs +1 -1
  223. package/dist/index46.cjs +1 -1
  224. package/dist/index46.mjs +1 -1
  225. package/dist/index47.cjs +1 -1
  226. package/dist/index47.mjs +1 -1
  227. package/dist/index49.cjs +1 -1
  228. package/dist/index49.mjs +1 -1
  229. package/dist/index5.cjs +1 -1
  230. package/dist/index5.mjs +1 -1
  231. package/dist/index50.cjs +1 -1
  232. package/dist/index50.mjs +1 -1
  233. package/dist/index51.cjs +1 -1
  234. package/dist/index51.mjs +1 -1
  235. package/dist/index52.cjs +1 -1
  236. package/dist/index52.mjs +1 -1
  237. package/dist/index53.cjs +1 -1
  238. package/dist/index53.mjs +1 -1
  239. package/dist/index54.cjs +1 -1
  240. package/dist/index54.mjs +1 -1
  241. package/dist/index55.cjs +1 -1
  242. package/dist/index55.mjs +1 -1
  243. package/dist/index56.cjs +1 -1
  244. package/dist/index56.mjs +1 -1
  245. package/dist/index57.cjs +1 -1
  246. package/dist/index57.mjs +1 -1
  247. package/dist/index58.cjs +1 -1
  248. package/dist/index58.mjs +1 -1
  249. package/dist/index59.cjs +1 -1
  250. package/dist/index59.mjs +1 -1
  251. package/dist/index6.cjs +1 -1
  252. package/dist/index6.mjs +1 -1
  253. package/dist/index60.cjs +1 -1
  254. package/dist/index60.mjs +1 -1
  255. package/dist/index61.cjs +1 -1
  256. package/dist/index61.mjs +1 -1
  257. package/dist/index62.cjs +1 -1
  258. package/dist/index62.mjs +1 -1
  259. package/dist/index64.cjs +1 -1
  260. package/dist/index64.mjs +1 -1
  261. package/dist/index65.cjs +1 -1
  262. package/dist/index65.mjs +1 -1
  263. package/dist/index66.cjs +1 -1
  264. package/dist/index66.mjs +1 -1
  265. package/dist/index67.cjs +1 -1
  266. package/dist/index67.mjs +1 -1
  267. package/dist/index69.cjs +1 -1
  268. package/dist/index69.mjs +1 -1
  269. package/dist/index7.cjs +1 -1
  270. package/dist/index7.mjs +1 -1
  271. package/dist/index70.cjs +1 -1
  272. package/dist/index70.mjs +1 -1
  273. package/dist/index71.cjs +1 -1
  274. package/dist/index71.mjs +1 -1
  275. package/dist/index72.cjs +1 -1
  276. package/dist/index72.mjs +1 -1
  277. package/dist/index73.cjs +1 -1
  278. package/dist/index73.mjs +1 -1
  279. package/dist/index76.cjs +1 -1
  280. package/dist/index76.mjs +1 -1
  281. package/dist/index77.cjs +1 -1
  282. package/dist/index77.mjs +1 -1
  283. package/dist/index78.cjs +1 -1
  284. package/dist/index78.mjs +1 -1
  285. package/dist/index79.cjs +1 -1
  286. package/dist/index79.mjs +1 -1
  287. package/dist/index8.cjs +1 -1
  288. package/dist/index8.mjs +1 -1
  289. package/dist/index80.cjs +1 -1
  290. package/dist/index80.mjs +1 -1
  291. package/dist/index81.cjs +1 -1
  292. package/dist/index81.mjs +1 -1
  293. package/dist/index82.cjs +1 -1
  294. package/dist/index82.mjs +2 -2
  295. package/dist/index9.cjs +1 -1
  296. package/dist/index9.mjs +1 -1
  297. package/dist/index97.cjs +1 -1
  298. package/dist/index97.mjs +154 -30
  299. package/dist/index98.cjs +1 -1
  300. package/dist/index98.mjs +202 -138
  301. package/dist/index99.cjs +1 -1
  302. package/dist/index99.mjs +30 -218
  303. package/package.json +1 -1
package/dist/index167.mjs CHANGED
@@ -1,111 +1,127 @@
1
- import { jsx as r, jsxs as c } from "react/jsx-runtime";
2
- import { X as t, Square as b, Send as C, Mic as j } from "lucide-react";
3
- import { useVoiceRecorder as S } from "./index95.mjs";
4
- import { formatTime as k } from "./index184.mjs";
5
- import e from "./index157.mjs";
6
- const z = ({
7
- onRecordingComplete: d,
8
- onCancel: v,
9
- maxDuration: m = 300,
10
- className: a,
11
- ...n
1
+ import { jsxs as p, jsx as r } from "react/jsx-runtime";
2
+ import { useState as h, useRef as M, useCallback as s, useEffect as R } from "react";
3
+ import { Pause as j, Play as B } from "lucide-react";
4
+ import { formatTime as m } from "./index184.mjs";
5
+ import o from "./index158.mjs";
6
+ const L = ({
7
+ src: g,
8
+ duration: v,
9
+ title: y,
10
+ className: w,
11
+ ...T
12
12
  }) => {
13
- const {
14
- isRecording: o,
15
- duration: R,
16
- audioBlob: i,
17
- error: s,
18
- startRecording: h,
19
- stopRecording: u,
20
- cancelRecording: N,
21
- reset: l,
22
- isSupported: f
23
- } = S({
24
- maxDuration: m,
25
- onRecordingComplete: d,
26
- onError: (g) => console.error("Recording error:", g)
27
- }), p = () => {
28
- o ? u() : i ? (d?.(i), l()) : h();
29
- }, B = () => {
30
- N(), v?.();
31
- };
32
- return f ? s ? /* @__PURE__ */ c(
13
+ const [c, f] = h(!1), [t, u] = h(0), [a, k] = h(v || 0), n = M(null), N = s(() => {
14
+ const e = n.current;
15
+ e && !isNaN(e.duration) && isFinite(e.duration) && k(e.duration);
16
+ }, []), b = s(() => {
17
+ const e = n.current;
18
+ e && u(e.currentTime);
19
+ }, []), C = s(() => {
20
+ f(!1), u(0);
21
+ }, []), D = s(() => {
22
+ const e = n.current;
23
+ e && (c ? e.pause() : e.play().catch(() => {
24
+ f(!1);
25
+ }), f(!c));
26
+ }, [c]), x = s(
27
+ (e) => {
28
+ const l = n.current;
29
+ if (!l || !a) return;
30
+ const d = e.currentTarget.getBoundingClientRect(), P = (e.clientX - d.left) / d.width * a;
31
+ l.currentTime = P, u(P);
32
+ },
33
+ [a]
34
+ ), A = s(
35
+ (e) => {
36
+ const l = n.current;
37
+ if (!l || !a) return;
38
+ const d = 5;
39
+ let i = t;
40
+ switch (e.key) {
41
+ case "ArrowRight":
42
+ case "ArrowUp":
43
+ e.preventDefault(), i = Math.min(t + d, a);
44
+ break;
45
+ case "ArrowLeft":
46
+ case "ArrowDown":
47
+ e.preventDefault(), i = Math.max(t - d, 0);
48
+ break;
49
+ case "Home":
50
+ e.preventDefault(), i = 0;
51
+ break;
52
+ case "End":
53
+ e.preventDefault(), i = a;
54
+ break;
55
+ default:
56
+ return;
57
+ }
58
+ l.currentTime = i, u(i);
59
+ },
60
+ [t, a]
61
+ ), E = a > 0 ? t / a * 100 : 0;
62
+ return R(() => () => {
63
+ const e = n.current;
64
+ e && e.pause();
65
+ }, []), /* @__PURE__ */ p(
33
66
  "div",
34
67
  {
35
- className: [e.voiceRecorder, a].filter(Boolean).join(" "),
36
- ...n,
68
+ className: [o.audioPlayer, w].filter(Boolean).join(" "),
69
+ ...T,
37
70
  children: [
38
- /* @__PURE__ */ r("div", { className: e.voiceRecorderInfo, children: /* @__PURE__ */ r(
39
- "span",
40
- {
41
- className: [
42
- e.voiceRecorderLabel,
43
- e.voiceRecorderError
44
- ].join(" "),
45
- children: s
46
- }
47
- ) }),
48
71
  /* @__PURE__ */ r(
49
- "button",
72
+ "audio",
50
73
  {
51
- className: e.inputButton,
52
- onClick: l,
53
- "aria-label": "Try again",
54
- children: /* @__PURE__ */ r(t, { size: 20 })
74
+ ref: n,
75
+ src: g,
76
+ onLoadedMetadata: N,
77
+ onTimeUpdate: b,
78
+ onEnded: C,
79
+ preload: "metadata"
55
80
  }
56
- )
57
- ]
58
- }
59
- ) : /* @__PURE__ */ c(
60
- "div",
61
- {
62
- className: [e.voiceRecorder, a].filter(Boolean).join(" "),
63
- ...n,
64
- children: [
81
+ ),
65
82
  /* @__PURE__ */ r(
66
83
  "button",
67
84
  {
68
- className: [
69
- e.voiceRecorderButton,
70
- !o && !i && e.voiceRecorderButtonIdle
71
- ].filter(Boolean).join(" "),
72
- onClick: p,
73
- "aria-label": o ? "Stop recording" : i ? "Send recording" : "Start recording",
74
- children: o ? /* @__PURE__ */ r(b, { size: 20 }) : i ? /* @__PURE__ */ r(C, { size: 20 }) : /* @__PURE__ */ r(j, { size: 20 })
85
+ className: o.audioPlayerButton,
86
+ onClick: D,
87
+ "aria-label": c ? "Pause" : "Play",
88
+ children: c ? /* @__PURE__ */ r(j, { size: 16 }) : /* @__PURE__ */ r(B, { size: 16 })
75
89
  }
76
90
  ),
77
- /* @__PURE__ */ c("div", { className: e.voiceRecorderInfo, children: [
78
- /* @__PURE__ */ r("span", { className: e.voiceRecorderDuration, children: k(R) }),
79
- /* @__PURE__ */ r("span", { className: e.voiceRecorderLabel, children: o ? "Recording..." : i ? "Recording ready" : "Click to record" })
80
- ] }),
81
- o && /* @__PURE__ */ c("div", { className: e.voiceRecorderWaveform, children: [
82
- /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
83
- /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
84
- /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
85
- /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
86
- /* @__PURE__ */ r("div", { className: e.voiceRecorderBar })
87
- ] }),
88
- (o || i) && /* @__PURE__ */ r("div", { className: e.voiceRecorderActions, children: /* @__PURE__ */ r(
89
- "button",
90
- {
91
- className: e.inputButton,
92
- onClick: B,
93
- "aria-label": "Cancel recording",
94
- children: /* @__PURE__ */ r(t, { size: 20 })
95
- }
96
- ) })
91
+ /* @__PURE__ */ p("div", { className: o.audioPlayerProgress, children: [
92
+ y && /* @__PURE__ */ r("span", { className: o.attachmentPreviewName, children: y }),
93
+ /* @__PURE__ */ r(
94
+ "div",
95
+ {
96
+ className: o.audioPlayerTrack,
97
+ onClick: x,
98
+ onKeyDown: A,
99
+ role: "slider",
100
+ "aria-label": "Audio progress",
101
+ "aria-valuemin": 0,
102
+ "aria-valuemax": a,
103
+ "aria-valuenow": t,
104
+ "aria-valuetext": `${m(t)} of ${m(a)}`,
105
+ tabIndex: 0,
106
+ children: /* @__PURE__ */ r(
107
+ "div",
108
+ {
109
+ className: o.audioPlayerFill,
110
+ style: { width: `${E}%` }
111
+ }
112
+ )
113
+ }
114
+ ),
115
+ /* @__PURE__ */ p("div", { className: o.audioPlayerTime, children: [
116
+ /* @__PURE__ */ r("span", { children: m(t) }),
117
+ /* @__PURE__ */ r("span", { children: m(a) })
118
+ ] })
119
+ ] })
97
120
  ]
98
121
  }
99
- ) : /* @__PURE__ */ r(
100
- "div",
101
- {
102
- className: [e.voiceRecorder, a].filter(Boolean).join(" "),
103
- ...n,
104
- children: /* @__PURE__ */ r("div", { className: e.voiceRecorderInfo, children: /* @__PURE__ */ r("span", { className: e.voiceRecorderLabel, children: "Voice recording is not supported in this browser" }) })
105
- }
106
122
  );
107
123
  };
108
- z.displayName = "ChatVoiceRecorder";
124
+ L.displayName = "ChatAudioPlayer";
109
125
  export {
110
- z as ChatVoiceRecorder
126
+ L as ChatAudioPlayer
111
127
  };
package/dist/index168.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),t=require("react"),R=require("lucide-react"),h=require("./index184.cjs"),o=require("./index157.cjs"),g=({onFilesSelected:f,accept:i=["*/*"],multiple:C=!0,maxSize:s=10*1024*1024,children:v,className:D,...k})=>{const[m,u]=t.useState(!1),c=t.useRef(null),d=t.useCallback(e=>{if(!e||e.length===0)return;const r=[];Array.from(e).forEach(l=>{if(s&&l.size>s){console.warn(`File ${l.name} exceeds max size of ${h.formatFileSize(s)}`);return}const F=i.includes("*/*"),q=i.flatMap(n=>(n.endsWith("/*"),n));if(!(F||q.some(n=>{if(n.endsWith("/*")){const N=n.split("/")[0];return l.type.startsWith(`${N}/`)}return l.type===n||l.name.endsWith(n)}))){console.warn(`File ${l.name} type not accepted`);return}r.push(l)}),r.length>0&&f?.(r)},[i,s,f]),b=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!0)},[]),j=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!1)},[]),y=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!1);const{files:r}=e.dataTransfer;d(r)},[d]),x=t.useCallback(e=>{d(e.target.files),c.current&&(c.current.value="")},[d]),p=t.useCallback(()=>{c.current?.click()},[]),U=t.useCallback(e=>{(e.key==="Enter"||e.key===" ")&&(e.preventDefault(),p())},[p]);return a.jsxs("div",{className:[o.default.fileUpload,m&&o.default.fileUploadDragging,D].filter(Boolean).join(" "),onDragOver:b,onDragLeave:j,onDrop:y,onClick:p,onKeyDown:U,role:"button",tabIndex:0,"aria-label":"Upload files",...k,children:[a.jsx("input",{ref:c,type:"file",accept:i.join(","),multiple:C,onChange:x,style:{display:"none"},"aria-hidden":"true"}),v||a.jsxs(a.Fragment,{children:[a.jsx("div",{className:o.default.fileUploadIcon,children:a.jsx(R.Upload,{size:32})}),a.jsxs("div",{className:o.default.fileUploadText,children:[a.jsx("strong",{children:"Click to upload"})," or drag and drop"]}),a.jsxs("div",{className:o.default.fileUploadHint,children:["Max file size: ",h.formatFileSize(s)]})]})]})};g.displayName="ChatFileUpload";exports.ChatFileUpload=g;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),i=require("lucide-react"),g=require("./index95.cjs"),b=require("./index184.cjs"),r=require("./index158.cjs"),t=({onRecordingComplete:s,onCancel:u,maxDuration:f=300,className:a,...d})=>{const{isRecording:o,duration:v,audioBlob:c,error:l,startRecording:R,stopRecording:j,cancelRecording:x,reset:n,isSupported:m}=g.useVoiceRecorder({maxDuration:f,onRecordingComplete:s,onError:B=>console.error("Recording error:",B)}),h=()=>{o?j():c?(s?.(c),n()):R()},N=()=>{x(),u?.()};return m?l?e.jsxs("div",{className:[r.default.voiceRecorder,a].filter(Boolean).join(" "),...d,children:[e.jsx("div",{className:r.default.voiceRecorderInfo,children:e.jsx("span",{className:[r.default.voiceRecorderLabel,r.default.voiceRecorderError].join(" "),children:l})}),e.jsx("button",{className:r.default.inputButton,onClick:n,"aria-label":"Try again",children:e.jsx(i.X,{size:20})})]}):e.jsxs("div",{className:[r.default.voiceRecorder,a].filter(Boolean).join(" "),...d,children:[e.jsx("button",{className:[r.default.voiceRecorderButton,!o&&!c&&r.default.voiceRecorderButtonIdle].filter(Boolean).join(" "),onClick:h,"aria-label":o?"Stop recording":c?"Send recording":"Start recording",children:o?e.jsx(i.Square,{size:20}):c?e.jsx(i.Send,{size:20}):e.jsx(i.Mic,{size:20})}),e.jsxs("div",{className:r.default.voiceRecorderInfo,children:[e.jsx("span",{className:r.default.voiceRecorderDuration,children:b.formatTime(v)}),e.jsx("span",{className:r.default.voiceRecorderLabel,children:o?"Recording...":c?"Recording ready":"Click to record"})]}),o&&e.jsxs("div",{className:r.default.voiceRecorderWaveform,children:[e.jsx("div",{className:r.default.voiceRecorderBar}),e.jsx("div",{className:r.default.voiceRecorderBar}),e.jsx("div",{className:r.default.voiceRecorderBar}),e.jsx("div",{className:r.default.voiceRecorderBar}),e.jsx("div",{className:r.default.voiceRecorderBar})]}),(o||c)&&e.jsx("div",{className:r.default.voiceRecorderActions,children:e.jsx("button",{className:r.default.inputButton,onClick:N,"aria-label":"Cancel recording",children:e.jsx(i.X,{size:20})})})]}):e.jsx("div",{className:[r.default.voiceRecorder,a].filter(Boolean).join(" "),...d,children:e.jsx("div",{className:r.default.voiceRecorderInfo,children:e.jsx("span",{className:r.default.voiceRecorderLabel,children:"Voice recording is not supported in this browser"})})})};t.displayName="ChatVoiceRecorder";exports.ChatVoiceRecorder=t;
package/dist/index168.mjs CHANGED
@@ -1,114 +1,111 @@
1
- import { jsxs as d, jsx as p, Fragment as A } from "react/jsx-runtime";
2
- import { useState as I, useRef as W, useCallback as a } from "react";
3
- import { Upload as $ } from "lucide-react";
4
- import { formatFileSize as g } from "./index184.mjs";
5
- import l from "./index157.mjs";
6
- const P = ({
7
- onFilesSelected: h,
8
- accept: s = ["*/*"],
9
- multiple: m = !0,
10
- maxSize: r = 10 * 1024 * 1024,
11
- // 10MB default
12
- children: D,
13
- className: v,
14
- ...y
1
+ import { jsx as r, jsxs as c } from "react/jsx-runtime";
2
+ import { X as t, Square as b, Send as C, Mic as j } from "lucide-react";
3
+ import { useVoiceRecorder as S } from "./index95.mjs";
4
+ import { formatTime as k } from "./index184.mjs";
5
+ import e from "./index158.mjs";
6
+ const z = ({
7
+ onRecordingComplete: d,
8
+ onCancel: v,
9
+ maxDuration: m = 300,
10
+ className: a,
11
+ ...n
15
12
  }) => {
16
- const [U, f] = I(!1), i = W(null), c = a(
17
- (e) => {
18
- if (!e || e.length === 0) return;
19
- const o = [];
20
- Array.from(e).forEach((t) => {
21
- if (r && t.size > r) {
22
- console.warn(
23
- `File ${t.name} exceeds max size of ${g(r)}`
24
- );
25
- return;
26
- }
27
- const j = s.includes("*/*"), w = s.flatMap((n) => (n.endsWith("/*"), n));
28
- if (!(j || w.some((n) => {
29
- if (n.endsWith("/*")) {
30
- const x = n.split("/")[0];
31
- return t.type.startsWith(`${x}/`);
13
+ const {
14
+ isRecording: o,
15
+ duration: R,
16
+ audioBlob: i,
17
+ error: s,
18
+ startRecording: h,
19
+ stopRecording: u,
20
+ cancelRecording: N,
21
+ reset: l,
22
+ isSupported: f
23
+ } = S({
24
+ maxDuration: m,
25
+ onRecordingComplete: d,
26
+ onError: (g) => console.error("Recording error:", g)
27
+ }), p = () => {
28
+ o ? u() : i ? (d?.(i), l()) : h();
29
+ }, B = () => {
30
+ N(), v?.();
31
+ };
32
+ return f ? s ? /* @__PURE__ */ c(
33
+ "div",
34
+ {
35
+ className: [e.voiceRecorder, a].filter(Boolean).join(" "),
36
+ ...n,
37
+ children: [
38
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderInfo, children: /* @__PURE__ */ r(
39
+ "span",
40
+ {
41
+ className: [
42
+ e.voiceRecorderLabel,
43
+ e.voiceRecorderError
44
+ ].join(" "),
45
+ children: s
32
46
  }
33
- return t.type === n || t.name.endsWith(n);
34
- }))) {
35
- console.warn(`File ${t.name} type not accepted`);
36
- return;
37
- }
38
- o.push(t);
39
- }), o.length > 0 && h?.(o);
40
- },
41
- [s, r, h]
42
- ), C = a((e) => {
43
- e.preventDefault(), e.stopPropagation(), f(!0);
44
- }, []), k = a((e) => {
45
- e.preventDefault(), e.stopPropagation(), f(!1);
46
- }, []), F = a(
47
- (e) => {
48
- e.preventDefault(), e.stopPropagation(), f(!1);
49
- const { files: o } = e.dataTransfer;
50
- c(o);
51
- },
52
- [c]
53
- ), N = a(
54
- (e) => {
55
- c(e.target.files), i.current && (i.current.value = "");
56
- },
57
- [c]
58
- ), u = a(() => {
59
- i.current?.click();
60
- }, []), b = a(
61
- (e) => {
62
- (e.key === "Enter" || e.key === " ") && (e.preventDefault(), u());
63
- },
64
- [u]
65
- );
66
- return /* @__PURE__ */ d(
47
+ ) }),
48
+ /* @__PURE__ */ r(
49
+ "button",
50
+ {
51
+ className: e.inputButton,
52
+ onClick: l,
53
+ "aria-label": "Try again",
54
+ children: /* @__PURE__ */ r(t, { size: 20 })
55
+ }
56
+ )
57
+ ]
58
+ }
59
+ ) : /* @__PURE__ */ c(
67
60
  "div",
68
61
  {
69
- className: [
70
- l.fileUpload,
71
- U && l.fileUploadDragging,
72
- v
73
- ].filter(Boolean).join(" "),
74
- onDragOver: C,
75
- onDragLeave: k,
76
- onDrop: F,
77
- onClick: u,
78
- onKeyDown: b,
79
- role: "button",
80
- tabIndex: 0,
81
- "aria-label": "Upload files",
82
- ...y,
62
+ className: [e.voiceRecorder, a].filter(Boolean).join(" "),
63
+ ...n,
83
64
  children: [
84
- /* @__PURE__ */ p(
85
- "input",
65
+ /* @__PURE__ */ r(
66
+ "button",
86
67
  {
87
- ref: i,
88
- type: "file",
89
- accept: s.join(","),
90
- multiple: m,
91
- onChange: N,
92
- style: { display: "none" },
93
- "aria-hidden": "true"
68
+ className: [
69
+ e.voiceRecorderButton,
70
+ !o && !i && e.voiceRecorderButtonIdle
71
+ ].filter(Boolean).join(" "),
72
+ onClick: p,
73
+ "aria-label": o ? "Stop recording" : i ? "Send recording" : "Start recording",
74
+ children: o ? /* @__PURE__ */ r(b, { size: 20 }) : i ? /* @__PURE__ */ r(C, { size: 20 }) : /* @__PURE__ */ r(j, { size: 20 })
94
75
  }
95
76
  ),
96
- D || /* @__PURE__ */ d(A, { children: [
97
- /* @__PURE__ */ p("div", { className: l.fileUploadIcon, children: /* @__PURE__ */ p($, { size: 32 }) }),
98
- /* @__PURE__ */ d("div", { className: l.fileUploadText, children: [
99
- /* @__PURE__ */ p("strong", { children: "Click to upload" }),
100
- " or drag and drop"
101
- ] }),
102
- /* @__PURE__ */ d("div", { className: l.fileUploadHint, children: [
103
- "Max file size: ",
104
- g(r)
105
- ] })
106
- ] })
77
+ /* @__PURE__ */ c("div", { className: e.voiceRecorderInfo, children: [
78
+ /* @__PURE__ */ r("span", { className: e.voiceRecorderDuration, children: k(R) }),
79
+ /* @__PURE__ */ r("span", { className: e.voiceRecorderLabel, children: o ? "Recording..." : i ? "Recording ready" : "Click to record" })
80
+ ] }),
81
+ o && /* @__PURE__ */ c("div", { className: e.voiceRecorderWaveform, children: [
82
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
83
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
84
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
85
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderBar }),
86
+ /* @__PURE__ */ r("div", { className: e.voiceRecorderBar })
87
+ ] }),
88
+ (o || i) && /* @__PURE__ */ r("div", { className: e.voiceRecorderActions, children: /* @__PURE__ */ r(
89
+ "button",
90
+ {
91
+ className: e.inputButton,
92
+ onClick: B,
93
+ "aria-label": "Cancel recording",
94
+ children: /* @__PURE__ */ r(t, { size: 20 })
95
+ }
96
+ ) })
107
97
  ]
108
98
  }
99
+ ) : /* @__PURE__ */ r(
100
+ "div",
101
+ {
102
+ className: [e.voiceRecorder, a].filter(Boolean).join(" "),
103
+ ...n,
104
+ children: /* @__PURE__ */ r("div", { className: e.voiceRecorderInfo, children: /* @__PURE__ */ r("span", { className: e.voiceRecorderLabel, children: "Voice recording is not supported in this browser" }) })
105
+ }
109
106
  );
110
107
  };
111
- P.displayName = "ChatFileUpload";
108
+ z.displayName = "ChatVoiceRecorder";
112
109
  export {
113
- P as ChatFileUpload
110
+ z as ChatVoiceRecorder
114
111
  };
package/dist/index169.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),a=require("lucide-react"),p=require("./index165.cjs"),P=require("./index166.cjs"),b=require("./index163.cjs"),C=require("./index184.cjs"),t=require("./index157.cjs"),w=d=>{switch(d){case"image":return e.jsx(a.Image,{size:18});case"audio":return e.jsx(a.Music,{size:18});case"code":return e.jsx(a.Code,{size:18});default:return e.jsx(a.FileText,{size:18})}},v=({attachment:d,removable:h=!1,onRemove:i,onClick:n,className:c,...o})=>{const{type:m,name:s,url:l,content:j,language:f,size:x,duration:u,thumbnail:g}=d;switch(m){case"image":if(l)return e.jsxs("div",{className:c,style:{position:"relative"},...o,children:[e.jsx(p.ChatImagePreview,{src:l,alt:s,thumbnail:g,onClick:n}),h&&i&&e.jsx("button",{className:t.default.attachmentPreviewRemove,onClick:r=>{r.stopPropagation(),i()},"aria-label":`Remove ${s}`,style:{position:"absolute",top:4,right:4,background:"var(--surface-base)"},children:e.jsx(a.X,{size:14})})]});break;case"audio":if(l)return e.jsxs("div",{className:c,style:{position:"relative"},...o,children:[e.jsx(P.ChatAudioPlayer,{src:l,duration:u,title:s}),h&&i&&e.jsx("button",{className:t.default.attachmentPreviewRemove,onClick:r=>{r.stopPropagation(),i()},"aria-label":`Remove ${s}`,children:e.jsx(a.X,{size:14})})]});break;case"code":if(j)return e.jsx(b.ChatCodeBlock,{code:j,language:f,className:c,...o});break}return e.jsxs("div",{className:[t.default.attachmentPreview,c].filter(Boolean).join(" "),onClick:n,role:n?"button":void 0,tabIndex:n?0:void 0,...o,children:[e.jsx("div",{className:t.default.attachmentPreviewIcon,children:w(m)}),e.jsxs("div",{className:t.default.attachmentPreviewInfo,children:[e.jsx("span",{className:t.default.attachmentPreviewName,children:s}),x&&e.jsxs("span",{className:t.default.attachmentPreviewMeta,children:[C.formatFileSize(x),u&&` · ${Math.floor(u/60)}:${(u%60).toString().padStart(2,"0")}`]})]}),h&&i&&e.jsx("button",{className:t.default.attachmentPreviewRemove,onClick:r=>{r.stopPropagation(),i()},"aria-label":`Remove ${s}`,children:e.jsx(a.X,{size:14})})]})};v.displayName="ChatAttachment";exports.ChatAttachment=v;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),t=require("react"),R=require("lucide-react"),h=require("./index184.cjs"),o=require("./index158.cjs"),g=({onFilesSelected:f,accept:i=["*/*"],multiple:C=!0,maxSize:s=10*1024*1024,children:v,className:D,...k})=>{const[m,u]=t.useState(!1),c=t.useRef(null),d=t.useCallback(e=>{if(!e||e.length===0)return;const r=[];Array.from(e).forEach(l=>{if(s&&l.size>s){console.warn(`File ${l.name} exceeds max size of ${h.formatFileSize(s)}`);return}const F=i.includes("*/*"),q=i.flatMap(n=>(n.endsWith("/*"),n));if(!(F||q.some(n=>{if(n.endsWith("/*")){const N=n.split("/")[0];return l.type.startsWith(`${N}/`)}return l.type===n||l.name.endsWith(n)}))){console.warn(`File ${l.name} type not accepted`);return}r.push(l)}),r.length>0&&f?.(r)},[i,s,f]),b=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!0)},[]),j=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!1)},[]),y=t.useCallback(e=>{e.preventDefault(),e.stopPropagation(),u(!1);const{files:r}=e.dataTransfer;d(r)},[d]),x=t.useCallback(e=>{d(e.target.files),c.current&&(c.current.value="")},[d]),p=t.useCallback(()=>{c.current?.click()},[]),U=t.useCallback(e=>{(e.key==="Enter"||e.key===" ")&&(e.preventDefault(),p())},[p]);return a.jsxs("div",{className:[o.default.fileUpload,m&&o.default.fileUploadDragging,D].filter(Boolean).join(" "),onDragOver:b,onDragLeave:j,onDrop:y,onClick:p,onKeyDown:U,role:"button",tabIndex:0,"aria-label":"Upload files",...k,children:[a.jsx("input",{ref:c,type:"file",accept:i.join(","),multiple:C,onChange:x,style:{display:"none"},"aria-hidden":"true"}),v||a.jsxs(a.Fragment,{children:[a.jsx("div",{className:o.default.fileUploadIcon,children:a.jsx(R.Upload,{size:32})}),a.jsxs("div",{className:o.default.fileUploadText,children:[a.jsx("strong",{children:"Click to upload"})," or drag and drop"]}),a.jsxs("div",{className:o.default.fileUploadHint,children:["Max file size: ",h.formatFileSize(s)]})]})]})};g.displayName="ChatFileUpload";exports.ChatFileUpload=g;