genassist-chat-react 1.0.0 → 1.0.1

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.
@@ -45,14 +45,23 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
45
45
  if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
46
  }
47
47
  };
48
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
49
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
50
+ if (ar || !(i in from)) {
51
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
52
+ ar[i] = from[i];
53
+ }
54
+ }
55
+ return to.concat(ar || Array.prototype.slice.call(from));
56
+ };
48
57
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
49
58
  import { useState, useRef, useEffect, useLayoutEffect } from 'react';
50
- import { ChatMessageComponent } from './ChatMessage';
59
+ import { ChatMessageComponent, AttachmentPreview } from './ChatMessage';
51
60
  import { useChat } from '../hooks/useChat';
52
61
  import { VoiceInput } from './VoiceInput';
53
62
  import { AudioService } from '../services/audioService';
54
63
  import { Send, Paperclip, MoreVertical, RefreshCw, XIcon, MessageSquareMore } from 'lucide-react';
55
- import chatLogo from '../../assets/chat-logo.png';
64
+ import chatLogo from '../assets/chat-logo.png';
56
65
  export var GenAgentChat = function (_a) {
57
66
  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
67
  var _f = useState(''), inputValue = _f[0], setInputValue = _f[1];
@@ -60,52 +69,46 @@ export var GenAgentChat = function (_a) {
60
69
  var _h = useState(false), showMenu = _h[0], setShowMenu = _h[1];
61
70
  var _j = useState(false), isPlayingAudio = _j[0], setIsPlayingAudio = _j[1];
62
71
  var _k = useState(false), isFloatingOpen = _k[0], setIsFloatingOpen = _k[1];
72
+ var _l = useState([]), attachments = _l[0], setAttachments = _l[1];
73
+ var _m = useState(new Set()), uploadingFiles = _m[0], setUploadingFiles = _m[1];
63
74
  var menuRef = useRef(null);
64
- var _l = useChat({
75
+ var fileInputRef = useRef(null);
76
+ var _o = useChat({
65
77
  baseUrl: baseUrl,
66
78
  apiKey: apiKey,
67
79
  metadata: metadata,
68
80
  onError: onError,
69
81
  onTakeover: onTakeover,
70
82
  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;
83
+ }), messages = _o.messages, isLoading = _o.isLoading, sendMessage = _o.sendMessage, uploadFile = _o.uploadFile, resetConversation = _o.resetConversation, startConversation = _o.startConversation, connectionState = _o.connectionState, conversationId = _o.conversationId, possibleQueries = _o.possibleQueries, isTakenOver = _o.isTakenOver, isFinalized = _o.isFinalized, isAgentTyping = _o.isAgentTyping;
72
84
  var messagesEndRef = useRef(null);
73
85
  var audioService = useRef(null);
74
86
  var hasUserMessages = messages.some(function (message) { return message.speaker === 'customer'; });
75
87
  useEffect(function () {
76
88
  audioService.current = new AudioService({ baseUrl: baseUrl, apiKey: apiKey });
77
89
  }, [baseUrl, apiKey]);
78
- // Auto-scroll to the latest message
79
90
  useLayoutEffect(function () {
80
91
  if (messagesEndRef.current) {
81
92
  messagesEndRef.current.scrollIntoView({ behavior: 'smooth' });
82
93
  }
83
94
  }, [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
95
  var handleSubmit = function (e) { return __awaiter(void 0, void 0, void 0, function () {
97
- var error_1;
96
+ var textToSend, filesToUpload, error_1;
98
97
  return __generator(this, function (_a) {
99
98
  switch (_a.label) {
100
99
  case 0:
101
100
  e.preventDefault();
102
- if (inputValue.trim() === '' || isLoading)
101
+ if (inputValue.trim() === '' && attachments.length === 0) {
103
102
  return [2 /*return*/];
103
+ }
104
+ textToSend = inputValue;
105
+ filesToUpload = __spreadArray([], attachments, true);
106
+ setInputValue('');
107
+ setAttachments([]);
104
108
  _a.label = 1;
105
109
  case 1:
106
110
  _a.trys.push([1, 3, , 4]);
107
- setInputValue('');
108
- return [4 /*yield*/, sendMessage(inputValue)];
111
+ return [4 /*yield*/, sendMessage(textToSend, filesToUpload)];
109
112
  case 2:
110
113
  _a.sent();
111
114
  return [3 /*break*/, 4];
@@ -117,14 +120,40 @@ export var GenAgentChat = function (_a) {
117
120
  }
118
121
  });
119
122
  }); };
120
- var handleVoiceTranscription = function (text) { return __awaiter(void 0, void 0, void 0, function () {
123
+ var handleFileChange = function (e) { return __awaiter(void 0, void 0, void 0, function () {
124
+ var newFiles_1, newUploadingFiles_1, error_2, finalUploadingFiles_1;
121
125
  return __generator(this, function (_a) {
122
- if (text.trim() === '')
123
- return [2 /*return*/];
124
- setInputValue(text);
125
- return [2 /*return*/];
126
+ switch (_a.label) {
127
+ case 0:
128
+ if (!e.target.files) return [3 /*break*/, 5];
129
+ newFiles_1 = Array.from(e.target.files);
130
+ setAttachments(function (prev) { return __spreadArray(__spreadArray([], prev, true), newFiles_1, true); });
131
+ newUploadingFiles_1 = new Set(uploadingFiles);
132
+ newFiles_1.forEach(function (file) { return newUploadingFiles_1.add(file.name); });
133
+ setUploadingFiles(newUploadingFiles_1);
134
+ _a.label = 1;
135
+ case 1:
136
+ _a.trys.push([1, 3, 4, 5]);
137
+ return [4 /*yield*/, Promise.all(newFiles_1.map(function (file) { return uploadFile(file); }))];
138
+ case 2:
139
+ _a.sent();
140
+ return [3 /*break*/, 5];
141
+ case 3:
142
+ error_2 = _a.sent();
143
+ console.error("An error occurred during file upload:", error_2);
144
+ return [3 /*break*/, 5];
145
+ case 4:
146
+ finalUploadingFiles_1 = new Set(uploadingFiles);
147
+ newFiles_1.forEach(function (file) { return finalUploadingFiles_1.delete(file.name); });
148
+ setUploadingFiles(finalUploadingFiles_1);
149
+ return [7 /*endfinally*/];
150
+ case 5: return [2 /*return*/];
151
+ }
126
152
  });
127
153
  }); };
154
+ var handleRemoveAttachment = function (fileName) {
155
+ setAttachments(function (prev) { return prev.filter(function (f) { return f.name !== fileName; }); });
156
+ };
128
157
  var handleVoiceError = function (error) {
129
158
  console.error('Voice input error:', error);
130
159
  if (onError) {
@@ -132,7 +161,7 @@ export var GenAgentChat = function (_a) {
132
161
  }
133
162
  };
134
163
  var playResponseAudio = function (text) { return __awaiter(void 0, void 0, void 0, function () {
135
- var audioBlob, error_2;
164
+ var audioBlob, error_3;
136
165
  return __generator(this, function (_a) {
137
166
  switch (_a.label) {
138
167
  case 0:
@@ -150,10 +179,10 @@ export var GenAgentChat = function (_a) {
150
179
  _a.sent();
151
180
  return [3 /*break*/, 6];
152
181
  case 4:
153
- error_2 = _a.sent();
154
- console.error('Error playing audio:', error_2);
182
+ error_3 = _a.sent();
183
+ console.error('Error playing audio:', error_3);
155
184
  if (onError) {
156
- onError(error_2);
185
+ onError(error_3);
157
186
  }
158
187
  return [3 /*break*/, 6];
159
188
  case 5:
@@ -164,7 +193,7 @@ export var GenAgentChat = function (_a) {
164
193
  });
165
194
  }); };
166
195
  var handleQueryClick = function (query) { return __awaiter(void 0, void 0, void 0, function () {
167
- var error_3;
196
+ var error_4;
168
197
  return __generator(this, function (_a) {
169
198
  switch (_a.label) {
170
199
  case 0:
@@ -178,15 +207,15 @@ export var GenAgentChat = function (_a) {
178
207
  _a.sent();
179
208
  return [3 /*break*/, 4];
180
209
  case 3:
181
- error_3 = _a.sent();
182
- console.error('Error sending quick query:', error_3);
210
+ error_4 = _a.sent();
211
+ console.error('Error sending quick query:', error_4);
183
212
  return [3 /*break*/, 4];
184
213
  case 4: return [2 /*return*/];
185
214
  }
186
215
  });
187
216
  }); };
188
217
  var handleStartConversation = function () { return __awaiter(void 0, void 0, void 0, function () {
189
- var error_4;
218
+ var error_5;
190
219
  return __generator(this, function (_a) {
191
220
  switch (_a.label) {
192
221
  case 0:
@@ -200,8 +229,8 @@ export var GenAgentChat = function (_a) {
200
229
  _a.sent();
201
230
  return [3 /*break*/, 4];
202
231
  case 3:
203
- error_4 = _a.sent();
204
- console.error('Error starting conversation:', error_4);
232
+ error_5 = _a.sent();
233
+ console.error('Error starting conversation:', error_5);
205
234
  return [3 /*break*/, 4];
206
235
  case 4: return [2 /*return*/];
207
236
  }
@@ -228,22 +257,15 @@ export var GenAgentChat = function (_a) {
228
257
  var handleCancelReset = function () {
229
258
  setShowResetConfirm(false);
230
259
  };
231
- var toggleFloatingChat = function () {
232
- setIsFloatingOpen(function (prev) { return !prev; });
233
- };
234
- // Extract theme colors or use defaults
235
260
  var primaryColor = (theme === null || theme === void 0 ? void 0 : theme.primaryColor) || '#2962FF';
236
261
  var backgroundColor = (theme === null || theme === void 0 ? void 0 : theme.backgroundColor) || '#ffffff';
237
262
  var textColor = (theme === null || theme === void 0 ? void 0 : theme.textColor) || '#000000';
238
263
  var fontFamily = (theme === null || theme === void 0 ? void 0 : theme.fontFamily) || 'Roboto, Arial, sans-serif';
239
264
  var fontSize = (theme === null || theme === void 0 ? void 0 : theme.fontSize) || '14px';
240
- // Floating configuration defaults
241
265
  var position = floatingConfig.position || 'bottom-right';
242
266
  var offset = floatingConfig.offset || { x: 20, y: 20 };
243
267
  var offsetX = offset.x || 20;
244
268
  var offsetY = offset.y || 20;
245
- var toggleButtonIcon = floatingConfig.toggleButtonIcon || _jsx(MessageSquareMore, {});
246
- var closeButtonIcon = floatingConfig.closeButtonIcon || _jsx(XIcon, {});
247
269
  var containerStyle = {
248
270
  display: 'flex',
249
271
  flexDirection: 'column',
@@ -507,14 +529,20 @@ export var GenAgentChat = function (_a) {
507
529
  };
508
530
  var floatingContainerStyle = __assign(__assign({}, getChatPositionStyles()), getResponsiveDimensions());
509
531
  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) {
532
+ var renderChatComponent = function () { return (_jsxs("div", { style: containerStyle, children: [_jsx("style", { children: "\n @keyframes blink { 0% { opacity: 0.2; } 20% { opacity: 1; } 100% { opacity: 0.2; } }\n " }), _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
533
  var isNextSameSpeaker = index < messages.length - 1 && messages[index + 1].speaker === message.speaker;
512
534
  var isPrevSameSpeaker = index > 0 && messages[index - 1].speaker === message.speaker;
513
535
  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" })] })] }) })] })); };
536
+ }), isAgentTyping && (_jsxs("div", { style: { display: 'flex', flexDirection: 'column', maxWidth: '80%' }, children: [_jsx("div", { style: { fontSize: '12px', color: '#757575', marginBottom: 4 }, children: "Agent" }), _jsxs("div", { style: {
537
+ backgroundColor: (theme === null || theme === void 0 ? void 0 : theme.secondaryColor) || '#eeeeee',
538
+ color: '#000',
539
+ padding: '12px 16px',
540
+ borderRadius: 8,
541
+ width: 72,
542
+ }, children: [_jsx("span", { className: "typing-dot", style: { display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', marginRight: 6, animation: 'blink 1.4s infinite 0s' } }), _jsx("span", { className: "typing-dot", style: { display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', marginRight: 6, animation: 'blink 1.4s infinite 0.2s' } }), _jsx("span", { className: "typing-dot", style: { display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', animation: 'blink 1.4s infinite 0.4s' } })] })] })), _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)); }) })), attachments.length > 0 && (_jsx("div", { style: { padding: '0 16px', marginBottom: '8px', display: 'flex', gap: '8px', flexWrap: 'wrap' }, children: attachments.map(function (file, index) { return (_jsx(AttachmentPreview, { file: file, onRemove: function () { return handleRemoveAttachment(file.name); }, uploading: uploadingFiles.has(file.name) }, 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", onClick: function () { var _a; return (_a = fileInputRef.current) === null || _a === void 0 ? void 0 : _a.click(); }, children: _jsx(Paperclip, { size: 24, color: "#757575" }) }), _jsx("input", { type: "file", multiple: true, ref: fileInputRef, style: { display: 'none' }, onChange: handleFileChange }), _jsx("input", { style: inputStyle, type: "text", value: inputValue, onChange: function (e) { return setInputValue(e.target.value); }, placeholder: placeholder, disabled: !conversationId || isFinalized })] }), _jsx(VoiceInput, { onTranscription: function (text) { return setInputValue(text); }, onError: handleVoiceError, baseUrl: baseUrl, apiKey: apiKey, theme: theme }), _jsx("button", { type: "submit", style: sendButtonStyle, disabled: inputValue.trim() === '' && attachments.length === 0 || 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: __assign(__assign({}, confirmButtonStyle(false)), { color: textColor }), onClick: handleCancelReset, children: "Cancel" }), _jsx("button", { style: confirmButtonStyle(true), onClick: handleConfirmReset, children: "Reset" })] })] }) })] })); };
515
543
  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() }))] }));
544
+ return (_jsxs(_Fragment, { children: [_jsx("button", { style: toggleButtonStyle, onClick: function () { return setIsFloatingOpen(function (prev) { return !prev; }); }, title: isFloatingOpen ? "Close Chat" : "Open Chat", children: isFloatingOpen ? _jsx(XIcon, { size: 24 }) : _jsx(MessageSquareMore, { size: 24 }) }), isFloatingOpen && (_jsx("div", { style: floatingContainerStyle, children: renderChatComponent() }))] }));
517
545
  }
518
546
  return renderChatComponent();
519
547
  };
520
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenAgentChat.js","sourceRoot":"","sources":["../../src/components/GenAgentChat.tsx"],"names":[],"mappings":"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","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}; "]}
548
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenAgentChat.js","sourceRoot":"","sources":["../../src/components/GenAgentChat.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useRef, useEffect, useLayoutEffect } from 'react';\nimport { ChatMessageComponent, AttachmentPreview } 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, File as FileIcon, FileImage, FileText, FileJson } 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}): React.ReactElement => {\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 [attachments, setAttachments] = useState<File[]>([]);\n  const [uploadingFiles, setUploadingFiles] = useState<Set<string>>(new Set());\n  const menuRef = useRef<HTMLDivElement>(null);\n  const fileInputRef = useRef<HTMLInputElement>(null);\n  const {\n    messages,\n    isLoading,\n    sendMessage,\n    uploadFile,\n    resetConversation,\n    startConversation,\n    connectionState,\n    conversationId,\n    possibleQueries,\n    isTakenOver,\n    isFinalized,\n    isAgentTyping,\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  useLayoutEffect(() => {\n    if (messagesEndRef.current) {\n      messagesEndRef.current.scrollIntoView({ behavior: 'smooth' });\n    }\n  }, [messages]);\n\n  const handleSubmit = async (e: React.FormEvent) => {\n    e.preventDefault();\n    if (inputValue.trim() === '' && attachments.length === 0) {\n      return;\n    }\n\n    const textToSend = inputValue;\n    const filesToUpload = [...attachments];\n\n    setInputValue('');\n    setAttachments([]);\n\n    try {\n      await sendMessage(textToSend, filesToUpload);\n    } catch (error) {\n      console.error('Error sending message:', error);\n    }\n  };\n\n  const handleFileChange = async (e: React.ChangeEvent<HTMLInputElement>) => {\n    if (e.target.files) {\n      const newFiles = Array.from(e.target.files);\n      setAttachments(prev => [...prev, ...newFiles]);\n\n      const newUploadingFiles = new Set(uploadingFiles);\n      newFiles.forEach(file => newUploadingFiles.add(file.name));\n      setUploadingFiles(newUploadingFiles);\n\n      try {\n        await Promise.all(newFiles.map(file => uploadFile(file)));\n      } catch (error) {\n        console.error(\"An error occurred during file upload:\", error)\n      } finally {\n        const finalUploadingFiles = new Set(uploadingFiles);\n        newFiles.forEach(file => finalUploadingFiles.delete(file.name));\n        setUploadingFiles(finalUploadingFiles);\n      }\n    }\n  };\n\n  const handleRemoveAttachment = (fileName: string) => {\n    setAttachments(prev => prev.filter(f => f.name !== fileName));\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 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  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\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      <style>{`\n        @keyframes blink { 0% { opacity: 0.2; } 20% { opacity: 1; } 100% { opacity: 0.2; } }\n      `}</style>\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        {isAgentTyping && (\n          <div style={{ display: 'flex', flexDirection: 'column', maxWidth: '80%' }}>\n            <div style={{ fontSize: '12px', color: '#757575', marginBottom: 4 }}>Agent</div>\n            <div style={{\n              backgroundColor: theme?.secondaryColor || '#eeeeee',\n              color: '#000',\n              padding: '12px 16px',\n              borderRadius: 8,\n              width: 72,\n            }}>\n              <span className=\"typing-dot\" style={{ display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', marginRight: 6, animation: 'blink 1.4s infinite 0s' }} />\n              <span className=\"typing-dot\" style={{ display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', marginRight: 6, animation: 'blink 1.4s infinite 0.2s' }} />\n              <span className=\"typing-dot\" style={{ display: 'inline-block', width: 6, height: 6, borderRadius: '50%', background: '#999', animation: 'blink 1.4s infinite 0.4s' }} />\n            </div>\n          </div>\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      {attachments.length > 0 && (\n        <div style={{ padding: '0 16px', marginBottom: '8px', display: 'flex', gap: '8px', flexWrap: 'wrap' }}>\n          {attachments.map((file, index) => (\n            <AttachmentPreview \n              key={index} \n              file={file} \n              onRemove={() => handleRemoveAttachment(file.name)}\n              uploading={uploadingFiles.has(file.name)}\n            />\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              onClick={() => fileInputRef.current?.click()}\n            >\n              <Paperclip size={24} color=\"#757575\" />\n            </button>\n            <input\n              type=\"file\"\n              multiple\n              ref={fileInputRef}\n              style={{ display: 'none' }}\n              onChange={handleFileChange}\n            />\n            <input\n              style={inputStyle}\n              type=\"text\"\n              value={inputValue}\n              onChange={(e) => setInputValue(e.target.value)}\n              placeholder={placeholder}\n              disabled={!conversationId || isFinalized}\n            />\n          </div>\n          \n          <VoiceInput\n            onTranscription={(text: string) => setInputValue(text)}\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() === '' && attachments.length === 0 || 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), color: textColor}} 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={() => setIsFloatingOpen(prev => !prev)}\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}; "]}
@@ -1,4 +1,4 @@
1
- import { ChatMessage } from '../types';
1
+ import { ChatMessage, Attachment } from '../types';
2
2
  export interface UseChatProps {
3
3
  baseUrl: string;
4
4
  apiKey: string;
@@ -10,7 +10,8 @@ export interface UseChatProps {
10
10
  export declare const useChat: ({ baseUrl, apiKey, metadata, onError, onTakeover, onFinalize }: UseChatProps) => {
11
11
  messages: ChatMessage[];
12
12
  isLoading: boolean;
13
- sendMessage: (text: string) => Promise<void>;
13
+ sendMessage: (text: string, files?: File[]) => Promise<void>;
14
+ uploadFile: (file: File) => Promise<Attachment | null>;
14
15
  resetConversation: () => Promise<void>;
15
16
  startConversation: () => Promise<void>;
16
17
  connectionState: "connecting" | "connected" | "disconnected";
@@ -18,4 +19,5 @@ export declare const useChat: ({ baseUrl, apiKey, metadata, onError, onTakeover,
18
19
  possibleQueries: string[];
19
20
  isTakenOver: boolean;
20
21
  isFinalized: boolean;
22
+ isAgentTyping: boolean;
21
23
  };