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.
@@ -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: 20, color: "#757575", style: {
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: 20, color: isRecording ? '#ff0000' : '#757575' });
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: '#ffffff',
32
- color: isRecording ? '#ff0000' : '#757575',
33
+ backgroundColor: isRecording ? activeBg : idleBg,
34
+ color: '#ffffff',
33
35
  border: 'none',
34
- borderRadius: '8px',
35
- width: '48px',
36
- height: '48px',
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.05)',
45
- opacity: isLoading ? 0.7 : 1,
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFjdkQsTUFBTSxDQUFDLElBQU0sVUFBVSxHQUE4QixVQUFDLEVBTXJEO1FBTEMsZUFBZSxxQkFBQSxFQUNmLE9BQU8sYUFBQSxFQUNQLE9BQU8sYUFBQSxFQUNQLE1BQU0sWUFBQSxFQUNOLEtBQUssV0FBQTtJQUVDLElBQUEsS0FBOEMsYUFBYSxDQUFDO1FBQ2hFLE9BQU8sU0FBQTtRQUNQLE1BQU0sUUFBQTtRQUNOLGVBQWUsaUJBQUE7UUFDZixPQUFPLFNBQUE7S0FDUixDQUFDLEVBTE0sV0FBVyxpQkFBQSxFQUFFLFNBQVMsZUFBQSxFQUFFLGVBQWUscUJBSzdDLENBQUM7SUFFSCxJQUFNLFdBQVcsR0FBRyxVQUFDLENBQW1CO1FBQ3RDLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNuQixDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDcEIsZUFBZSxFQUFFLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsSUFBTSxnQkFBZ0IsR0FBRztRQUN2QixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxDQUNMLEtBQUMsT0FBTyxJQUNOLElBQUksRUFBRSxFQUFFLEVBQ1IsS0FBSyxFQUFDLFNBQVMsRUFDZixLQUFLLEVBQUU7b0JBQ0wsU0FBUyxFQUFFLHlCQUF5QjtpQkFDckMsR0FDRCxDQUNILENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxLQUFDLEdBQUcsSUFBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUyxHQUFJLENBQUM7SUFDdkUsQ0FBQyxDQUFDO0lBRUYsSUFBTSxRQUFRLEdBQUc7UUFDZixJQUFJLFNBQVM7WUFBRSxPQUFPLGVBQWUsQ0FBQztRQUN0QyxPQUFPLFdBQVcsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDO0lBQzVELENBQUMsQ0FBQztJQUVGLElBQU0sV0FBVyxHQUF3QjtRQUN2QyxlQUFlLEVBQUUsU0FBUztRQUMxQixLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVM7UUFDMUMsTUFBTSxFQUFFLE1BQU07UUFDZCxZQUFZLEVBQUUsS0FBSztRQUNuQixLQUFLLEVBQUUsTUFBTTtRQUNiLE1BQU0sRUFBRSxNQUFNO1FBQ2QsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsUUFBUTtRQUNwQixjQUFjLEVBQUUsUUFBUTtRQUN4QixNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLFNBQVM7UUFDN0MsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsZUFBZTtRQUMzQixVQUFVLEVBQUUsQ0FBQztRQUNiLFNBQVMsRUFBRSwrQkFBK0I7UUFDMUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzdCLENBQUM7SUFFRixxQ0FBcUM7SUFDckMsSUFBTSxhQUFhLEdBQUcsc0pBU3JCLENBQUM7SUFFRixPQUFPLENBQ0wsOEJBQ0UsMEJBQVEsYUFBYSxHQUFTLEVBQzlCLGlCQUNFLElBQUksRUFBQyxRQUFRLEVBQ2IsS0FBSyxFQUFFLFdBQVcsRUFDbEIsT0FBTyxFQUFFLFdBQVcsRUFDcEIsS0FBSyxFQUFFLFFBQVEsRUFBRSxFQUNqQixRQUFRLEVBQUUsU0FBUyxZQUVsQixnQkFBZ0IsRUFBRSxHQUNaLElBQ1IsQ0FDSixDQUFDO0FBQ0osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IE1pYywgTG9hZGVyMiB9IGZyb20gJ2x1Y2lkZS1yZWFjdCc7XG5pbXBvcnQgeyB1c2VWb2ljZUlucHV0IH0gZnJvbSAnLi4vaG9va3MvdXNlVm9pY2VJbnB1dCc7XG5cbmludGVyZmFjZSBWb2ljZUlucHV0UHJvcHMge1xuICBvblRyYW5zY3JpcHRpb246ICh0ZXh0OiBzdHJpbmcpID0+IHZvaWQ7XG4gIG9uRXJyb3I6IChlcnJvcjogRXJyb3IpID0+IHZvaWQ7XG4gIGJhc2VVcmw6IHN0cmluZztcbiAgYXBpS2V5OiBzdHJpbmc7XG4gIHRoZW1lPzoge1xuICAgIHByaW1hcnlDb2xvcj86IHN0cmluZztcbiAgICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gICAgZm9udEZhbWlseT86IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IGNvbnN0IFZvaWNlSW5wdXQ6IFJlYWN0LkZDPFZvaWNlSW5wdXRQcm9wcz4gPSAoe1xuICBvblRyYW5zY3JpcHRpb24sXG4gIG9uRXJyb3IsXG4gIGJhc2VVcmwsXG4gIGFwaUtleSxcbiAgdGhlbWVcbn0pID0+IHtcbiAgY29uc3QgeyBpc1JlY29yZGluZywgaXNMb2FkaW5nLCB0b2dnbGVSZWNvcmRpbmcgfSA9IHVzZVZvaWNlSW5wdXQoe1xuICAgIGJhc2VVcmwsXG4gICAgYXBpS2V5LFxuICAgIG9uVHJhbnNjcmlwdGlvbixcbiAgICBvbkVycm9yLFxuICB9KTtcblxuICBjb25zdCBoYW5kbGVDbGljayA9IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgdG9nZ2xlUmVjb3JkaW5nKCk7XG4gIH07XG5cbiAgY29uc3QgZ2V0QnV0dG9uQ29udGVudCA9ICgpID0+IHtcbiAgICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8TG9hZGVyMiBcbiAgICAgICAgICBzaXplPXsyMH0gXG4gICAgICAgICAgY29sb3I9XCIjNzU3NTc1XCIgXG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGFuaW1hdGlvbjogJ3NwaW4gMXMgbGluZWFyIGluZmluaXRlJyxcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIDxNaWMgc2l6ZT17MjB9IGNvbG9yPXtpc1JlY29yZGluZyA/ICcjZmYwMDAwJyA6ICcjNzU3NTc1J30gLz47XG4gIH07XG5cbiAgY29uc3QgZ2V0VGl0bGUgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykgcmV0dXJuICdDb25uZWN0aW5nLi4uJztcbiAgICByZXR1cm4gaXNSZWNvcmRpbmcgPyAnU3RvcCBSZWNvcmRpbmcnIDogJ1N0YXJ0IFJlY29yZGluZyc7XG4gIH07XG5cbiAgY29uc3QgYnV0dG9uU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2ZmZmZmZicsXG4gICAgY29sb3I6IGlzUmVjb3JkaW5nID8gJyNmZjAwMDAnIDogJyM3NTc1NzUnLFxuICAgIGJvcmRlcjogJ25vbmUnLFxuICAgIGJvcmRlclJhZGl1czogJzhweCcsXG4gICAgd2lkdGg6ICc0OHB4JyxcbiAgICBoZWlnaHQ6ICc0OHB4JyxcbiAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgIGN1cnNvcjogaXNMb2FkaW5nID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyxcbiAgICBvdXRsaW5lOiAnbm9uZScsXG4gICAgdHJhbnNpdGlvbjogJ2FsbCAwLjJzIGVhc2UnLFxuICAgIGZsZXhTaHJpbms6IDAsXG4gICAgYm94U2hhZG93OiAnMCAxcHggM3B4IHJnYmEoMCwgMCwgMCwgMC4wNSknLFxuICAgIG9wYWNpdHk6IGlzTG9hZGluZyA/IDAuNyA6IDEsXG4gIH07XG5cbiAgLy8gS2V5ZnJhbWUgYW5pbWF0aW9uIGZvciB0aGUgc3Bpbm5lclxuICBjb25zdCBzcGluS2V5ZnJhbWVzID0gYFxuICAgIEBrZXlmcmFtZXMgc3BpbiB7XG4gICAgICBmcm9tIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG4gICAgICB9XG4gICAgICB0byB7XG4gICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG4gICAgICB9XG4gICAgfVxuICBgO1xuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxzdHlsZT57c3BpbktleWZyYW1lc308L3N0eWxlPlxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgc3R5bGU9e2J1dHRvblN0eWxlfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbGlja31cbiAgICAgICAgdGl0bGU9e2dldFRpdGxlKCl9XG4gICAgICAgIGRpc2FibGVkPXtpc0xvYWRpbmd9XG4gICAgICA+XG4gICAgICAgIHtnZXRCdXR0b25Db250ZW50KCl9XG4gICAgICA8L2J1dHRvbj5cbiAgICA8Lz5cbiAgKTtcbn07ICJdfQ==
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFjdkQsTUFBTSxDQUFDLElBQU0sVUFBVSxHQUE4QixVQUFDLEVBTXJEO1FBTEMsZUFBZSxxQkFBQSxFQUNmLE9BQU8sYUFBQSxFQUNQLE9BQU8sYUFBQSxFQUNQLE1BQU0sWUFBQSxFQUNOLEtBQUssV0FBQTtJQUVDLElBQUEsS0FBOEMsYUFBYSxDQUFDO1FBQ2hFLE9BQU8sU0FBQTtRQUNQLE1BQU0sUUFBQTtRQUNOLGVBQWUsaUJBQUE7UUFDZixPQUFPLFNBQUE7S0FDUixDQUFDLEVBTE0sV0FBVyxpQkFBQSxFQUFFLFNBQVMsZUFBQSxFQUFFLGVBQWUscUJBSzdDLENBQUM7SUFFSCxJQUFNLFdBQVcsR0FBRyxVQUFDLENBQW1CO1FBQ3RDLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNuQixDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDcEIsZUFBZSxFQUFFLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsSUFBTSxnQkFBZ0IsR0FBRztRQUN2QixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxDQUNMLEtBQUMsT0FBTyxJQUNOLElBQUksRUFBRSxFQUFFLEVBQ1IsS0FBSyxFQUFDLFNBQVMsRUFDZixLQUFLLEVBQUU7b0JBQ0wsU0FBUyxFQUFFLHlCQUF5QjtpQkFDckMsR0FDRCxDQUNILENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxLQUFDLEdBQUcsSUFBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBQyxTQUFTLEdBQUcsQ0FBQztJQUMzQyxDQUFDLENBQUM7SUFFRixJQUFNLFFBQVEsR0FBRztRQUNmLElBQUksU0FBUztZQUFFLE9BQU8sZUFBZSxDQUFDO1FBQ3RDLE9BQU8sV0FBVyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsaUJBQWlCLENBQUM7SUFDNUQsQ0FBQyxDQUFDO0lBRUYsSUFBTSxNQUFNLEdBQUcsQ0FBQSxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsWUFBWSxLQUFJLFNBQVMsQ0FBQztJQUNoRCxJQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsQ0FBQyxxQkFBcUI7SUFDakQsSUFBTSxXQUFXLEdBQXdCO1FBQ3ZDLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTTtRQUNoRCxLQUFLLEVBQUUsU0FBUztRQUNoQixNQUFNLEVBQUUsTUFBTTtRQUNkLFlBQVksRUFBRSxLQUFLO1FBQ25CLEtBQUssRUFBRSxNQUFNO1FBQ2IsTUFBTSxFQUFFLE1BQU07UUFDZCxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLGNBQWMsRUFBRSxRQUFRO1FBQ3hCLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUM3QyxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxlQUFlO1FBQzNCLFVBQVUsRUFBRSxDQUFDO1FBQ2IsU0FBUyxFQUFFLCtCQUErQjtRQUMxQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDN0IsQ0FBQztJQUVGLHFDQUFxQztJQUNyQyxJQUFNLGFBQWEsR0FBRyxzSkFTckIsQ0FBQztJQUVGLE9BQU8sQ0FDTCw4QkFDRSwwQkFBUSxhQUFhLEdBQVMsRUFDOUIsaUJBQ0UsSUFBSSxFQUFDLFFBQVEsRUFDYixLQUFLLEVBQUUsV0FBVyxFQUNsQixPQUFPLEVBQUUsV0FBVyxFQUNwQixLQUFLLEVBQUUsUUFBUSxFQUFFLEVBQ2pCLFFBQVEsRUFBRSxTQUFTLFlBRWxCLGdCQUFnQixFQUFFLEdBQ1osSUFDUixDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWljLCBMb2FkZXIyIH0gZnJvbSAnbHVjaWRlLXJlYWN0JztcbmltcG9ydCB7IHVzZVZvaWNlSW5wdXQgfSBmcm9tICcuLi9ob29rcy91c2VWb2ljZUlucHV0JztcblxuaW50ZXJmYWNlIFZvaWNlSW5wdXRQcm9wcyB7XG4gIG9uVHJhbnNjcmlwdGlvbjogKHRleHQ6IHN0cmluZykgPT4gdm9pZDtcbiAgb25FcnJvcjogKGVycm9yOiBFcnJvcikgPT4gdm9pZDtcbiAgYmFzZVVybDogc3RyaW5nO1xuICBhcGlLZXk6IHN0cmluZztcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgICBmb250RmFtaWx5Pzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgVm9pY2VJbnB1dDogUmVhY3QuRkM8Vm9pY2VJbnB1dFByb3BzPiA9ICh7XG4gIG9uVHJhbnNjcmlwdGlvbixcbiAgb25FcnJvcixcbiAgYmFzZVVybCxcbiAgYXBpS2V5LFxuICB0aGVtZVxufSkgPT4ge1xuICBjb25zdCB7IGlzUmVjb3JkaW5nLCBpc0xvYWRpbmcsIHRvZ2dsZVJlY29yZGluZyB9ID0gdXNlVm9pY2VJbnB1dCh7XG4gICAgYmFzZVVybCxcbiAgICBhcGlLZXksXG4gICAgb25UcmFuc2NyaXB0aW9uLFxuICAgIG9uRXJyb3IsXG4gIH0pO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrID0gKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0b2dnbGVSZWNvcmRpbmcoKTtcbiAgfTtcblxuICBjb25zdCBnZXRCdXR0b25Db250ZW50ID0gKCkgPT4ge1xuICAgIGlmIChpc0xvYWRpbmcpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxMb2FkZXIyIFxuICAgICAgICAgIHNpemU9ezE4fSBcbiAgICAgICAgICBjb2xvcj1cIiNmZmZmZmZcIiBcbiAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgYW5pbWF0aW9uOiAnc3BpbiAxcyBsaW5lYXIgaW5maW5pdGUnLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gPE1pYyBzaXplPXsxOH0gY29sb3I9XCIjZmZmZmZmXCIgLz47XG4gIH07XG5cbiAgY29uc3QgZ2V0VGl0bGUgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykgcmV0dXJuICdDb25uZWN0aW5nLi4uJztcbiAgICByZXR1cm4gaXNSZWNvcmRpbmcgPyAnU3RvcCBSZWNvcmRpbmcnIDogJ1N0YXJ0IFJlY29yZGluZyc7XG4gIH07XG5cbiAgY29uc3QgaWRsZUJnID0gdGhlbWU/LnByaW1hcnlDb2xvciB8fCAnIzI5NjJGRic7XG4gIGNvbnN0IGFjdGl2ZUJnID0gJyNGRjNCMzAnOyAvLyByZWQgd2hlbiByZWNvcmRpbmdcbiAgY29uc3QgYnV0dG9uU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgYmFja2dyb3VuZENvbG9yOiBpc1JlY29yZGluZyA/IGFjdGl2ZUJnIDogaWRsZUJnLFxuICAgIGNvbG9yOiAnI2ZmZmZmZicsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNTAlJyxcbiAgICB3aWR0aDogJzM2cHgnLFxuICAgIGhlaWdodDogJzM2cHgnLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgY3Vyc29yOiBpc0xvYWRpbmcgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInLFxuICAgIG91dGxpbmU6ICdub25lJyxcbiAgICB0cmFuc2l0aW9uOiAnYWxsIDAuMnMgZWFzZScsXG4gICAgZmxleFNocmluazogMCxcbiAgICBib3hTaGFkb3c6ICcwIDFweCAzcHggcmdiYSgwLCAwLCAwLCAwLjA4KScsXG4gICAgb3BhY2l0eTogaXNMb2FkaW5nID8gMC45IDogMSxcbiAgfTtcblxuICAvLyBLZXlmcmFtZSBhbmltYXRpb24gZm9yIHRoZSBzcGlubmVyXG4gIGNvbnN0IHNwaW5LZXlmcmFtZXMgPSBgXG4gICAgQGtleWZyYW1lcyBzcGluIHtcbiAgICAgIGZyb20ge1xuICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICAgIH1cbiAgICAgIHRvIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTtcbiAgICAgIH1cbiAgICB9XG4gIGA7XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPHN0eWxlPntzcGluS2V5ZnJhbWVzfTwvc3R5bGU+XG4gICAgICA8YnV0dG9uXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICBzdHlsZT17YnV0dG9uU3R5bGV9XG4gICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrfVxuICAgICAgICB0aXRsZT17Z2V0VGl0bGUoKX1cbiAgICAgICAgZGlzYWJsZWQ9e2lzTG9hZGluZ31cbiAgICAgID5cbiAgICAgICAge2dldEJ1dHRvbkNvbnRlbnQoKX1cbiAgICAgIDwvYnV0dG9uPlxuICAgIDwvPlxuICApO1xufTsgXG4iXX0=
@@ -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
  };
@@ -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(false), isTakenOver = _j[0], setIsTakenOver = _j[1];
79
- var _k = useState(false), isFinalized = _k[0], setIsFinalized = _k[1];
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
- chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata);
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
- setIsAgentTyping(true);
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":"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","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 '../types';
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
- constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>);
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: 'connecting' | 'connected' | 'disconnected') => void): void;
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
  }