genassist-chat-react 1.0.3 → 1.0.4
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/README.md +2 -0
- package/dist/components/ChatMessage.d.ts +6 -0
- package/dist/components/ChatMessage.js +181 -54
- package/dist/components/GenAgentChat.js +178 -42
- package/dist/components/VoiceInput.js +12 -10
- package/dist/hooks/useChat.d.ts +7 -1
- package/dist/hooks/useChat.js +104 -10
- package/dist/services/chatService.d.ts +10 -3
- package/dist/services/chatService.js +168 -73
- package/dist/types/index.d.ts +27 -3
- package/dist/types/index.js +1 -1
- package/package.json +3 -2
- package/dist/assets/chat-logo.png +0 -0
|
@@ -16,24 +16,26 @@ export var VoiceInput = function (_a) {
|
|
|
16
16
|
};
|
|
17
17
|
var getButtonContent = function () {
|
|
18
18
|
if (isLoading) {
|
|
19
|
-
return (_jsx(Loader2, { size:
|
|
19
|
+
return (_jsx(Loader2, { size: 18, color: "#ffffff", style: {
|
|
20
20
|
animation: 'spin 1s linear infinite',
|
|
21
21
|
} }));
|
|
22
22
|
}
|
|
23
|
-
return _jsx(Mic, { size:
|
|
23
|
+
return _jsx(Mic, { size: 18, color: "#ffffff" });
|
|
24
24
|
};
|
|
25
25
|
var getTitle = function () {
|
|
26
26
|
if (isLoading)
|
|
27
27
|
return 'Connecting...';
|
|
28
28
|
return isRecording ? 'Stop Recording' : 'Start Recording';
|
|
29
29
|
};
|
|
30
|
+
var idleBg = (theme === null || theme === void 0 ? void 0 : theme.primaryColor) || '#2962FF';
|
|
31
|
+
var activeBg = '#FF3B30'; // red when recording
|
|
30
32
|
var buttonStyle = {
|
|
31
|
-
backgroundColor:
|
|
32
|
-
color:
|
|
33
|
+
backgroundColor: isRecording ? activeBg : idleBg,
|
|
34
|
+
color: '#ffffff',
|
|
33
35
|
border: 'none',
|
|
34
|
-
borderRadius: '
|
|
35
|
-
width: '
|
|
36
|
-
height: '
|
|
36
|
+
borderRadius: '50%',
|
|
37
|
+
width: '36px',
|
|
38
|
+
height: '36px',
|
|
37
39
|
display: 'flex',
|
|
38
40
|
alignItems: 'center',
|
|
39
41
|
justifyContent: 'center',
|
|
@@ -41,11 +43,11 @@ export var VoiceInput = function (_a) {
|
|
|
41
43
|
outline: 'none',
|
|
42
44
|
transition: 'all 0.2s ease',
|
|
43
45
|
flexShrink: 0,
|
|
44
|
-
boxShadow: '0 1px 3px rgba(0, 0, 0, 0.
|
|
45
|
-
opacity: isLoading ? 0.
|
|
46
|
+
boxShadow: '0 1px 3px rgba(0, 0, 0, 0.08)',
|
|
47
|
+
opacity: isLoading ? 0.9 : 1,
|
|
46
48
|
};
|
|
47
49
|
// Keyframe animation for the spinner
|
|
48
50
|
var spinKeyframes = "\n @keyframes spin {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n }\n ";
|
|
49
51
|
return (_jsxs(_Fragment, { children: [_jsx("style", { children: spinKeyframes }), _jsx("button", { type: "button", style: buttonStyle, onClick: handleClick, title: getTitle(), disabled: isLoading, children: getButtonContent() })] }));
|
|
50
52
|
};
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFjdkQsTUFBTSxDQUFDLElBQU0sVUFBVSxHQUE4QixVQUFDLEVBTXJEO1FBTEMsZUFBZSxxQkFBQSxFQUNmLE9BQU8sYUFBQSxFQUNQLE9BQU8sYUFBQSxFQUNQLE1BQU0sWUFBQSxFQUNOLEtBQUssV0FBQTtJQUVDLElBQUEsS0FBOEMsYUFBYSxDQUFDO1FBQ2hFLE9BQU8sU0FBQTtRQUNQLE1BQU0sUUFBQTtRQUNOLGVBQWUsaUJBQUE7UUFDZixPQUFPLFNBQUE7S0FDUixDQUFDLEVBTE0sV0FBVyxpQkFBQSxFQUFFLFNBQVMsZUFBQSxFQUFFLGVBQWUscUJBSzdDLENBQUM7SUFFSCxJQUFNLFdBQVcsR0FBRyxVQUFDLENBQW1CO1FBQ3RDLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNuQixDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDcEIsZUFBZSxFQUFFLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsSUFBTSxnQkFBZ0IsR0FBRztRQUN2QixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxDQUNMLEtBQUMsT0FBTyxJQUNOLElBQUksRUFBRSxFQUFFLEVBQ1IsS0FBSyxFQUFDLFNBQVMsRUFDZixLQUFLLEVBQUU7b0JBQ0wsU0FBUyxFQUFFLHlCQUF5QjtpQkFDckMsR0FDRCxDQUNILENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxLQUFDLEdBQUcsSUFBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBQyxTQUFTLEdBQUcsQ0FBQztJQUMzQyxDQUFDLENBQUM7SUFFRixJQUFNLFFBQVEsR0FBRztRQUNmLElBQUksU0FBUztZQUFFLE9BQU8sZUFBZSxDQUFDO1FBQ3RDLE9BQU8sV0FBVyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsaUJBQWlCLENBQUM7SUFDNUQsQ0FBQyxDQUFDO0lBRUYsSUFBTSxNQUFNLEdBQUcsQ0FBQSxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsWUFBWSxLQUFJLFNBQVMsQ0FBQztJQUNoRCxJQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsQ0FBQyxxQkFBcUI7SUFDakQsSUFBTSxXQUFXLEdBQXdCO1FBQ3ZDLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTTtRQUNoRCxLQUFLLEVBQUUsU0FBUztRQUNoQixNQUFNLEVBQUUsTUFBTTtRQUNkLFlBQVksRUFBRSxLQUFLO1FBQ25CLEtBQUssRUFBRSxNQUFNO1FBQ2IsTUFBTSxFQUFFLE1BQU07UUFDZCxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLGNBQWMsRUFBRSxRQUFRO1FBQ3hCLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUM3QyxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxlQUFlO1FBQzNCLFVBQVUsRUFBRSxDQUFDO1FBQ2IsU0FBUyxFQUFFLCtCQUErQjtRQUMxQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDN0IsQ0FBQztJQUVGLHFDQUFxQztJQUNyQyxJQUFNLGFBQWEsR0FBRyxzSkFTckIsQ0FBQztJQUVGLE9BQU8sQ0FDTCw4QkFDRSwwQkFBUSxhQUFhLEdBQVMsRUFDOUIsaUJBQ0UsSUFBSSxFQUFDLFFBQVEsRUFDYixLQUFLLEVBQUUsV0FBVyxFQUNsQixPQUFPLEVBQUUsV0FBVyxFQUNwQixLQUFLLEVBQUUsUUFBUSxFQUFFLEVBQ2pCLFFBQVEsRUFBRSxTQUFTLFlBRWxCLGdCQUFnQixFQUFFLEdBQ1osSUFDUixDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWljLCBMb2FkZXIyIH0gZnJvbSAnbHVjaWRlLXJlYWN0JztcbmltcG9ydCB7IHVzZVZvaWNlSW5wdXQgfSBmcm9tICcuLi9ob29rcy91c2VWb2ljZUlucHV0JztcblxuaW50ZXJmYWNlIFZvaWNlSW5wdXRQcm9wcyB7XG4gIG9uVHJhbnNjcmlwdGlvbjogKHRleHQ6IHN0cmluZykgPT4gdm9pZDtcbiAgb25FcnJvcjogKGVycm9yOiBFcnJvcikgPT4gdm9pZDtcbiAgYmFzZVVybDogc3RyaW5nO1xuICBhcGlLZXk6IHN0cmluZztcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgICBmb250RmFtaWx5Pzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgVm9pY2VJbnB1dDogUmVhY3QuRkM8Vm9pY2VJbnB1dFByb3BzPiA9ICh7XG4gIG9uVHJhbnNjcmlwdGlvbixcbiAgb25FcnJvcixcbiAgYmFzZVVybCxcbiAgYXBpS2V5LFxuICB0aGVtZVxufSkgPT4ge1xuICBjb25zdCB7IGlzUmVjb3JkaW5nLCBpc0xvYWRpbmcsIHRvZ2dsZVJlY29yZGluZyB9ID0gdXNlVm9pY2VJbnB1dCh7XG4gICAgYmFzZVVybCxcbiAgICBhcGlLZXksXG4gICAgb25UcmFuc2NyaXB0aW9uLFxuICAgIG9uRXJyb3IsXG4gIH0pO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrID0gKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0b2dnbGVSZWNvcmRpbmcoKTtcbiAgfTtcblxuICBjb25zdCBnZXRCdXR0b25Db250ZW50ID0gKCkgPT4ge1xuICAgIGlmIChpc0xvYWRpbmcpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxMb2FkZXIyIFxuICAgICAgICAgIHNpemU9ezE4fSBcbiAgICAgICAgICBjb2xvcj1cIiNmZmZmZmZcIiBcbiAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgYW5pbWF0aW9uOiAnc3BpbiAxcyBsaW5lYXIgaW5maW5pdGUnLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gPE1pYyBzaXplPXsxOH0gY29sb3I9XCIjZmZmZmZmXCIgLz47XG4gIH07XG5cbiAgY29uc3QgZ2V0VGl0bGUgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykgcmV0dXJuICdDb25uZWN0aW5nLi4uJztcbiAgICByZXR1cm4gaXNSZWNvcmRpbmcgPyAnU3RvcCBSZWNvcmRpbmcnIDogJ1N0YXJ0IFJlY29yZGluZyc7XG4gIH07XG5cbiAgY29uc3QgaWRsZUJnID0gdGhlbWU/LnByaW1hcnlDb2xvciB8fCAnIzI5NjJGRic7XG4gIGNvbnN0IGFjdGl2ZUJnID0gJyNGRjNCMzAnOyAvLyByZWQgd2hlbiByZWNvcmRpbmdcbiAgY29uc3QgYnV0dG9uU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgYmFja2dyb3VuZENvbG9yOiBpc1JlY29yZGluZyA/IGFjdGl2ZUJnIDogaWRsZUJnLFxuICAgIGNvbG9yOiAnI2ZmZmZmZicsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNTAlJyxcbiAgICB3aWR0aDogJzM2cHgnLFxuICAgIGhlaWdodDogJzM2cHgnLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgY3Vyc29yOiBpc0xvYWRpbmcgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInLFxuICAgIG91dGxpbmU6ICdub25lJyxcbiAgICB0cmFuc2l0aW9uOiAnYWxsIDAuMnMgZWFzZScsXG4gICAgZmxleFNocmluazogMCxcbiAgICBib3hTaGFkb3c6ICcwIDFweCAzcHggcmdiYSgwLCAwLCAwLCAwLjA4KScsXG4gICAgb3BhY2l0eTogaXNMb2FkaW5nID8gMC45IDogMSxcbiAgfTtcblxuICAvLyBLZXlmcmFtZSBhbmltYXRpb24gZm9yIHRoZSBzcGlubmVyXG4gIGNvbnN0IHNwaW5LZXlmcmFtZXMgPSBgXG4gICAgQGtleWZyYW1lcyBzcGluIHtcbiAgICAgIGZyb20ge1xuICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICAgIH1cbiAgICAgIHRvIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTtcbiAgICAgIH1cbiAgICB9XG4gIGA7XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPHN0eWxlPntzcGluS2V5ZnJhbWVzfTwvc3R5bGU+XG4gICAgICA8YnV0dG9uXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICBzdHlsZT17YnV0dG9uU3R5bGV9XG4gICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrfVxuICAgICAgICB0aXRsZT17Z2V0VGl0bGUoKX1cbiAgICAgICAgZGlzYWJsZWQ9e2lzTG9hZGluZ31cbiAgICAgID5cbiAgICAgICAge2dldEJ1dHRvbkNvbnRlbnQoKX1cbiAgICAgIDwvYnV0dG9uPlxuICAgIDwvPlxuICApO1xufTsgXG4iXX0=
|
package/dist/hooks/useChat.d.ts
CHANGED
|
@@ -2,12 +2,13 @@ import { ChatMessage, Attachment } from '../types';
|
|
|
2
2
|
export interface UseChatProps {
|
|
3
3
|
baseUrl: string;
|
|
4
4
|
apiKey: string;
|
|
5
|
+
tenant?: string | undefined;
|
|
5
6
|
metadata?: Record<string, any>;
|
|
6
7
|
onError?: (error: Error) => void;
|
|
7
8
|
onTakeover?: () => void;
|
|
8
9
|
onFinalize?: () => void;
|
|
9
10
|
}
|
|
10
|
-
export declare const useChat: ({ baseUrl, apiKey, metadata, onError, onTakeover, onFinalize }: UseChatProps) => {
|
|
11
|
+
export declare const useChat: ({ baseUrl, apiKey, tenant, metadata, onError, onTakeover, onFinalize }: UseChatProps) => {
|
|
11
12
|
messages: ChatMessage[];
|
|
12
13
|
isLoading: boolean;
|
|
13
14
|
sendMessage: (text: string, files?: File[]) => Promise<void>;
|
|
@@ -20,4 +21,9 @@ export declare const useChat: ({ baseUrl, apiKey, metadata, onError, onTakeover,
|
|
|
20
21
|
isTakenOver: boolean;
|
|
21
22
|
isFinalized: boolean;
|
|
22
23
|
isAgentTyping: boolean;
|
|
24
|
+
addFeedback: (messageId: string, value: "good" | "bad", feedbackMessage?: string) => Promise<void>;
|
|
25
|
+
welcomeTitle: string | null;
|
|
26
|
+
welcomeImageUrl: string | null;
|
|
27
|
+
thinkingPhrases: string[];
|
|
28
|
+
thinkingDelayMs: number;
|
|
23
29
|
};
|
package/dist/hooks/useChat.js
CHANGED
|
@@ -57,7 +57,7 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
57
57
|
import { useState, useEffect, useCallback, useRef } from 'react';
|
|
58
58
|
import { ChatService } from '../services/chatService';
|
|
59
59
|
export var useChat = function (_a) {
|
|
60
|
-
var baseUrl = _a.baseUrl, apiKey = _a.apiKey, metadata = _a.metadata, onError = _a.onError, onTakeover = _a.onTakeover, onFinalize = _a.onFinalize;
|
|
60
|
+
var baseUrl = _a.baseUrl, apiKey = _a.apiKey, tenant = _a.tenant, metadata = _a.metadata, onError = _a.onError, onTakeover = _a.onTakeover, onFinalize = _a.onFinalize;
|
|
61
61
|
var _b = useState(function () {
|
|
62
62
|
try {
|
|
63
63
|
var storedMessages = localStorage.getItem('chatMessages');
|
|
@@ -75,11 +75,16 @@ export var useChat = function (_a) {
|
|
|
75
75
|
var chatServiceRef = useRef(null);
|
|
76
76
|
var _g = useState(null), conversationId = _g[0], setConversationId = _g[1];
|
|
77
77
|
var _h = useState([]), possibleQueries = _h[0], setPossibleQueries = _h[1];
|
|
78
|
-
var _j = useState(
|
|
79
|
-
var _k = useState(
|
|
78
|
+
var _j = useState(null), welcomeTitle = _j[0], setWelcomeTitle = _j[1];
|
|
79
|
+
var _k = useState(null), welcomeImageUrl = _k[0], setWelcomeImageUrl = _k[1];
|
|
80
|
+
var _l = useState([]), thinkingPhrases = _l[0], setThinkingPhrases = _l[1];
|
|
81
|
+
var _m = useState(1000), thinkingDelayMs = _m[0], setThinkingDelayMs = _m[1];
|
|
82
|
+
var _o = useState(false), isTakenOver = _o[0], setIsTakenOver = _o[1];
|
|
83
|
+
var _p = useState(false), isFinalized = _p[0], setIsFinalized = _p[1];
|
|
80
84
|
// Initialize chat service
|
|
81
85
|
useEffect(function () {
|
|
82
|
-
|
|
86
|
+
var _a, _b, _c, _d, _e, _f;
|
|
87
|
+
chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata, tenant);
|
|
83
88
|
chatServiceRef.current.setMessageHandler(function (message) {
|
|
84
89
|
var normalizedMessage = __assign(__assign({}, message), { create_time: (!message.create_time || isNaN(message.create_time))
|
|
85
90
|
? Math.floor(Date.now() / 1000)
|
|
@@ -122,6 +127,22 @@ export var useChat = function (_a) {
|
|
|
122
127
|
chatServiceRef.current.connectWebSocket();
|
|
123
128
|
}
|
|
124
129
|
}
|
|
130
|
+
// Pull initial static data
|
|
131
|
+
if (chatServiceRef.current) {
|
|
132
|
+
var queries = ((_b = (_a = chatServiceRef.current).getPossibleQueries) === null || _b === void 0 ? void 0 : _b.call(_a)) || [];
|
|
133
|
+
if (queries.length)
|
|
134
|
+
setPossibleQueries(queries);
|
|
135
|
+
var welcome = (_d = (_c = chatServiceRef.current).getWelcomeData) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
136
|
+
if (welcome) {
|
|
137
|
+
setWelcomeTitle(welcome.title || null);
|
|
138
|
+
setWelcomeImageUrl(welcome.imageUrl || null);
|
|
139
|
+
}
|
|
140
|
+
var thinking = (_f = (_e = chatServiceRef.current).getThinkingConfig) === null || _f === void 0 ? void 0 : _f.call(_e);
|
|
141
|
+
if (thinking) {
|
|
142
|
+
setThinkingPhrases(thinking.phrases || []);
|
|
143
|
+
setThinkingDelayMs(thinking.delayMs || 1000);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
125
146
|
// Cleanup
|
|
126
147
|
return function () {
|
|
127
148
|
if (chatServiceRef.current) {
|
|
@@ -139,7 +160,7 @@ export var useChat = function (_a) {
|
|
|
139
160
|
}, [messages]);
|
|
140
161
|
// Reset conversation
|
|
141
162
|
var resetConversation = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
142
|
-
var convId, queries, error_1;
|
|
163
|
+
var convId, queries, welcome, thinking, error_1;
|
|
143
164
|
return __generator(this, function (_a) {
|
|
144
165
|
switch (_a.label) {
|
|
145
166
|
case 0:
|
|
@@ -150,8 +171,13 @@ export var useChat = function (_a) {
|
|
|
150
171
|
setIsLoading(true);
|
|
151
172
|
setMessages([]);
|
|
152
173
|
setPossibleQueries([]);
|
|
174
|
+
setWelcomeTitle(null);
|
|
175
|
+
setWelcomeImageUrl(null);
|
|
176
|
+
setThinkingPhrases([]);
|
|
177
|
+
setThinkingDelayMs(1000);
|
|
153
178
|
localStorage.removeItem('chatMessages');
|
|
154
179
|
setIsFinalized(false);
|
|
180
|
+
setIsTakenOver(false);
|
|
155
181
|
setIsAgentTyping(false);
|
|
156
182
|
_a.label = 1;
|
|
157
183
|
case 1:
|
|
@@ -170,6 +196,17 @@ export var useChat = function (_a) {
|
|
|
170
196
|
setPossibleQueries(queries);
|
|
171
197
|
}
|
|
172
198
|
}
|
|
199
|
+
// welcome and thinking data
|
|
200
|
+
if (chatServiceRef.current.getWelcomeData) {
|
|
201
|
+
welcome = chatServiceRef.current.getWelcomeData();
|
|
202
|
+
setWelcomeTitle(welcome.title || null);
|
|
203
|
+
setWelcomeImageUrl(welcome.imageUrl || null);
|
|
204
|
+
}
|
|
205
|
+
if (chatServiceRef.current.getThinkingConfig) {
|
|
206
|
+
thinking = chatServiceRef.current.getThinkingConfig();
|
|
207
|
+
setThinkingPhrases(thinking.phrases || []);
|
|
208
|
+
setThinkingDelayMs(thinking.delayMs || 1000);
|
|
209
|
+
}
|
|
173
210
|
return [3 /*break*/, 5];
|
|
174
211
|
case 3:
|
|
175
212
|
error_1 = _a.sent();
|
|
@@ -247,8 +284,10 @@ export var useChat = function (_a) {
|
|
|
247
284
|
uploadedFiles = files.map(function (f) { return preloadedAttachments.find(function (pa) { return pa.name === f.name && pa.size === f.size; }); }).filter(Boolean);
|
|
248
285
|
newAttachments.push.apply(newAttachments, uploadedFiles);
|
|
249
286
|
}
|
|
250
|
-
// Start typing immediately when user sends
|
|
251
|
-
|
|
287
|
+
// Start typing immediately when user sends, unless conversation is taken over by a human
|
|
288
|
+
if (!isTakenOver) {
|
|
289
|
+
setIsAgentTyping(true);
|
|
290
|
+
}
|
|
252
291
|
return [4 /*yield*/, chatServiceRef.current.sendMessage(text, newAttachments)];
|
|
253
292
|
case 2:
|
|
254
293
|
_a.sent();
|
|
@@ -271,9 +310,9 @@ export var useChat = function (_a) {
|
|
|
271
310
|
}
|
|
272
311
|
});
|
|
273
312
|
});
|
|
274
|
-
}, [onError, preloadedAttachments]);
|
|
313
|
+
}, [onError, preloadedAttachments, isTakenOver]);
|
|
275
314
|
var startConversation = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
276
|
-
var convId, queries, error_4;
|
|
315
|
+
var convId, queries, welcome, thinking, error_4;
|
|
277
316
|
return __generator(this, function (_a) {
|
|
278
317
|
switch (_a.label) {
|
|
279
318
|
case 0:
|
|
@@ -290,6 +329,7 @@ export var useChat = function (_a) {
|
|
|
290
329
|
setPossibleQueries([]);
|
|
291
330
|
localStorage.removeItem('chatMessages');
|
|
292
331
|
setIsFinalized(false);
|
|
332
|
+
setIsTakenOver(false);
|
|
293
333
|
setIsAgentTyping(false);
|
|
294
334
|
chatServiceRef.current.resetConversation();
|
|
295
335
|
return [4 /*yield*/, chatServiceRef.current.startConversation()];
|
|
@@ -303,6 +343,16 @@ export var useChat = function (_a) {
|
|
|
303
343
|
setPossibleQueries(queries);
|
|
304
344
|
}
|
|
305
345
|
}
|
|
346
|
+
if (chatServiceRef.current.getWelcomeData) {
|
|
347
|
+
welcome = chatServiceRef.current.getWelcomeData();
|
|
348
|
+
setWelcomeTitle(welcome.title || null);
|
|
349
|
+
setWelcomeImageUrl(welcome.imageUrl || null);
|
|
350
|
+
}
|
|
351
|
+
if (chatServiceRef.current.getThinkingConfig) {
|
|
352
|
+
thinking = chatServiceRef.current.getThinkingConfig();
|
|
353
|
+
setThinkingPhrases(thinking.phrases || []);
|
|
354
|
+
setThinkingDelayMs(thinking.delayMs || 1000);
|
|
355
|
+
}
|
|
306
356
|
return [3 /*break*/, 5];
|
|
307
357
|
case 3:
|
|
308
358
|
error_4 = _a.sent();
|
|
@@ -322,6 +372,45 @@ export var useChat = function (_a) {
|
|
|
322
372
|
}
|
|
323
373
|
});
|
|
324
374
|
}); }, [onError]);
|
|
375
|
+
// Add feedback to an agent message
|
|
376
|
+
var addFeedback = useCallback(function (messageId, value, feedbackMessage) { return __awaiter(void 0, void 0, void 0, function () {
|
|
377
|
+
var newFeedback_1, error_5;
|
|
378
|
+
return __generator(this, function (_a) {
|
|
379
|
+
switch (_a.label) {
|
|
380
|
+
case 0:
|
|
381
|
+
if (!chatServiceRef.current || !conversationId) {
|
|
382
|
+
console.error('Cannot add feedback, conversation not ready');
|
|
383
|
+
return [2 /*return*/];
|
|
384
|
+
}
|
|
385
|
+
_a.label = 1;
|
|
386
|
+
case 1:
|
|
387
|
+
_a.trys.push([1, 3, , 4]);
|
|
388
|
+
return [4 /*yield*/, chatServiceRef.current.addFeedback(messageId, value, feedbackMessage)];
|
|
389
|
+
case 2:
|
|
390
|
+
_a.sent();
|
|
391
|
+
newFeedback_1 = {
|
|
392
|
+
feedback: value,
|
|
393
|
+
feedback_message: feedbackMessage,
|
|
394
|
+
feedback_timestamp: new Date().toISOString(),
|
|
395
|
+
};
|
|
396
|
+
setMessages(function (prev) {
|
|
397
|
+
return prev.map(function (m) {
|
|
398
|
+
return m.message_id === messageId
|
|
399
|
+
? __assign(__assign({}, m), { feedback: __spreadArray(__spreadArray([], (m.feedback || []), true), [newFeedback_1], false) }) : m;
|
|
400
|
+
});
|
|
401
|
+
});
|
|
402
|
+
return [3 /*break*/, 4];
|
|
403
|
+
case 3:
|
|
404
|
+
error_5 = _a.sent();
|
|
405
|
+
console.error('Failed to add feedback:', error_5);
|
|
406
|
+
if (onError) {
|
|
407
|
+
onError(error_5);
|
|
408
|
+
}
|
|
409
|
+
return [3 /*break*/, 4];
|
|
410
|
+
case 4: return [2 /*return*/];
|
|
411
|
+
}
|
|
412
|
+
});
|
|
413
|
+
}); }, [conversationId, onError]);
|
|
325
414
|
return {
|
|
326
415
|
messages: messages,
|
|
327
416
|
isLoading: isLoading,
|
|
@@ -335,6 +424,11 @@ export var useChat = function (_a) {
|
|
|
335
424
|
isTakenOver: isTakenOver,
|
|
336
425
|
isFinalized: isFinalized,
|
|
337
426
|
isAgentTyping: isAgentTyping,
|
|
427
|
+
addFeedback: addFeedback,
|
|
428
|
+
welcomeTitle: welcomeTitle,
|
|
429
|
+
welcomeImageUrl: welcomeImageUrl,
|
|
430
|
+
thinkingPhrases: thinkingPhrases,
|
|
431
|
+
thinkingDelayMs: thinkingDelayMs,
|
|
338
432
|
};
|
|
339
433
|
};
|
|
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}; "]}
|
|
434
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"useChat.js","sourceRoot":"","sources":["../../src/hooks/useChat.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAatD,MAAM,CAAC,IAAM,OAAO,GAAG,UAAC,EAAoF;QAAlF,OAAO,aAAA,EAAE,MAAM,YAAA,EAAE,MAAM,YAAA,EAAE,QAAQ,cAAA,EAAE,OAAO,aAAA,EAAE,UAAU,gBAAA,EAAE,UAAU,gBAAA;IACpF,IAAA,KAA0B,QAAQ,CAAgB;QACtD,IAAI,CAAC;YACH,IAAM,cAAc,GAAG,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC5D,OAAO,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,2CAA2C,EAAE,KAAK,CAAC,CAAC;YAClE,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,CAAC,EARK,QAAQ,QAAA,EAAE,WAAW,QAQ1B,CAAC;IACG,IAAA,KAA4B,QAAQ,CAAU,KAAK,CAAC,EAAnD,SAAS,QAAA,EAAE,YAAY,QAA4B,CAAC;IACrD,IAAA,KAAkD,QAAQ,CAAe,EAAE,CAAC,EAA3E,oBAAoB,QAAA,EAAE,uBAAuB,QAA8B,CAAC;IAC7E,IAAA,KAAwC,QAAQ,CAA8C,cAAc,CAAC,EAA5G,eAAe,QAAA,EAAE,kBAAkB,QAAyE,CAAC;IAC9G,IAAA,KAAoC,QAAQ,CAAU,KAAK,CAAC,EAA3D,aAAa,QAAA,EAAE,gBAAgB,QAA4B,CAAC;IACnE,IAAM,cAAc,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAC;IAClD,IAAA,KAAsC,QAAQ,CAAgB,IAAI,CAAC,EAAlE,cAAc,QAAA,EAAE,iBAAiB,QAAiC,CAAC;IACpE,IAAA,KAAwC,QAAQ,CAAW,EAAE,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAkC,QAAQ,CAAgB,IAAI,CAAC,EAA9D,YAAY,QAAA,EAAE,eAAe,QAAiC,CAAC;IAChE,IAAA,KAAwC,QAAQ,CAAgB,IAAI,CAAC,EAApE,eAAe,QAAA,EAAE,kBAAkB,QAAiC,CAAC;IACtE,IAAA,KAAwC,QAAQ,CAAW,EAAE,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAwC,QAAQ,CAAS,IAAI,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAgC,QAAQ,CAAU,KAAK,CAAC,EAAvD,WAAW,QAAA,EAAE,cAAc,QAA4B,CAAC;IACzD,IAAA,KAAgC,QAAQ,CAAU,KAAK,CAAC,EAAvD,WAAW,QAAA,EAAE,cAAc,QAA4B,CAAC;IAE/D,0BAA0B;IAC1B,SAAS,CAAC;;QACR,cAAc,CAAC,OAAO,GAAG,IAAI,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;QAE5E,cAAc,CAAC,OAAO,CAAC,iBAAiB,CAAC,UAAC,OAAoB;YAC5D,IAAM,iBAAiB,yBAClB,OAAO,KACV,WAAW,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;oBAC/D,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;oBAC/B,CAAC,CAAC,OAAO,CAAC,WAAW,GACxB,CAAC;YAEF,WAAW,CAAC,UAAA,YAAY,IAAI,uCAAI,YAAY,UAAE,iBAAiB,WAAnC,CAAoC,CAAC,CAAC;YAClE,6DAA6D;YAC7D,IAAI,iBAAiB,CAAC,OAAO,KAAK,OAAO,IAAI,iBAAiB,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBACrF,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,OAAO,CAAC,kBAAkB,CAAC;YACxC,cAAc,CAAC,IAAI,CAAC,CAAC;YACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,UAAU,EAAE,CAAC;gBACf,UAAU,EAAE,CAAC;YACf,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,OAAO,CAAC,mBAAmB,CAAC;YACzC,cAAc,CAAC,IAAI,CAAC,CAAC;YACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,UAAU,EAAE,CAAC;gBACf,UAAU,EAAE,CAAC;YACf,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,mDAAmD;QACnD,cAAc,CAAC,OAAO,CAAC,yBAAyB,CAAC,UAAC,KAAK;YACrD,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;gBAC1B,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,mDAAmD;QACnD,IAAM,MAAM,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;QAC1D,IAAI,MAAM,EAAE,CAAC;YACT,iBAAiB,CAAC,MAAM,CAAC,CAAC;YAC1B,IAAI,cAAc,CAAC,OAAO,CAAC,uBAAuB,EAAE,EAAE,CAAC;gBACrD,cAAc,CAAC,IAAI,CAAC,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACN,cAAc,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAC5C,CAAC;QACL,CAAC;QACD,2BAA2B;QAC3B,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;YAC3B,IAAM,OAAO,GAAG,CAAA,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,kBAAkB,kDAAI,KAAI,EAAE,CAAC;YACpE,IAAI,OAAO,CAAC,MAAM;gBAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;YAChD,IAAM,OAAO,GAAG,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,cAAc,kDAAI,CAAC;YAC1D,IAAI,OAAO,EAAE,CAAC;gBACZ,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;gBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;YAC/C,CAAC;YACD,IAAM,QAAQ,GAAG,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,iBAAiB,kDAAI,CAAC;YAC9D,IAAI,QAAQ,EAAE,CAAC;gBACb,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;gBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC;QAED,UAAU;QACV,OAAO;YACL,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC3B,cAAc,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;YACtC,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC;IAEjE,SAAS,CAAC;QACR,IAAI,CAAC;YACH,YAAY,CAAC,OAAO,CAAC,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,wCAAwC,EAAE,KAAK,CAAC,CAAC;QACjE,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,qBAAqB;IACrB,IAAM,iBAAiB,GAAG,WAAW,CAAC;;;;;oBACpC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;wBAC5B,sBAAO;oBACT,CAAC;oBAED,kBAAkB,CAAC,YAAY,CAAC,CAAC;oBACjC,YAAY,CAAC,IAAI,CAAC,CAAC;oBACnB,WAAW,CAAC,EAAE,CAAC,CAAC;oBAChB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACvB,eAAe,CAAC,IAAI,CAAC,CAAC;oBACtB,kBAAkB,CAAC,IAAI,CAAC,CAAC;oBACzB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACvB,kBAAkB,CAAC,IAAI,CAAC,CAAC;oBACzB,YAAY,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;oBACxC,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,gBAAgB,CAAC,KAAK,CAAC,CAAC;;;;oBAGtB,6CAA6C;oBAC7C,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;oBAG5B,qBAAM,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAAA;;oBAAzD,MAAM,GAAG,SAAgD;oBAC/D,iBAAiB,CAAC,MAAM,CAAC,CAAC;oBAC1B,kBAAkB,CAAC,WAAW,CAAC,CAAC;oBAEhC,yCAAyC;oBACzC,IAAI,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBACxC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBAC5D,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BAClC,kBAAkB,CAAC,OAAO,CAAC,CAAC;wBAC9B,CAAC;oBACH,CAAC;oBACD,4BAA4B;oBAC5B,IAAI,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACpC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACxD,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;wBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACvC,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBAC5D,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;wBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;;;;oBAED,kBAAkB,CAAC,cAAc,CAAC,CAAC;oBACnC,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;wBACtC,OAAO,CAAC,OAAK,CAAC,CAAC;oBACjB,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,OAAK,CAAC,CAAC;oBACxD,CAAC;;;oBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;SAEvB,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,IAAM,UAAU,GAAG,WAAW,CAAC,UAAO,IAAU;;;;;oBAC9C,IAAI,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAAE,CAAC;wBAC3E,OAAO,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;wBAC5D,sBAAO,IAAI,EAAC;oBACd,CAAC;;;;oBAGqB,qBAAM,cAAc,CAAC,OAAO,CAAC,UAAU,CACzD,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAY,EACpD,IAAI,CACL,EAAA;;oBAHO,OAAO,GAAK,CAAA,SAGnB,CAAA,QAHc;oBAKT,eAAyB;wBAC7B,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,GAAG,EAAE,OAAO;qBACb,CAAC;oBAEF,uBAAuB,CAAC,UAAA,IAAI,IAAI,uCAAI,IAAI,UAAE,YAAU,WAApB,CAAqB,CAAC,CAAC;oBACvD,sBAAO,YAAU,EAAC;;;oBAElB,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,OAAK,CAAC,CAAC;oBAC5C,IAAI,OAAO,EAAE,CAAC;wBACZ,OAAO,CAAC,OAAc,CAAC,CAAC;oBAC1B,CAAC;oBACD,sBAAO,IAAI,EAAC;;;;SAEf,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,eAAe;IACf,IAAM,WAAW,GAAG,WAAW,CAAC;;;;;0FAAO,IAAY,EAAE,KAAkB;;YAAlB,sBAAA,EAAA,UAAkB;;;;wBACrE,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;4BAC5B,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;wBAClD,CAAC;;;;wBAGC,YAAY,CAAC,IAAI,CAAC,CAAC;wBAEb,cAAc,GAAiB,EAAE,CAAC;wBAExC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BACf,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,oBAAoB,CAAC,IAAI,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,EAAxC,CAAwC,CAAC,EAAzE,CAAyE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAiB,CAAC;4BAChJ,cAAc,CAAC,IAAI,OAAnB,cAAc,EAAS,aAAa,EAAE;wBACxC,CAAC;wBAED,yFAAyF;wBACzF,IAAI,CAAC,WAAW,EAAE,CAAC;4BACjB,gBAAgB,CAAC,IAAI,CAAC,CAAC;wBACzB,CAAC;wBACD,qBAAM,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,cAAc,CAAC,EAAA;;wBAA9D,SAA8D,CAAC;wBAE/D,uBAAuB,CAAC,EAAE,CAAC,CAAC;;;;wBAG5B,gBAAgB,CAAC,KAAK,CAAC,CAAC;wBACxB,IAAI,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;4BACtC,OAAO,CAAC,OAAK,CAAC,CAAC;wBACjB,CAAC;6BAAM,CAAC;4BACN,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,OAAK,CAAC,CAAC;wBAClD,CAAC;;;wBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;;KAEvB,EAAE,CAAC,OAAO,EAAE,oBAAoB,EAAE,WAAW,CAAC,CAAC,CAAC;IAEjD,IAAM,iBAAiB,GAAG,WAAW,CAAC;;;;;oBACpC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;wBAC5B,sBAAO;oBACT,CAAC;;;;oBAEC,kBAAkB,CAAC,YAAY,CAAC,CAAC;oBACjC,YAAY,CAAC,IAAI,CAAC,CAAC;oBAEnB,mCAAmC;oBACnC,WAAW,CAAC,EAAE,CAAC,CAAC;oBAChB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACvB,YAAY,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;oBACxC,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;oBAE5B,qBAAM,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAAA;;oBAAzD,MAAM,GAAG,SAAgD;oBAC/D,iBAAiB,CAAC,MAAM,CAAC,CAAC;oBAC1B,kBAAkB,CAAC,WAAW,CAAC,CAAC;oBAEhC,IAAI,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBACxC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBAC5D,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BAClC,kBAAkB,CAAC,OAAO,CAAC,CAAC;wBAC9B,CAAC;oBACH,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACpC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACxD,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;wBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACvC,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBAC5D,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;wBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;;;;oBAED,kBAAkB,CAAC,cAAc,CAAC,CAAC;oBACnC,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;wBACtC,OAAO,CAAC,OAAK,CAAC,CAAC;oBACjB,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,OAAK,CAAC,CAAC;oBACxD,CAAC;;;oBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;SAEvB,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,mCAAmC;IACnC,IAAM,WAAW,GAAG,WAAW,CAC7B,UAAO,SAAiB,EAAE,KAAqB,EAAE,eAAwB;;;;;oBACvE,IAAI,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC;wBAC/C,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;wBAC7D,sBAAO;oBACT,CAAC;;;;oBAEC,qBAAM,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,KAAK,EAAE,eAAe,CAAC,EAAA;;oBAA3E,SAA2E,CAAC;oBAEtE,gBAA+B;wBACnC,QAAQ,EAAE,KAAK;wBACf,gBAAgB,EAAE,eAAe;wBACjC,kBAAkB,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;qBAC7C,CAAC;oBAEF,WAAW,CAAC,UAAA,IAAI;wBACd,OAAA,IAAI,CAAC,GAAG,CAAC,UAAA,CAAC;4BACR,OAAA,CAAC,CAAC,UAAU,KAAK,SAAS;gCACxB,CAAC,uBAAM,CAAC,KAAE,QAAQ,kCAAM,CAAC,CAAC,CAAC,QAAQ,IAAI,EAAE,CAAC,UAAE,aAAW,aACvD,CAAC,CAAC,CAAC;wBAFL,CAEK,CACN;oBAJD,CAIC,CACF,CAAC;;;;oBAEF,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,OAAK,CAAC,CAAC;oBAChD,IAAI,OAAO,EAAE,CAAC;wBACZ,OAAO,CAAC,OAAc,CAAC,CAAC;oBAC1B,CAAC;;;;;SAEJ,EACD,CAAC,cAAc,EAAE,OAAO,CAAC,CAC1B,CAAC;IAEF,OAAO;QACL,QAAQ,UAAA;QACR,SAAS,WAAA;QACT,WAAW,aAAA;QACX,UAAU,YAAA;QACV,iBAAiB,mBAAA;QACjB,iBAAiB,mBAAA;QACjB,eAAe,iBAAA;QACf,cAAc,gBAAA;QACd,eAAe,iBAAA;QACf,WAAW,aAAA;QACX,WAAW,aAAA;QACX,aAAa,eAAA;QACb,WAAW,aAAA;QACX,YAAY,cAAA;QACZ,eAAe,iBAAA;QACf,eAAe,iBAAA;QACf,eAAe,iBAAA;KAChB,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { useState, useEffect, useCallback, useRef } from 'react';\nimport { ChatService } from '../services/chatService';\nimport { ChatMessage, Attachment, MessageFeedback } from '../types';\n\nexport interface UseChatProps {\n  baseUrl: string;\n  apiKey: string;\n  tenant?: string | undefined;\n  metadata?: Record<string, any>;\n  onError?: (error: Error) => void;\n  onTakeover?: () => void;\n  onFinalize?: () => void;\n}\n\nexport const useChat = ({ baseUrl, apiKey, tenant, 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 [welcomeTitle, setWelcomeTitle] = useState<string | null>(null);\n  const [welcomeImageUrl, setWelcomeImageUrl] = useState<string | null>(null);\n  const [thinkingPhrases, setThinkingPhrases] = useState<string[]>([]);\n  const [thinkingDelayMs, setThinkingDelayMs] = useState<number>(1000);\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, tenant);\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    // Pull initial static data\n    if (chatServiceRef.current) {\n      const queries = chatServiceRef.current.getPossibleQueries?.() || [];\n      if (queries.length) setPossibleQueries(queries);\n      const welcome = chatServiceRef.current.getWelcomeData?.();\n      if (welcome) {\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n      }\n      const thinking = chatServiceRef.current.getThinkingConfig?.();\n      if (thinking) {\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\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    setWelcomeTitle(null);\n    setWelcomeImageUrl(null);\n    setThinkingPhrases([]);\n    setThinkingDelayMs(1000);\n    localStorage.removeItem('chatMessages');\n    setIsFinalized(false);\n    setIsTakenOver(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      // welcome and thinking data\n      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\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, unless conversation is taken over by a human\n      if (!isTakenOver) {\n        setIsAgentTyping(true);\n      }\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, isTakenOver]);\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      setIsTakenOver(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      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\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  // Add feedback to an agent message\n  const addFeedback = useCallback(\n    async (messageId: string, value: 'good' | 'bad', feedbackMessage?: string) => {\n      if (!chatServiceRef.current || !conversationId) {\n        console.error('Cannot add feedback, conversation not ready');\n        return;\n      }\n      try {\n        await chatServiceRef.current.addFeedback(messageId, value, feedbackMessage);\n\n        const newFeedback: MessageFeedback = {\n          feedback: value,\n          feedback_message: feedbackMessage,\n          feedback_timestamp: new Date().toISOString(),\n        };\n\n        setMessages(prev =>\n          prev.map(m =>\n            m.message_id === messageId\n              ? { ...m, feedback: [...(m.feedback || []), newFeedback] }\n              : m\n          )\n        );\n      } catch (error) {\n        console.error('Failed to add feedback:', error);\n        if (onError) {\n          onError(error as Error);\n        }\n      }\n    },\n    [conversationId, onError]\n  );\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    addFeedback,\n    welcomeTitle,\n    welcomeImageUrl,\n    thinkingPhrases,\n    thinkingDelayMs,\n  };\n};"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChatMessage, Attachment } from
|
|
1
|
+
import { ChatMessage, Attachment, AgentThinkingConfig, AgentWelcomeData } from "../types";
|
|
2
2
|
export declare class ChatService {
|
|
3
3
|
private baseUrl;
|
|
4
4
|
private apiKey;
|
|
@@ -13,12 +13,18 @@ export declare class ChatService {
|
|
|
13
13
|
private connectionStateHandler;
|
|
14
14
|
private storageKey;
|
|
15
15
|
private possibleQueries;
|
|
16
|
-
|
|
16
|
+
private welcomeData;
|
|
17
|
+
private thinkingConfig;
|
|
18
|
+
private welcomeObjectUrl;
|
|
19
|
+
private tenant;
|
|
20
|
+
constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>, tenant?: string);
|
|
17
21
|
setMessageHandler(handler: (message: ChatMessage) => void): void;
|
|
18
22
|
setTakeoverHandler(handler: () => void): void;
|
|
19
23
|
setFinalizedHandler(handler: () => void): void;
|
|
20
|
-
setConnectionStateHandler(handler: (state:
|
|
24
|
+
setConnectionStateHandler(handler: (state: "connecting" | "connected" | "disconnected") => void): void;
|
|
21
25
|
getPossibleQueries(): string[];
|
|
26
|
+
getWelcomeData(): AgentWelcomeData;
|
|
27
|
+
getThinkingConfig(): AgentThinkingConfig;
|
|
22
28
|
/**
|
|
23
29
|
* Load a saved conversation ID from localStorage
|
|
24
30
|
*/
|
|
@@ -47,5 +53,6 @@ export declare class ChatService {
|
|
|
47
53
|
}>;
|
|
48
54
|
connectWebSocket(): void;
|
|
49
55
|
disconnect(): void;
|
|
56
|
+
addFeedback(messageId: string, feedback: "good" | "bad", feedback_message?: string): Promise<void>;
|
|
50
57
|
private adjustMessageTimestamps;
|
|
51
58
|
}
|