genassist-chat-react 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/ChatMessage.d.ts +6 -0
- package/dist/components/ChatMessage.js +137 -3
- package/dist/components/GenAgentChat.js +75 -47
- package/dist/hooks/useChat.d.ts +4 -2
- package/dist/hooks/useChat.js +117 -33
- package/dist/services/chatService.d.ts +5 -2
- package/dist/services/chatService.js +44 -5
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.js +1 -1
- package/package.json +1 -1
- package/assets/chat-logo.png +0 -0
package/dist/hooks/useChat.js
CHANGED
|
@@ -1,3 +1,14 @@
|
|
|
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
|
+
};
|
|
1
12
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
13
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
14
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -58,31 +69,48 @@ export var useChat = function (_a) {
|
|
|
58
69
|
}
|
|
59
70
|
}), messages = _b[0], setMessages = _b[1];
|
|
60
71
|
var _c = useState(false), isLoading = _c[0], setIsLoading = _c[1];
|
|
61
|
-
var _d = useState(
|
|
72
|
+
var _d = useState([]), preloadedAttachments = _d[0], setPreloadedAttachments = _d[1];
|
|
73
|
+
var _e = useState('disconnected'), connectionState = _e[0], setConnectionState = _e[1];
|
|
74
|
+
var _f = useState(false), isAgentTyping = _f[0], setIsAgentTyping = _f[1];
|
|
62
75
|
var chatServiceRef = useRef(null);
|
|
63
|
-
var
|
|
64
|
-
var
|
|
65
|
-
var
|
|
66
|
-
var
|
|
76
|
+
var _g = useState(null), conversationId = _g[0], setConversationId = _g[1];
|
|
77
|
+
var _h = useState([]), possibleQueries = _h[0], setPossibleQueries = _h[1];
|
|
78
|
+
var _j = useState(false), isTakenOver = _j[0], setIsTakenOver = _j[1];
|
|
79
|
+
var _k = useState(false), isFinalized = _k[0], setIsFinalized = _k[1];
|
|
67
80
|
// Initialize chat service
|
|
68
81
|
useEffect(function () {
|
|
69
82
|
chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata);
|
|
70
83
|
chatServiceRef.current.setMessageHandler(function (message) {
|
|
71
|
-
|
|
84
|
+
var normalizedMessage = __assign(__assign({}, message), { create_time: (!message.create_time || isNaN(message.create_time))
|
|
85
|
+
? Math.floor(Date.now() / 1000)
|
|
86
|
+
: message.create_time });
|
|
87
|
+
setMessages(function (prevMessages) { return __spreadArray(__spreadArray([], prevMessages, true), [normalizedMessage], false); });
|
|
88
|
+
// Stop typing animation when agent or system message arrives
|
|
89
|
+
if (normalizedMessage.speaker === 'agent' || normalizedMessage.speaker === 'special') {
|
|
90
|
+
setIsAgentTyping(false);
|
|
91
|
+
}
|
|
72
92
|
});
|
|
73
93
|
chatServiceRef.current.setTakeoverHandler(function () {
|
|
74
94
|
setIsTakenOver(true);
|
|
95
|
+
setIsAgentTyping(false);
|
|
75
96
|
if (onTakeover) {
|
|
76
97
|
onTakeover();
|
|
77
98
|
}
|
|
78
99
|
});
|
|
79
100
|
chatServiceRef.current.setFinalizedHandler(function () {
|
|
80
101
|
setIsFinalized(true);
|
|
102
|
+
setIsAgentTyping(false);
|
|
81
103
|
if (onFinalize) {
|
|
82
104
|
onFinalize();
|
|
83
105
|
}
|
|
84
106
|
});
|
|
85
|
-
|
|
107
|
+
// Clear typing animation if agent is not connected
|
|
108
|
+
chatServiceRef.current.setConnectionStateHandler(function (state) {
|
|
109
|
+
setConnectionState(state);
|
|
110
|
+
if (state !== 'connected') {
|
|
111
|
+
setIsAgentTyping(false);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
86
114
|
// Check for a saved conversation and connect to it
|
|
87
115
|
var convId = chatServiceRef.current.getConversationId();
|
|
88
116
|
if (convId) {
|
|
@@ -124,6 +152,7 @@ export var useChat = function (_a) {
|
|
|
124
152
|
setPossibleQueries([]);
|
|
125
153
|
localStorage.removeItem('chatMessages');
|
|
126
154
|
setIsFinalized(false);
|
|
155
|
+
setIsAgentTyping(false);
|
|
127
156
|
_a.label = 1;
|
|
128
157
|
case 1:
|
|
129
158
|
_a.trys.push([1, 3, 4, 5]);
|
|
@@ -145,6 +174,7 @@ export var useChat = function (_a) {
|
|
|
145
174
|
case 3:
|
|
146
175
|
error_1 = _a.sent();
|
|
147
176
|
setConnectionState('disconnected');
|
|
177
|
+
setIsAgentTyping(false);
|
|
148
178
|
if (onError && error_1 instanceof Error) {
|
|
149
179
|
onError(error_1);
|
|
150
180
|
}
|
|
@@ -159,41 +189,91 @@ export var useChat = function (_a) {
|
|
|
159
189
|
}
|
|
160
190
|
});
|
|
161
191
|
}); }, [onError]);
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
var error_2;
|
|
192
|
+
var uploadFile = useCallback(function (file) { return __awaiter(void 0, void 0, void 0, function () {
|
|
193
|
+
var fileUrl, attachment_1, error_2;
|
|
165
194
|
return __generator(this, function (_a) {
|
|
166
195
|
switch (_a.label) {
|
|
167
196
|
case 0:
|
|
168
|
-
if (!chatServiceRef.current) {
|
|
169
|
-
|
|
197
|
+
if (!chatServiceRef.current || !chatServiceRef.current.getConversationId()) {
|
|
198
|
+
console.error('Cannot upload file, conversation not ready');
|
|
199
|
+
return [2 /*return*/, null];
|
|
170
200
|
}
|
|
171
201
|
_a.label = 1;
|
|
172
202
|
case 1:
|
|
173
|
-
_a.trys.push([1, 3,
|
|
174
|
-
|
|
175
|
-
return [4 /*yield*/, chatServiceRef.current.sendMessage(text)];
|
|
203
|
+
_a.trys.push([1, 3, , 4]);
|
|
204
|
+
return [4 /*yield*/, chatServiceRef.current.uploadFile(chatServiceRef.current.getConversationId(), file)];
|
|
176
205
|
case 2:
|
|
177
|
-
_a.sent();
|
|
178
|
-
|
|
206
|
+
fileUrl = (_a.sent()).fileUrl;
|
|
207
|
+
attachment_1 = {
|
|
208
|
+
name: file.name,
|
|
209
|
+
type: file.type,
|
|
210
|
+
size: file.size,
|
|
211
|
+
url: fileUrl,
|
|
212
|
+
};
|
|
213
|
+
setPreloadedAttachments(function (prev) { return __spreadArray(__spreadArray([], prev, true), [attachment_1], false); });
|
|
214
|
+
return [2 /*return*/, attachment_1];
|
|
179
215
|
case 3:
|
|
180
216
|
error_2 = _a.sent();
|
|
181
|
-
|
|
217
|
+
console.error('File upload failed:', error_2);
|
|
218
|
+
if (onError) {
|
|
182
219
|
onError(error_2);
|
|
183
220
|
}
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
}
|
|
187
|
-
return [3 /*break*/, 5];
|
|
188
|
-
case 4:
|
|
189
|
-
setIsLoading(false);
|
|
190
|
-
return [7 /*endfinally*/];
|
|
191
|
-
case 5: return [2 /*return*/];
|
|
221
|
+
return [2 /*return*/, null];
|
|
222
|
+
case 4: return [2 /*return*/];
|
|
192
223
|
}
|
|
193
224
|
});
|
|
194
225
|
}); }, [onError]);
|
|
226
|
+
// Send message
|
|
227
|
+
var sendMessage = useCallback(function (text_1) {
|
|
228
|
+
var args_1 = [];
|
|
229
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
230
|
+
args_1[_i - 1] = arguments[_i];
|
|
231
|
+
}
|
|
232
|
+
return __awaiter(void 0, __spreadArray([text_1], args_1, true), void 0, function (text, files) {
|
|
233
|
+
var newAttachments, uploadedFiles, error_3;
|
|
234
|
+
if (files === void 0) { files = []; }
|
|
235
|
+
return __generator(this, function (_a) {
|
|
236
|
+
switch (_a.label) {
|
|
237
|
+
case 0:
|
|
238
|
+
if (!chatServiceRef.current) {
|
|
239
|
+
throw new Error('Chat service not initialized');
|
|
240
|
+
}
|
|
241
|
+
_a.label = 1;
|
|
242
|
+
case 1:
|
|
243
|
+
_a.trys.push([1, 3, 4, 5]);
|
|
244
|
+
setIsLoading(true);
|
|
245
|
+
newAttachments = [];
|
|
246
|
+
if (files.length > 0) {
|
|
247
|
+
uploadedFiles = files.map(function (f) { return preloadedAttachments.find(function (pa) { return pa.name === f.name && pa.size === f.size; }); }).filter(Boolean);
|
|
248
|
+
newAttachments.push.apply(newAttachments, uploadedFiles);
|
|
249
|
+
}
|
|
250
|
+
// Start typing immediately when user sends
|
|
251
|
+
setIsAgentTyping(true);
|
|
252
|
+
return [4 /*yield*/, chatServiceRef.current.sendMessage(text, newAttachments)];
|
|
253
|
+
case 2:
|
|
254
|
+
_a.sent();
|
|
255
|
+
setPreloadedAttachments([]);
|
|
256
|
+
return [3 /*break*/, 5];
|
|
257
|
+
case 3:
|
|
258
|
+
error_3 = _a.sent();
|
|
259
|
+
setIsAgentTyping(false);
|
|
260
|
+
if (onError && error_3 instanceof Error) {
|
|
261
|
+
onError(error_3);
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
console.error('Failed to send message:', error_3);
|
|
265
|
+
}
|
|
266
|
+
return [3 /*break*/, 5];
|
|
267
|
+
case 4:
|
|
268
|
+
setIsLoading(false);
|
|
269
|
+
return [7 /*endfinally*/];
|
|
270
|
+
case 5: return [2 /*return*/];
|
|
271
|
+
}
|
|
272
|
+
});
|
|
273
|
+
});
|
|
274
|
+
}, [onError, preloadedAttachments]);
|
|
195
275
|
var startConversation = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
196
|
-
var convId, queries,
|
|
276
|
+
var convId, queries, error_4;
|
|
197
277
|
return __generator(this, function (_a) {
|
|
198
278
|
switch (_a.label) {
|
|
199
279
|
case 0:
|
|
@@ -210,6 +290,7 @@ export var useChat = function (_a) {
|
|
|
210
290
|
setPossibleQueries([]);
|
|
211
291
|
localStorage.removeItem('chatMessages');
|
|
212
292
|
setIsFinalized(false);
|
|
293
|
+
setIsAgentTyping(false);
|
|
213
294
|
chatServiceRef.current.resetConversation();
|
|
214
295
|
return [4 /*yield*/, chatServiceRef.current.startConversation()];
|
|
215
296
|
case 2:
|
|
@@ -224,13 +305,14 @@ export var useChat = function (_a) {
|
|
|
224
305
|
}
|
|
225
306
|
return [3 /*break*/, 5];
|
|
226
307
|
case 3:
|
|
227
|
-
|
|
308
|
+
error_4 = _a.sent();
|
|
228
309
|
setConnectionState('disconnected');
|
|
229
|
-
|
|
230
|
-
|
|
310
|
+
setIsAgentTyping(false);
|
|
311
|
+
if (onError && error_4 instanceof Error) {
|
|
312
|
+
onError(error_4);
|
|
231
313
|
}
|
|
232
314
|
else {
|
|
233
|
-
console.error('Failed to start conversation:',
|
|
315
|
+
console.error('Failed to start conversation:', error_4);
|
|
234
316
|
}
|
|
235
317
|
return [3 /*break*/, 5];
|
|
236
318
|
case 4:
|
|
@@ -244,13 +326,15 @@ export var useChat = function (_a) {
|
|
|
244
326
|
messages: messages,
|
|
245
327
|
isLoading: isLoading,
|
|
246
328
|
sendMessage: sendMessage,
|
|
329
|
+
uploadFile: uploadFile,
|
|
247
330
|
resetConversation: resetConversation,
|
|
248
331
|
startConversation: startConversation,
|
|
249
332
|
connectionState: connectionState,
|
|
250
333
|
conversationId: conversationId,
|
|
251
334
|
possibleQueries: possibleQueries,
|
|
252
335
|
isTakenOver: isTakenOver,
|
|
253
|
-
isFinalized: isFinalized
|
|
336
|
+
isFinalized: isFinalized,
|
|
337
|
+
isAgentTyping: isAgentTyping,
|
|
254
338
|
};
|
|
255
339
|
};
|
|
256
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"useChat.js","sourceRoot":"","sources":["../../src/hooks/useChat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useState, useEffect, useCallback, useRef } from 'react';\nimport { ChatService } from '../services/chatService';\nimport { ChatMessage } from '../types';\n\nexport interface UseChatProps {\n  baseUrl: string;\n  apiKey: string;\n  metadata?: Record<string, any>;\n  onError?: (error: Error) => void;\n  onTakeover?: () => void;\n  onFinalize?: () => void;\n}\n\nexport const useChat = ({ baseUrl, apiKey, metadata, onError, onTakeover, onFinalize }: UseChatProps) => {\n  const [messages, setMessages] = useState<ChatMessage[]>(() => {\n    try {\n      const storedMessages = localStorage.getItem('chatMessages');\n      return storedMessages ? JSON.parse(storedMessages) : [];\n    } catch (error) {\n      console.error('Error loading messages from localStorage:', error);\n      return [];\n    }\n  });\n  const [isLoading, setIsLoading] = useState<boolean>(false);\n  const [connectionState, setConnectionState] = useState<'connecting' | 'connected' | 'disconnected'>('disconnected');\n  const chatServiceRef = useRef<ChatService | null>(null);\n  const [conversationId, setConversationId] = useState<string | null>(null);\n  const [possibleQueries, setPossibleQueries] = useState<string[]>([]);\n  const [isTakenOver, setIsTakenOver] = useState<boolean>(false);\n  const [isFinalized, setIsFinalized] = useState<boolean>(false);\n\n  // Initialize chat service\n  useEffect(() => {\n    chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata);\n    \n    chatServiceRef.current.setMessageHandler((message: ChatMessage) => {\n      setMessages(prevMessages => [...prevMessages, message]);\n    });\n\n    chatServiceRef.current.setTakeoverHandler(() => {\n      setIsTakenOver(true);\n      if (onTakeover) {\n        onTakeover();\n      }\n    });\n\n    chatServiceRef.current.setFinalizedHandler(() => {\n      setIsFinalized(true);\n      if (onFinalize) {\n        onFinalize();\n      }\n    });\n\n    chatServiceRef.current.setConnectionStateHandler(setConnectionState);\n\n    // Check for a saved conversation and connect to it\n    const convId = chatServiceRef.current.getConversationId();\n    if (convId) {\n        setConversationId(convId);\n        if (chatServiceRef.current.isConversationFinalized()) {\n          setIsFinalized(true);\n        } else {\n          chatServiceRef.current.connectWebSocket();\n        }\n    }\n\n    // Cleanup\n    return () => {\n      if (chatServiceRef.current) {\n        chatServiceRef.current.disconnect();\n      }\n    };\n  }, [baseUrl, apiKey, metadata, onError, onTakeover, onFinalize]);\n\n  useEffect(() => {\n    try {\n      localStorage.setItem('chatMessages', JSON.stringify(messages));\n    } catch (error) {\n      console.error('Error saving messages to localStorage:', error);\n    }\n  }, [messages]);\n\n  // Reset conversation\n  const resetConversation = useCallback(async () => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    \n    setConnectionState('connecting');\n    setIsLoading(true);\n    setMessages([]);\n    setPossibleQueries([]);\n    localStorage.removeItem('chatMessages');\n    setIsFinalized(false);\n    \n    try {\n      // Reset the conversation in the chat service\n      chatServiceRef.current.resetConversation();\n      \n      // Start a new conversation\n      const convId = await chatServiceRef.current.startConversation();\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      // Get possible queries from API response\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to reset conversation:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError]);\n\n  // Send message\n  const sendMessage = useCallback(async (text: string) => {\n    if (!chatServiceRef.current) {\n      throw new Error('Chat service not initialized');\n    }\n\n    try {\n      setIsLoading(true);\n      await chatServiceRef.current.sendMessage(text);\n    } catch (error) {\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to send message:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError]);\n\n  const startConversation = useCallback(async () => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    try {\n      setConnectionState('connecting');\n      setIsLoading(true);\n      \n      // Reset state for new conversation\n      setMessages([]);\n      setPossibleQueries([]);\n      localStorage.removeItem('chatMessages');\n      setIsFinalized(false);\n      chatServiceRef.current.resetConversation();\n\n      const convId = await chatServiceRef.current.startConversation();\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to start conversation:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError]);\n\n  return {\n    messages,\n    isLoading,\n    sendMessage,\n    resetConversation,\n    startConversation,\n    connectionState,\n    conversationId,\n    possibleQueries,\n    isTakenOver,\n    isFinalized\n  };\n}; "]}
|
|
340
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"useChat.js","sourceRoot":"","sources":["../../src/hooks/useChat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useState, useEffect, useCallback, useRef } from 'react';\nimport { ChatService } from '../services/chatService';\nimport { ChatMessage, Attachment } from '../types';\n\nexport interface UseChatProps {\n  baseUrl: string;\n  apiKey: string;\n  metadata?: Record<string, any>;\n  onError?: (error: Error) => void;\n  onTakeover?: () => void;\n  onFinalize?: () => void;\n}\n\nexport const useChat = ({ baseUrl, apiKey, metadata, onError, onTakeover, onFinalize }: UseChatProps) => {\n  const [messages, setMessages] = useState<ChatMessage[]>(() => {\n    try {\n      const storedMessages = localStorage.getItem('chatMessages');\n      return storedMessages ? JSON.parse(storedMessages) : [];\n    } catch (error) {\n      console.error('Error loading messages from localStorage:', error);\n      return [];\n    }\n  });\n  const [isLoading, setIsLoading] = useState<boolean>(false);\n  const [preloadedAttachments, setPreloadedAttachments] = useState<Attachment[]>([]);\n  const [connectionState, setConnectionState] = useState<'connecting' | 'connected' | 'disconnected'>('disconnected');\n  const [isAgentTyping, setIsAgentTyping] = useState<boolean>(false);\n  const chatServiceRef = useRef<ChatService | null>(null);\n  const [conversationId, setConversationId] = useState<string | null>(null);\n  const [possibleQueries, setPossibleQueries] = useState<string[]>([]);\n  const [isTakenOver, setIsTakenOver] = useState<boolean>(false);\n  const [isFinalized, setIsFinalized] = useState<boolean>(false);\n\n  // Initialize chat service\n  useEffect(() => {\n    chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata);\n    \n    chatServiceRef.current.setMessageHandler((message: ChatMessage) => {\n      const normalizedMessage: ChatMessage = {\n        ...message,\n        create_time: (!message.create_time || isNaN(message.create_time))\n          ? Math.floor(Date.now() / 1000)\n          : message.create_time,\n      };\n\n      setMessages(prevMessages => [...prevMessages, normalizedMessage]);\n      // Stop typing animation when agent or system message arrives\n      if (normalizedMessage.speaker === 'agent' || normalizedMessage.speaker === 'special') {\n        setIsAgentTyping(false);\n      }\n    });\n\n    chatServiceRef.current.setTakeoverHandler(() => {\n      setIsTakenOver(true);\n      setIsAgentTyping(false);\n      if (onTakeover) {\n        onTakeover();\n      }\n    });\n\n    chatServiceRef.current.setFinalizedHandler(() => {\n      setIsFinalized(true);\n      setIsAgentTyping(false);\n      if (onFinalize) {\n        onFinalize();\n      }\n    });\n\n    // Clear typing animation if agent is not connected\n    chatServiceRef.current.setConnectionStateHandler((state) => {\n      setConnectionState(state);\n      if (state !== 'connected') {\n        setIsAgentTyping(false);\n      }\n    });\n\n    // Check for a saved conversation and connect to it\n    const convId = chatServiceRef.current.getConversationId();\n    if (convId) {\n        setConversationId(convId);\n        if (chatServiceRef.current.isConversationFinalized()) {\n          setIsFinalized(true);\n        } else {\n          chatServiceRef.current.connectWebSocket();\n        }\n    }\n\n    // Cleanup\n    return () => {\n      if (chatServiceRef.current) {\n        chatServiceRef.current.disconnect();\n      }\n    };\n  }, [baseUrl, apiKey, metadata, onError, onTakeover, onFinalize]);\n\n  useEffect(() => {\n    try {\n      localStorage.setItem('chatMessages', JSON.stringify(messages));\n    } catch (error) {\n      console.error('Error saving messages to localStorage:', error);\n    }\n  }, [messages]);\n\n  // Reset conversation\n  const resetConversation = useCallback(async () => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    \n    setConnectionState('connecting');\n    setIsLoading(true);\n    setMessages([]);\n    setPossibleQueries([]);\n    localStorage.removeItem('chatMessages');\n    setIsFinalized(false);\n    setIsAgentTyping(false);\n    \n    try {\n      // Reset the conversation in the chat service\n      chatServiceRef.current.resetConversation();\n      \n      // Start a new conversation\n      const convId = await chatServiceRef.current.startConversation();\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      // Get possible queries from API response\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to reset conversation:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError]);\n\n  const uploadFile = useCallback(async (file: File): Promise<Attachment | null> => {\n    if (!chatServiceRef.current || !chatServiceRef.current.getConversationId()) {\n      console.error('Cannot upload file, conversation not ready');\n      return null;\n    }\n\n    try {\n      const { fileUrl } = await chatServiceRef.current.uploadFile(\n        chatServiceRef.current.getConversationId() as string,\n        file\n      );\n      \n      const attachment: Attachment = {\n        name: file.name,\n        type: file.type,\n        size: file.size,\n        url: fileUrl,\n      };\n\n      setPreloadedAttachments(prev => [...prev, attachment]);\n      return attachment;\n    } catch (error) {\n      console.error('File upload failed:', error);\n      if (onError) {\n        onError(error as Error);\n      }\n      return null;\n    }\n  }, [onError]);\n\n  // Send message\n  const sendMessage = useCallback(async (text: string, files: File[] = []) => {\n    if (!chatServiceRef.current) {\n      throw new Error('Chat service not initialized');\n    }\n\n    try {\n      setIsLoading(true);\n\n      const newAttachments: Attachment[] = [];\n      \n      if (files.length > 0) {\n        const uploadedFiles = files.map(f => preloadedAttachments.find(pa => pa.name === f.name && pa.size === f.size)).filter(Boolean) as Attachment[];\n        newAttachments.push(...uploadedFiles);\n      }\n\n      // Start typing immediately when user sends\n      setIsAgentTyping(true);\n      await chatServiceRef.current.sendMessage(text, newAttachments);\n\n      setPreloadedAttachments([]);\n\n    } catch (error) {\n      setIsAgentTyping(false);\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to send message:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError, preloadedAttachments]);\n\n  const startConversation = useCallback(async () => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    try {\n      setConnectionState('connecting');\n      setIsLoading(true);\n      \n      // Reset state for new conversation\n      setMessages([]);\n      setPossibleQueries([]);\n      localStorage.removeItem('chatMessages');\n      setIsFinalized(false);\n      setIsAgentTyping(false);\n      chatServiceRef.current.resetConversation();\n\n      const convId = await chatServiceRef.current.startConversation();\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onError && error instanceof Error) {\n        onError(error);\n      } else {\n        console.error('Failed to start conversation:', error);\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [onError]);\n\n  return {\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  };\n}; "]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChatMessage } from '../types';
|
|
1
|
+
import { ChatMessage, Attachment } from '../types';
|
|
2
2
|
export declare class ChatService {
|
|
3
3
|
private baseUrl;
|
|
4
4
|
private apiKey;
|
|
@@ -41,7 +41,10 @@ export declare class ChatService {
|
|
|
41
41
|
getConversationId(): string | null;
|
|
42
42
|
isConversationFinalized(): boolean;
|
|
43
43
|
startConversation(): Promise<string>;
|
|
44
|
-
sendMessage(message: string): Promise<void>;
|
|
44
|
+
sendMessage(message: string, attachments?: Attachment[]): Promise<void>;
|
|
45
|
+
uploadFile(chatId: string, file: File): Promise<{
|
|
46
|
+
fileUrl: string;
|
|
47
|
+
}>;
|
|
45
48
|
connectWebSocket(): void;
|
|
46
49
|
disconnect(): void;
|
|
47
50
|
private adjustMessageTimestamps;
|
|
@@ -210,7 +210,7 @@ var ChatService = /** @class */ (function () {
|
|
|
210
210
|
});
|
|
211
211
|
});
|
|
212
212
|
};
|
|
213
|
-
ChatService.prototype.sendMessage = function (message) {
|
|
213
|
+
ChatService.prototype.sendMessage = function (message, attachments) {
|
|
214
214
|
return __awaiter(this, void 0, void 0, function () {
|
|
215
215
|
var now, chatMessage, error_2, errorMessage;
|
|
216
216
|
return __generator(this, function (_a) {
|
|
@@ -225,8 +225,12 @@ var ChatService = /** @class */ (function () {
|
|
|
225
225
|
start_time: now - this.conversationCreateTime, // Relative to conversation start
|
|
226
226
|
end_time: (now - this.conversationCreateTime) + 0.01, // Relative to conversation start
|
|
227
227
|
speaker: 'customer',
|
|
228
|
-
text: message
|
|
228
|
+
text: message,
|
|
229
|
+
attachments: attachments,
|
|
229
230
|
};
|
|
231
|
+
if (this.messageHandler) {
|
|
232
|
+
this.messageHandler(chatMessage);
|
|
233
|
+
}
|
|
230
234
|
_a.label = 1;
|
|
231
235
|
case 1:
|
|
232
236
|
_a.trys.push([1, 3, , 4]);
|
|
@@ -266,6 +270,39 @@ var ChatService = /** @class */ (function () {
|
|
|
266
270
|
});
|
|
267
271
|
});
|
|
268
272
|
};
|
|
273
|
+
ChatService.prototype.uploadFile = function (chatId, file) {
|
|
274
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
275
|
+
var formData, response, error_3;
|
|
276
|
+
return __generator(this, function (_a) {
|
|
277
|
+
switch (_a.label) {
|
|
278
|
+
case 0:
|
|
279
|
+
if (!this.conversationId) {
|
|
280
|
+
throw new Error('Conversation not started');
|
|
281
|
+
}
|
|
282
|
+
formData = new FormData();
|
|
283
|
+
formData.append('chat_id', chatId);
|
|
284
|
+
formData.append('file', file);
|
|
285
|
+
_a.label = 1;
|
|
286
|
+
case 1:
|
|
287
|
+
_a.trys.push([1, 3, , 4]);
|
|
288
|
+
return [4 /*yield*/, axios.post("".concat(this.baseUrl, "/api/genagent/knowledge/upload-chat-file"), formData, {
|
|
289
|
+
headers: {
|
|
290
|
+
'x-api-key': this.apiKey,
|
|
291
|
+
'Content-Type': 'multipart/form-data',
|
|
292
|
+
},
|
|
293
|
+
})];
|
|
294
|
+
case 2:
|
|
295
|
+
response = _a.sent();
|
|
296
|
+
return [2 /*return*/, response.data];
|
|
297
|
+
case 3:
|
|
298
|
+
error_3 = _a.sent();
|
|
299
|
+
console.error('Error uploading file:', error_3);
|
|
300
|
+
throw error_3;
|
|
301
|
+
case 4: return [2 /*return*/];
|
|
302
|
+
}
|
|
303
|
+
});
|
|
304
|
+
});
|
|
305
|
+
};
|
|
269
306
|
ChatService.prototype.connectWebSocket = function () {
|
|
270
307
|
var _this = this;
|
|
271
308
|
if (this.webSocket) {
|
|
@@ -291,12 +328,14 @@ var ChatService = /** @class */ (function () {
|
|
|
291
328
|
if (Array.isArray(data.payload)) {
|
|
292
329
|
var messages = data.payload;
|
|
293
330
|
// Adjust timestamps to be relative to conversation start
|
|
294
|
-
var adjustedMessages = messages.map(function (msg) { return _this.adjustMessageTimestamps(msg); });
|
|
331
|
+
var adjustedMessages = messages.map(function (msg) { return _this.adjustMessageTimestamps(msg); }).filter(function (msg) { return msg.speaker !== 'customer'; });
|
|
295
332
|
adjustedMessages.forEach(_this.messageHandler);
|
|
296
333
|
}
|
|
297
334
|
else {
|
|
298
335
|
var adjustedMessage = _this.adjustMessageTimestamps(data.payload);
|
|
299
|
-
|
|
336
|
+
if (adjustedMessage.speaker !== 'customer') {
|
|
337
|
+
_this.messageHandler(adjustedMessage);
|
|
338
|
+
}
|
|
300
339
|
}
|
|
301
340
|
}
|
|
302
341
|
else if (data.type === 'takeover') {
|
|
@@ -373,4 +412,4 @@ var ChatService = /** @class */ (function () {
|
|
|
373
412
|
return ChatService;
|
|
374
413
|
}());
|
|
375
414
|
export { ChatService };
|
|
376
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from 'axios';\nimport { w3cwebsocket as WebSocket, IMessageEvent, ICloseEvent } from 'websocket';\nimport { ChatMessage, StartConversationResponse } from '../types';\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler: ((state: 'connecting' | 'connected' | 'disconnected') => void) | null = null;\n  private storageKey = 'genassist_conversation';\n  private possibleQueries: string[] = [];\n\n  constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>) {\n    this.baseUrl = baseUrl.endsWith('/') ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    // Try to load a saved conversation ID from localStorage\n    this.loadSavedConversation();\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(handler: (state: 'connecting' | 'connected' | 'disconnected') => void) {\n    this.connectionStateHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      const savedConversation = localStorage.getItem(this.storageKey);\n      if (savedConversation) {\n        const { conversationId, createTime, isFinalized } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        console.log('Loaded saved conversation:', this.conversationId, 'Finalized:', this.isFinalized);\n      }\n    } catch (error) {\n      console.error('Error loading saved conversation:', error);\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n        };\n        localStorage.setItem(this.storageKey, JSON.stringify(conversationData));\n        console.log('Saved conversation:', this.conversationId);\n      }\n    } catch (error) {\n      console.error('Error saving conversation:', error);\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n    \n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    \n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.storageKey);\n    } catch (error) {\n      console.error('Error removing conversation from storage:', error);\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\"\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            'x-api-key': this.apiKey,\n            'Content-Type': 'application/json'\n          }\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time ? response.data.create_time / 1000 : Date.now() / 1000;\n      this.isFinalized = false;\n      this.saveConversation();\n      this.connectWebSocket();\n\n      // Store possible queries if available\n      if (response.data.agent_possible_queries && response.data.agent_possible_queries.length > 0) {\n        this.possibleQueries = response.data.agent_possible_queries;\n      }\n      \n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: (now - this.conversationCreateTime) + 0.01, // Relative to conversation start\n          speaker: 'agent',\n          text: response.data.agent_welcome_message\n        };\n        this.messageHandler(welcomeMessage);\n      }\n      return response.data.conversation_id;\n    } catch (error) {\n      console.error('Error starting conversation:', error);\n      throw error;\n    }\n  }\n\n  async sendMessage(message: string): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error('Conversation not started');\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: (now - this.conversationCreateTime) + 0.01, // Relative to conversation start\n      speaker: 'customer',\n      text: message\n    };\n\n    try {\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        {\n          messages: [chatMessage]\n        },\n        {\n          headers: {\n            'x-api-key': this.apiKey,\n            'Content-Type': 'application/json'\n          }\n        }\n      );\n    } catch (error: any) {\n      console.error('Error sending message:', error);\n      \n      // Check if this is the agent inactive error\n      if (error.response && error.response.data && error.response.data.error_key === 'AGENT_INACTIVE') {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: (now - this.conversationCreateTime) + 0.01,\n            speaker: 'special',\n            text: 'The agent is currently offline, please check back later. Thank you!'\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n      \n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n    \n    if (!this.conversationId) {\n      throw new Error('Conversation ID is required for WebSocket connection');\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler('connecting');\n    const wsUrl = `${this.baseUrl.replace('http', 'ws')}/api/conversations/ws/${this.conversationId}?api_key=${this.apiKey}&lang=en&topics=message&topics=takeover&topics=finalize`;\n    this.webSocket = new WebSocket(wsUrl);\n\n    this.webSocket.onopen = () => {\n      console.log('WebSocket connected');\n      if (this.connectionStateHandler) this.connectionStateHandler('connected');\n    };\n\n    this.webSocket.onmessage = (event: IMessageEvent) => {\n      console.log('WebSocket message:', event.data);\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === 'message' && this.messageHandler) {\n          if(Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[]\n            // Adjust timestamps to be relative to conversation start\n            const adjustedMessages = messages.map(msg => this.adjustMessageTimestamps(msg));\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(data.payload as ChatMessage);\n            this.messageHandler(adjustedMessage);\n          }\n        } else if (data.type === 'takeover') {\n          // Handle takeover event\n          console.log('Takeover event received');\n          \n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime ? now - this.conversationCreateTime : 0,\n              end_time: this.conversationCreateTime ? (now - this.conversationCreateTime) + 0.01 : 0.01,\n              speaker: 'special',\n              text: 'Supervisor took over'\n            };\n            this.messageHandler(takeoverMessage);\n          }\n          \n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === 'finalize') {\n          // Handle finalized event\n          console.log('Finalized event received');\n          \n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime ? now - this.conversationCreateTime : 0,\n              end_time: this.conversationCreateTime ? (now - this.conversationCreateTime) + 0.01 : 0.01,\n              speaker: 'special',\n              text: 'Conversation Finalized'\n            };\n            this.messageHandler(finalizedMessage);\n          }\n          \n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        console.error('Error parsing WebSocket message:', error);\n      }\n    };\n\n    this.webSocket.onerror = (error: Error) => {\n      console.error('WebSocket error:', error);\n      if (this.connectionStateHandler) this.connectionStateHandler('disconnected');\n    };\n\n    this.webSocket.onclose = (event: ICloseEvent) => {\n      console.log('WebSocket closed:', event.code, event.reason);\n      if (this.connectionStateHandler) this.connectionStateHandler('disconnected');\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime\n    };\n  }\n} "]}
|
|
415
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from 'axios';\nimport { w3cwebsocket as WebSocket, IMessageEvent, ICloseEvent } from 'websocket';\nimport { ChatMessage, StartConversationResponse, Attachment } from '../types';\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler: ((state: 'connecting' | 'connected' | 'disconnected') => void) | null = null;\n  private storageKey = 'genassist_conversation';\n  private possibleQueries: string[] = [];\n\n  constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>) {\n    this.baseUrl = baseUrl.endsWith('/') ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    // Try to load a saved conversation ID from localStorage\n    this.loadSavedConversation();\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(handler: (state: 'connecting' | 'connected' | 'disconnected') => void) {\n    this.connectionStateHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      const savedConversation = localStorage.getItem(this.storageKey);\n      if (savedConversation) {\n        const { conversationId, createTime, isFinalized } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        console.log('Loaded saved conversation:', this.conversationId, 'Finalized:', this.isFinalized);\n      }\n    } catch (error) {\n      console.error('Error loading saved conversation:', error);\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n        };\n        localStorage.setItem(this.storageKey, JSON.stringify(conversationData));\n        console.log('Saved conversation:', this.conversationId);\n      }\n    } catch (error) {\n      console.error('Error saving conversation:', error);\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n    \n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    \n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.storageKey);\n    } catch (error) {\n      console.error('Error removing conversation from storage:', error);\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\"\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            'x-api-key': this.apiKey,\n            'Content-Type': 'application/json'\n          }\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time ? response.data.create_time / 1000 : Date.now() / 1000;\n      this.isFinalized = false;\n      this.saveConversation();\n      this.connectWebSocket();\n\n      // Store possible queries if available\n      if (response.data.agent_possible_queries && response.data.agent_possible_queries.length > 0) {\n        this.possibleQueries = response.data.agent_possible_queries;\n      }\n      \n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: (now - this.conversationCreateTime) + 0.01, // Relative to conversation start\n          speaker: 'agent',\n          text: response.data.agent_welcome_message\n        };\n        this.messageHandler(welcomeMessage);\n      }\n      return response.data.conversation_id;\n    } catch (error) {\n      console.error('Error starting conversation:', error);\n      throw error;\n    }\n  }\n\n  async sendMessage(message: string, attachments?: Attachment[]): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error('Conversation not started');\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: (now - this.conversationCreateTime) + 0.01, // Relative to conversation start\n      speaker: 'customer',\n      text: message,\n      attachments: attachments,\n    };\n\n    if (this.messageHandler) {\n      this.messageHandler(chatMessage);\n    }\n\n    try {\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        {\n          messages: [chatMessage]\n        },\n        {\n          headers: {\n            'x-api-key': this.apiKey,\n            'Content-Type': 'application/json'\n          }\n        }\n      );\n    } catch (error: any) {\n      console.error('Error sending message:', error);\n      \n      // Check if this is the agent inactive error\n      if (error.response && error.response.data && error.response.data.error_key === 'AGENT_INACTIVE') {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: (now - this.conversationCreateTime) + 0.01,\n            speaker: 'special',\n            text: 'The agent is currently offline, please check back later. Thank you!'\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n      \n      throw error;\n    }\n  }\n\n  async uploadFile(chatId: string, file: File): Promise<{ fileUrl: string }> {\n    if (!this.conversationId) {\n      throw new Error('Conversation not started');\n    }\n\n    const formData = new FormData();\n    formData.append('chat_id', chatId);\n    formData.append('file', file);\n\n    try {\n      const response = await axios.post<{ fileUrl: string }>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: {\n            'x-api-key': this.apiKey,\n            'Content-Type': 'multipart/form-data',\n          },\n        }\n      );\n      return response.data;\n    } catch (error) {\n      console.error('Error uploading file:', error);\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n    \n    if (!this.conversationId) {\n      throw new Error('Conversation ID is required for WebSocket connection');\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler('connecting');\n    const wsUrl = `${this.baseUrl.replace('http', 'ws')}/api/conversations/ws/${this.conversationId}?api_key=${this.apiKey}&lang=en&topics=message&topics=takeover&topics=finalize`;\n    this.webSocket = new WebSocket(wsUrl);\n\n    this.webSocket.onopen = () => {\n      console.log('WebSocket connected');\n      if (this.connectionStateHandler) this.connectionStateHandler('connected');\n    };\n\n    this.webSocket.onmessage = (event: IMessageEvent) => {\n      console.log('WebSocket message:', event.data);\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === 'message' && this.messageHandler) {\n          if(Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[]\n            // Adjust timestamps to be relative to conversation start\n            const adjustedMessages = messages.map(msg => this.adjustMessageTimestamps(msg)).filter(msg => msg.speaker !== 'customer');\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(data.payload as ChatMessage);\n            if (adjustedMessage.speaker !== 'customer') {\n              this.messageHandler(adjustedMessage);\n            }\n          }\n        } else if (data.type === 'takeover') {\n          // Handle takeover event\n          console.log('Takeover event received');\n          \n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime ? now - this.conversationCreateTime : 0,\n              end_time: this.conversationCreateTime ? (now - this.conversationCreateTime) + 0.01 : 0.01,\n              speaker: 'special',\n              text: 'Supervisor took over'\n            };\n            this.messageHandler(takeoverMessage);\n          }\n          \n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === 'finalize') {\n          // Handle finalized event\n          console.log('Finalized event received');\n          \n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime ? now - this.conversationCreateTime : 0,\n              end_time: this.conversationCreateTime ? (now - this.conversationCreateTime) + 0.01 : 0.01,\n              speaker: 'special',\n              text: 'Conversation Finalized'\n            };\n            this.messageHandler(finalizedMessage);\n          }\n          \n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        console.error('Error parsing WebSocket message:', error);\n      }\n    };\n\n    this.webSocket.onerror = (error: Error) => {\n      console.error('WebSocket error:', error);\n      if (this.connectionStateHandler) this.connectionStateHandler('disconnected');\n    };\n\n    this.webSocket.onclose = (event: ICloseEvent) => {\n      console.log('WebSocket closed:', event.code, event.reason);\n      if (this.connectionStateHandler) this.connectionStateHandler('disconnected');\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime\n    };\n  }\n} "]}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -4,6 +4,13 @@ export interface ChatMessage {
|
|
|
4
4
|
end_time: number;
|
|
5
5
|
speaker: 'customer' | 'agent' | 'special';
|
|
6
6
|
text: string;
|
|
7
|
+
attachments?: Attachment[];
|
|
8
|
+
}
|
|
9
|
+
export interface Attachment {
|
|
10
|
+
name: string;
|
|
11
|
+
type: string;
|
|
12
|
+
size: number;
|
|
13
|
+
url: string;
|
|
7
14
|
}
|
|
8
15
|
export interface StartConversationResponse {
|
|
9
16
|
message: string;
|
package/dist/types/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIENoYXQgbWVzc2FnZSB0eXBlc1xuZXhwb3J0IGludGVyZmFjZSBDaGF0TWVzc2FnZSB7XG4gIGNyZWF0ZV90aW1lOiBudW1iZXI7XG4gIHN0YXJ0X3RpbWU6IG51bWJlcjtcbiAgZW5kX3RpbWU6IG51bWJlcjtcbiAgc3BlYWtlcjogJ2N1c3RvbWVyJyB8ICdhZ2VudCcgfCAnc3BlY2lhbCc7XG4gIHRleHQ6IHN0cmluZztcbiAgYXR0YWNobWVudHM/OiBBdHRhY2htZW50W107XG59XG5cbi8vIEF0dGFjaG1lbnQgdHlwZVxuZXhwb3J0IGludGVyZmFjZSBBdHRhY2htZW50IHtcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG4gIHNpemU6IG51bWJlcjtcbiAgdXJsOiBzdHJpbmc7XG59XG5cbi8vIEFQSSBSZXNwb25zZSB0eXBlc1xuZXhwb3J0IGludGVyZmFjZSBTdGFydENvbnZlcnNhdGlvblJlc3BvbnNlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBjb252ZXJzYXRpb25faWQ6IHN0cmluZztcbiAgYWdlbnRfd2VsY29tZV9tZXNzYWdlPzogc3RyaW5nO1xuICBhZ2VudF9wb3NzaWJsZV9xdWVyaWVzPzogc3RyaW5nW107XG4gIGNyZWF0ZV90aW1lPzogbnVtYmVyO1xufVxuXG4vLyBQcm9wcyBmb3IgdGhlIEdlbkFnZW50Q2hhdCBjb21wb25lbnRcbmV4cG9ydCBpbnRlcmZhY2UgR2VuQWdlbnRDaGF0UHJvcHMge1xuICBiYXNlVXJsOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT47IC8vIEZvciBwYXNzaW5nIHVzZXIgaW5mb3JtYXRpb24gb3Igb3RoZXIgbWV0YWRhdGFcbiAgb25FcnJvcj86IChlcnJvcjogRXJyb3IpID0+IHZvaWQ7XG4gIG9uVGFrZW92ZXI/OiAoKSA9PiB2b2lkO1xuICBvbkZpbmFsaXplPzogKCkgPT4gdm9pZDtcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIHNlY29uZGFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGZvbnRGYW1pbHk/OiBzdHJpbmc7XG4gICAgZm9udFNpemU/OiBzdHJpbmc7XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICAgIHRleHRDb2xvcj86IHN0cmluZztcbiAgfTtcbiAgaGVhZGVyVGl0bGU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICBtb2RlPzogJ2VtYmVkZGVkJyB8ICdmbG9hdGluZyc7XG4gIGZsb2F0aW5nQ29uZmlnPzoge1xuICAgIHBvc2l0aW9uPzogJ2JvdHRvbS1yaWdodCcgfCAnYm90dG9tLWxlZnQnIHwgJ3RvcC1yaWdodCcgfCAndG9wLWxlZnQnO1xuICAgIG9mZnNldD86IHsgeD86IG51bWJlcjsgeT86IG51bWJlciB9O1xuICAgIHRvZ2dsZUJ1dHRvbkljb24/OiBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gICAgY2xvc2VCdXR0b25JY29uPzogUmVhY3QuUmVhY3RFbGVtZW50O1xuICB9O1xufSAiXX0=
|
package/package.json
CHANGED
package/assets/chat-logo.png
DELETED
|
Binary file
|