genassist-chat-react 1.0.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.
@@ -0,0 +1,520 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
23
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
49
+ import { useState, useRef, useEffect, useLayoutEffect } from 'react';
50
+ import { ChatMessageComponent } from './ChatMessage';
51
+ import { useChat } from '../hooks/useChat';
52
+ import { VoiceInput } from './VoiceInput';
53
+ import { AudioService } from '../services/audioService';
54
+ import { Send, Paperclip, MoreVertical, RefreshCw, XIcon, MessageSquareMore } from 'lucide-react';
55
+ import chatLogo from '../../assets/chat-logo.png';
56
+ export var GenAgentChat = function (_a) {
57
+ var baseUrl = _a.baseUrl, apiKey = _a.apiKey, metadata = _a.metadata, onError = _a.onError, onTakeover = _a.onTakeover, onFinalize = _a.onFinalize, theme = _a.theme, _b = _a.headerTitle, headerTitle = _b === void 0 ? 'Genassist' : _b, _c = _a.placeholder, placeholder = _c === void 0 ? 'Ask a question' : _c, _d = _a.mode, mode = _d === void 0 ? 'embedded' : _d, _e = _a.floatingConfig, floatingConfig = _e === void 0 ? {} : _e;
58
+ var _f = useState(''), inputValue = _f[0], setInputValue = _f[1];
59
+ var _g = useState(false), showResetConfirm = _g[0], setShowResetConfirm = _g[1];
60
+ var _h = useState(false), showMenu = _h[0], setShowMenu = _h[1];
61
+ var _j = useState(false), isPlayingAudio = _j[0], setIsPlayingAudio = _j[1];
62
+ var _k = useState(false), isFloatingOpen = _k[0], setIsFloatingOpen = _k[1];
63
+ var menuRef = useRef(null);
64
+ var _l = useChat({
65
+ baseUrl: baseUrl,
66
+ apiKey: apiKey,
67
+ metadata: metadata,
68
+ onError: onError,
69
+ onTakeover: onTakeover,
70
+ onFinalize: onFinalize
71
+ }), messages = _l.messages, isLoading = _l.isLoading, sendMessage = _l.sendMessage, resetConversation = _l.resetConversation, startConversation = _l.startConversation, connectionState = _l.connectionState, conversationId = _l.conversationId, possibleQueries = _l.possibleQueries, isTakenOver = _l.isTakenOver, isFinalized = _l.isFinalized;
72
+ var messagesEndRef = useRef(null);
73
+ var audioService = useRef(null);
74
+ var hasUserMessages = messages.some(function (message) { return message.speaker === 'customer'; });
75
+ useEffect(function () {
76
+ audioService.current = new AudioService({ baseUrl: baseUrl, apiKey: apiKey });
77
+ }, [baseUrl, apiKey]);
78
+ // Auto-scroll to the latest message
79
+ useLayoutEffect(function () {
80
+ if (messagesEndRef.current) {
81
+ messagesEndRef.current.scrollIntoView({ behavior: 'smooth' });
82
+ }
83
+ }, [messages]);
84
+ // Close menu when clicking outside
85
+ // useEffect(() => {
86
+ // const handleClickOutside = (event: MouseEvent) => {
87
+ // if (menuRef.current && !menuRef.current.contains(event.target as Node)) {
88
+ // setShowMenu(false);
89
+ // }
90
+ // };
91
+ // document.addEventListener('mousedown', handleClickOutside);
92
+ // return () => {
93
+ // document.removeEventListener('mousedown', handleClickOutside);
94
+ // };
95
+ // }, []);
96
+ var handleSubmit = function (e) { return __awaiter(void 0, void 0, void 0, function () {
97
+ var error_1;
98
+ return __generator(this, function (_a) {
99
+ switch (_a.label) {
100
+ case 0:
101
+ e.preventDefault();
102
+ if (inputValue.trim() === '' || isLoading)
103
+ return [2 /*return*/];
104
+ _a.label = 1;
105
+ case 1:
106
+ _a.trys.push([1, 3, , 4]);
107
+ setInputValue('');
108
+ return [4 /*yield*/, sendMessage(inputValue)];
109
+ case 2:
110
+ _a.sent();
111
+ return [3 /*break*/, 4];
112
+ case 3:
113
+ error_1 = _a.sent();
114
+ console.error('Error sending message:', error_1);
115
+ return [3 /*break*/, 4];
116
+ case 4: return [2 /*return*/];
117
+ }
118
+ });
119
+ }); };
120
+ var handleVoiceTranscription = function (text) { return __awaiter(void 0, void 0, void 0, function () {
121
+ return __generator(this, function (_a) {
122
+ if (text.trim() === '')
123
+ return [2 /*return*/];
124
+ setInputValue(text);
125
+ return [2 /*return*/];
126
+ });
127
+ }); };
128
+ var handleVoiceError = function (error) {
129
+ console.error('Voice input error:', error);
130
+ if (onError) {
131
+ onError(error);
132
+ }
133
+ };
134
+ var playResponseAudio = function (text) { return __awaiter(void 0, void 0, void 0, function () {
135
+ var audioBlob, error_2;
136
+ return __generator(this, function (_a) {
137
+ switch (_a.label) {
138
+ case 0:
139
+ if (!audioService.current || isPlayingAudio)
140
+ return [2 /*return*/];
141
+ _a.label = 1;
142
+ case 1:
143
+ _a.trys.push([1, 4, 5, 6]);
144
+ setIsPlayingAudio(true);
145
+ return [4 /*yield*/, audioService.current.textToSpeech(text)];
146
+ case 2:
147
+ audioBlob = _a.sent();
148
+ return [4 /*yield*/, audioService.current.playAudio(audioBlob)];
149
+ case 3:
150
+ _a.sent();
151
+ return [3 /*break*/, 6];
152
+ case 4:
153
+ error_2 = _a.sent();
154
+ console.error('Error playing audio:', error_2);
155
+ if (onError) {
156
+ onError(error_2);
157
+ }
158
+ return [3 /*break*/, 6];
159
+ case 5:
160
+ setIsPlayingAudio(false);
161
+ return [7 /*endfinally*/];
162
+ case 6: return [2 /*return*/];
163
+ }
164
+ });
165
+ }); };
166
+ var handleQueryClick = function (query) { return __awaiter(void 0, void 0, void 0, function () {
167
+ var error_3;
168
+ return __generator(this, function (_a) {
169
+ switch (_a.label) {
170
+ case 0:
171
+ if (isLoading)
172
+ return [2 /*return*/];
173
+ _a.label = 1;
174
+ case 1:
175
+ _a.trys.push([1, 3, , 4]);
176
+ return [4 /*yield*/, sendMessage(query)];
177
+ case 2:
178
+ _a.sent();
179
+ return [3 /*break*/, 4];
180
+ case 3:
181
+ error_3 = _a.sent();
182
+ console.error('Error sending quick query:', error_3);
183
+ return [3 /*break*/, 4];
184
+ case 4: return [2 /*return*/];
185
+ }
186
+ });
187
+ }); };
188
+ var handleStartConversation = function () { return __awaiter(void 0, void 0, void 0, function () {
189
+ var error_4;
190
+ return __generator(this, function (_a) {
191
+ switch (_a.label) {
192
+ case 0:
193
+ if (isLoading)
194
+ return [2 /*return*/];
195
+ _a.label = 1;
196
+ case 1:
197
+ _a.trys.push([1, 3, , 4]);
198
+ return [4 /*yield*/, startConversation()];
199
+ case 2:
200
+ _a.sent();
201
+ return [3 /*break*/, 4];
202
+ case 3:
203
+ error_4 = _a.sent();
204
+ console.error('Error starting conversation:', error_4);
205
+ return [3 /*break*/, 4];
206
+ case 4: return [2 /*return*/];
207
+ }
208
+ });
209
+ }); };
210
+ var handleMenuClick = function () {
211
+ setShowMenu(function (prev) { return !prev; });
212
+ };
213
+ var handleResetClick = function () {
214
+ setShowMenu(false);
215
+ setShowResetConfirm(true);
216
+ };
217
+ var handleConfirmReset = function () { return __awaiter(void 0, void 0, void 0, function () {
218
+ return __generator(this, function (_a) {
219
+ switch (_a.label) {
220
+ case 0: return [4 /*yield*/, resetConversation()];
221
+ case 1:
222
+ _a.sent();
223
+ setShowResetConfirm(false);
224
+ return [2 /*return*/];
225
+ }
226
+ });
227
+ }); };
228
+ var handleCancelReset = function () {
229
+ setShowResetConfirm(false);
230
+ };
231
+ var toggleFloatingChat = function () {
232
+ setIsFloatingOpen(function (prev) { return !prev; });
233
+ };
234
+ // Extract theme colors or use defaults
235
+ var primaryColor = (theme === null || theme === void 0 ? void 0 : theme.primaryColor) || '#2962FF';
236
+ var backgroundColor = (theme === null || theme === void 0 ? void 0 : theme.backgroundColor) || '#ffffff';
237
+ var textColor = (theme === null || theme === void 0 ? void 0 : theme.textColor) || '#000000';
238
+ var fontFamily = (theme === null || theme === void 0 ? void 0 : theme.fontFamily) || 'Roboto, Arial, sans-serif';
239
+ var fontSize = (theme === null || theme === void 0 ? void 0 : theme.fontSize) || '14px';
240
+ // Floating configuration defaults
241
+ var position = floatingConfig.position || 'bottom-right';
242
+ var offset = floatingConfig.offset || { x: 20, y: 20 };
243
+ var offsetX = offset.x || 20;
244
+ var offsetY = offset.y || 20;
245
+ var toggleButtonIcon = floatingConfig.toggleButtonIcon || _jsx(MessageSquareMore, {});
246
+ var closeButtonIcon = floatingConfig.closeButtonIcon || _jsx(XIcon, {});
247
+ var containerStyle = {
248
+ display: 'flex',
249
+ flexDirection: 'column',
250
+ height: '100%',
251
+ maxHeight: '600px',
252
+ width: '100%',
253
+ maxWidth: '400px',
254
+ border: '1px solid #e0e0e0',
255
+ borderRadius: '8px',
256
+ overflow: 'hidden',
257
+ backgroundColor: backgroundColor,
258
+ fontFamily: fontFamily,
259
+ boxShadow: '0 2px 10px rgba(0, 0, 0, 0.1)',
260
+ position: 'relative'
261
+ };
262
+ var headerStyle = {
263
+ padding: '15px',
264
+ backgroundColor: primaryColor,
265
+ color: '#ffffff',
266
+ fontWeight: 'bold',
267
+ display: 'flex',
268
+ justifyContent: 'space-between',
269
+ alignItems: 'center',
270
+ position: 'relative'
271
+ };
272
+ var logoContainerStyle = {
273
+ display: 'flex',
274
+ alignItems: 'center',
275
+ gap: '10px'
276
+ };
277
+ var logoStyle = {
278
+ width: '28px',
279
+ height: '28px',
280
+ };
281
+ var headerTitleContainerStyle = {
282
+ display: 'flex',
283
+ flexDirection: 'column',
284
+ };
285
+ var headerTitleStyle = {
286
+ fontSize: '16px',
287
+ fontWeight: 'bold',
288
+ margin: 0,
289
+ fontFamily: fontFamily,
290
+ };
291
+ var headerSubtitleStyle = {
292
+ fontSize: '14px',
293
+ fontWeight: 'normal',
294
+ margin: 0,
295
+ fontFamily: fontFamily,
296
+ };
297
+ var menuButtonStyle = {
298
+ backgroundColor: 'transparent',
299
+ color: '#ffffff',
300
+ border: 'none',
301
+ borderRadius: '50%',
302
+ width: '32px',
303
+ height: '32px',
304
+ display: 'flex',
305
+ alignItems: 'center',
306
+ justifyContent: 'center',
307
+ cursor: 'pointer',
308
+ outline: 'none',
309
+ };
310
+ var menuPopupStyle = {
311
+ position: 'absolute',
312
+ top: '50px',
313
+ right: '15px',
314
+ backgroundColor: backgroundColor,
315
+ borderRadius: '8px',
316
+ boxShadow: '0 2px 10px rgba(0, 0, 0, 0.1)',
317
+ zIndex: 10,
318
+ display: showMenu ? 'block' : 'none',
319
+ minWidth: '150px',
320
+ overflow: 'hidden',
321
+ };
322
+ var menuItemStyle = {
323
+ display: 'flex',
324
+ alignItems: 'center',
325
+ gap: '8px',
326
+ padding: '10px 15px',
327
+ color: textColor,
328
+ cursor: 'pointer',
329
+ fontSize: fontSize,
330
+ fontFamily: fontFamily,
331
+ borderBottom: '1px solid #f0f0f0',
332
+ };
333
+ var chatContainerStyle = {
334
+ flex: 1,
335
+ overflowY: 'auto',
336
+ padding: '15px',
337
+ backgroundColor: backgroundColor,
338
+ display: 'flex',
339
+ flexDirection: 'column',
340
+ };
341
+ var inputContainerStyle = {
342
+ display: 'flex',
343
+ padding: '15px',
344
+ backgroundColor: '#f5f5f5',
345
+ alignItems: 'center',
346
+ gap: '8px',
347
+ borderTop: '1px solid #e0e0e0',
348
+ };
349
+ var inputWrapperStyle = {
350
+ display: 'flex',
351
+ flex: 1,
352
+ alignItems: 'center',
353
+ backgroundColor: '#ffffff',
354
+ borderRadius: '8px',
355
+ padding: '0 15px',
356
+ height: '48px',
357
+ boxShadow: '0 1px 3px rgba(0, 0, 0, 0.05)',
358
+ };
359
+ var inputStyle = {
360
+ flex: 1,
361
+ border: 'none',
362
+ outline: 'none',
363
+ background: 'transparent',
364
+ fontSize: fontSize,
365
+ fontFamily: fontFamily,
366
+ padding: '0 10px',
367
+ color: textColor,
368
+ };
369
+ var attachButtonStyle = {
370
+ backgroundColor: 'transparent',
371
+ border: 'none',
372
+ display: 'flex',
373
+ alignItems: 'center',
374
+ justifyContent: 'center',
375
+ cursor: 'pointer',
376
+ outline: 'none',
377
+ color: '#757575',
378
+ padding: 0,
379
+ };
380
+ var sendButtonStyle = {
381
+ backgroundColor: primaryColor,
382
+ color: '#ffffff',
383
+ border: 'none',
384
+ borderRadius: '8px',
385
+ width: '48px',
386
+ height: '48px',
387
+ display: 'flex',
388
+ alignItems: 'center',
389
+ justifyContent: 'center',
390
+ cursor: 'pointer',
391
+ outline: 'none',
392
+ flexShrink: 0,
393
+ boxShadow: '0 1px 3px rgba(0, 0, 0, 0.05)',
394
+ };
395
+ var possibleQueriesContainerStyle = {
396
+ display: 'flex',
397
+ flexDirection: 'column',
398
+ gap: '8px',
399
+ padding: '0',
400
+ paddingLeft: '28px',
401
+ paddingRight: '28px',
402
+ marginTop: '5px',
403
+ marginBottom: '15px',
404
+ width: '100%',
405
+ fontFamily: fontFamily,
406
+ };
407
+ var queryButtonStyle = {
408
+ padding: '12px 15px',
409
+ backgroundColor: (theme === null || theme === void 0 ? void 0 : theme.secondaryColor) || '#f5f5f5',
410
+ color: textColor,
411
+ border: 'none',
412
+ borderRadius: '6px',
413
+ fontSize: fontSize,
414
+ cursor: 'pointer',
415
+ textAlign: 'left',
416
+ fontWeight: 'normal',
417
+ boxShadow: 'none',
418
+ width: '100%',
419
+ maxWidth: '240px',
420
+ fontFamily: fontFamily,
421
+ };
422
+ var confirmOverlayStyle = {
423
+ display: showResetConfirm ? 'flex' : 'none',
424
+ position: 'absolute',
425
+ top: 0,
426
+ left: 0,
427
+ right: 0,
428
+ bottom: 0,
429
+ backgroundColor: 'rgba(0, 0, 0, 0.5)',
430
+ zIndex: 10,
431
+ justifyContent: 'center',
432
+ alignItems: 'center',
433
+ };
434
+ var confirmDialogStyle = {
435
+ backgroundColor: backgroundColor,
436
+ padding: '20px',
437
+ borderRadius: '8px',
438
+ maxWidth: '300px',
439
+ textAlign: 'center',
440
+ fontFamily: fontFamily,
441
+ color: textColor,
442
+ };
443
+ var confirmButtonsStyle = {
444
+ display: 'flex',
445
+ justifyContent: 'center',
446
+ marginTop: '15px',
447
+ gap: '10px',
448
+ };
449
+ var confirmButtonStyle = function (isConfirm) { return ({
450
+ padding: '8px 16px',
451
+ backgroundColor: isConfirm ? '#F44336' : '#e0e0e0',
452
+ color: isConfirm ? '#ffffff' : textColor,
453
+ border: 'none',
454
+ borderRadius: '4px',
455
+ cursor: 'pointer',
456
+ fontFamily: fontFamily,
457
+ fontSize: fontSize,
458
+ }); };
459
+ // Floating mode styles
460
+ var getPositionStyles = function () {
461
+ var base = {
462
+ position: 'fixed',
463
+ zIndex: 1000,
464
+ };
465
+ switch (position) {
466
+ case 'bottom-right':
467
+ return __assign(__assign({}, base), { bottom: offsetY, right: offsetX });
468
+ case 'bottom-left':
469
+ return __assign(__assign({}, base), { bottom: offsetY, left: offsetX });
470
+ case 'top-right':
471
+ return __assign(__assign({}, base), { top: offsetY, right: offsetX });
472
+ case 'top-left':
473
+ return __assign(__assign({}, base), { top: offsetY, left: offsetX });
474
+ default:
475
+ return __assign(__assign({}, base), { bottom: offsetY, right: offsetX });
476
+ }
477
+ };
478
+ var getChatPositionStyles = function () {
479
+ var base = {
480
+ position: 'fixed',
481
+ zIndex: 999,
482
+ };
483
+ switch (position) {
484
+ case 'bottom-right':
485
+ return __assign(__assign({}, base), { bottom: offsetY + 80, right: offsetX });
486
+ case 'bottom-left':
487
+ return __assign(__assign({}, base), { bottom: offsetY + 80, left: offsetX });
488
+ case 'top-right':
489
+ return __assign(__assign({}, base), { top: offsetY + 80, right: offsetX });
490
+ case 'top-left':
491
+ return __assign(__assign({}, base), { top: offsetY + 80, left: offsetX });
492
+ default:
493
+ return __assign(__assign({}, base), { bottom: offsetY + 80, right: offsetX });
494
+ }
495
+ };
496
+ var getResponsiveDimensions = function () {
497
+ var screenWidth = typeof window !== 'undefined' ? window.innerWidth : 1024;
498
+ if (screenWidth <= 480) {
499
+ return { width: 'calc(100vw - 40px)', height: '450px' };
500
+ }
501
+ else if (screenWidth <= 768) {
502
+ return { width: '350px', height: '500px' };
503
+ }
504
+ else {
505
+ return { width: '380px', height: '600px' };
506
+ }
507
+ };
508
+ var floatingContainerStyle = __assign(__assign({}, getChatPositionStyles()), getResponsiveDimensions());
509
+ var toggleButtonStyle = __assign(__assign({}, getPositionStyles()), { width: '60px', height: '60px', borderRadius: '50%', backgroundColor: primaryColor, border: 'none', color: 'white', fontSize: '24px', cursor: 'pointer', boxShadow: '0 4px 12px rgba(41, 98, 255, 0.3)', transition: 'all 0.3s ease', display: 'flex', alignItems: 'center', justifyContent: 'center', zIndex: 1001 });
510
+ var renderChatComponent = function () { return (_jsxs("div", { style: containerStyle, children: [_jsxs("div", { style: headerStyle, children: [_jsxs("div", { style: logoContainerStyle, children: [_jsx("img", { src: chatLogo, alt: "Logo", style: logoStyle }), _jsxs("div", { style: headerTitleContainerStyle, children: [_jsx("div", { style: headerTitleStyle, children: headerTitle }), _jsx("div", { style: headerSubtitleStyle, children: "Support" })] })] }), _jsx("button", { style: menuButtonStyle, onClick: handleMenuClick, title: "Menu", children: _jsx(MoreVertical, { size: 24, color: "#ffffff" }) }), _jsx("div", { ref: menuRef, style: menuPopupStyle, children: _jsxs("div", { style: menuItemStyle, onClick: handleResetClick, children: [_jsx(RefreshCw, { size: 16 }), "Reset conversation"] }) })] }), _jsxs("div", { style: chatContainerStyle, children: [messages.map(function (message, index) {
511
+ var isNextSameSpeaker = index < messages.length - 1 && messages[index + 1].speaker === message.speaker;
512
+ var isPrevSameSpeaker = index > 0 && messages[index - 1].speaker === message.speaker;
513
+ return (_jsx(ChatMessageComponent, { message: message, theme: theme, onPlayAudio: message.speaker === 'agent' ? playResponseAudio : undefined, isPlayingAudio: isPlayingAudio, isFirstMessage: index === 0 && message.speaker === 'agent' && !hasUserMessages, isNextSameSpeaker: isNextSameSpeaker, isPrevSameSpeaker: isPrevSameSpeaker }, index));
514
+ }), _jsx("div", { ref: messagesEndRef })] }), possibleQueries.length > 0 && !hasUserMessages && (_jsx("div", { style: possibleQueriesContainerStyle, children: possibleQueries.map(function (query, index) { return (_jsx("button", { style: queryButtonStyle, onClick: function () { return handleQueryClick(query); }, disabled: isLoading, children: query }, index)); }) })), !conversationId || isFinalized ? (_jsx("div", { style: inputContainerStyle, children: _jsx("button", { style: __assign(__assign({}, sendButtonStyle), { width: '100%', height: '48px', borderRadius: '8px' }), onClick: handleStartConversation, disabled: isLoading, children: "Start Conversation" }) })) : (_jsxs("form", { onSubmit: handleSubmit, style: inputContainerStyle, children: [_jsxs("div", { style: inputWrapperStyle, children: [_jsx("button", { type: "button", style: attachButtonStyle, title: "Attach", children: _jsx(Paperclip, { size: 24, color: "#757575" }) }), _jsx("input", { style: inputStyle, type: "text", value: inputValue, onChange: function (e) { return setInputValue(e.target.value); }, placeholder: placeholder, disabled: connectionState !== 'connected' })] }), _jsx(VoiceInput, { onTranscription: handleVoiceTranscription, onError: handleVoiceError, baseUrl: baseUrl, apiKey: apiKey, theme: theme }), _jsx("button", { type: "submit", style: sendButtonStyle, disabled: inputValue.trim() === '' || connectionState !== 'connected', children: _jsx(Send, { size: 20, color: "#ffffff" }) })] })), _jsx("div", { style: confirmOverlayStyle, children: _jsxs("div", { style: confirmDialogStyle, children: [_jsx("h3", { style: { fontFamily: fontFamily, marginTop: 0 }, children: "Reset Conversation" }), _jsx("p", { style: { fontFamily: fontFamily, fontSize: fontSize }, children: "This will clear the current conversation history and start a new conversation. Are you sure?" }), _jsxs("div", { style: confirmButtonsStyle, children: [_jsx("button", { style: confirmButtonStyle(false), onClick: handleCancelReset, children: "Cancel" }), _jsx("button", { style: confirmButtonStyle(true), onClick: handleConfirmReset, children: "Reset" })] })] }) })] })); };
515
+ if (mode === 'floating') {
516
+ return (_jsxs(_Fragment, { children: [_jsx("button", { style: toggleButtonStyle, onClick: toggleFloatingChat, title: isFloatingOpen ? "Close Chat" : "Open Chat", children: isFloatingOpen ? _jsx(XIcon, { size: 24 }) : _jsx(MessageSquareMore, { size: 24 }) }), isFloatingOpen && (_jsx("div", { style: floatingContainerStyle, children: renderChatComponent() }))] }));
517
+ }
518
+ return renderChatComponent();
519
+ };
520
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenAgentChat.js","sourceRoot":"","sources":["../../src/components/GenAgentChat.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAc,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,OAAO,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAClG,OAAO,QAAQ,MAAM,4BAA4B,CAAC;AAElD,MAAM,CAAC,IAAM,YAAY,GAAgC,UAAC,EAYzD;QAXC,OAAO,aAAA,EACP,MAAM,YAAA,EACN,QAAQ,cAAA,EACR,OAAO,aAAA,EACP,UAAU,gBAAA,EACV,UAAU,gBAAA,EACV,KAAK,WAAA,EACL,mBAAyB,EAAzB,WAAW,mBAAG,WAAW,KAAA,EACzB,mBAA8B,EAA9B,WAAW,mBAAG,gBAAgB,KAAA,EAC9B,YAAiB,EAAjB,IAAI,mBAAG,UAAU,KAAA,EACjB,sBAAmB,EAAnB,cAAc,mBAAG,EAAE,KAAA;IAEb,IAAA,KAA8B,QAAQ,CAAC,EAAE,CAAC,EAAzC,UAAU,QAAA,EAAE,aAAa,QAAgB,CAAC;IAC3C,IAAA,KAA0C,QAAQ,CAAC,KAAK,CAAC,EAAxD,gBAAgB,QAAA,EAAE,mBAAmB,QAAmB,CAAC;IAC1D,IAAA,KAA0B,QAAQ,CAAC,KAAK,CAAC,EAAxC,QAAQ,QAAA,EAAE,WAAW,QAAmB,CAAC;IAC1C,IAAA,KAAsC,QAAQ,CAAC,KAAK,CAAC,EAApD,cAAc,QAAA,EAAE,iBAAiB,QAAmB,CAAC;IACtD,IAAA,KAAsC,QAAQ,CAAC,KAAK,CAAC,EAApD,cAAc,QAAA,EAAE,iBAAiB,QAAmB,CAAC;IAC5D,IAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IACvC,IAAA,KAWF,OAAO,CAAC;QACV,OAAO,SAAA;QACP,MAAM,QAAA;QACN,QAAQ,UAAA;QACR,OAAO,SAAA;QACP,UAAU,YAAA;QACV,UAAU,YAAA;KACX,CAAC,EAjBA,QAAQ,cAAA,EACR,SAAS,eAAA,EACT,WAAW,iBAAA,EACX,iBAAiB,uBAAA,EACjB,iBAAiB,uBAAA,EACjB,eAAe,qBAAA,EACf,cAAc,oBAAA,EACd,eAAe,qBAAA,EACf,WAAW,iBAAA,EACX,WAAW,iBAQX,CAAC;IACH,IAAM,cAAc,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IACpD,IAAM,YAAY,GAAG,MAAM,CAAsB,IAAI,CAAC,CAAC;IAEvD,IAAM,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,OAAO,KAAK,UAAU,EAA9B,CAA8B,CAAC,CAAC;IAEjF,SAAS,CAAC;QACR,YAAY,CAAC,OAAO,GAAG,IAAI,YAAY,CAAC,EAAE,OAAO,SAAA,EAAE,MAAM,QAAA,EAAE,CAAC,CAAC;IAC/D,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;IAEtB,oCAAoC;IACpC,eAAe,CAAC;QACd,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;YAC3B,cAAc,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAChE,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,mCAAmC;IACnC,oBAAoB;IACpB,wDAAwD;IACxD,gFAAgF;IAChF,4BAA4B;IAC5B,QAAQ;IACR,OAAO;IAEP,gEAAgE;IAChE,mBAAmB;IACnB,qEAAqE;IACrE,OAAO;IACP,UAAU;IAEV,IAAM,YAAY,GAAG,UAAO,CAAkB;;;;;oBAC5C,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,SAAS;wBAAE,sBAAO;;;;oBAGhD,aAAa,CAAC,EAAE,CAAC,CAAC;oBAClB,qBAAM,WAAW,CAAC,UAAU,CAAC,EAAA;;oBAA7B,SAA6B,CAAC;;;;oBAE9B,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,OAAK,CAAC,CAAC;;;;;SAElD,CAAC;IAEF,IAAM,wBAAwB,GAAG,UAAO,IAAY;;YAClD,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE;gBAAE,sBAAO;YAC/B,aAAa,CAAC,IAAI,CAAC,CAAC;;;SACrB,CAAC;IAEF,IAAM,gBAAgB,GAAG,UAAC,KAAY;QACpC,OAAO,CAAC,KAAK,CAAC,oBAAoB,EAAE,KAAK,CAAC,CAAC;QAC3C,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,KAAK,CAAC,CAAC;QACjB,CAAC;IACH,CAAC,CAAC;IAEF,IAAM,iBAAiB,GAAG,UAAO,IAAY;;;;;oBAC3C,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,cAAc;wBAAE,sBAAO;;;;oBAGlD,iBAAiB,CAAC,IAAI,CAAC,CAAC;oBACN,qBAAM,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,EAAA;;oBAAzD,SAAS,GAAG,SAA6C;oBAC/D,qBAAM,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,EAAA;;oBAA/C,SAA+C,CAAC;;;;oBAEhD,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,OAAK,CAAC,CAAC;oBAC7C,IAAI,OAAO,EAAE,CAAC;wBACZ,OAAO,CAAC,OAAc,CAAC,CAAC;oBAC1B,CAAC;;;oBAED,iBAAiB,CAAC,KAAK,CAAC,CAAC;;;;;SAE5B,CAAC;IAEF,IAAM,gBAAgB,GAAG,UAAO,KAAa;;;;;oBAC3C,IAAI,SAAS;wBAAE,sBAAO;;;;oBAGpB,qBAAM,WAAW,CAAC,KAAK,CAAC,EAAA;;oBAAxB,SAAwB,CAAC;;;;oBAEzB,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,OAAK,CAAC,CAAC;;;;;SAEtD,CAAC;IAEF,IAAM,uBAAuB,GAAG;;;;;oBAC9B,IAAI,SAAS;wBAAE,sBAAO;;;;oBAGpB,qBAAM,iBAAiB,EAAE,EAAA;;oBAAzB,SAAyB,CAAC;;;;oBAE1B,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,OAAK,CAAC,CAAC;;;;;SAExD,CAAC;IAEF,IAAM,eAAe,GAAG;QACtB,WAAW,CAAC,UAAA,IAAI,IAAI,OAAA,CAAC,IAAI,EAAL,CAAK,CAAC,CAAC;IAC7B,CAAC,CAAC;IAEF,IAAM,gBAAgB,GAAG;QACvB,WAAW,CAAC,KAAK,CAAC,CAAC;QACnB,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC,CAAC;IAEF,IAAM,kBAAkB,GAAG;;;wBACzB,qBAAM,iBAAiB,EAAE,EAAA;;oBAAzB,SAAyB,CAAC;oBAC1B,mBAAmB,CAAC,KAAK,CAAC,CAAC;;;;SAC5B,CAAC;IAEF,IAAM,iBAAiB,GAAG;QACxB,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC,CAAC;IAEF,IAAM,kBAAkB,GAAG;QACzB,iBAAiB,CAAC,UAAA,IAAI,IAAI,OAAA,CAAC,IAAI,EAAL,CAAK,CAAC,CAAC;IACnC,CAAC,CAAC;IAEF,uCAAuC;IACvC,IAAM,YAAY,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,KAAI,SAAS,CAAC;IACtD,IAAM,eAAe,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,eAAe,KAAI,SAAS,CAAC;IAC5D,IAAM,SAAS,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,SAAS,KAAI,SAAS,CAAC;IAChD,IAAM,UAAU,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,KAAI,2BAA2B,CAAC;IACpE,IAAM,QAAQ,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,KAAI,MAAM,CAAC;IAE3C,kCAAkC;IAClC,IAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,IAAI,cAAc,CAAC;IAC3D,IAAM,MAAM,GAAG,cAAc,CAAC,MAAM,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IACzD,IAAM,OAAO,GAAG,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC;IAC/B,IAAM,OAAO,GAAG,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC;IAC/B,IAAM,gBAAgB,GAAG,cAAc,CAAC,gBAAgB,IAAI,KAAC,iBAAiB,KAAG,CAAC;IAClF,IAAM,eAAe,GAAG,cAAc,CAAC,eAAe,IAAI,KAAC,KAAK,KAAG,CAAC;IAEpE,IAAM,cAAc,GAAwB;QAC1C,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,MAAM,EAAE,MAAM;QACd,SAAS,EAAE,OAAO;QAClB,KAAK,EAAE,MAAM;QACb,QAAQ,EAAE,OAAO;QACjB,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,KAAK;QACnB,QAAQ,EAAE,QAAQ;QAClB,eAAe,iBAAA;QACf,UAAU,YAAA;QACV,SAAS,EAAE,+BAA+B;QAC1C,QAAQ,EAAE,UAAU;KACrB,CAAC;IAEF,IAAM,WAAW,GAAwB;QACvC,OAAO,EAAE,MAAM;QACf,eAAe,EAAE,YAAY;QAC7B,KAAK,EAAE,SAAS;QAChB,UAAU,EAAE,MAAM;QAClB,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,QAAQ,EAAE,UAAU;KACrB,CAAC;IAEF,IAAM,kBAAkB,GAAwB;QAC9C,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,MAAM;KACZ,CAAC;IAEF,IAAM,SAAS,GAAwB;QACrC,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;KACf,CAAC;IAEF,IAAM,yBAAyB,GAAwB;QACrD,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;KACxB,CAAC;IAEF,IAAM,gBAAgB,GAAwB;QAC5C,QAAQ,EAAE,MAAM;QAChB,UAAU,EAAE,MAAM;QAClB,MAAM,EAAE,CAAC;QACT,UAAU,YAAA;KACX,CAAC;IAEF,IAAM,mBAAmB,GAAwB;QAC/C,QAAQ,EAAE,MAAM;QAChB,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,CAAC;QACT,UAAU,YAAA;KACX,CAAC;IAEF,IAAM,eAAe,GAAwB;QAC3C,eAAe,EAAE,aAAa;QAC9B,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,KAAK;QACnB,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,MAAM,EAAE,SAAS;QACjB,OAAO,EAAE,MAAM;KAChB,CAAC;IAEF,IAAM,cAAc,GAAwB;QAC1C,QAAQ,EAAE,UAAU;QACpB,GAAG,EAAE,MAAM;QACX,KAAK,EAAE,MAAM;QACb,eAAe,EAAE,eAAe;QAChC,YAAY,EAAE,KAAK;QACnB,SAAS,EAAE,+BAA+B;QAC1C,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QACpC,QAAQ,EAAE,OAAO;QACjB,QAAQ,EAAE,QAAQ;KACnB,CAAC;IAEF,IAAM,aAAa,GAAwB;QACzC,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,WAAW;QACpB,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,SAAS;QACjB,QAAQ,UAAA;QACR,UAAU,YAAA;QACV,YAAY,EAAE,mBAAmB;KAClC,CAAC;IAEF,IAAM,kBAAkB,GAAwB;QAC9C,IAAI,EAAE,CAAC;QACP,SAAS,EAAE,MAAM;QACjB,OAAO,EAAE,MAAM;QACf,eAAe,iBAAA;QACf,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;KACxB,CAAC;IAEF,IAAM,mBAAmB,GAAwB;QAC/C,OAAO,EAAE,MAAM;QACf,OAAO,EAAE,MAAM;QACf,eAAe,EAAE,SAAS;QAC1B,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,KAAK;QACV,SAAS,EAAE,mBAAmB;KAC/B,CAAC;IAEF,IAAM,iBAAiB,GAAwB;QAC7C,OAAO,EAAE,MAAM;QACf,IAAI,EAAE,CAAC;QACP,UAAU,EAAE,QAAQ;QACpB,eAAe,EAAE,SAAS;QAC1B,YAAY,EAAE,KAAK;QACnB,OAAO,EAAE,QAAQ;QACjB,MAAM,EAAE,MAAM;QACd,SAAS,EAAE,+BAA+B;KAC3C,CAAC;IAEF,IAAM,UAAU,GAAwB;QACtC,IAAI,EAAE,CAAC;QACP,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,aAAa;QACzB,QAAQ,UAAA;QACR,UAAU,YAAA;QACV,OAAO,EAAE,QAAQ;QACjB,KAAK,EAAE,SAAS;KACjB,CAAC;IAEF,IAAM,iBAAiB,GAAwB;QAC7C,eAAe,EAAE,aAAa;QAC9B,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,MAAM,EAAE,SAAS;QACjB,OAAO,EAAE,MAAM;QACf,KAAK,EAAE,SAAS;QAChB,OAAO,EAAE,CAAC;KACX,CAAC;IAEF,IAAM,eAAe,GAAwB;QAC3C,eAAe,EAAE,YAAY;QAC7B,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,KAAK;QACnB,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,MAAM,EAAE,SAAS;QACjB,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,CAAC;QACb,SAAS,EAAE,+BAA+B;KAC3C,CAAC;IAEF,IAAM,6BAA6B,GAAwB;QACzD,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,GAAG;QACZ,WAAW,EAAE,MAAM;QACnB,YAAY,EAAE,MAAM;QACpB,SAAS,EAAE,KAAK;QAChB,YAAY,EAAE,MAAM;QACpB,KAAK,EAAE,MAAM;QACb,UAAU,YAAA;KACX,CAAC;IAEF,IAAM,gBAAgB,GAAwB;QAC5C,OAAO,EAAE,WAAW;QACpB,eAAe,EAAE,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,cAAc,KAAI,SAAS;QACnD,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,KAAK;QACnB,QAAQ,UAAA;QACR,MAAM,EAAE,SAAS;QACjB,SAAS,EAAE,MAAM;QACjB,UAAU,EAAE,QAAQ;QACpB,SAAS,EAAE,MAAM;QACjB,KAAK,EAAE,MAAM;QACb,QAAQ,EAAE,OAAO;QACjB,UAAU,YAAA;KACX,CAAC;IAEF,IAAM,mBAAmB,GAAwB;QAC/C,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;QAC3C,QAAQ,EAAE,UAAU;QACpB,GAAG,EAAE,CAAC;QACN,IAAI,EAAE,CAAC;QACP,KAAK,EAAE,CAAC;QACR,MAAM,EAAE,CAAC;QACT,eAAe,EAAE,oBAAoB;QACrC,MAAM,EAAE,EAAE;QACV,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;KACrB,CAAC;IAEF,IAAM,kBAAkB,GAAwB;QAC9C,eAAe,EAAE,eAAe;QAChC,OAAO,EAAE,MAAM;QACf,YAAY,EAAE,KAAK;QACnB,QAAQ,EAAE,OAAO;QACjB,SAAS,EAAE,QAAQ;QACnB,UAAU,YAAA;QACV,KAAK,EAAE,SAAS;KACjB,CAAC;IAEF,IAAM,mBAAmB,GAAwB;QAC/C,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,QAAQ;QACxB,SAAS,EAAE,MAAM;QACjB,GAAG,EAAE,MAAM;KACZ,CAAC;IAEF,IAAM,kBAAkB,GAAG,UAAC,SAAkB,IAA0B,OAAA,CAAC;QACvE,OAAO,EAAE,UAAU;QACnB,eAAe,EAAE,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAClD,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QACxC,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,KAAK;QACnB,MAAM,EAAE,SAAS;QACjB,UAAU,YAAA;QACV,QAAQ,UAAA;KACT,CAAC,EATsE,CAStE,CAAC;IAEH,uBAAuB;IACvB,IAAM,iBAAiB,GAAG;QACxB,IAAM,IAAI,GAAwB;YAChC,QAAQ,EAAE,OAAO;YACjB,MAAM,EAAE,IAAI;SACb,CAAC;QAEF,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,cAAc;gBACjB,6BAAY,IAAI,KAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,IAAG;YACtD,KAAK,aAAa;gBAChB,6BAAY,IAAI,KAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,IAAG;YACrD,KAAK,WAAW;gBACd,6BAAY,IAAI,KAAE,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,IAAG;YACnD,KAAK,UAAU;gBACb,6BAAY,IAAI,KAAE,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,IAAG;YAClD;gBACE,6BAAY,IAAI,KAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,IAAG;QACxD,CAAC;IACH,CAAC,CAAC;IAEF,IAAM,qBAAqB,GAAG;QAC5B,IAAM,IAAI,GAAwB;YAChC,QAAQ,EAAE,OAAO;YACjB,MAAM,EAAE,GAAG;SACZ,CAAC;QAEF,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,cAAc;gBACjB,6BACK,IAAI,KACP,MAAM,EAAE,OAAO,GAAG,EAAE,EACpB,KAAK,EAAE,OAAO,IACd;YACJ,KAAK,aAAa;gBAChB,6BACK,IAAI,KACP,MAAM,EAAE,OAAO,GAAG,EAAE,EACpB,IAAI,EAAE,OAAO,IACb;YACJ,KAAK,WAAW;gBACd,6BACK,IAAI,KACP,GAAG,EAAE,OAAO,GAAG,EAAE,EACjB,KAAK,EAAE,OAAO,IACd;YACJ,KAAK,UAAU;gBACb,6BACK,IAAI,KACP,GAAG,EAAE,OAAO,GAAG,EAAE,EACjB,IAAI,EAAE,OAAO,IACb;YACJ;gBACE,6BACK,IAAI,KACP,MAAM,EAAE,OAAO,GAAG,EAAE,EACpB,KAAK,EAAE,OAAO,IACd;QACN,CAAC;IACH,CAAC,CAAC;IAEF,IAAM,uBAAuB,GAAG;QAC9B,IAAM,WAAW,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7E,IAAI,WAAW,IAAI,GAAG,EAAE,CAAC;YACvB,OAAO,EAAE,KAAK,EAAE,oBAAoB,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;QAC1D,CAAC;aAAM,IAAI,WAAW,IAAI,GAAG,EAAE,CAAC;YAC9B,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;QAC7C,CAAC;IACH,CAAC,CAAC;IAEF,IAAM,sBAAsB,yBACvB,qBAAqB,EAAE,GACvB,uBAAuB,EAAE,CAC7B,CAAC;IAEF,IAAM,iBAAiB,yBAClB,iBAAiB,EAAE,KACtB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,KAAK,EACnB,eAAe,EAAE,YAAY,EAC7B,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,mCAAmC,EAC9C,UAAU,EAAE,eAAe,EAC3B,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,QAAQ,EACpB,cAAc,EAAE,QAAQ,EACxB,MAAM,EAAE,IAAI,GACb,CAAC;IAEF,IAAM,mBAAmB,GAAG,cAAM,OAAA,CAChC,eAAK,KAAK,EAAE,cAAc,aACxB,eAAK,KAAK,EAAE,WAAW,aACrB,eAAK,KAAK,EAAE,kBAAkB,aAC5B,cAAK,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAC,MAAM,EAAC,KAAK,EAAE,SAAS,GAAI,EACnD,eAAK,KAAK,EAAE,yBAAyB,aACnC,cAAK,KAAK,EAAE,gBAAgB,YAAG,WAAW,GAAO,EACjD,cAAK,KAAK,EAAE,mBAAmB,wBAAe,IAC1C,IACF,EACN,iBACE,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE,eAAe,EACxB,KAAK,EAAC,MAAM,YAEZ,KAAC,YAAY,IAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAC,SAAS,GAAG,GACnC,EAET,cAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,cAAc,YACtC,eAAK,KAAK,EAAE,aAAa,EAAE,OAAO,EAAE,gBAAgB,aAClD,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,0BAEnB,GACF,IACF,EAEN,eAAK,KAAK,EAAE,kBAAkB,aAC3B,QAAQ,CAAC,GAAG,CAAC,UAAC,OAAO,EAAE,KAAK;wBAC3B,IAAM,iBAAiB,GAAG,KAAK,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC;wBACzG,IAAM,iBAAiB,GAAG,KAAK,GAAG,CAAC,IAAI,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC;wBAEvF,OAAO,CACL,KAAC,oBAAoB,IAEnB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,OAAO,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,SAAS,EACxE,cAAc,EAAE,cAAc,EAC9B,cAAc,EAAE,KAAK,KAAK,CAAC,IAAI,OAAO,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,eAAe,EAC9E,iBAAiB,EAAE,iBAAiB,EACpC,iBAAiB,EAAE,iBAAiB,IAP/B,KAAK,CAQV,CACH,CAAC;oBACJ,CAAC,CAAC,EACF,cAAK,GAAG,EAAE,cAAc,GAAI,IACxB,EAEL,eAAe,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,CACjD,cAAK,KAAK,EAAE,6BAA6B,YACtC,eAAe,CAAC,GAAG,CAAC,UAAC,KAAK,EAAE,KAAK,IAAK,OAAA,CACrC,iBAEE,KAAK,EAAE,gBAAgB,EACvB,OAAO,EAAE,cAAM,OAAA,gBAAgB,CAAC,KAAK,CAAC,EAAvB,CAAuB,EACtC,QAAQ,EAAE,SAAS,YAElB,KAAK,IALD,KAAK,CAMH,CACV,EATsC,CAStC,CAAC,GACE,CACP,EAEA,CAAC,cAAc,IAAI,WAAW,CAAC,CAAC,CAAC,CAChC,cAAK,KAAK,EAAE,mBAAmB,YAC7B,iBACE,KAAK,wBAAM,eAAe,KAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,KAC9E,OAAO,EAAE,uBAAuB,EAChC,QAAQ,EAAE,SAAS,mCAGZ,GACL,CACP,CAAC,CAAC,CAAC,CACF,gBAAM,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,mBAAmB,aACtD,eAAK,KAAK,EAAE,iBAAiB,aAC3B,iBACE,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE,iBAAiB,EACxB,KAAK,EAAC,QAAQ,YAEd,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAC,SAAS,GAAG,GAChC,EACT,gBACE,KAAK,EAAE,UAAU,EACjB,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,UAAU,EACjB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAA7B,CAA6B,EAC9C,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,eAAe,KAAK,WAAW,GACzC,IACE,EAEN,KAAC,UAAU,IACT,eAAe,EAAE,wBAAwB,EACzC,OAAO,EAAE,gBAAgB,EACzB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,GACZ,EAEF,iBACE,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE,eAAe,EACtB,QAAQ,EAAE,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,eAAe,KAAK,WAAW,YAErE,KAAC,IAAI,IAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAC,SAAS,GAAG,GAC3B,IACJ,CACR,EAED,cAAK,KAAK,EAAE,mBAAmB,YAC7B,eAAK,KAAK,EAAE,kBAAkB,aAC5B,aAAI,KAAK,EAAE,EAAC,UAAU,YAAA,EAAE,SAAS,EAAE,CAAC,EAAC,mCAAyB,EAC9D,YAAG,KAAK,EAAE,EAAC,UAAU,YAAA,EAAE,QAAQ,UAAA,EAAC,6GAAkG,EAClI,eAAK,KAAK,EAAE,mBAAmB,aAC7B,iBAAQ,KAAK,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,iBAAiB,uBAAiB,EACrF,iBAAQ,KAAK,EAAE,kBAAkB,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,kBAAkB,sBAAgB,IAChF,IACF,GACF,IACF,CACP,EAzHiC,CAyHjC,CAAC;IAEF,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;QACxB,OAAO,CACL,8BACE,iBACE,KAAK,EAAE,iBAAiB,EACxB,OAAO,EAAE,kBAAkB,EAC3B,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,YAEjD,cAAc,CAAC,CAAC,CAAC,KAAC,KAAK,IAAC,IAAI,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,KAAC,iBAAiB,IAAC,IAAI,EAAE,EAAE,GAAI,GAChE,EAER,cAAc,IAAI,CACjB,cAAK,KAAK,EAAE,sBAAsB,YAC/B,mBAAmB,EAAE,GAClB,CACP,IACA,CACJ,CAAC;IACJ,CAAC;IAED,OAAO,mBAAmB,EAAE,CAAC;AAC/B,CAAC,CAAC","sourcesContent":["import React, { useState, useRef, useEffect, useLayoutEffect } from 'react';\nimport { ChatMessageComponent } from './ChatMessage';\nimport { useChat } from '../hooks/useChat';\nimport { ChatMessage, GenAgentChatProps } from '../types';\nimport { VoiceInput } from './VoiceInput';\nimport { AudioService } from '../services/audioService';\nimport { Send, Paperclip, MoreVertical, RefreshCw, XIcon, MessageSquareMore } from 'lucide-react';\nimport chatLogo from '../../assets/chat-logo.png';\n\nexport const GenAgentChat: React.FC<GenAgentChatProps> = ({\n  baseUrl,\n  apiKey,\n  metadata,\n  onError,\n  onTakeover,\n  onFinalize,\n  theme,\n  headerTitle = 'Genassist',\n  placeholder = 'Ask a question',\n  mode = 'embedded',\n  floatingConfig = {}\n}) => {\n  const [inputValue, setInputValue] = useState('');\n  const [showResetConfirm, setShowResetConfirm] = useState(false);\n  const [showMenu, setShowMenu] = useState(false);\n  const [isPlayingAudio, setIsPlayingAudio] = useState(false);\n  const [isFloatingOpen, setIsFloatingOpen] = useState(false);\n  const menuRef = useRef<HTMLDivElement>(null);\n  const { \n    messages, \n    isLoading, \n    sendMessage, \n    resetConversation,\n    startConversation,\n    connectionState, \n    conversationId,\n    possibleQueries,\n    isTakenOver,\n    isFinalized\n  } = useChat({\n    baseUrl,\n    apiKey,\n    metadata,\n    onError,\n    onTakeover,\n    onFinalize\n  });\n  const messagesEndRef = useRef<HTMLDivElement>(null);\n  const audioService = useRef<AudioService | null>(null);\n\n  const hasUserMessages = messages.some(message => message.speaker === 'customer');\n\n  useEffect(() => {\n    audioService.current = new AudioService({ baseUrl, apiKey });\n  }, [baseUrl, apiKey]);\n\n  // Auto-scroll to the latest message\n  useLayoutEffect(() => {\n    if (messagesEndRef.current) {\n      messagesEndRef.current.scrollIntoView({ behavior: 'smooth' });\n    }\n  }, [messages]);\n\n  // Close menu when clicking outside\n  // useEffect(() => {\n  //   const handleClickOutside = (event: MouseEvent) => {\n  //     if (menuRef.current && !menuRef.current.contains(event.target as Node)) {\n  //       setShowMenu(false);\n  //     }\n  //   };\n\n  //   document.addEventListener('mousedown', handleClickOutside);\n  //   return () => {\n  //     document.removeEventListener('mousedown', handleClickOutside);\n  //   };\n  // }, []);\n\n  const handleSubmit = async (e: React.FormEvent) => {\n    e.preventDefault();\n    if (inputValue.trim() === '' || isLoading) return;\n\n    try {\n      setInputValue('');\n      await sendMessage(inputValue);\n    } catch (error) {\n      console.error('Error sending message:', error);\n    }\n  };\n\n  const handleVoiceTranscription = async (text: string) => {\n    if (text.trim() === '') return;\n    setInputValue(text);\n  };\n\n  const handleVoiceError = (error: Error) => {\n    console.error('Voice input error:', error);\n    if (onError) {\n      onError(error);\n    }\n  };\n\n  const playResponseAudio = async (text: string) => {\n    if (!audioService.current || isPlayingAudio) return;\n\n    try {\n      setIsPlayingAudio(true);\n      const audioBlob = await audioService.current.textToSpeech(text);\n      await audioService.current.playAudio(audioBlob);\n    } catch (error) {\n      console.error('Error playing audio:', error);\n      if (onError) {\n        onError(error as Error);\n      }\n    } finally {\n      setIsPlayingAudio(false);\n    }\n  };\n\n  const handleQueryClick = async (query: string) => {\n    if (isLoading) return;\n    \n    try {\n      await sendMessage(query);\n    } catch (error) {\n      console.error('Error sending quick query:', error);\n    }\n  };\n\n  const handleStartConversation = async () => {\n    if (isLoading) return;\n\n    try {\n      await startConversation();\n    } catch (error) {\n      console.error('Error starting conversation:', error);\n    }\n  };\n\n  const handleMenuClick = () => {\n    setShowMenu(prev => !prev);\n  };\n\n  const handleResetClick = () => {\n    setShowMenu(false);\n    setShowResetConfirm(true);\n  };\n\n  const handleConfirmReset = async () => {\n    await resetConversation();\n    setShowResetConfirm(false);\n  };\n\n  const handleCancelReset = () => {\n    setShowResetConfirm(false);\n  };\n\n  const toggleFloatingChat = () => {\n    setIsFloatingOpen(prev => !prev);\n  };\n\n  // Extract theme colors or use defaults\n  const primaryColor = theme?.primaryColor || '#2962FF';\n  const backgroundColor = theme?.backgroundColor || '#ffffff';\n  const textColor = theme?.textColor || '#000000';\n  const fontFamily = theme?.fontFamily || 'Roboto, Arial, sans-serif';\n  const fontSize = theme?.fontSize || '14px';\n\n  // Floating configuration defaults\n  const position = floatingConfig.position || 'bottom-right';\n  const offset = floatingConfig.offset || { x: 20, y: 20 };\n  const offsetX = offset.x || 20;\n  const offsetY = offset.y || 20;\n  const toggleButtonIcon = floatingConfig.toggleButtonIcon || <MessageSquareMore />;\n  const closeButtonIcon = floatingConfig.closeButtonIcon || <XIcon />;\n\n  const containerStyle: React.CSSProperties = {\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    maxHeight: '600px',\n    width: '100%',\n    maxWidth: '400px',\n    border: '1px solid #e0e0e0',\n    borderRadius: '8px',\n    overflow: 'hidden',\n    backgroundColor,\n    fontFamily,\n    boxShadow: '0 2px 10px rgba(0, 0, 0, 0.1)',\n    position: 'relative'\n  };\n\n  const headerStyle: React.CSSProperties = {\n    padding: '15px',\n    backgroundColor: primaryColor,\n    color: '#ffffff',\n    fontWeight: 'bold',\n    display: 'flex',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    position: 'relative'\n  };\n\n  const logoContainerStyle: React.CSSProperties = {\n    display: 'flex',\n    alignItems: 'center',\n    gap: '10px'\n  };\n\n  const logoStyle: React.CSSProperties = {\n    width: '28px',\n    height: '28px',\n  };\n\n  const headerTitleContainerStyle: React.CSSProperties = {\n    display: 'flex',\n    flexDirection: 'column',\n  };\n\n  const headerTitleStyle: React.CSSProperties = {\n    fontSize: '16px',\n    fontWeight: 'bold',\n    margin: 0,\n    fontFamily,\n  };\n\n  const headerSubtitleStyle: React.CSSProperties = {\n    fontSize: '14px',\n    fontWeight: 'normal',\n    margin: 0,\n    fontFamily,\n  };\n\n  const menuButtonStyle: React.CSSProperties = {\n    backgroundColor: 'transparent',\n    color: '#ffffff',\n    border: 'none',\n    borderRadius: '50%',\n    width: '32px',\n    height: '32px',\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    cursor: 'pointer',\n    outline: 'none',\n  };\n\n  const menuPopupStyle: React.CSSProperties = {\n    position: 'absolute',\n    top: '50px',\n    right: '15px',\n    backgroundColor: backgroundColor,\n    borderRadius: '8px',\n    boxShadow: '0 2px 10px rgba(0, 0, 0, 0.1)',\n    zIndex: 10,\n    display: showMenu ? 'block' : 'none',\n    minWidth: '150px',\n    overflow: 'hidden',\n  };\n\n  const menuItemStyle: React.CSSProperties = {\n    display: 'flex',\n    alignItems: 'center',\n    gap: '8px',\n    padding: '10px 15px',\n    color: textColor,\n    cursor: 'pointer',\n    fontSize,\n    fontFamily,\n    borderBottom: '1px solid #f0f0f0',\n  };\n\n  const chatContainerStyle: React.CSSProperties = {\n    flex: 1,\n    overflowY: 'auto',\n    padding: '15px',\n    backgroundColor,\n    display: 'flex',\n    flexDirection: 'column',\n  };\n\n  const inputContainerStyle: React.CSSProperties = {\n    display: 'flex',\n    padding: '15px',\n    backgroundColor: '#f5f5f5',\n    alignItems: 'center',\n    gap: '8px',\n    borderTop: '1px solid #e0e0e0',\n  };\n\n  const inputWrapperStyle: React.CSSProperties = {\n    display: 'flex',\n    flex: 1,\n    alignItems: 'center',\n    backgroundColor: '#ffffff',\n    borderRadius: '8px',\n    padding: '0 15px',\n    height: '48px',\n    boxShadow: '0 1px 3px rgba(0, 0, 0, 0.05)',\n  };\n\n  const inputStyle: React.CSSProperties = {\n    flex: 1,\n    border: 'none',\n    outline: 'none',\n    background: 'transparent',\n    fontSize,\n    fontFamily,\n    padding: '0 10px',\n    color: textColor,\n  };\n\n  const attachButtonStyle: React.CSSProperties = {\n    backgroundColor: 'transparent',\n    border: 'none',\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    cursor: 'pointer',\n    outline: 'none',\n    color: '#757575',\n    padding: 0,\n  };\n\n  const sendButtonStyle: React.CSSProperties = {\n    backgroundColor: primaryColor,\n    color: '#ffffff',\n    border: 'none',\n    borderRadius: '8px',\n    width: '48px',\n    height: '48px',\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    cursor: 'pointer',\n    outline: 'none',\n    flexShrink: 0,\n    boxShadow: '0 1px 3px rgba(0, 0, 0, 0.05)',\n  };\n\n  const possibleQueriesContainerStyle: React.CSSProperties = {\n    display: 'flex',\n    flexDirection: 'column',\n    gap: '8px',\n    padding: '0',\n    paddingLeft: '28px',\n    paddingRight: '28px',\n    marginTop: '5px',\n    marginBottom: '15px',\n    width: '100%',\n    fontFamily,\n  };\n  \n  const queryButtonStyle: React.CSSProperties = {\n    padding: '12px 15px',\n    backgroundColor: theme?.secondaryColor || '#f5f5f5',\n    color: textColor,\n    border: 'none',\n    borderRadius: '6px',\n    fontSize,\n    cursor: 'pointer',\n    textAlign: 'left',\n    fontWeight: 'normal',\n    boxShadow: 'none',\n    width: '100%',\n    maxWidth: '240px',\n    fontFamily,\n  };\n\n  const confirmOverlayStyle: React.CSSProperties = {\n    display: showResetConfirm ? 'flex' : 'none',\n    position: 'absolute',\n    top: 0,\n    left: 0,\n    right: 0,\n    bottom: 0,\n    backgroundColor: 'rgba(0, 0, 0, 0.5)',\n    zIndex: 10,\n    justifyContent: 'center',\n    alignItems: 'center',\n  };\n\n  const confirmDialogStyle: React.CSSProperties = {\n    backgroundColor: backgroundColor,\n    padding: '20px',\n    borderRadius: '8px',\n    maxWidth: '300px',\n    textAlign: 'center',\n    fontFamily,\n    color: textColor,\n  };\n\n  const confirmButtonsStyle: React.CSSProperties = {\n    display: 'flex',\n    justifyContent: 'center',\n    marginTop: '15px',\n    gap: '10px',\n  };\n\n  const confirmButtonStyle = (isConfirm: boolean): React.CSSProperties => ({\n    padding: '8px 16px',\n    backgroundColor: isConfirm ? '#F44336' : '#e0e0e0',\n    color: isConfirm ? '#ffffff' : textColor,\n    border: 'none',\n    borderRadius: '4px',\n    cursor: 'pointer',\n    fontFamily,\n    fontSize,\n  });\n\n  // Floating mode styles\n  const getPositionStyles = (): React.CSSProperties => {\n    const base: React.CSSProperties = {\n      position: 'fixed',\n      zIndex: 1000,\n    };\n\n    switch (position) {\n      case 'bottom-right':\n        return { ...base, bottom: offsetY, right: offsetX };\n      case 'bottom-left':\n        return { ...base, bottom: offsetY, left: offsetX };\n      case 'top-right':\n        return { ...base, top: offsetY, right: offsetX };\n      case 'top-left':\n        return { ...base, top: offsetY, left: offsetX };\n      default:\n        return { ...base, bottom: offsetY, right: offsetX };\n    }\n  };\n\n  const getChatPositionStyles = (): React.CSSProperties => {\n    const base: React.CSSProperties = {\n      position: 'fixed',\n      zIndex: 999,\n    };\n\n    switch (position) {\n      case 'bottom-right':\n        return { \n          ...base, \n          bottom: offsetY + 80,\n          right: offsetX \n        };\n      case 'bottom-left':\n        return { \n          ...base, \n          bottom: offsetY + 80,\n          left: offsetX \n        };\n      case 'top-right':\n        return { \n          ...base, \n          top: offsetY + 80,\n          right: offsetX \n        };\n      case 'top-left':\n        return { \n          ...base, \n          top: offsetY + 80,\n          left: offsetX \n        };\n      default:\n        return { \n          ...base, \n          bottom: offsetY + 80,\n          right: offsetX \n        };\n    }\n  };\n\n  const getResponsiveDimensions = () => {\n    const screenWidth = typeof window !== 'undefined' ? window.innerWidth : 1024;\n    if (screenWidth <= 480) {\n      return { width: 'calc(100vw - 40px)', height: '450px' };\n    } else if (screenWidth <= 768) {\n      return { width: '350px', height: '500px' };\n    } else {\n      return { width: '380px', height: '600px' };\n    }\n  };\n\n  const floatingContainerStyle: React.CSSProperties = {\n    ...getChatPositionStyles(),\n    ...getResponsiveDimensions(),\n  };\n\n  const toggleButtonStyle: React.CSSProperties = {\n    ...getPositionStyles(),\n    width: '60px',\n    height: '60px',\n    borderRadius: '50%',\n    backgroundColor: primaryColor,\n    border: 'none',\n    color: 'white',\n    fontSize: '24px',\n    cursor: 'pointer',\n    boxShadow: '0 4px 12px rgba(41, 98, 255, 0.3)',\n    transition: 'all 0.3s ease',\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    zIndex: 1001,\n  };\n\n  const renderChatComponent = () => (\n    <div style={containerStyle}>\n      <div style={headerStyle}>\n        <div style={logoContainerStyle}>\n          <img src={chatLogo} alt=\"Logo\" style={logoStyle} />\n          <div style={headerTitleContainerStyle}>\n            <div style={headerTitleStyle}>{headerTitle}</div>\n            <div style={headerSubtitleStyle}>Support</div>\n          </div>\n        </div>\n        <button \n          style={menuButtonStyle} \n          onClick={handleMenuClick}\n          title=\"Menu\"\n        >\n          <MoreVertical size={24} color=\"#ffffff\" />\n        </button>\n\n        <div ref={menuRef} style={menuPopupStyle}>\n          <div style={menuItemStyle} onClick={handleResetClick}>\n            <RefreshCw size={16} />\n            Reset conversation\n          </div>\n        </div>\n      </div>\n      \n      <div style={chatContainerStyle}>\n        {messages.map((message, index) => {\n          const isNextSameSpeaker = index < messages.length - 1 && messages[index + 1].speaker === message.speaker;\n          const isPrevSameSpeaker = index > 0 && messages[index - 1].speaker === message.speaker;\n          \n          return (\n            <ChatMessageComponent \n              key={index} \n              message={message} \n              theme={theme}\n              onPlayAudio={message.speaker === 'agent' ? playResponseAudio : undefined}\n              isPlayingAudio={isPlayingAudio}\n              isFirstMessage={index === 0 && message.speaker === 'agent' && !hasUserMessages}\n              isNextSameSpeaker={isNextSameSpeaker}\n              isPrevSameSpeaker={isPrevSameSpeaker}\n            />\n          );\n        })}\n        <div ref={messagesEndRef} />\n      </div>\n\n      {possibleQueries.length > 0 && !hasUserMessages && (\n        <div style={possibleQueriesContainerStyle}>\n          {possibleQueries.map((query, index) => (\n            <button \n              key={index}\n              style={queryButtonStyle}\n              onClick={() => handleQueryClick(query)}\n              disabled={isLoading}\n            >\n              {query}\n            </button>\n          ))}\n        </div>\n      )}\n      \n      {!conversationId || isFinalized ? (\n        <div style={inputContainerStyle}>\n          <button\n            style={{...sendButtonStyle, width: '100%', height: '48px', borderRadius: '8px'}}\n            onClick={handleStartConversation}\n            disabled={isLoading}\n          >\n            Start Conversation\n          </button>\n        </div>\n      ) : (\n        <form onSubmit={handleSubmit} style={inputContainerStyle}>\n          <div style={inputWrapperStyle}>\n            <button \n              type=\"button\" \n              style={attachButtonStyle}\n              title=\"Attach\"\n            >\n              <Paperclip size={24} color=\"#757575\" />\n            </button>\n            <input\n              style={inputStyle}\n              type=\"text\"\n              value={inputValue}\n              onChange={(e) => setInputValue(e.target.value)}\n              placeholder={placeholder}\n              disabled={connectionState !== 'connected'}\n            />\n          </div>\n          \n          <VoiceInput\n            onTranscription={handleVoiceTranscription}\n            onError={handleVoiceError}\n            baseUrl={baseUrl}\n            apiKey={apiKey}\n            theme={theme}\n          />\n          \n          <button \n            type=\"submit\" \n            style={sendButtonStyle}\n            disabled={inputValue.trim() === '' || connectionState !== 'connected'}\n          >\n            <Send size={20} color=\"#ffffff\" />\n          </button>\n        </form>\n      )}\n\n      <div style={confirmOverlayStyle}>\n        <div style={confirmDialogStyle}>\n          <h3 style={{fontFamily, marginTop: 0}}>Reset Conversation</h3>\n          <p style={{fontFamily, fontSize}}>This will clear the current conversation history and start a new conversation. Are you sure?</p>\n          <div style={confirmButtonsStyle}>\n            <button style={confirmButtonStyle(false)} onClick={handleCancelReset}>Cancel</button>\n            <button style={confirmButtonStyle(true)} onClick={handleConfirmReset}>Reset</button>\n          </div>\n        </div>\n      </div>\n    </div>\n  );\n\n  if (mode === 'floating') {\n    return (\n      <>\n        <button\n          style={toggleButtonStyle}\n          onClick={toggleFloatingChat}\n          title={isFloatingOpen ? \"Close Chat\" : \"Open Chat\"}\n        >\n          {isFloatingOpen ? <XIcon size={24} /> : <MessageSquareMore size={24} />}\n        </button>\n        \n        {isFloatingOpen && (\n          <div style={floatingContainerStyle}>\n            {renderChatComponent()}\n          </div>\n        )}\n      </>\n    );\n  }\n\n  return renderChatComponent();\n}; "]}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ interface VoiceInputProps {
3
+ onTranscription: (text: string) => void;
4
+ onError: (error: Error) => void;
5
+ baseUrl: string;
6
+ apiKey: string;
7
+ theme?: {
8
+ primaryColor?: string;
9
+ backgroundColor?: string;
10
+ fontFamily?: string;
11
+ };
12
+ }
13
+ export declare const VoiceInput: React.FC<VoiceInputProps>;
14
+ export {};