genassist-chat-react 1.0.16 → 1.0.18

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.
@@ -34,6 +34,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
34
34
  if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
35
  }
36
36
  };
37
+ import { createWebSocket } from '../utils/websocket';
37
38
  var AudioService = /** @class */ (function () {
38
39
  function AudioService(config) {
39
40
  this.ws = null;
@@ -52,9 +53,9 @@ var AudioService = /** @class */ (function () {
52
53
  _this.resolvePromise = resolve;
53
54
  _this.rejectPromise = reject;
54
55
  _this.audioChunks = [];
55
- // Create WebSocket connection
56
+ // Create WebSocket connection using browser-native WebSocket
56
57
  var wsUrl = "".concat(_this.baseUrl.replace('http', 'ws'), "/api/voice/audio/tts?api_key=").concat(_this.apiKey);
57
- _this.ws = new WebSocket(wsUrl);
58
+ _this.ws = createWebSocket(wsUrl);
58
59
  _this.ws.onopen = function () {
59
60
  var _a;
60
61
  (_a = _this.ws) === null || _a === void 0 ? void 0 : _a.send(JSON.stringify({ text: text }));
@@ -115,4 +116,4 @@ var AudioService = /** @class */ (function () {
115
116
  return AudioService;
116
117
  }());
117
118
  export { AudioService };
118
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW9TZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZpY2VzL2F1ZGlvU2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFPQTtJQVFFLHNCQUFZLE1BQTBCO1FBTDlCLE9BQUUsR0FBcUIsSUFBSSxDQUFDO1FBQzVCLGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBQ3pCLG1CQUFjLEdBQW1DLElBQUksQ0FBQztRQUN0RCxrQkFBYSxHQUFvQyxJQUFJLENBQUM7UUFHNUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO1FBQzlCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztJQUM5QixDQUFDO0lBRUssbUNBQVksR0FBbEI7NERBQW1CLElBQVksRUFBRSxLQUF1Qjs7WUFBdkIsc0JBQUEsRUFBQSxlQUF1Qjs7Z0JBQ3RELHNCQUFPLElBQUksT0FBTyxDQUFDLFVBQUMsT0FBTyxFQUFFLE1BQU07d0JBQ2pDLEtBQUksQ0FBQyxjQUFjLEdBQUcsT0FBTyxDQUFDO3dCQUM5QixLQUFJLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FBQzt3QkFDNUIsS0FBSSxDQUFDLFdBQVcsR0FBRyxFQUFFLENBQUM7d0JBRXRCLDhCQUE4Qjt3QkFDOUIsSUFBTSxLQUFLLEdBQUcsVUFBRyxLQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLDBDQUFnQyxLQUFJLENBQUMsTUFBTSxDQUFFLENBQUM7d0JBQ2pHLEtBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7d0JBRS9CLEtBQUksQ0FBQyxFQUFFLENBQUMsTUFBTSxHQUFHOzs0QkFDZixNQUFBLEtBQUksQ0FBQyxFQUFFLDBDQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsSUFBSSxNQUFBLEVBQUUsQ0FBQyxDQUFDLENBQUM7d0JBQzFDLENBQUMsQ0FBQzt3QkFFRixLQUFJLENBQUMsRUFBRSxDQUFDLFNBQVMsR0FBRyxVQUFDLEtBQUs7NEJBQ3hCLElBQUksS0FBSyxDQUFDLElBQUksWUFBWSxJQUFJLEVBQUUsQ0FBQztnQ0FDL0IsS0FBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDOzRCQUNwQyxDQUFDO3dCQUNILENBQUMsQ0FBQzt3QkFFRixLQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sR0FBRzs7NEJBQ2hCLElBQUksS0FBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7Z0NBQ2hDLElBQU0sU0FBUyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztnQ0FDcEUsTUFBQSxLQUFJLENBQUMsY0FBYyxzREFBRyxTQUFTLENBQUMsQ0FBQzs0QkFDbkMsQ0FBQztpQ0FBTSxDQUFDO2dDQUNOLE1BQUEsS0FBSSxDQUFDLGFBQWEsc0RBQUcsSUFBSSxLQUFLLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDOzRCQUM1RCxDQUFDOzRCQUNELEtBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQzt3QkFDakIsQ0FBQyxDQUFDO3dCQUVGLEtBQUksQ0FBQyxFQUFFLENBQUMsT0FBTyxHQUFHLFVBQUMsS0FBSzs7NEJBQ3RCLE1BQUEsS0FBSSxDQUFDLGFBQWEsc0RBQUcsS0FBSyxDQUFDLENBQUM7NEJBQzVCLEtBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQzt3QkFDakIsQ0FBQyxDQUFDO29CQUNKLENBQUMsQ0FBQyxFQUFDOzs7S0FDSjtJQUVPLDhCQUFPLEdBQWY7UUFDRSxJQUFJLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNaLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDaEIsSUFBSSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDakIsQ0FBQztRQUNELElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQzNCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFSyxnQ0FBUyxHQUFmLFVBQWdCLFNBQWU7Ozs7Z0JBQ3ZCLFFBQVEsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUMxQyxLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBRWxDLHNCQUFPLElBQUksT0FBTyxDQUFDLFVBQUMsT0FBTyxFQUFFLE1BQU07d0JBQ2pDLEtBQUssQ0FBQyxPQUFPLEdBQUc7NEJBQ2QsR0FBRyxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQzs0QkFDOUIsT0FBTyxFQUFFLENBQUM7d0JBQ1osQ0FBQyxDQUFDO3dCQUVGLEtBQUssQ0FBQyxPQUFPLEdBQUcsVUFBQyxLQUFLOzRCQUNwQixHQUFHLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDOzRCQUM5QixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7d0JBQ2hCLENBQUMsQ0FBQzt3QkFFRixLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO29CQUM3QixDQUFDLENBQUMsRUFBQzs7O0tBQ0o7SUFDSCxtQkFBQztBQUFELENBQUMsQUE3RUQsSUE2RUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXhpb3MgZnJvbSAnYXhpb3MnO1xuXG5pbnRlcmZhY2UgQXVkaW9TZXJ2aWNlQ29uZmlnIHtcbiAgYmFzZVVybDogc3RyaW5nO1xuICBhcGlLZXk6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIEF1ZGlvU2VydmljZSB7XG4gIHByaXZhdGUgYmFzZVVybDogc3RyaW5nO1xuICBwcml2YXRlIGFwaUtleTogc3RyaW5nO1xuICBwcml2YXRlIHdzOiBXZWJTb2NrZXQgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBhdWRpb0NodW5rczogQmxvYltdID0gW107XG4gIHByaXZhdGUgcmVzb2x2ZVByb21pc2U6ICgodmFsdWU6IEJsb2IpID0+IHZvaWQpIHwgbnVsbCA9IG51bGw7XG4gIHByaXZhdGUgcmVqZWN0UHJvbWlzZTogKChyZWFzb24/OiBhbnkpID0+IHZvaWQpIHwgbnVsbCA9IG51bGw7XG5cbiAgY29uc3RydWN0b3IoY29uZmlnOiBBdWRpb1NlcnZpY2VDb25maWcpIHtcbiAgICB0aGlzLmJhc2VVcmwgPSBjb25maWcuYmFzZVVybDtcbiAgICB0aGlzLmFwaUtleSA9IGNvbmZpZy5hcGlLZXk7XG4gIH1cblxuICBhc3luYyB0ZXh0VG9TcGVlY2godGV4dDogc3RyaW5nLCB2b2ljZTogc3RyaW5nID0gJ2FsbG95Jyk6IFByb21pc2U8QmxvYj4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICB0aGlzLnJlc29sdmVQcm9taXNlID0gcmVzb2x2ZTtcbiAgICAgIHRoaXMucmVqZWN0UHJvbWlzZSA9IHJlamVjdDtcbiAgICAgIHRoaXMuYXVkaW9DaHVua3MgPSBbXTtcblxuICAgICAgLy8gQ3JlYXRlIFdlYlNvY2tldCBjb25uZWN0aW9uXG4gICAgICBjb25zdCB3c1VybCA9IGAke3RoaXMuYmFzZVVybC5yZXBsYWNlKCdodHRwJywgJ3dzJyl9L2FwaS92b2ljZS9hdWRpby90dHM/YXBpX2tleT0ke3RoaXMuYXBpS2V5fWA7XG4gICAgICB0aGlzLndzID0gbmV3IFdlYlNvY2tldCh3c1VybCk7XG5cbiAgICAgIHRoaXMud3Mub25vcGVuID0gKCkgPT4ge1xuICAgICAgICB0aGlzLndzPy5zZW5kKEpTT04uc3RyaW5naWZ5KHsgdGV4dCB9KSk7XG4gICAgICB9O1xuXG4gICAgICB0aGlzLndzLm9ubWVzc2FnZSA9IChldmVudCkgPT4ge1xuICAgICAgICBpZiAoZXZlbnQuZGF0YSBpbnN0YW5jZW9mIEJsb2IpIHtcbiAgICAgICAgICB0aGlzLmF1ZGlvQ2h1bmtzLnB1c2goZXZlbnQuZGF0YSk7XG4gICAgICAgIH1cbiAgICAgIH07XG5cbiAgICAgIHRoaXMud3Mub25jbG9zZSA9ICgpID0+IHtcbiAgICAgICAgaWYgKHRoaXMuYXVkaW9DaHVua3MubGVuZ3RoID4gMCkge1xuICAgICAgICAgIGNvbnN0IGF1ZGlvQmxvYiA9IG5ldyBCbG9iKHRoaXMuYXVkaW9DaHVua3MsIHsgdHlwZTogJ2F1ZGlvL21wMycgfSk7XG4gICAgICAgICAgdGhpcy5yZXNvbHZlUHJvbWlzZT8uKGF1ZGlvQmxvYik7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhpcy5yZWplY3RQcm9taXNlPy4obmV3IEVycm9yKCdObyBhdWRpbyBkYXRhIHJlY2VpdmVkJykpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuY2xlYW51cCgpO1xuICAgICAgfTtcblxuICAgICAgdGhpcy53cy5vbmVycm9yID0gKGVycm9yKSA9PiB7XG4gICAgICAgIHRoaXMucmVqZWN0UHJvbWlzZT8uKGVycm9yKTtcbiAgICAgICAgdGhpcy5jbGVhbnVwKCk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBjbGVhbnVwKCkge1xuICAgIGlmICh0aGlzLndzKSB7XG4gICAgICB0aGlzLndzLmNsb3NlKCk7XG4gICAgICB0aGlzLndzID0gbnVsbDtcbiAgICB9XG4gICAgdGhpcy5yZXNvbHZlUHJvbWlzZSA9IG51bGw7XG4gICAgdGhpcy5yZWplY3RQcm9taXNlID0gbnVsbDtcbiAgfVxuXG4gIGFzeW5jIHBsYXlBdWRpbyhhdWRpb0Jsb2I6IEJsb2IpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBhdWRpb1VybCA9IFVSTC5jcmVhdGVPYmplY3RVUkwoYXVkaW9CbG9iKTtcbiAgICBjb25zdCBhdWRpbyA9IG5ldyBBdWRpbyhhdWRpb1VybCk7XG4gICAgXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGF1ZGlvLm9uZW5kZWQgPSAoKSA9PiB7XG4gICAgICAgIFVSTC5yZXZva2VPYmplY3RVUkwoYXVkaW9VcmwpO1xuICAgICAgICByZXNvbHZlKCk7XG4gICAgICB9O1xuICAgICAgXG4gICAgICBhdWRpby5vbmVycm9yID0gKGVycm9yKSA9PiB7XG4gICAgICAgIFVSTC5yZXZva2VPYmplY3RVUkwoYXVkaW9VcmwpO1xuICAgICAgICByZWplY3QoZXJyb3IpO1xuICAgICAgfTtcbiAgICAgIFxuICAgICAgYXVkaW8ucGxheSgpLmNhdGNoKHJlamVjdCk7XG4gICAgfSk7XG4gIH1cbn0gIl19
119
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW9TZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZpY2VzL2F1ZGlvU2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFPckQ7SUFRRSxzQkFBWSxNQUEwQjtRQUw5QixPQUFFLEdBQXFCLElBQUksQ0FBQztRQUM1QixnQkFBVyxHQUFXLEVBQUUsQ0FBQztRQUN6QixtQkFBYyxHQUFtQyxJQUFJLENBQUM7UUFDdEQsa0JBQWEsR0FBb0MsSUFBSSxDQUFDO1FBRzVELElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUM5QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7SUFDOUIsQ0FBQztJQUVLLG1DQUFZLEdBQWxCOzREQUFtQixJQUFZLEVBQUUsS0FBdUI7O1lBQXZCLHNCQUFBLEVBQUEsZUFBdUI7O2dCQUN0RCxzQkFBTyxJQUFJLE9BQU8sQ0FBQyxVQUFDLE9BQU8sRUFBRSxNQUFNO3dCQUNqQyxLQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQzt3QkFDOUIsS0FBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7d0JBQzVCLEtBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO3dCQUV0Qiw2REFBNkQ7d0JBQzdELElBQU0sS0FBSyxHQUFHLFVBQUcsS0FBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQywwQ0FBZ0MsS0FBSSxDQUFDLE1BQU0sQ0FBRSxDQUFDO3dCQUNqRyxLQUFJLENBQUMsRUFBRSxHQUFHLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQzt3QkFFakMsS0FBSSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEdBQUc7OzRCQUNmLE1BQUEsS0FBSSxDQUFDLEVBQUUsMENBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLE1BQUEsRUFBRSxDQUFDLENBQUMsQ0FBQzt3QkFDMUMsQ0FBQyxDQUFDO3dCQUVGLEtBQUksQ0FBQyxFQUFFLENBQUMsU0FBUyxHQUFHLFVBQUMsS0FBSzs0QkFDeEIsSUFBSSxLQUFLLENBQUMsSUFBSSxZQUFZLElBQUksRUFBRSxDQUFDO2dDQUMvQixLQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7NEJBQ3BDLENBQUM7d0JBQ0gsQ0FBQyxDQUFDO3dCQUVGLEtBQUksQ0FBQyxFQUFFLENBQUMsT0FBTyxHQUFHOzs0QkFDaEIsSUFBSSxLQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztnQ0FDaEMsSUFBTSxTQUFTLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO2dDQUNwRSxNQUFBLEtBQUksQ0FBQyxjQUFjLHNEQUFHLFNBQVMsQ0FBQyxDQUFDOzRCQUNuQyxDQUFDO2lDQUFNLENBQUM7Z0NBQ04sTUFBQSxLQUFJLENBQUMsYUFBYSxzREFBRyxJQUFJLEtBQUssQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDLENBQUM7NEJBQzVELENBQUM7NEJBQ0QsS0FBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO3dCQUNqQixDQUFDLENBQUM7d0JBRUYsS0FBSSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEdBQUcsVUFBQyxLQUFLOzs0QkFDdEIsTUFBQSxLQUFJLENBQUMsYUFBYSxzREFBRyxLQUFLLENBQUMsQ0FBQzs0QkFDNUIsS0FBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO3dCQUNqQixDQUFDLENBQUM7b0JBQ0osQ0FBQyxDQUFDLEVBQUM7OztLQUNKO0lBRU8sOEJBQU8sR0FBZjtRQUNFLElBQUksSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ1osSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQztRQUNqQixDQUFDO1FBQ0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDNUIsQ0FBQztJQUVLLGdDQUFTLEdBQWYsVUFBZ0IsU0FBZTs7OztnQkFDdkIsUUFBUSxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBQzFDLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFFbEMsc0JBQU8sSUFBSSxPQUFPLENBQUMsVUFBQyxPQUFPLEVBQUUsTUFBTTt3QkFDakMsS0FBSyxDQUFDLE9BQU8sR0FBRzs0QkFDZCxHQUFHLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDOzRCQUM5QixPQUFPLEVBQUUsQ0FBQzt3QkFDWixDQUFDLENBQUM7d0JBRUYsS0FBSyxDQUFDLE9BQU8sR0FBRyxVQUFDLEtBQUs7NEJBQ3BCLEdBQUcsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7NEJBQzlCLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQzt3QkFDaEIsQ0FBQyxDQUFDO3dCQUVGLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQzdCLENBQUMsQ0FBQyxFQUFDOzs7S0FDSjtJQUNILG1CQUFDO0FBQUQsQ0FBQyxBQTdFRCxJQTZFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVdlYlNvY2tldCB9IGZyb20gJy4uL3V0aWxzL3dlYnNvY2tldCc7XG5cbmludGVyZmFjZSBBdWRpb1NlcnZpY2VDb25maWcge1xuICBiYXNlVXJsOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgQXVkaW9TZXJ2aWNlIHtcbiAgcHJpdmF0ZSBiYXNlVXJsOiBzdHJpbmc7XG4gIHByaXZhdGUgYXBpS2V5OiBzdHJpbmc7XG4gIHByaXZhdGUgd3M6IFdlYlNvY2tldCB8IG51bGwgPSBudWxsO1xuICBwcml2YXRlIGF1ZGlvQ2h1bmtzOiBCbG9iW10gPSBbXTtcbiAgcHJpdmF0ZSByZXNvbHZlUHJvbWlzZTogKCh2YWx1ZTogQmxvYikgPT4gdm9pZCkgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSByZWplY3RQcm9taXNlOiAoKHJlYXNvbj86IGFueSkgPT4gdm9pZCkgfCBudWxsID0gbnVsbDtcblxuICBjb25zdHJ1Y3Rvcihjb25maWc6IEF1ZGlvU2VydmljZUNvbmZpZykge1xuICAgIHRoaXMuYmFzZVVybCA9IGNvbmZpZy5iYXNlVXJsO1xuICAgIHRoaXMuYXBpS2V5ID0gY29uZmlnLmFwaUtleTtcbiAgfVxuXG4gIGFzeW5jIHRleHRUb1NwZWVjaCh0ZXh0OiBzdHJpbmcsIHZvaWNlOiBzdHJpbmcgPSAnYWxsb3knKTogUHJvbWlzZTxCbG9iPiB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHRoaXMucmVzb2x2ZVByb21pc2UgPSByZXNvbHZlO1xuICAgICAgdGhpcy5yZWplY3RQcm9taXNlID0gcmVqZWN0O1xuICAgICAgdGhpcy5hdWRpb0NodW5rcyA9IFtdO1xuXG4gICAgICAvLyBDcmVhdGUgV2ViU29ja2V0IGNvbm5lY3Rpb24gdXNpbmcgYnJvd3Nlci1uYXRpdmUgV2ViU29ja2V0XG4gICAgICBjb25zdCB3c1VybCA9IGAke3RoaXMuYmFzZVVybC5yZXBsYWNlKCdodHRwJywgJ3dzJyl9L2FwaS92b2ljZS9hdWRpby90dHM/YXBpX2tleT0ke3RoaXMuYXBpS2V5fWA7XG4gICAgICB0aGlzLndzID0gY3JlYXRlV2ViU29ja2V0KHdzVXJsKTtcblxuICAgICAgdGhpcy53cy5vbm9wZW4gPSAoKSA9PiB7XG4gICAgICAgIHRoaXMud3M/LnNlbmQoSlNPTi5zdHJpbmdpZnkoeyB0ZXh0IH0pKTtcbiAgICAgIH07XG5cbiAgICAgIHRoaXMud3Mub25tZXNzYWdlID0gKGV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChldmVudC5kYXRhIGluc3RhbmNlb2YgQmxvYikge1xuICAgICAgICAgIHRoaXMuYXVkaW9DaHVua3MucHVzaChldmVudC5kYXRhKTtcbiAgICAgICAgfVxuICAgICAgfTtcblxuICAgICAgdGhpcy53cy5vbmNsb3NlID0gKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5hdWRpb0NodW5rcy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgY29uc3QgYXVkaW9CbG9iID0gbmV3IEJsb2IodGhpcy5hdWRpb0NodW5rcywgeyB0eXBlOiAnYXVkaW8vbXAzJyB9KTtcbiAgICAgICAgICB0aGlzLnJlc29sdmVQcm9taXNlPy4oYXVkaW9CbG9iKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aGlzLnJlamVjdFByb21pc2U/LihuZXcgRXJyb3IoJ05vIGF1ZGlvIGRhdGEgcmVjZWl2ZWQnKSk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5jbGVhbnVwKCk7XG4gICAgICB9O1xuXG4gICAgICB0aGlzLndzLm9uZXJyb3IgPSAoZXJyb3IpID0+IHtcbiAgICAgICAgdGhpcy5yZWplY3RQcm9taXNlPy4oZXJyb3IpO1xuICAgICAgICB0aGlzLmNsZWFudXAoKTtcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIGNsZWFudXAoKSB7XG4gICAgaWYgKHRoaXMud3MpIHtcbiAgICAgIHRoaXMud3MuY2xvc2UoKTtcbiAgICAgIHRoaXMud3MgPSBudWxsO1xuICAgIH1cbiAgICB0aGlzLnJlc29sdmVQcm9taXNlID0gbnVsbDtcbiAgICB0aGlzLnJlamVjdFByb21pc2UgPSBudWxsO1xuICB9XG5cbiAgYXN5bmMgcGxheUF1ZGlvKGF1ZGlvQmxvYjogQmxvYik6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGF1ZGlvVXJsID0gVVJMLmNyZWF0ZU9iamVjdFVSTChhdWRpb0Jsb2IpO1xuICAgIGNvbnN0IGF1ZGlvID0gbmV3IEF1ZGlvKGF1ZGlvVXJsKTtcbiAgICBcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgYXVkaW8ub25lbmRlZCA9ICgpID0+IHtcbiAgICAgICAgVVJMLnJldm9rZU9iamVjdFVSTChhdWRpb1VybCk7XG4gICAgICAgIHJlc29sdmUoKTtcbiAgICAgIH07XG4gICAgICBcbiAgICAgIGF1ZGlvLm9uZXJyb3IgPSAoZXJyb3IpID0+IHtcbiAgICAgICAgVVJMLnJldm9rZU9iamVjdFVSTChhdWRpb1VybCk7XG4gICAgICAgIHJlamVjdChlcnJvcik7XG4gICAgICB9O1xuICAgICAgXG4gICAgICBhdWRpby5wbGF5KCkuY2F0Y2gocmVqZWN0KTtcbiAgICB9KTtcbiAgfVxufSAiXX0=
@@ -46,7 +46,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
46
46
  }
47
47
  };
48
48
  import axios from "axios";
49
- import { w3cwebsocket as WebSocket, } from "websocket";
49
+ import { createWebSocket, createWebSocketDiagnostic, } from "../utils/websocket";
50
50
  var ChatService = /** @class */ (function () {
51
51
  function ChatService(baseUrl, apiKey, metadata, tenant) {
52
52
  this.conversationId = null;
@@ -402,11 +402,10 @@ var ChatService = /** @class */ (function () {
402
402
  var wsUrl = "".concat(this.baseUrl.replace("http", "ws"), "/api/conversations/ws/").concat(this.conversationId, "?api_key=").concat(this.apiKey, "&lang=en&topics=message&topics=takeover&topics=finalize");
403
403
  // Add tenant as query parameter if provided
404
404
  if (this.tenant) {
405
- wsUrl += "&X-Tenant-Id=".concat(encodeURIComponent(this.tenant));
405
+ wsUrl += "&X-Tenant-ID=".concat(encodeURIComponent(this.tenant));
406
406
  }
407
- // Also try to pass tenant as header (for Node.js environments that support it)
408
- var headers = this.tenant ? { "X-Tenant-Id": this.tenant } : undefined;
409
- this.webSocket = new WebSocket(wsUrl, undefined, undefined, headers);
407
+ // Use native browser WebSocket factory
408
+ this.webSocket = createWebSocket(wsUrl);
410
409
  this.webSocket.onopen = function () {
411
410
  if (_this.connectionStateHandler)
412
411
  _this.connectionStateHandler("connected");
@@ -498,10 +497,18 @@ var ChatService = /** @class */ (function () {
498
497
  this.webSocket.onerror = function (error) {
499
498
  if (_this.connectionStateHandler)
500
499
  _this.connectionStateHandler("disconnected");
500
+ // Log diagnostic
501
+ var diagnostic = createWebSocketDiagnostic(error, wsUrl);
502
+ console.error("[GenAssist Chat] ".concat(diagnostic));
501
503
  };
502
504
  this.webSocket.onclose = function (event) {
503
505
  if (_this.connectionStateHandler)
504
506
  _this.connectionStateHandler("disconnected");
507
+ // Log diagnostic
508
+ if (!event.wasClean) {
509
+ var diagnostic = createWebSocketDiagnostic(event, wsUrl);
510
+ console.warn("[GenAssist Chat] ".concat(diagnostic));
511
+ }
505
512
  };
506
513
  };
507
514
  ChatService.prototype.disconnect = function () {
@@ -588,4 +595,4 @@ var ChatService = /** @class */ (function () {
588
595
  return ChatService;
589
596
  }());
590
597
  export { ChatService };
591
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from \"axios\";\nimport {\n  w3cwebsocket as WebSocket,\n  IMessageEvent,\n  ICloseEvent,\n} from \"websocket\";\nimport {\n  ChatMessage,\n  StartConversationResponse,\n  Attachment,\n  AgentThinkingConfig,\n  AgentWelcomeData,\n} from \"../types\";\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler:\n    | ((state: \"connecting\" | \"connected\" | \"disconnected\") => void)\n    | null = null;\n  private welcomeDataHandler: ((data: AgentWelcomeData) => void) | null = null;\n  private storageKeyBase = \"genassist_conversation\";\n  private possibleQueries: string[] = [];\n  private welcomeData: AgentWelcomeData = {};\n  private thinkingConfig: AgentThinkingConfig = { phrases: [], delayMs: 1000 };\n  private welcomeObjectUrl: string | null = null; // to revoke on reset\n  private tenant: string | undefined;\n  private agentId: string | undefined;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string\n  ) {\n    this.baseUrl = baseUrl.endsWith(\"/\") ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    this.tenant = tenant;\n    // Try to load a saved conversation for this apiKey from localStorage\n    this.loadSavedConversation();\n  }\n\n  private getStorageKey(): string {\n    // Pointer to current conversation metadata for this apiKey\n    return `${this.storageKeyBase}:${this.apiKey}`;\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(\n    handler: (state: \"connecting\" | \"connected\" | \"disconnected\") => void\n  ) {\n    this.connectionStateHandler = handler;\n  }\n\n  setWelcomeDataHandler(handler: ((data: AgentWelcomeData) => void) | null) {\n    this.welcomeDataHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  getWelcomeData(): AgentWelcomeData {\n    return this.welcomeData;\n  }\n\n  getThinkingConfig(): AgentThinkingConfig {\n    return this.thinkingConfig;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      let savedConversation = localStorage.getItem(this.getStorageKey());\n      // Backward-compat: check old unscoped key if scoped one missing\n      if (!savedConversation) {\n        savedConversation = localStorage.getItem(this.storageKeyBase);\n      }\n      if (savedConversation) {\n        const {\n          conversationId,\n          createTime,\n          isFinalized,\n          possibleQueries,\n          welcomeData,\n          thinkingConfig,\n          agentId,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.possibleQueries = Array.isArray(possibleQueries)\n          ? possibleQueries\n          : [];\n        this.welcomeData = welcomeData || {};\n        if (!this.welcomeData.possibleQueries) {\n          this.welcomeData.possibleQueries = this.possibleQueries;\n        }\n        this.thinkingConfig = {\n          phrases: (thinkingConfig && thinkingConfig.phrases) || [],\n          delayMs:\n            thinkingConfig && typeof thinkingConfig.delayMs === \"number\"\n              ? thinkingConfig.delayMs\n              : 1000,\n        };\n        this.agentId = agentId;\n        if (!this.welcomeData.imageUrl && this.agentId) {\n          this.fetchWelcomeImage(this.agentId);\n        }\n        if (this.welcomeDataHandler) {\n          this.welcomeDataHandler(this.welcomeData);\n        }\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n          possibleQueries: this.possibleQueries,\n          welcomeData: {\n            ...this.welcomeData,\n            imageUrl:\n              this.welcomeObjectUrl &&\n              this.welcomeData.imageUrl &&\n              this.welcomeData.imageUrl.startsWith(\"blob:\")\n                ? null\n                : this.welcomeData.imageUrl || null,\n          },\n          thinkingConfig: this.thinkingConfig,\n          agentId: this.agentId,\n        };\n        localStorage.setItem(this.getStorageKey(), JSON.stringify(conversationData));\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n\n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    this.welcomeData = {};\n    this.thinkingConfig = { phrases: [], delayMs: 1000 };\n    if (this.welcomeObjectUrl) {\n      try {\n        URL.revokeObjectURL(this.welcomeObjectUrl);\n      } catch {}\n      this.welcomeObjectUrl = null;\n    }\n    this.agentId = undefined;\n\n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.getStorageKey());\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\",\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time\n        ? response.data.create_time / 1000\n        : Date.now() / 1000;\n      this.isFinalized = false;\n\n      // Store possible queries if available\n      if (\n        response.data.agent_possible_queries &&\n        response.data.agent_possible_queries.length > 0\n      ) {\n        this.possibleQueries = response.data.agent_possible_queries.filter(\n          (query) => typeof query === \"string\" && query.trim().length > 0\n        );\n      }\n\n      const anyData: any = response.data as any;\n      const agentId: string | undefined = anyData.agent_id;\n      this.agentId = agentId;\n      const welcomeTitle: string | undefined = anyData.agent_welcome_title;\n      const welcomeImageUrl: string | undefined =\n        anyData.agent_welcome_image_url;\n      const thinkingPhrases: string[] | undefined =\n        anyData.agent_thinking_phrases;\n      const thinkingDelaySec: number | undefined =\n        anyData.agent_thinking_phrase_delay;\n\n      this.welcomeData = {\n        title: welcomeTitle || null,\n        message: null,\n        imageUrl: welcomeImageUrl || null,\n        possibleQueries: this.possibleQueries,\n      };\n\n      if (Array.isArray(thinkingPhrases) && thinkingPhrases.length > 0) {\n        this.thinkingConfig.phrases = thinkingPhrases;\n      }\n      if (typeof thinkingDelaySec === \"number\" && thinkingDelaySec >= 0) {\n        this.thinkingConfig.delayMs = Math.max(\n          250,\n          Math.round(thinkingDelaySec * 1000)\n        );\n      }\n\n      if (!this.welcomeData.imageUrl && agentId) {\n        await this.fetchWelcomeImage(agentId);\n      }\n\n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n          speaker: \"agent\",\n          text: response.data.agent_welcome_message,\n        };\n        this.welcomeData.message = response.data.agent_welcome_message;\n        this.messageHandler(welcomeMessage);\n      }\n\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n\n      this.saveConversation();\n      this.connectWebSocket();\n      return response.data.conversation_id;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  async sendMessage(\n    message: string,\n    attachments?: Attachment[],\n    extraMetadata?: Record<string, any>\n  ): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n      speaker: \"customer\",\n      text: message,\n      attachments: attachments,\n    };\n\n    if (this.messageHandler) {\n      this.messageHandler(chatMessage);\n    }\n\n    try {\n      const requestBody: any = {\n        messages: [chatMessage],\n        recorded_at: new Date().toISOString(),\n      };\n\n      // Include metadata\n      const mergedMetadata = {\n        ...(this.metadata || {}),\n        ...(extraMetadata || {}),\n      };\n      if (Object.keys(mergedMetadata).length > 0) {\n        requestBody.metadata = mergedMetadata;\n      }\n\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n    } catch (error: any) {\n      // Check if this is the agent inactive error\n      if (\n        error.response &&\n        error.response.data &&\n        error.response.data.error_key === \"AGENT_INACTIVE\"\n      ) {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: now - this.conversationCreateTime + 0.01,\n            speaker: \"special\",\n            text: \"The agent is currently offline, please check back later. Thank you!\",\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n\n      throw error;\n    }\n  }\n\n  async uploadFile(chatId: string, file: File): Promise<{ fileUrl: string }> {\n    if (!this.conversationId) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const formData = new FormData();\n    formData.append(\"chat_id\", chatId);\n    formData.append(\"file\", file);\n\n    try {\n      const response = await axios.post<{ fileUrl: string }>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"multipart/form-data\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n      return response.data;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n\n    if (!this.conversationId) {\n      throw new Error(\"Conversation ID is required for WebSocket connection\");\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler(\"connecting\");\n    let wsUrl = `${this.baseUrl.replace(\"http\", \"ws\")}/api/conversations/ws/${\n      this.conversationId\n    }?api_key=${\n      this.apiKey\n    }&lang=en&topics=message&topics=takeover&topics=finalize`;\n    \n    // Add tenant as query parameter if provided\n    if (this.tenant) {\n      wsUrl += `&X-Tenant-Id=${encodeURIComponent(this.tenant)}`;\n    }\n    \n    // Also try to pass tenant as header (for Node.js environments that support it)\n    const headers = this.tenant ? { \"X-Tenant-Id\": this.tenant } : undefined;\n    this.webSocket = new WebSocket(wsUrl, undefined, undefined, headers);\n\n\n    this.webSocket.onopen = () => {\n      if (this.connectionStateHandler) this.connectionStateHandler(\"connected\");\n    };\n\n    this.webSocket.onmessage = (event: IMessageEvent) => {\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === \"message\" && this.messageHandler) {\n          if (Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[];\n            // Adjust timestamps to be relative to conversation start\n            // Also normalize message_id field (backend might send 'id' instead of 'message_id')\n            const adjustedMessages = messages\n              .map((msg) => {\n                const adjusted = this.adjustMessageTimestamps(msg);\n                // Normalize: if backend sends 'id', use it as 'message_id'\n                if (!adjusted.message_id && (msg as any).id) {\n                  adjusted.message_id = (msg as any).id;\n                }\n                return adjusted;\n              })\n              .filter((msg) => msg.speaker !== \"customer\");\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(\n              data.payload as ChatMessage\n            );\n            // Normalize: if backend sends 'id', use it as 'message_id'\n            if (!adjustedMessage.message_id && (data.payload as any).id) {\n              adjustedMessage.message_id = (data.payload as any).id;\n            }\n            if (adjustedMessage.speaker !== \"customer\") {\n              this.messageHandler(adjustedMessage);\n            }\n          }\n        } else if (data.type === \"takeover\") {\n          // Handle takeover event\n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Supervisor took over\",\n            };\n            this.messageHandler(takeoverMessage);\n          }\n\n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === \"finalize\") {\n          // Handle finalized event\n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Conversation Finalized\",\n            };\n            this.messageHandler(finalizedMessage);\n          }\n\n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        // ignore\n      }\n    };\n\n    this.webSocket.onerror = (error: Error) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n    };\n\n    this.webSocket.onclose = (event: ICloseEvent) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  private async fetchWelcomeImage(agentId: string): Promise<void> {\n    try {\n      const imageResponse = await axios.get(\n        `${this.baseUrl}/api/genagent/agents/configs/${agentId}/welcome-image`,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n          responseType: \"blob\",\n        }\n      );\n      const blobUrl = URL.createObjectURL(imageResponse.data);\n      this.welcomeObjectUrl = blobUrl;\n      this.welcomeData.imageUrl = blobUrl;\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n    } catch (err) {\n      // ignore\n    }\n  }\n\n  // Add feedback to a specific agent message in the conversation\n  async addFeedback(\n    messageId: string,\n    feedback: \"good\" | \"bad\",\n    feedback_message?: string\n  ): Promise<void> {\n    if (!messageId) {\n      throw new Error(\"Message ID is required for feedback\");\n    }\n\n    try {\n      // Use message ID in the URL path, not conversation ID\n      const url = `${this.baseUrl}/api/conversations/message/add-feedback/${messageId}`;\n      // Body should only contain feedback and feedback_message (no message_id)\n      const payload: {\n        feedback: \"good\" | \"bad\";\n        feedback_message?: string;\n      } = {\n        feedback,\n      };\n      \n      if (feedback_message) {\n        payload.feedback_message = feedback_message;\n      }\n      \n      await axios.patch(url, payload, {\n        headers: {\n          \"x-api-key\": this.apiKey,\n          \"Content-Type\": \"application/json\",\n          ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n        },\n      });\n      \n    } catch (error: any) {\n      console.error('Feedback API call failed:', {\n        message: error.message,\n        response: error.response?.data,\n        status: error.response?.status,\n      });\n      throw error;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime,\n    };\n  }\n}\n"]}
598
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from \"axios\";\nimport {\n  ChatMessage,\n  StartConversationResponse,\n  Attachment,\n  AgentThinkingConfig,\n  AgentWelcomeData,\n} from \"../types\";\nimport {\n  createWebSocket,\n  createWebSocketDiagnostic,\n} from \"../utils/websocket\";\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler:\n    | ((state: \"connecting\" | \"connected\" | \"disconnected\") => void)\n    | null = null;\n  private welcomeDataHandler: ((data: AgentWelcomeData) => void) | null = null;\n  private storageKeyBase = \"genassist_conversation\";\n  private possibleQueries: string[] = [];\n  private welcomeData: AgentWelcomeData = {};\n  private thinkingConfig: AgentThinkingConfig = { phrases: [], delayMs: 1000 };\n  private welcomeObjectUrl: string | null = null; // to revoke on reset\n  private tenant: string | undefined;\n  private agentId: string | undefined;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string\n  ) {\n    this.baseUrl = baseUrl.endsWith(\"/\") ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    this.tenant = tenant;\n    // Try to load a saved conversation for this apiKey from localStorage\n    this.loadSavedConversation();\n  }\n\n  private getStorageKey(): string {\n    // Pointer to current conversation metadata for this apiKey\n    return `${this.storageKeyBase}:${this.apiKey}`;\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(\n    handler: (state: \"connecting\" | \"connected\" | \"disconnected\") => void\n  ) {\n    this.connectionStateHandler = handler;\n  }\n\n  setWelcomeDataHandler(handler: ((data: AgentWelcomeData) => void) | null) {\n    this.welcomeDataHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  getWelcomeData(): AgentWelcomeData {\n    return this.welcomeData;\n  }\n\n  getThinkingConfig(): AgentThinkingConfig {\n    return this.thinkingConfig;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      let savedConversation = localStorage.getItem(this.getStorageKey());\n      // Backward-compat: check old unscoped key if scoped one missing\n      if (!savedConversation) {\n        savedConversation = localStorage.getItem(this.storageKeyBase);\n      }\n      if (savedConversation) {\n        const {\n          conversationId,\n          createTime,\n          isFinalized,\n          possibleQueries,\n          welcomeData,\n          thinkingConfig,\n          agentId,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.possibleQueries = Array.isArray(possibleQueries)\n          ? possibleQueries\n          : [];\n        this.welcomeData = welcomeData || {};\n        if (!this.welcomeData.possibleQueries) {\n          this.welcomeData.possibleQueries = this.possibleQueries;\n        }\n        this.thinkingConfig = {\n          phrases: (thinkingConfig && thinkingConfig.phrases) || [],\n          delayMs:\n            thinkingConfig && typeof thinkingConfig.delayMs === \"number\"\n              ? thinkingConfig.delayMs\n              : 1000,\n        };\n        this.agentId = agentId;\n        if (!this.welcomeData.imageUrl && this.agentId) {\n          this.fetchWelcomeImage(this.agentId);\n        }\n        if (this.welcomeDataHandler) {\n          this.welcomeDataHandler(this.welcomeData);\n        }\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n          possibleQueries: this.possibleQueries,\n          welcomeData: {\n            ...this.welcomeData,\n            imageUrl:\n              this.welcomeObjectUrl &&\n              this.welcomeData.imageUrl &&\n              this.welcomeData.imageUrl.startsWith(\"blob:\")\n                ? null\n                : this.welcomeData.imageUrl || null,\n          },\n          thinkingConfig: this.thinkingConfig,\n          agentId: this.agentId,\n        };\n        localStorage.setItem(this.getStorageKey(), JSON.stringify(conversationData));\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n\n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    this.welcomeData = {};\n    this.thinkingConfig = { phrases: [], delayMs: 1000 };\n    if (this.welcomeObjectUrl) {\n      try {\n        URL.revokeObjectURL(this.welcomeObjectUrl);\n      } catch {}\n      this.welcomeObjectUrl = null;\n    }\n    this.agentId = undefined;\n\n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.getStorageKey());\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\",\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time\n        ? response.data.create_time / 1000\n        : Date.now() / 1000;\n      this.isFinalized = false;\n\n      // Store possible queries if available\n      if (\n        response.data.agent_possible_queries &&\n        response.data.agent_possible_queries.length > 0\n      ) {\n        this.possibleQueries = response.data.agent_possible_queries.filter(\n          (query) => typeof query === \"string\" && query.trim().length > 0\n        );\n      }\n\n      const anyData: any = response.data as any;\n      const agentId: string | undefined = anyData.agent_id;\n      this.agentId = agentId;\n      const welcomeTitle: string | undefined = anyData.agent_welcome_title;\n      const welcomeImageUrl: string | undefined =\n        anyData.agent_welcome_image_url;\n      const thinkingPhrases: string[] | undefined =\n        anyData.agent_thinking_phrases;\n      const thinkingDelaySec: number | undefined =\n        anyData.agent_thinking_phrase_delay;\n\n      this.welcomeData = {\n        title: welcomeTitle || null,\n        message: null,\n        imageUrl: welcomeImageUrl || null,\n        possibleQueries: this.possibleQueries,\n      };\n\n      if (Array.isArray(thinkingPhrases) && thinkingPhrases.length > 0) {\n        this.thinkingConfig.phrases = thinkingPhrases;\n      }\n      if (typeof thinkingDelaySec === \"number\" && thinkingDelaySec >= 0) {\n        this.thinkingConfig.delayMs = Math.max(\n          250,\n          Math.round(thinkingDelaySec * 1000)\n        );\n      }\n\n      if (!this.welcomeData.imageUrl && agentId) {\n        await this.fetchWelcomeImage(agentId);\n      }\n\n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n          speaker: \"agent\",\n          text: response.data.agent_welcome_message,\n        };\n        this.welcomeData.message = response.data.agent_welcome_message;\n        this.messageHandler(welcomeMessage);\n      }\n\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n\n      this.saveConversation();\n      this.connectWebSocket();\n      return response.data.conversation_id;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  async sendMessage(\n    message: string,\n    attachments?: Attachment[],\n    extraMetadata?: Record<string, any>\n  ): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n      speaker: \"customer\",\n      text: message,\n      attachments: attachments,\n    };\n\n    if (this.messageHandler) {\n      this.messageHandler(chatMessage);\n    }\n\n    try {\n      const requestBody: any = {\n        messages: [chatMessage],\n        recorded_at: new Date().toISOString(),\n      };\n\n      // Include metadata\n      const mergedMetadata = {\n        ...(this.metadata || {}),\n        ...(extraMetadata || {}),\n      };\n      if (Object.keys(mergedMetadata).length > 0) {\n        requestBody.metadata = mergedMetadata;\n      }\n\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n    } catch (error: any) {\n      // Check if this is the agent inactive error\n      if (\n        error.response &&\n        error.response.data &&\n        error.response.data.error_key === \"AGENT_INACTIVE\"\n      ) {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: now - this.conversationCreateTime + 0.01,\n            speaker: \"special\",\n            text: \"The agent is currently offline, please check back later. Thank you!\",\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n\n      throw error;\n    }\n  }\n\n  async uploadFile(chatId: string, file: File): Promise<{ fileUrl: string }> {\n    if (!this.conversationId) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const formData = new FormData();\n    formData.append(\"chat_id\", chatId);\n    formData.append(\"file\", file);\n\n    try {\n      const response = await axios.post<{ fileUrl: string }>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"multipart/form-data\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n      return response.data;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n\n    if (!this.conversationId) {\n      throw new Error(\"Conversation ID is required for WebSocket connection\");\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler(\"connecting\");\n    let wsUrl = `${this.baseUrl.replace(\"http\", \"ws\")}/api/conversations/ws/${\n      this.conversationId\n    }?api_key=${\n      this.apiKey\n    }&lang=en&topics=message&topics=takeover&topics=finalize`;\n    \n    // Add tenant as query parameter if provided\n    if (this.tenant) {\n      wsUrl += `&X-Tenant-ID=${encodeURIComponent(this.tenant)}`;\n    }\n    \n    // Use native browser WebSocket factory\n    this.webSocket = createWebSocket(wsUrl);\n\n\n    this.webSocket.onopen = () => {\n      if (this.connectionStateHandler) this.connectionStateHandler(\"connected\");\n    };\n\n    this.webSocket.onmessage = (event: MessageEvent) => {\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === \"message\" && this.messageHandler) {\n          if (Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[];\n            // Adjust timestamps to be relative to conversation start\n            // Also normalize message_id field (backend might send 'id' instead of 'message_id')\n            const adjustedMessages = messages\n              .map((msg) => {\n                const adjusted = this.adjustMessageTimestamps(msg);\n                // Normalize: if backend sends 'id', use it as 'message_id'\n                if (!adjusted.message_id && (msg as any).id) {\n                  adjusted.message_id = (msg as any).id;\n                }\n                return adjusted;\n              })\n              .filter((msg) => msg.speaker !== \"customer\");\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(\n              data.payload as ChatMessage\n            );\n            // Normalize: if backend sends 'id', use it as 'message_id'\n            if (!adjustedMessage.message_id && (data.payload as any).id) {\n              adjustedMessage.message_id = (data.payload as any).id;\n            }\n            if (adjustedMessage.speaker !== \"customer\") {\n              this.messageHandler(adjustedMessage);\n            }\n          }\n        } else if (data.type === \"takeover\") {\n          // Handle takeover event\n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Supervisor took over\",\n            };\n            this.messageHandler(takeoverMessage);\n          }\n\n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === \"finalize\") {\n          // Handle finalized event\n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Conversation Finalized\",\n            };\n            this.messageHandler(finalizedMessage);\n          }\n\n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        // ignore\n      }\n    };\n\n    this.webSocket.onerror = (error: Event) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      const diagnostic = createWebSocketDiagnostic(error, wsUrl);\n      console.error(`[GenAssist Chat] ${diagnostic}`);\n    };\n\n    this.webSocket.onclose = (event: CloseEvent) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      if (!event.wasClean) {\n        const diagnostic = createWebSocketDiagnostic(event, wsUrl);\n        console.warn(`[GenAssist Chat] ${diagnostic}`);\n      }\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  private async fetchWelcomeImage(agentId: string): Promise<void> {\n    try {\n      const imageResponse = await axios.get(\n        `${this.baseUrl}/api/genagent/agents/configs/${agentId}/welcome-image`,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n          responseType: \"blob\",\n        }\n      );\n      const blobUrl = URL.createObjectURL(imageResponse.data);\n      this.welcomeObjectUrl = blobUrl;\n      this.welcomeData.imageUrl = blobUrl;\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n    } catch (err) {\n      // ignore\n    }\n  }\n\n  // Add feedback to a specific agent message in the conversation\n  async addFeedback(\n    messageId: string,\n    feedback: \"good\" | \"bad\",\n    feedback_message?: string\n  ): Promise<void> {\n    if (!messageId) {\n      throw new Error(\"Message ID is required for feedback\");\n    }\n\n    try {\n      // Use message ID in the URL path, not conversation ID\n      const url = `${this.baseUrl}/api/conversations/message/add-feedback/${messageId}`;\n      // Body should only contain feedback and feedback_message (no message_id)\n      const payload: {\n        feedback: \"good\" | \"bad\";\n        feedback_message?: string;\n      } = {\n        feedback,\n      };\n      \n      if (feedback_message) {\n        payload.feedback_message = feedback_message;\n      }\n      \n      await axios.patch(url, payload, {\n        headers: {\n          \"x-api-key\": this.apiKey,\n          \"Content-Type\": \"application/json\",\n          ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n        },\n      });\n      \n    } catch (error: any) {\n      console.error('Feedback API call failed:', {\n        message: error.message,\n        response: error.response?.data,\n        status: error.response?.status,\n      });\n      throw error;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime,\n    };\n  }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * This factory ensures the library uses the native browser WebSocket API
3
+ * and does not require Node.js-specific WebSocket packages or shims.
4
+ */
5
+ export declare function createWebSocket(url: string, protocols?: string | string[]): WebSocket;
6
+ export declare function redactUrl(url: string): string;
7
+ export declare function createWebSocketDiagnostic(event: CloseEvent | Event, url: string): string;
@@ -0,0 +1,60 @@
1
+ /**
2
+ * This factory ensures the library uses the native browser WebSocket API
3
+ * and does not require Node.js-specific WebSocket packages or shims.
4
+ */
5
+ export function createWebSocket(url, protocols) {
6
+ // Use native browser WebSocket and polyfilled by bundlers when needed
7
+ if (typeof globalThis !== 'undefined' && globalThis.WebSocket) {
8
+ return new globalThis.WebSocket(url, protocols);
9
+ }
10
+ // Fallback for environments where globalThis might not be available
11
+ if (typeof window !== 'undefined' && window.WebSocket) {
12
+ return new window.WebSocket(url, protocols);
13
+ }
14
+ // Last resort - should not happen in browser environments
15
+ if (typeof WebSocket !== 'undefined') {
16
+ return new WebSocket(url, protocols);
17
+ }
18
+ throw new Error('WebSocket is not available in this environment. ' +
19
+ 'This library requires a browser environment with native WebSocket support.');
20
+ }
21
+ export function redactUrl(url) {
22
+ try {
23
+ var urlObj = new URL(url);
24
+ // Redact api_key and access_token query params
25
+ if (urlObj.searchParams.has('api_key')) {
26
+ urlObj.searchParams.set('api_key', '[REDACTED]');
27
+ }
28
+ if (urlObj.searchParams.has('access_token')) {
29
+ urlObj.searchParams.set('access_token', '[REDACTED]');
30
+ }
31
+ return urlObj.toString();
32
+ }
33
+ catch (_a) {
34
+ // If URL parsing fails, return a safe redacted version
35
+ return url.replace(/[?&](api_key|access_token)=[^&]*/g, function (match) {
36
+ var param = match.split('=')[0];
37
+ return "".concat(param, "=[REDACTED]");
38
+ });
39
+ }
40
+ }
41
+ export function createWebSocketDiagnostic(event, url) {
42
+ var redactedUrl = redactUrl(url);
43
+ var parts = [];
44
+ parts.push("WebSocket connection issue");
45
+ parts.push("URL: ".concat(redactedUrl));
46
+ if (event instanceof CloseEvent) {
47
+ parts.push("Close code: ".concat(event.code));
48
+ if (event.reason) {
49
+ parts.push("Reason: ".concat(event.reason));
50
+ }
51
+ parts.push("Was clean: ".concat(event.wasClean));
52
+ }
53
+ if ('readyState' in event && typeof event.readyState === 'number') {
54
+ var states = ['CONNECTING', 'OPEN', 'CLOSING', 'CLOSED'];
55
+ var state = states[event.readyState] || 'UNKNOWN';
56
+ parts.push("Ready state: ".concat(state, " (").concat(event.readyState, ")"));
57
+ }
58
+ return parts.join(' | ');
59
+ }
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vic29ja2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL3dlYnNvY2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxNQUFNLFVBQVUsZUFBZSxDQUM3QixHQUFXLEVBQ1gsU0FBNkI7SUFFN0Isc0VBQXNFO0lBQ3RFLElBQUksT0FBTyxVQUFVLEtBQUssV0FBVyxJQUFJLFVBQVUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUM5RCxPQUFPLElBQUksVUFBVSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELG9FQUFvRTtJQUNwRSxJQUFJLE9BQU8sTUFBTSxLQUFLLFdBQVcsSUFBSSxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDdEQsT0FBTyxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFRCwwREFBMEQ7SUFDMUQsSUFBSSxPQUFPLFNBQVMsS0FBSyxXQUFXLEVBQUUsQ0FBQztRQUNyQyxPQUFPLElBQUksU0FBUyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsTUFBTSxJQUFJLEtBQUssQ0FDYixrREFBa0Q7UUFDbEQsNEVBQTRFLENBQzdFLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLFNBQVMsQ0FBQyxHQUFXO0lBQ25DLElBQUksQ0FBQztRQUNILElBQU0sTUFBTSxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzVCLCtDQUErQztRQUMvQyxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7WUFDdkMsTUFBTSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBQ25ELENBQUM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7WUFDNUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsY0FBYyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBQUMsV0FBTSxDQUFDO1FBQ1AsdURBQXVEO1FBQ3ZELE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxtQ0FBbUMsRUFBRSxVQUFDLEtBQUs7WUFDNUQsSUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQyxPQUFPLFVBQUcsS0FBSyxnQkFBYSxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUseUJBQXlCLENBQ3ZDLEtBQXlCLEVBQ3pCLEdBQVc7SUFFWCxJQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbkMsSUFBTSxLQUFLLEdBQWEsRUFBRSxDQUFDO0lBRTNCLEtBQUssQ0FBQyxJQUFJLENBQUMsNEJBQTRCLENBQUMsQ0FBQztJQUN6QyxLQUFLLENBQUMsSUFBSSxDQUFDLGVBQVEsV0FBVyxDQUFFLENBQUMsQ0FBQztJQUVsQyxJQUFJLEtBQUssWUFBWSxVQUFVLEVBQUUsQ0FBQztRQUNoQyxLQUFLLENBQUMsSUFBSSxDQUFDLHNCQUFlLEtBQUssQ0FBQyxJQUFJLENBQUUsQ0FBQyxDQUFDO1FBQ3hDLElBQUksS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2pCLEtBQUssQ0FBQyxJQUFJLENBQUMsa0JBQVcsS0FBSyxDQUFDLE1BQU0sQ0FBRSxDQUFDLENBQUM7UUFDeEMsQ0FBQztRQUNELEtBQUssQ0FBQyxJQUFJLENBQUMscUJBQWMsS0FBSyxDQUFDLFFBQVEsQ0FBRSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELElBQUksWUFBWSxJQUFJLEtBQUssSUFBSSxPQUFRLEtBQWEsQ0FBQyxVQUFVLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDM0UsSUFBTSxNQUFNLEdBQUcsQ0FBQyxZQUFZLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMzRCxJQUFNLEtBQUssR0FBRyxNQUFNLENBQUUsS0FBYSxDQUFDLFVBQVUsQ0FBQyxJQUFJLFNBQVMsQ0FBQztRQUM3RCxLQUFLLENBQUMsSUFBSSxDQUFDLHVCQUFnQixLQUFLLGVBQU0sS0FBYSxDQUFDLFVBQVUsTUFBRyxDQUFDLENBQUM7SUFDckUsQ0FBQztJQUVELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGlzIGZhY3RvcnkgZW5zdXJlcyB0aGUgbGlicmFyeSB1c2VzIHRoZSBuYXRpdmUgYnJvd3NlciBXZWJTb2NrZXQgQVBJXG4gKiBhbmQgZG9lcyBub3QgcmVxdWlyZSBOb2RlLmpzLXNwZWNpZmljIFdlYlNvY2tldCBwYWNrYWdlcyBvciBzaGltcy5cbiAqL1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV2ViU29ja2V0KFxuICB1cmw6IHN0cmluZyxcbiAgcHJvdG9jb2xzPzogc3RyaW5nIHwgc3RyaW5nW11cbik6IFdlYlNvY2tldCB7XG4gIC8vIFVzZSBuYXRpdmUgYnJvd3NlciBXZWJTb2NrZXQgYW5kIHBvbHlmaWxsZWQgYnkgYnVuZGxlcnMgd2hlbiBuZWVkZWRcbiAgaWYgKHR5cGVvZiBnbG9iYWxUaGlzICE9PSAndW5kZWZpbmVkJyAmJiBnbG9iYWxUaGlzLldlYlNvY2tldCkge1xuICAgIHJldHVybiBuZXcgZ2xvYmFsVGhpcy5XZWJTb2NrZXQodXJsLCBwcm90b2NvbHMpO1xuICB9XG4gIFxuICAvLyBGYWxsYmFjayBmb3IgZW52aXJvbm1lbnRzIHdoZXJlIGdsb2JhbFRoaXMgbWlnaHQgbm90IGJlIGF2YWlsYWJsZVxuICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcgJiYgd2luZG93LldlYlNvY2tldCkge1xuICAgIHJldHVybiBuZXcgd2luZG93LldlYlNvY2tldCh1cmwsIHByb3RvY29scyk7XG4gIH1cbiAgXG4gIC8vIExhc3QgcmVzb3J0IC0gc2hvdWxkIG5vdCBoYXBwZW4gaW4gYnJvd3NlciBlbnZpcm9ubWVudHNcbiAgaWYgKHR5cGVvZiBXZWJTb2NrZXQgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgcmV0dXJuIG5ldyBXZWJTb2NrZXQodXJsLCBwcm90b2NvbHMpO1xuICB9XG4gIFxuICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgJ1dlYlNvY2tldCBpcyBub3QgYXZhaWxhYmxlIGluIHRoaXMgZW52aXJvbm1lbnQuICcgK1xuICAgICdUaGlzIGxpYnJhcnkgcmVxdWlyZXMgYSBicm93c2VyIGVudmlyb25tZW50IHdpdGggbmF0aXZlIFdlYlNvY2tldCBzdXBwb3J0LidcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlZGFjdFVybCh1cmw6IHN0cmluZyk6IHN0cmluZyB7XG4gIHRyeSB7XG4gICAgY29uc3QgdXJsT2JqID0gbmV3IFVSTCh1cmwpO1xuICAgIC8vIFJlZGFjdCBhcGlfa2V5IGFuZCBhY2Nlc3NfdG9rZW4gcXVlcnkgcGFyYW1zXG4gICAgaWYgKHVybE9iai5zZWFyY2hQYXJhbXMuaGFzKCdhcGlfa2V5JykpIHtcbiAgICAgIHVybE9iai5zZWFyY2hQYXJhbXMuc2V0KCdhcGlfa2V5JywgJ1tSRURBQ1RFRF0nKTtcbiAgICB9XG4gICAgaWYgKHVybE9iai5zZWFyY2hQYXJhbXMuaGFzKCdhY2Nlc3NfdG9rZW4nKSkge1xuICAgICAgdXJsT2JqLnNlYXJjaFBhcmFtcy5zZXQoJ2FjY2Vzc190b2tlbicsICdbUkVEQUNURURdJyk7XG4gICAgfVxuICAgIHJldHVybiB1cmxPYmoudG9TdHJpbmcoKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gSWYgVVJMIHBhcnNpbmcgZmFpbHMsIHJldHVybiBhIHNhZmUgcmVkYWN0ZWQgdmVyc2lvblxuICAgIHJldHVybiB1cmwucmVwbGFjZSgvWz8mXShhcGlfa2V5fGFjY2Vzc190b2tlbik9W14mXSovZywgKG1hdGNoKSA9PiB7XG4gICAgICBjb25zdCBwYXJhbSA9IG1hdGNoLnNwbGl0KCc9JylbMF07XG4gICAgICByZXR1cm4gYCR7cGFyYW19PVtSRURBQ1RFRF1gO1xuICAgIH0pO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVXZWJTb2NrZXREaWFnbm9zdGljKFxuICBldmVudDogQ2xvc2VFdmVudCB8IEV2ZW50LFxuICB1cmw6IHN0cmluZ1xuKTogc3RyaW5nIHtcbiAgY29uc3QgcmVkYWN0ZWRVcmwgPSByZWRhY3RVcmwodXJsKTtcbiAgY29uc3QgcGFydHM6IHN0cmluZ1tdID0gW107XG4gIFxuICBwYXJ0cy5wdXNoKGBXZWJTb2NrZXQgY29ubmVjdGlvbiBpc3N1ZWApO1xuICBwYXJ0cy5wdXNoKGBVUkw6ICR7cmVkYWN0ZWRVcmx9YCk7XG4gIFxuICBpZiAoZXZlbnQgaW5zdGFuY2VvZiBDbG9zZUV2ZW50KSB7XG4gICAgcGFydHMucHVzaChgQ2xvc2UgY29kZTogJHtldmVudC5jb2RlfWApO1xuICAgIGlmIChldmVudC5yZWFzb24pIHtcbiAgICAgIHBhcnRzLnB1c2goYFJlYXNvbjogJHtldmVudC5yZWFzb259YCk7XG4gICAgfVxuICAgIHBhcnRzLnB1c2goYFdhcyBjbGVhbjogJHtldmVudC53YXNDbGVhbn1gKTtcbiAgfVxuICBcbiAgaWYgKCdyZWFkeVN0YXRlJyBpbiBldmVudCAmJiB0eXBlb2YgKGV2ZW50IGFzIGFueSkucmVhZHlTdGF0ZSA9PT0gJ251bWJlcicpIHtcbiAgICBjb25zdCBzdGF0ZXMgPSBbJ0NPTk5FQ1RJTkcnLCAnT1BFTicsICdDTE9TSU5HJywgJ0NMT1NFRCddO1xuICAgIGNvbnN0IHN0YXRlID0gc3RhdGVzWyhldmVudCBhcyBhbnkpLnJlYWR5U3RhdGVdIHx8ICdVTktOT1dOJztcbiAgICBwYXJ0cy5wdXNoKGBSZWFkeSBzdGF0ZTogJHtzdGF0ZX0gKCR7KGV2ZW50IGFzIGFueSkucmVhZHlTdGF0ZX0pYCk7XG4gIH1cbiAgXG4gIHJldHVybiBwYXJ0cy5qb2luKCcgfCAnKTtcbn1cblxuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "genassist-chat-react",
3
- "version": "1.0.16",
3
+ "version": "1.0.18",
4
4
  "description": "React chat component for GenAssist",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.js",
@@ -10,10 +10,14 @@
10
10
  "types": "./dist/index.d.ts",
11
11
  "import": "./dist/index.js",
12
12
  "require": "./dist/index.js",
13
- "default": "./dist/index.js"
13
+ "default": "./dist/index.js",
14
+ "browser": "./dist/index.js"
14
15
  },
15
16
  "./package.json": "./package.json"
16
17
  },
18
+ "browser": {
19
+ "websocket": false
20
+ },
17
21
  "files": [
18
22
  "dist",
19
23
  "assets"
@@ -37,14 +41,12 @@
37
41
  },
38
42
  "dependencies": {
39
43
  "axios": "^1.6.0",
40
- "lucide-react": "^0.511.0",
41
- "websocket": "^1.0.34"
44
+ "lucide-react": "^0.511.0"
42
45
  },
43
46
  "devDependencies": {
44
47
  "@types/react": "^18.2.0",
45
48
  "@types/react-dom": "^18.2.0",
46
49
  "@types/node": "^24.1.0",
47
- "@types/websocket": "^1.0.5",
48
50
  "@vitejs/plugin-react": "^4.7.0",
49
51
  "esbuild": "^0.25.8",
50
52
  "typescript": "^5.0.0",