genassist-chat-react 1.0.21 → 1.0.23

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.
@@ -48,7 +48,8 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
48
48
  import axios from "axios";
49
49
  import { createWebSocket, createWebSocketDiagnostic, } from "../utils/websocket";
50
50
  var ChatService = /** @class */ (function () {
51
- function ChatService(baseUrl, apiKey, metadata, tenant, language) {
51
+ function ChatService(baseUrl, apiKey, metadata, tenant, language, useWs) {
52
+ if (useWs === void 0) { useWs = true; }
52
53
  this.conversationId = null;
53
54
  this.conversationCreateTime = null; // Track conversation start time
54
55
  this.guestToken = null; // Guest token for authorization
@@ -69,6 +70,7 @@ var ChatService = /** @class */ (function () {
69
70
  this.metadata = metadata;
70
71
  this.tenant = tenant;
71
72
  this.language = language;
73
+ this.useWs = useWs;
72
74
  // Try to load a saved conversation for this apiKey from localStorage
73
75
  this.loadSavedConversation();
74
76
  }
@@ -245,6 +247,15 @@ var ChatService = /** @class */ (function () {
245
247
  // ignore
246
248
  }
247
249
  };
250
+ // Check if an error is a token expiration error
251
+ ChatService.prototype.isTokenExpiredError = function (error) {
252
+ return (error.response &&
253
+ error.response.status === 401 &&
254
+ error.response.data &&
255
+ (error.response.data.error === "Token has expired." ||
256
+ error.response.data.message === "Token has expired." ||
257
+ (typeof error.response.data === "string" && error.response.data.includes("Token has expired"))));
258
+ };
248
259
  /**
249
260
  * Reset the current conversation by clearing the ID and websocket
250
261
  */
@@ -370,10 +381,15 @@ var ChatService = /** @class */ (function () {
370
381
  this.welcomeDataHandler(this.welcomeData);
371
382
  }
372
383
  this.saveConversation();
373
- this.connectWebSocket();
384
+ if (this.useWs) {
385
+ this.connectWebSocket();
386
+ }
374
387
  return [2 /*return*/, response.data.conversation_id];
375
388
  case 4:
376
389
  error_1 = _a.sent();
390
+ if (this.isTokenExpiredError(error_1)) {
391
+ this.resetConversation();
392
+ }
377
393
  throw error_1;
378
394
  case 5: return [2 /*return*/];
379
395
  }
@@ -382,7 +398,7 @@ var ChatService = /** @class */ (function () {
382
398
  };
383
399
  ChatService.prototype.sendMessage = function (message, attachments, extraMetadata, reCaptchaToken) {
384
400
  return __awaiter(this, void 0, void 0, function () {
385
- var now, chatMessage, requestBody, mergedMetadata, error_2, errorMessage;
401
+ var now, chatMessage, requestBody, mergedMetadata, response, responseData, i, messageData, agentMessage, error_2, errorMessage;
386
402
  return __generator(this, function (_a) {
387
403
  switch (_a.label) {
388
404
  case 0:
@@ -419,10 +435,52 @@ var ChatService = /** @class */ (function () {
419
435
  headers: this.getHeaders(),
420
436
  })];
421
437
  case 2:
422
- _a.sent();
438
+ response = _a.sent();
439
+ // If not using WebSocket, try to retrieve the response message from the update conversation response
440
+ if (!this.useWs && this.messageHandler) {
441
+ try {
442
+ responseData = response.data;
443
+ if (responseData.messages && Array.isArray(responseData.messages)) {
444
+ // Look for the latest agent message in the response
445
+ for (i = responseData.messages.length - 1; i >= 0; i--) {
446
+ messageData = responseData.messages[i];
447
+ if (messageData.speaker === "agent" &&
448
+ messageData.text &&
449
+ messageData.create_time !== undefined &&
450
+ messageData.start_time !== undefined &&
451
+ messageData.end_time !== undefined) {
452
+ agentMessage = {
453
+ create_time: messageData.create_time,
454
+ start_time: this.conversationCreateTime
455
+ ? messageData.start_time - this.conversationCreateTime
456
+ : messageData.start_time,
457
+ end_time: this.conversationCreateTime
458
+ ? messageData.end_time - this.conversationCreateTime
459
+ : messageData.end_time,
460
+ speaker: "agent",
461
+ text: messageData.text,
462
+ message_id: messageData.message_id || messageData.id,
463
+ };
464
+ // Only process if this is a new message we haven't seen before
465
+ // We can't easily check here, so we'll let the handler manage duplicates
466
+ this.messageHandler(agentMessage);
467
+ break;
468
+ }
469
+ }
470
+ }
471
+ }
472
+ catch (parseError) {
473
+ console.error("Failed to parse update conversation response:", parseError);
474
+ }
475
+ }
423
476
  return [3 /*break*/, 4];
424
477
  case 3:
425
478
  error_2 = _a.sent();
479
+ // Check if this is a token expiration error
480
+ if (this.isTokenExpiredError(error_2)) {
481
+ this.resetConversation();
482
+ throw error_2;
483
+ }
426
484
  // Check if this is the agent inactive error
427
485
  if (error_2.response &&
428
486
  error_2.response.data &&
@@ -470,6 +528,9 @@ var ChatService = /** @class */ (function () {
470
528
  return [2 /*return*/, response.data];
471
529
  case 3:
472
530
  error_3 = _a.sent();
531
+ if (this.isTokenExpiredError(error_3)) {
532
+ this.resetConversation();
533
+ }
473
534
  throw error_3;
474
535
  case 4: return [2 /*return*/];
475
536
  }
@@ -478,6 +539,9 @@ var ChatService = /** @class */ (function () {
478
539
  };
479
540
  ChatService.prototype.connectWebSocket = function () {
480
541
  var _this = this;
542
+ if (!this.useWs) {
543
+ return;
544
+ }
481
545
  if (this.webSocket) {
482
546
  this.webSocket.close();
483
547
  }
@@ -634,6 +698,9 @@ var ChatService = /** @class */ (function () {
634
698
  return [3 /*break*/, 3];
635
699
  case 2:
636
700
  err_1 = _a.sent();
701
+ if (this.isTokenExpiredError(err_1)) {
702
+ this.resetConversation();
703
+ }
637
704
  return [3 /*break*/, 3];
638
705
  case 3: return [2 /*return*/];
639
706
  }
@@ -669,6 +736,9 @@ var ChatService = /** @class */ (function () {
669
736
  return [3 /*break*/, 4];
670
737
  case 3:
671
738
  error_4 = _c.sent();
739
+ if (this.isTokenExpiredError(error_4)) {
740
+ this.resetConversation();
741
+ }
672
742
  console.error('Feedback API call failed:', {
673
743
  message: error_4.message,
674
744
  response: (_a = error_4.response) === null || _a === void 0 ? void 0 : _a.data,
@@ -690,4 +760,4 @@ var ChatService = /** @class */ (function () {
690
760
  return ChatService;
691
761
  }());
692
762
  export { ChatService };
693
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAQ1B,OAAO,EACL,eAAe,EACf,yBAAyB,GAC1B,MAAM,oBAAoB,CAAC;AAE5B;IAyBE,qBACE,OAAe,EACf,MAAc,EACd,QAA8B,EAC9B,MAAe,EACf,QAAiB;QA1BX,mBAAc,GAAkB,IAAI,CAAC;QACrC,2BAAsB,GAAkB,IAAI,CAAC,CAAC,gCAAgC;QAC9E,eAAU,GAAkB,IAAI,CAAC,CAAC,gCAAgC;QAClE,gBAAW,GAAY,KAAK,CAAC;QAC7B,cAAS,GAAqB,IAAI,CAAC;QACnC,mBAAc,GAA4C,IAAI,CAAC;QAC/D,oBAAe,GAAwB,IAAI,CAAC;QAC5C,qBAAgB,GAAwB,IAAI,CAAC;QAC7C,2BAAsB,GAEnB,IAAI,CAAC;QACR,uBAAkB,GAA8C,IAAI,CAAC;QACrE,mBAAc,GAAG,wBAAwB,CAAC;QAC1C,oBAAe,GAAa,EAAE,CAAC;QAC/B,gBAAW,GAAqB,EAAE,CAAC;QACnC,mBAAc,GAAwB,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QACrE,qBAAgB,GAAkB,IAAI,CAAC,CAAC,qBAAqB;QAYnE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACtE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,qEAAqE;QACrE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAEO,mCAAa,GAArB;QACE,2DAA2D;QAC3D,OAAO,UAAG,IAAI,CAAC,cAAc,cAAI,IAAI,CAAC,MAAM,CAAE,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,iCAAW,GAAX,UAAY,QAA4B;QACtC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,iCAAW,GAAX,UAAY,QAAyC;QACnD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED;;;;OAIG;IACK,0CAAoB,GAA5B,UAA6B,QAAgB;QAC3C,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE,CAAC;QAEzB,6DAA6D;QAC7D,IAAM,UAAU,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;QAEjD,wDAAwD;QACxD,IAAM,WAAW,GAA2B;YAC1C,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,OAAO;SACd,CAAC;QAEF,kEAAkE;QAClE,IAAM,SAAS,GAAG,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAE3C,0EAA0E;QAC1E,IAAM,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,UAAU,CAAC,CAAC;QAEpF,uEAAuE;QACvE,IAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAE5D,6FAA6F;QAC7F,4CAA4C;QAC5C,IAAM,KAAK,GAAa,CAAC,UAAU,CAAC,CAAC;QAErC,WAAW;QACX,KAAK,CAAC,IAAI,CAAC,UAAG,YAAY,WAAQ,CAAC,CAAC;QAEpC,8DAA8D;QAC9D,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;YAC1B,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzB,CAAC;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED;;OAEG;IACK,gCAAU,GAAlB,UAAmB,WAAwC;QAAxC,4BAAA,EAAA,gCAAwC;QACzD,IAAM,OAAO,GAA2B;YACtC,WAAW,EAAE,IAAI,CAAC,MAAM;YACxB,cAAc,EAAE,WAAW;SAC5B,CAAC;QAEF,gCAAgC;QAChC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;QACvC,CAAC;QAED,uDAAuD;QACvD,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO,CAAC,eAAe,CAAC,GAAG,iBAAU,IAAI,CAAC,UAAU,CAAE,CAAC;QACzD,CAAC;QAED,gDAAgD;QAChD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAM,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChE,IAAI,cAAc,EAAE,CAAC;gBACnB,OAAO,CAAC,iBAAiB,CAAC,GAAG,cAAc,CAAC;YAC9C,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,uCAAiB,GAAjB,UAAkB,OAAuC;QACvD,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;IAChC,CAAC;IAED,wCAAkB,GAAlB,UAAmB,OAAmB;QACpC,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC;IACjC,CAAC;IAED,yCAAmB,GAAnB,UAAoB,OAAmB;QACrC,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC;IAClC,CAAC;IAED,+CAAyB,GAAzB,UACE,OAAqE;QAErE,IAAI,CAAC,sBAAsB,GAAG,OAAO,CAAC;IACxC,CAAC;IAED,2CAAqB,GAArB,UAAsB,OAAkD;QACtE,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;IACpC,CAAC;IAED,wCAAkB,GAAlB;QACE,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,oCAAc,GAAd;QACE,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,uCAAiB,GAAjB;QACE,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED;;OAEG;IACK,2CAAqB,GAA7B;QACE,IAAI,CAAC;YACH,IAAI,iBAAiB,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YACnE,gEAAgE;YAChE,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACvB,iBAAiB,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAChE,CAAC;YACD,IAAI,iBAAiB,EAAE,CAAC;gBAChB,IAAA,KASF,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAR/B,cAAc,oBAAA,EACd,UAAU,gBAAA,EACV,WAAW,iBAAA,EACX,eAAe,qBAAA,EACf,WAAW,iBAAA,EACX,cAAc,oBAAA,EACd,OAAO,aAAA,EACP,UAAU,gBACqB,CAAC;gBAClC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;gBACrC,IAAI,CAAC,sBAAsB,GAAG,UAAU,CAAC;gBACzC,IAAI,CAAC,WAAW,GAAG,WAAW,IAAI,KAAK,CAAC;gBACxC,IAAI,CAAC,UAAU,GAAG,UAAU,IAAI,IAAI,CAAC;gBACrC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC;oBACnD,CAAC,CAAC,eAAe;oBACjB,CAAC,CAAC,EAAE,CAAC;gBACP,IAAI,CAAC,WAAW,GAAG,WAAW,IAAI,EAAE,CAAC;gBACrC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;oBACtC,IAAI,CAAC,WAAW,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC;gBAC1D,CAAC;gBACD,IAAI,CAAC,cAAc,GAAG;oBACpB,OAAO,EAAE,CAAC,cAAc,IAAI,cAAc,CAAC,OAAO,CAAC,IAAI,EAAE;oBACzD,OAAO,EACL,cAAc,IAAI,OAAO,cAAc,CAAC,OAAO,KAAK,QAAQ;wBAC1D,CAAC,CAAC,cAAc,CAAC,OAAO;wBACxB,CAAC,CAAC,IAAI;iBACX,CAAC;gBACF,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;gBACvB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;oBAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACvC,CAAC;gBACD,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC5C,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,SAAS;QACX,CAAC;IACH,CAAC;IAED;;OAEG;IACK,sCAAgB,GAAxB;QACE,IAAI,CAAC;YACH,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBACvD,IAAM,gBAAgB,GAAG;oBACvB,cAAc,EAAE,IAAI,CAAC,cAAc;oBACnC,UAAU,EAAE,IAAI,CAAC,sBAAsB;oBACvC,WAAW,EAAE,IAAI,CAAC,WAAW;oBAC7B,eAAe,EAAE,IAAI,CAAC,eAAe;oBACrC,WAAW,wBACN,IAAI,CAAC,WAAW,KACnB,QAAQ,EACN,IAAI,CAAC,gBAAgB;4BACrB,IAAI,CAAC,WAAW,CAAC,QAAQ;4BACzB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC;4BAC3C,CAAC,CAAC,IAAI;4BACN,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,GACxC;oBACD,cAAc,EAAE,IAAI,CAAC,cAAc;oBACnC,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,UAAU,EAAE,IAAI,CAAC,UAAU;iBAC5B,CAAC;gBACF,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC;YAC/E,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,SAAS;QACX,CAAC;IACH,CAAC;IAED;;OAEG;IACH,uCAAiB,GAAjB;QACE,sDAAsD;QACtD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACxB,CAAC;QAED,4BAA4B;QAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,yBAAyB;QACzB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QACrD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC;gBACH,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC7C,CAAC;YAAC,WAAM,CAAC,CAAA,CAAC;YACV,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QAEzB,4BAA4B;QAC5B,IAAI,CAAC;YACH,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QAChD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,SAAS;QACX,CAAC;IACH,CAAC;IAED;;OAEG;IACH,2CAAqB,GAArB;QACE,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,uCAAiB,GAAjB;QACE,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,6CAAuB,GAAvB;QACE,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAEK,uCAAiB,GAAvB,UAAwB,cAAkC;;;;;;;wBAEhD,WAAW,GAAQ;4BACvB,QAAQ,EAAE,EAAE;4BACZ,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;4BACrC,cAAc,EAAE,sCAAsC;4BACtD,eAAe,EAAE,cAAc;yBAChC,CAAC;wBAEF,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;4BAClB,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;wBACvC,CAAC;wBAEgB,qBAAM,KAAK,CAAC,IAAI,CAC/B,UAAG,IAAI,CAAC,OAAO,yCAAsC,EACrD,WAAW,EACX;gCACE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;6BAC3B,CACF,EAAA;;wBANK,QAAQ,GAAG,SAMhB;wBAED,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC;wBACpD,0FAA0F;wBAC1F,IAAI,CAAC,sBAAsB,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW;4BACrD,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI;4BAClC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;wBACtB,gCAAgC;wBAChC,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC;wBACpD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;wBAEzB,sCAAsC;wBACtC,IACE,QAAQ,CAAC,IAAI,CAAC,sBAAsB;4BACpC,QAAQ,CAAC,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,CAAC,EAC/C,CAAC;4BACD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAChE,UAAC,KAAK,IAAK,OAAA,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAApD,CAAoD,CAChE,CAAC;wBACJ,CAAC;wBAEK,OAAO,GAAQ,QAAQ,CAAC,IAAW,CAAC;wBACpC,OAAO,GAAuB,OAAO,CAAC,QAAQ,CAAC;wBACrD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;wBACjB,YAAY,GAAuB,OAAO,CAAC,mBAAmB,CAAC;wBAC/D,eAAe,GACnB,OAAO,CAAC,uBAAuB,CAAC;wBAC5B,eAAe,GACnB,OAAO,CAAC,sBAAsB,CAAC;wBAC3B,gBAAgB,GACpB,OAAO,CAAC,2BAA2B,CAAC;wBAEtC,IAAI,CAAC,WAAW,GAAG;4BACjB,KAAK,EAAE,YAAY,IAAI,IAAI;4BAC3B,OAAO,EAAE,IAAI;4BACb,QAAQ,EAAE,eAAe,IAAI,IAAI;4BACjC,eAAe,EAAE,IAAI,CAAC,eAAe;yBACtC,CAAC;wBAEF,IAAI,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BACjE,IAAI,CAAC,cAAc,CAAC,OAAO,GAAG,eAAe,CAAC;wBAChD,CAAC;wBACD,IAAI,OAAO,gBAAgB,KAAK,QAAQ,IAAI,gBAAgB,IAAI,CAAC,EAAE,CAAC;4BAClE,IAAI,CAAC,cAAc,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CACpC,GAAG,EACH,IAAI,CAAC,KAAK,CAAC,gBAAgB,GAAG,IAAI,CAAC,CACpC,CAAC;wBACJ,CAAC;6BAEG,CAAA,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,OAAO,CAAA,EAArC,wBAAqC;wBACvC,qBAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAA;;wBAArC,SAAqC,CAAC;;;wBAGxC,6CAA6C;wBAC7C,IAAI,QAAQ,CAAC,IAAI,CAAC,qBAAqB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;4BACzD,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;4BACxB,cAAc,GAAgB;gCAClC,WAAW,EAAE,GAAG;gCAChB,UAAU,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB,EAAE,iCAAiC;gCAChF,QAAQ,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB,GAAG,IAAI,EAAE,iCAAiC;gCACrF,OAAO,EAAE,OAAO;gCAChB,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,qBAAqB;6BAC1C,CAAC;4BACF,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC;4BAC/D,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;wBACtC,CAAC;wBAED,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;4BAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBAC5C,CAAC;wBAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBACxB,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBACxB,sBAAO,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAC;;;wBAErC,MAAM,OAAK,CAAC;;;;;KAEf;IAEK,iCAAW,GAAjB,UACE,OAAe,EACf,WAA0B,EAC1B,aAAmC,EACnC,cAAuB;;;;;;wBAEvB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;4BACzD,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;wBAC9C,CAAC;wBAEK,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;wBACxB,WAAW,GAAgB;4BAC/B,WAAW,EAAE,GAAG;4BAChB,UAAU,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB,EAAE,iCAAiC;4BAChF,QAAQ,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB,GAAG,IAAI,EAAE,iCAAiC;4BACrF,OAAO,EAAE,UAAU;4BACnB,IAAI,EAAE,OAAO;4BACb,WAAW,EAAE,WAAW;yBACzB,CAAC;wBAEF,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;4BACxB,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;wBACnC,CAAC;;;;wBAGO,WAAW,GAAQ;4BACvB,QAAQ,EAAE,CAAC,WAAW,CAAC;4BACvB,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;yBACtC,CAAC;wBAEF,IAAI,cAAc,EAAE,CAAC;4BACnB,WAAW,CAAC,eAAe,GAAG,cAAc,CAAC;wBAC/C,CAAC;wBAGK,cAAc,yBACf,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,GACrB,CAAC,aAAa,IAAI,EAAE,CAAC,CACzB,CAAC;wBACF,IAAI,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BAC3C,WAAW,CAAC,QAAQ,GAAG,cAAc,CAAC;wBACxC,CAAC;wBAED,qBAAM,KAAK,CAAC,KAAK,CACf,UAAG,IAAI,CAAC,OAAO,mDAAyC,IAAI,CAAC,cAAc,CAAE,EAC7E,WAAW,EACX;gCACE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;6BAC3B,CACF,EAAA;;wBAND,SAMC,CAAC;;;;wBAEF,4CAA4C;wBAC5C,IACE,OAAK,CAAC,QAAQ;4BACd,OAAK,CAAC,QAAQ,CAAC,IAAI;4BACnB,OAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,KAAK,gBAAgB,EAClD,CAAC;4BACD,uDAAuD;4BACvD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gCAClB,YAAY,GAAgB;oCAChC,WAAW,EAAE,GAAG;oCAChB,UAAU,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB;oCAC7C,QAAQ,EAAE,GAAG,GAAG,IAAI,CAAC,sBAAsB,GAAG,IAAI;oCAClD,OAAO,EAAE,SAAS;oCAClB,IAAI,EAAE,qEAAqE;iCAC5E,CAAC;gCACF,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;4BACpC,CAAC;4BACD,2DAA2D;4BAC3D,sBAAO;wBACT,CAAC;wBAED,MAAM,OAAK,CAAC;;;;;KAEf;IAEK,gCAAU,GAAhB,UAAiB,MAAc,EAAE,IAAU;;;;;;wBACzC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;4BACzB,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;wBAC9C,CAAC;wBAEK,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;wBAChC,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;wBACnC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;;;;wBAGX,qBAAM,KAAK,CAAC,IAAI,CAC/B,UAAG,IAAI,CAAC,OAAO,6CAA0C,EACzD,QAAQ,EACR;gCACE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC;6BAChD,CACF,EAAA;;wBANK,QAAQ,GAAG,SAMhB;wBACD,sBAAO,QAAQ,CAAC,IAAI,EAAC;;;wBAErB,MAAM,OAAK,CAAC;;;;;KAEf;IAED,sCAAgB,GAAhB;QAAA,iBA4IC;QA3IC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QAED,IAAI,IAAI,CAAC,sBAAsB;YAAE,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,CAAC;QAE3E,iDAAiD;QACjD,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAClD,IAAM,MAAM,GAAG,CAAC,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QACnD,IAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,iBAAU,CAAC,CAAE,EAAb,CAAa,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAE/D,+DAA+D;QAC/D,IAAM,SAAS,GAAG,IAAI,CAAC,UAAU;YAC/B,CAAC,CAAC,uBAAgB,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAE;YACvD,CAAC,CAAC,kBAAW,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAE,CAAC;QAEjD,IAAI,KAAK,GAAG,UAAG,MAAM,mCAAyB,IAAI,CAAC,cAAc,cAAI,SAAS,sBAAY,WAAW,CAAE,CAAC;QAExG,4CAA4C;QAC5C,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,KAAK,IAAI,uBAAgB,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAE,CAAC;QAC7D,CAAC;QAED,uCAAuC;QACvC,IAAI,CAAC,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;QAGxC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG;YACtB,IAAI,KAAI,CAAC,sBAAsB;gBAAE,KAAI,CAAC,sBAAsB,CAAC,WAAW,CAAC,CAAC;QAC5E,CAAC,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,SAAS,GAAG,UAAC,KAAmB;YAC7C,IAAI,CAAC;gBACH,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAc,CAAC,CAAC;gBAC9C,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,KAAI,CAAC,cAAc,EAAE,CAAC;oBACnD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;wBAChC,IAAM,QAAQ,GAAG,IAAI,CAAC,OAAwB,CAAC;wBAC/C,yDAAyD;wBACzD,oFAAoF;wBACpF,IAAM,gBAAgB,GAAG,QAAQ;6BAC9B,GAAG,CAAC,UAAC,GAAG;4BACP,IAAM,QAAQ,GAAG,KAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;4BACnD,2DAA2D;4BAC3D,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAK,GAAW,CAAC,EAAE,EAAE,CAAC;gCAC5C,QAAQ,CAAC,UAAU,GAAI,GAAW,CAAC,EAAE,CAAC;4BACxC,CAAC;4BACD,OAAO,QAAQ,CAAC;wBAClB,CAAC,CAAC;6BACD,MAAM,CAAC,UAAC,GAAG,IAAK,OAAA,GAAG,CAAC,OAAO,KAAK,UAAU,EAA1B,CAA0B,CAAC,CAAC;wBAC/C,gBAAgB,CAAC,OAAO,CAAC,KAAI,CAAC,cAAc,CAAC,CAAC;oBAChD,CAAC;yBAAM,CAAC;wBACN,IAAM,eAAe,GAAG,KAAI,CAAC,uBAAuB,CAClD,IAAI,CAAC,OAAsB,CAC5B,CAAC;wBACF,2DAA2D;wBAC3D,IAAI,CAAC,eAAe,CAAC,UAAU,IAAK,IAAI,CAAC,OAAe,CAAC,EAAE,EAAE,CAAC;4BAC5D,eAAe,CAAC,UAAU,GAAI,IAAI,CAAC,OAAe,CAAC,EAAE,CAAC;wBACxD,CAAC;wBACD,IAAI,eAAe,CAAC,OAAO,KAAK,UAAU,EAAE,CAAC;4BAC3C,KAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;wBACvC,CAAC;oBACH,CAAC;gBACH,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBACpC,wBAAwB;oBACxB,oDAAoD;oBACpD,IAAI,KAAI,CAAC,cAAc,EAAE,CAAC;wBACxB,IAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;wBAC9B,IAAM,eAAe,GAAgB;4BACnC,WAAW,EAAE,GAAG;4BAChB,UAAU,EAAE,KAAI,CAAC,sBAAsB;gCACrC,CAAC,CAAC,GAAG,GAAG,KAAI,CAAC,sBAAsB;gCACnC,CAAC,CAAC,CAAC;4BACL,QAAQ,EAAE,KAAI,CAAC,sBAAsB;gCACnC,CAAC,CAAC,GAAG,GAAG,KAAI,CAAC,sBAAsB,GAAG,IAAI;gCAC1C,CAAC,CAAC,IAAI;4BACR,OAAO,EAAE,SAAS;4BAClB,IAAI,EAAE,sBAAsB;yBAC7B,CAAC;wBACF,KAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;oBACvC,CAAC;oBAED,wCAAwC;oBACxC,IAAI,KAAI,CAAC,eAAe,EAAE,CAAC;wBACzB,KAAI,CAAC,eAAe,EAAE,CAAC;oBACzB,CAAC;gBACH,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBACpC,yBAAyB;oBACzB,qDAAqD;oBACrD,IAAI,KAAI,CAAC,cAAc,EAAE,CAAC;wBACxB,IAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;wBAC9B,IAAM,gBAAgB,GAAgB;4BACpC,WAAW,EAAE,GAAG;4BAChB,UAAU,EAAE,KAAI,CAAC,sBAAsB;gCACrC,CAAC,CAAC,GAAG,GAAG,KAAI,CAAC,sBAAsB;gCACnC,CAAC,CAAC,CAAC;4BACL,QAAQ,EAAE,KAAI,CAAC,sBAAsB;gCACnC,CAAC,CAAC,GAAG,GAAG,KAAI,CAAC,sBAAsB,GAAG,IAAI;gCAC1C,CAAC,CAAC,IAAI;4BACR,OAAO,EAAE,SAAS;4BAClB,IAAI,EAAE,wBAAwB;yBAC/B,CAAC;wBACF,KAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;oBACxC,CAAC;oBAED,yCAAyC;oBACzC,IAAI,KAAI,CAAC,gBAAgB,EAAE,CAAC;wBAC1B,KAAI,CAAC,gBAAgB,EAAE,CAAC;oBAC1B,CAAC;oBACD,KAAI,CAAC,WAAW,GAAG,IAAI,CAAC;oBACxB,KAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,SAAS;YACX,CAAC;QACH,CAAC,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,UAAC,KAAY;YACpC,IAAI,KAAI,CAAC,sBAAsB;gBAC7B,KAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;YAE9C,iBAAiB;YACjB,IAAM,UAAU,GAAG,yBAAyB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAC3D,OAAO,CAAC,KAAK,CAAC,2BAAoB,UAAU,CAAE,CAAC,CAAC;QAClD,CAAC,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,UAAC,KAAiB;YACzC,IAAI,KAAI,CAAC,sBAAsB;gBAC7B,KAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;YAE9C,iBAAiB;YACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACpB,IAAM,UAAU,GAAG,yBAAyB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBAC3D,OAAO,CAAC,IAAI,CAAC,2BAAoB,UAAU,CAAE,CAAC,CAAC;YACjD,CAAC;QACH,CAAC,CAAC;IACJ,CAAC;IAED,gCAAU,GAAV;QACE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACxB,CAAC;IACH,CAAC;IAEa,uCAAiB,GAA/B,UAAgC,OAAe;;;;;;;wBAErB,qBAAM,KAAK,CAAC,GAAG,CACnC,UAAG,IAAI,CAAC,OAAO,0CAAgC,OAAO,mBAAgB,EACtE;gCACE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;gCAC1B,YAAY,EAAE,MAAM;6BACrB,CACF,EAAA;;wBANK,aAAa,GAAG,SAMrB;wBACK,OAAO,GAAG,GAAG,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;wBACxD,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC;wBAChC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,OAAO,CAAC;wBACpC,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;4BAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBAC5C,CAAC;;;;;;;;;KAIJ;IAED,+DAA+D;IACzD,iCAAW,GAAjB,UACE,SAAiB,EACjB,QAAwB,EACxB,gBAAyB;;;;;;;wBAEzB,IAAI,CAAC,SAAS,EAAE,CAAC;4BACf,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;wBACzD,CAAC;;;;wBAIO,GAAG,GAAG,UAAG,IAAI,CAAC,OAAO,qDAA2C,SAAS,CAAE,CAAC;wBAE5E,OAAO,GAGT;4BACF,QAAQ,UAAA;yBACT,CAAC;wBAEF,IAAI,gBAAgB,EAAE,CAAC;4BACrB,OAAO,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;wBAC9C,CAAC;wBAED,qBAAM,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,EAAE;gCAC9B,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;6BAC3B,CAAC,EAAA;;wBAFF,SAEE,CAAC;;;;wBAGH,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE;4BACzC,OAAO,EAAE,OAAK,CAAC,OAAO;4BACtB,QAAQ,EAAE,MAAA,OAAK,CAAC,QAAQ,0CAAE,IAAI;4BAC9B,MAAM,EAAE,MAAA,OAAK,CAAC,QAAQ,0CAAE,MAAM;yBAC/B,CAAC,CAAC;wBACH,MAAM,OAAK,CAAC;;;;;KAEf;IAED,4EAA4E;IACpE,6CAAuB,GAA/B,UAAgC,OAAoB;QAClD,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YACjC,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,6BACK,OAAO,KACV,UAAU,EAAE,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,sBAAsB,EAC5D,QAAQ,EAAE,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,sBAAsB,IACxD;IACJ,CAAC;IACH,kBAAC;AAAD,CAAC,AArtBD,IAqtBC","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 guestToken: string | null = null; // Guest token for authorization\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  private language: string | undefined;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string,\n    language?: 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    this.language = language;\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  /**\n   * Set the language for Accept-Language header\n   */\n  setLanguage(language: string | undefined): void {\n    this.language = language;\n  }\n\n  /**\n   * Update metadata (useful for updating language or other dynamic metadata)\n   */\n  setMetadata(metadata: Record<string, any> | undefined): void {\n    this.metadata = metadata;\n  }\n\n  /**\n   * Format language code for Accept-Language header\n   * Converts simple language codes (e.g., \"en\", \"es\") to proper format (e.g., \"en-US,en;q=0.9\")\n   * Follows HTTP Accept-Language header standards\n   */\n  private formatAcceptLanguage(langCode: string): string {\n    if (!langCode) return '';\n    \n    // Normalize language code (lowercase, handle common formats)\n    const normalized = langCode.toLowerCase().trim();\n    \n    // Map common language codes to their full locale format\n    const languageMap: Record<string, string> = {\n      'en': 'en-US',\n      'es': 'es-ES',\n      'fr': 'fr-FR',\n      'de': 'de-DE',\n      'it': 'it-IT',\n      'pt': 'pt-PT',\n      'ar': 'ar-SA',\n      'sq': 'sq-AL',\n    };\n    \n    // Check if the code already has a region (e.g., \"en-US\", \"es-ES\")\n    const hasRegion = normalized.includes('-');\n    \n    // Get the full locale or use the provided code if it already has a region\n    const fullLocale = hasRegion ? normalized : (languageMap[normalized] || normalized);\n    \n    // Extract base language from the full locale (e.g., \"en\" from \"en-US\")\n    const fullBaseLang = fullLocale.split('-')[0].toLowerCase();\n    \n    // Build Accept-Language header: primary locale, base language with quality, English fallback\n    // Format: \"locale,base-lang;q=0.9,en;q=0.8\"\n    const parts: string[] = [fullLocale];\n    \n    // fallback\n    parts.push(`${fullBaseLang};q=0.9`);\n    \n    // Add English as fallback if not already the primary language\n    if (fullBaseLang !== 'en') {\n      parts.push('en;q=0.8');\n    }\n    \n    return parts.join(', ');\n  }\n\n  /**\n   * Get headers for API requests, including authorization if guest token is available\n   */\n  private getHeaders(contentType: string = \"application/json\"): Record<string, string> {\n    const headers: Record<string, string> = {\n      \"x-api-key\": this.apiKey,\n      \"Content-Type\": contentType,\n    };\n\n    // Add tenant header if provided\n    if (this.tenant) {\n      headers[\"x-tenant-id\"] = this.tenant;\n    }\n\n    // Add authorization header if guest token is available\n    if (this.guestToken) {\n      headers[\"Authorization\"] = `Bearer ${this.guestToken}`;\n    }\n\n    // Add Accept-Language header if language is set\n    if (this.language) {\n      const acceptLanguage = this.formatAcceptLanguage(this.language);\n      if (acceptLanguage) {\n        headers[\"Accept-Language\"] = acceptLanguage;\n      }\n    }\n\n    return headers;\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          guestToken,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.guestToken = guestToken || null;\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          guestToken: this.guestToken,\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.guestToken = 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(reCaptchaToken: string | undefined): 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        recaptcha_token: reCaptchaToken,\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: this.getHeaders(),\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      // Store guest token if provided\n      this.guestToken = response.data.guest_token || null;\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    reCaptchaToken?: string\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      if (reCaptchaToken) {\n        requestBody.recaptcha_token = reCaptchaToken;\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: this.getHeaders(),\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: this.getHeaders(\"multipart/form-data\"),\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    \n    // Build WebSocket URL with proper authentication\n    const wsBase = this.baseUrl.replace(\"http\", \"ws\");\n    const topics = [\"message\", \"takeover\", \"finalize\"];\n    const topicsQuery = topics.map((t) => `topics=${t}`).join(\"&\");\n    \n    // Use guest_token if available, otherwise fall back to api_key\n    const authParam = this.guestToken \n      ? `access_token=${encodeURIComponent(this.guestToken)}`\n      : `api_key=${encodeURIComponent(this.apiKey)}`;\n    \n    let wsUrl = `${wsBase}/api/conversations/ws/${this.conversationId}?${authParam}&lang=en&${topicsQuery}`;\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: this.getHeaders(),\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: this.getHeaders(),\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"]}
763
+ //# 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  FileUploadResponse,\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 guestToken: string | null = null; // Guest token for authorization\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  private language: string | undefined;\n  private useWs: boolean;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string,\n    language?: string,\n    useWs: boolean = true\n  ) {\n    this.baseUrl = baseUrl.endsWith(\"/\") ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    this.tenant = tenant;\n    this.language = language;\n    this.useWs = useWs;\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  /**\n   * Set the language for Accept-Language header\n   */\n  setLanguage(language: string | undefined): void {\n    this.language = language;\n  }\n\n  /**\n   * Update metadata (useful for updating language or other dynamic metadata)\n   */\n  setMetadata(metadata: Record<string, any> | undefined): void {\n    this.metadata = metadata;\n  }\n\n  /**\n   * Format language code for Accept-Language header\n   * Converts simple language codes (e.g., \"en\", \"es\") to proper format (e.g., \"en-US,en;q=0.9\")\n   * Follows HTTP Accept-Language header standards\n   */\n  private formatAcceptLanguage(langCode: string): string {\n    if (!langCode) return '';\n    \n    // Normalize language code (lowercase, handle common formats)\n    const normalized = langCode.toLowerCase().trim();\n    \n    // Map common language codes to their full locale format\n    const languageMap: Record<string, string> = {\n      'en': 'en-US',\n      'es': 'es-ES',\n      'fr': 'fr-FR',\n      'de': 'de-DE',\n      'it': 'it-IT',\n      'pt': 'pt-PT',\n      'ar': 'ar-SA',\n      'sq': 'sq-AL',\n    };\n    \n    // Check if the code already has a region (e.g., \"en-US\", \"es-ES\")\n    const hasRegion = normalized.includes('-');\n    \n    // Get the full locale or use the provided code if it already has a region\n    const fullLocale = hasRegion ? normalized : (languageMap[normalized] || normalized);\n    \n    // Extract base language from the full locale (e.g., \"en\" from \"en-US\")\n    const fullBaseLang = fullLocale.split('-')[0].toLowerCase();\n    \n    // Build Accept-Language header: primary locale, base language with quality, English fallback\n    // Format: \"locale,base-lang;q=0.9,en;q=0.8\"\n    const parts: string[] = [fullLocale];\n    \n    // fallback\n    parts.push(`${fullBaseLang};q=0.9`);\n    \n    // Add English as fallback if not already the primary language\n    if (fullBaseLang !== 'en') {\n      parts.push('en;q=0.8');\n    }\n    \n    return parts.join(', ');\n  }\n\n  /**\n   * Get headers for API requests, including authorization if guest token is available\n   */\n  private getHeaders(contentType: string = \"application/json\"): Record<string, string> {\n    const headers: Record<string, string> = {\n      \"x-api-key\": this.apiKey,\n      \"Content-Type\": contentType,\n    };\n\n    // Add tenant header if provided\n    if (this.tenant) {\n      headers[\"x-tenant-id\"] = this.tenant;\n    }\n\n    // Add authorization header if guest token is available\n    if (this.guestToken) {\n      headers[\"Authorization\"] = `Bearer ${this.guestToken}`;\n    }\n\n    // Add Accept-Language header if language is set\n    if (this.language) {\n      const acceptLanguage = this.formatAcceptLanguage(this.language);\n      if (acceptLanguage) {\n        headers[\"Accept-Language\"] = acceptLanguage;\n      }\n    }\n\n    return headers;\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          guestToken,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.guestToken = guestToken || null;\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          guestToken: this.guestToken,\n        };\n        localStorage.setItem(this.getStorageKey(), JSON.stringify(conversationData));\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  // Check if an error is a token expiration error\n  private isTokenExpiredError(error: any): boolean {\n    return (\n      error.response &&\n      error.response.status === 401 &&\n      error.response.data &&\n      (error.response.data.error === \"Token has expired.\" ||\n        error.response.data.message === \"Token has expired.\" ||\n        (typeof error.response.data === \"string\" && error.response.data.includes(\"Token has expired\")))\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.guestToken = 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(reCaptchaToken: string | undefined): 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        recaptcha_token: reCaptchaToken,\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: this.getHeaders(),\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      // Store guest token if provided\n      this.guestToken = response.data.guest_token || null;\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      if (this.useWs) {\n        this.connectWebSocket();\n      }\n      return response.data.conversation_id;\n    } catch (error: any) {\n      if (this.isTokenExpiredError(error)) {\n        this.resetConversation();\n      }\n      throw error;\n    }\n  }\n\n  async sendMessage(\n    message: string,\n    attachments?: Attachment[],\n    extraMetadata?: Record<string, any>,\n    reCaptchaToken?: string\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      if (reCaptchaToken) {\n        requestBody.recaptcha_token = reCaptchaToken;\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      const response = await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        requestBody,\n        {\n          headers: this.getHeaders(),\n        }\n      );\n\n      // If not using WebSocket, try to retrieve the response message from the update conversation response\n      if (!this.useWs && this.messageHandler) {\n        try {\n          const responseData = response.data as any;\n          \n          if (responseData.messages && Array.isArray(responseData.messages)) {\n            // Look for the latest agent message in the response\n            for (let i = responseData.messages.length - 1; i >= 0; i--) {\n              const messageData = responseData.messages[i];\n              \n              if (\n                messageData.speaker === \"agent\" &&\n                messageData.text &&\n                messageData.create_time !== undefined &&\n                messageData.start_time !== undefined &&\n                messageData.end_time !== undefined\n              ) {\n                const agentMessage: ChatMessage = {\n                  create_time: messageData.create_time,\n                  start_time: this.conversationCreateTime\n                    ? messageData.start_time - this.conversationCreateTime\n                    : messageData.start_time,\n                  end_time: this.conversationCreateTime\n                    ? messageData.end_time - this.conversationCreateTime\n                    : messageData.end_time,\n                  speaker: \"agent\",\n                  text: messageData.text,\n                  message_id: messageData.message_id || messageData.id,\n                };\n                \n                // Only process if this is a new message we haven't seen before\n                // We can't easily check here, so we'll let the handler manage duplicates\n                this.messageHandler(agentMessage);\n                break;\n              }\n            }\n          }\n        } catch (parseError) {\n          console.error(\"Failed to parse update conversation response:\", parseError);\n        }\n      }\n    } catch (error: any) {\n      // Check if this is a token expiration error\n      if (this.isTokenExpiredError(error)) {\n        this.resetConversation();\n        throw error;\n      }\n\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<FileUploadResponse | null> {\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<FileUploadResponse>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: this.getHeaders(\"multipart/form-data\"),\n        }\n      );\n\n      return response.data as FileUploadResponse;\n    } catch (error: any) {\n      if (this.isTokenExpiredError(error)) {\n        this.resetConversation();\n      }\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (!this.useWs) {\n      return;\n    }\n\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    \n    // Build WebSocket URL with proper authentication\n    const wsBase = this.baseUrl.replace(\"http\", \"ws\");\n    const topics = [\"message\", \"takeover\", \"finalize\"];\n    const topicsQuery = topics.map((t) => `topics=${t}`).join(\"&\");\n    \n    // Use guest_token if available, otherwise fall back to api_key\n    const authParam = this.guestToken \n      ? `access_token=${encodeURIComponent(this.guestToken)}`\n      : `api_key=${encodeURIComponent(this.apiKey)}`;\n    \n    let wsUrl = `${wsBase}/api/conversations/ws/${this.conversationId}?${authParam}&lang=en&${topicsQuery}`;\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\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: this.getHeaders(),\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: any) {\n      if (this.isTokenExpiredError(err)) {\n        this.resetConversation();\n      }\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: this.getHeaders(),\n      });\n      \n    } catch (error: any) {\n      if (this.isTokenExpiredError(error)) {\n        this.resetConversation();\n      }\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"]}
@@ -14,12 +14,18 @@ export interface ChatMessage {
14
14
  attachments?: Attachment[];
15
15
  message_id?: string;
16
16
  feedback?: MessageFeedback[];
17
+ type?: string;
17
18
  }
18
19
  export interface Attachment {
19
20
  name: string;
20
21
  type: string;
21
22
  size: number;
22
23
  url: string;
24
+ file_id?: string;
25
+ }
26
+ export interface AttachmentWithFile {
27
+ file: File;
28
+ attachment: Attachment | null;
23
29
  }
24
30
  export interface StartConversationResponse {
25
31
  message: string;
@@ -60,6 +66,12 @@ export interface ScheduleItem {
60
66
  title?: string | null;
61
67
  restaurants: DynamicChatItem[];
62
68
  }
69
+ export interface FileItem {
70
+ url: string;
71
+ type: string;
72
+ name: string;
73
+ id: string;
74
+ }
63
75
  export type ChatContentBlock = {
64
76
  kind: "text";
65
77
  text: string;
@@ -72,12 +84,16 @@ export type ChatContentBlock = {
72
84
  } | {
73
85
  kind: "options";
74
86
  options: string[];
87
+ } | {
88
+ kind: "file";
89
+ data: FileItem;
75
90
  };
76
91
  export interface GenAgentChatProps {
77
92
  baseUrl: string;
78
93
  apiKey: string;
79
94
  tenant: string | undefined;
80
95
  metadata?: Record<string, any>;
96
+ useWs?: boolean;
81
97
  onError?: (error: Error) => void;
82
98
  onTakeover?: () => void;
83
99
  onFinalize?: () => void;
@@ -90,6 +106,7 @@ export interface GenAgentChatProps {
90
106
  textColor?: string;
91
107
  };
92
108
  headerTitle?: string;
109
+ description?: string;
93
110
  placeholder?: string;
94
111
  agentName?: string;
95
112
  logoUrl?: string;
@@ -107,5 +124,19 @@ export interface GenAgentChatProps {
107
124
  translations?: Partial<Translations>;
108
125
  reCaptchaKey?: string;
109
126
  widget?: boolean;
127
+ useAudio?: boolean;
128
+ useFile?: boolean;
129
+ noColorAnimation?: boolean;
130
+ showWelcomeBeforeStart?: boolean;
131
+ allowedExtensions?: AllowedExtension[];
110
132
  }
133
+ export type AllowedExtension = 'image/*' | 'image/png' | 'image/jpeg' | 'image/jpg' | 'image/gif' | 'application/pdf' | 'application/msword' | 'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
111
134
  export type { Translations } from '../utils/i18n';
135
+ export interface FileUploadResponse {
136
+ filename: string;
137
+ original_filename: string;
138
+ storage_path: string;
139
+ file_path: string;
140
+ file_url: string;
141
+ file_id?: string;
142
+ }
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zbGF0aW9ucyB9IGZyb20gJy4uL3V0aWxzL2kxOG4nO1xuXG4vLyBDaGF0IG1lc3NhZ2UgdHlwZXNcbmV4cG9ydCBpbnRlcmZhY2UgTWVzc2FnZUZlZWRiYWNrIHtcbiAgZmVlZGJhY2s6IFwiZ29vZFwiIHwgXCJiYWRcIjtcbiAgZmVlZGJhY2tfdGltZXN0YW1wPzogc3RyaW5nO1xuICBmZWVkYmFja191c2VyX2lkPzogc3RyaW5nO1xuICBmZWVkYmFja19tZXNzYWdlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRNZXNzYWdlIHtcbiAgY3JlYXRlX3RpbWU6IG51bWJlcjtcbiAgc3RhcnRfdGltZTogbnVtYmVyO1xuICBlbmRfdGltZTogbnVtYmVyO1xuICBzcGVha2VyOiBcImN1c3RvbWVyXCIgfCBcImFnZW50XCIgfCBcInNwZWNpYWxcIjtcbiAgdGV4dDogc3RyaW5nO1xuICBhdHRhY2htZW50cz86IEF0dGFjaG1lbnRbXTtcbiAgLy8gT3B0aW9uYWwgbWV0YWRhdGFcbiAgbWVzc2FnZV9pZD86IHN0cmluZztcbiAgZmVlZGJhY2s/OiBNZXNzYWdlRmVlZGJhY2tbXTtcbn1cblxuLy8gQXR0YWNobWVudCB0eXBlXG5leHBvcnQgaW50ZXJmYWNlIEF0dGFjaG1lbnQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHR5cGU6IHN0cmluZztcbiAgc2l6ZTogbnVtYmVyO1xuICB1cmw6IHN0cmluZztcbn1cblxuLy8gQVBJIFJlc3BvbnNlIHR5cGVzXG5leHBvcnQgaW50ZXJmYWNlIFN0YXJ0Q29udmVyc2F0aW9uUmVzcG9uc2Uge1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIGNvbnZlcnNhdGlvbl9pZDogc3RyaW5nO1xuICBhZ2VudF93ZWxjb21lX21lc3NhZ2U/OiBzdHJpbmc7XG4gIGFnZW50X3Bvc3NpYmxlX3F1ZXJpZXM/OiBzdHJpbmdbXTtcbiAgYWdlbnRfd2VsY29tZV90aXRsZT86IHN0cmluZztcbiAgYWdlbnRfd2VsY29tZV9pbWFnZV91cmw/OiBzdHJpbmc7XG4gIGFnZW50X2lkPzogc3RyaW5nO1xuICBhZ2VudF90aGlua2luZ19waHJhc2VzPzogc3RyaW5nW107XG4gIGFnZW50X3RoaW5raW5nX3BocmFzZV9kZWxheT86IG51bWJlcjsgLy8gc2Vjb25kc1xuICBjcmVhdGVfdGltZT86IG51bWJlcjtcbiAgZ3Vlc3RfdG9rZW4/OiBzdHJpbmc7XG59XG5cbi8vIEFnZW50IHdlbGNvbWUvY29uZmlnIGluZm9cbmV4cG9ydCBpbnRlcmZhY2UgQWdlbnRXZWxjb21lRGF0YSB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgbWVzc2FnZT86IHN0cmluZyB8IG51bGw7XG4gIGltYWdlVXJsPzogc3RyaW5nIHwgbnVsbDtcbiAgcG9zc2libGVRdWVyaWVzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWdlbnRUaGlua2luZ0NvbmZpZyB7XG4gIHBocmFzZXM6IHN0cmluZ1tdO1xuICBkZWxheU1zOiBudW1iZXI7IC8vIHJvdGF0aW9uIGRlbGF5IGluIG1zXG59XG5cbi8vIEludGVyYWN0aXZlIGNvbnRlbnQgdHlwZXNcbmV4cG9ydCBpbnRlcmZhY2UgRHluYW1pY0NoYXRJdGVtIHtcbiAgaWQ6IHN0cmluZztcbiAgaW1hZ2U/OiBzdHJpbmc7XG4gIHR5cGU/OiBzdHJpbmc7XG4gIGNhdGVnb3J5Pzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICB2ZW51ZUlkPzogc3RyaW5nO1xuICBzbG90cz86IHN0cmluZ1tdO1xuICBzZWxlY3RlZFNsb3Q/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZWR1bGVJdGVtIHtcbiAgaWQ6IHN0cmluZztcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICByZXN0YXVyYW50czogRHluYW1pY0NoYXRJdGVtW107XG59XG5cbmV4cG9ydCB0eXBlIENoYXRDb250ZW50QmxvY2sgPVxuICB8IHsga2luZDogXCJ0ZXh0XCI7IHRleHQ6IHN0cmluZyB9XG4gIHwgeyBraW5kOiBcIml0ZW1zXCI7IGl0ZW1zOiBEeW5hbWljQ2hhdEl0ZW1bXSB9XG4gIHwgeyBraW5kOiBcInNjaGVkdWxlXCI7IHNjaGVkdWxlOiBTY2hlZHVsZUl0ZW0gfVxuICB8IHsga2luZDogXCJvcHRpb25zXCI7IG9wdGlvbnM6IHN0cmluZ1tdIH07XG5cbi8vIFByb3BzIGZvciB0aGUgR2VuQWdlbnRDaGF0IGNvbXBvbmVudFxuZXhwb3J0IGludGVyZmFjZSBHZW5BZ2VudENoYXRQcm9wcyB7XG4gIGJhc2VVcmw6IHN0cmluZztcbiAgYXBpS2V5OiBzdHJpbmc7XG4gIHRlbmFudDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT47IC8vIEZvciBwYXNzaW5nIHVzZXIgaW5mb3JtYXRpb24gb3Igb3RoZXIgbWV0YWRhdGFcbiAgb25FcnJvcj86IChlcnJvcjogRXJyb3IpID0+IHZvaWQ7XG4gIG9uVGFrZW92ZXI/OiAoKSA9PiB2b2lkO1xuICBvbkZpbmFsaXplPzogKCkgPT4gdm9pZDtcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIHNlY29uZGFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGZvbnRGYW1pbHk/OiBzdHJpbmc7XG4gICAgZm9udFNpemU/OiBzdHJpbmc7XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICAgIHRleHRDb2xvcj86IHN0cmluZztcbiAgfTtcbiAgaGVhZGVyVGl0bGU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICBhZ2VudE5hbWU/OiBzdHJpbmc7IC8vIEN1c3RvbSBhZ2VudCBuYW1lIHRvIGRpc3BsYXkgaW5zdGVhZCBvZiBcIkFnZW50XCJcbiAgbG9nb1VybD86IHN0cmluZzsgLy8gQ3VzdG9tIGxvZ28gVVJMIHRvIGRpc3BsYXkgaW4gaGVhZGVyIGluc3RlYWQgb2YgZGVmYXVsdCBsb2dvXG4gIG1vZGU/OiBcImVtYmVkZGVkXCIgfCBcImZsb2F0aW5nXCIgfCBcImZ1bGxzY3JlZW5cIjtcbiAgZmxvYXRpbmdDb25maWc/OiB7XG4gICAgcG9zaXRpb24/OiBcImJvdHRvbS1yaWdodFwiIHwgXCJib3R0b20tbGVmdFwiIHwgXCJ0b3AtcmlnaHRcIiB8IFwidG9wLWxlZnRcIjtcbiAgICBvZmZzZXQ/OiB7IHg/OiBudW1iZXI7IHk/OiBudW1iZXIgfTtcbiAgICB0b2dnbGVCdXR0b25JY29uPzogUmVhY3QuUmVhY3RFbGVtZW50O1xuICAgIGNsb3NlQnV0dG9uSWNvbj86IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgfTtcbiAgbGFuZ3VhZ2U/OiBzdHJpbmc7IC8vIExhbmd1YWdlIGNvZGUgKGUuZy4sICdlbicsICdlcycsICdmcicpLiBJZiBub3QgcHJvdmlkZWQsIHdpbGwgdXNlIGJyb3dzZXIgbGFuZ3VhZ2VcbiAgdHJhbnNsYXRpb25zPzogUGFydGlhbDxUcmFuc2xhdGlvbnM+OyAvLyBDdXN0b20gdHJhbnNsYXRpb25zLiBJZiBub3QgcHJvdmlkZWQsIHdpbGwgdXNlIGRlZmF1bHQgRW5nbGlzaCB0cmFuc2xhdGlvbnNcbiAgcmVDYXB0Y2hhS2V5Pzogc3RyaW5nOyAvLyBSZUNhcHRjaGEga2V5IGZvciB0aGUgY2hhdFxuICB3aWRnZXQ/OiBib29sZWFuOyAvLyBJZiB0cnVlLCBvcGVucyBjaGF0IGluIGZ1bGxzY3JlZW4gbW9kZSBvbiBkZXNrdG9wIChzaW1pbGFyIHRvIG1vYmlsZSBiZWhhdmlvcilcbn1cblxuZXhwb3J0IHR5cGUgeyBUcmFuc2xhdGlvbnMgfSBmcm9tICcuLi91dGlscy9pMThuJztcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zbGF0aW9ucyB9IGZyb20gJy4uL3V0aWxzL2kxOG4nO1xuXG4vLyBDaGF0IG1lc3NhZ2UgdHlwZXNcbmV4cG9ydCBpbnRlcmZhY2UgTWVzc2FnZUZlZWRiYWNrIHtcbiAgZmVlZGJhY2s6IFwiZ29vZFwiIHwgXCJiYWRcIjtcbiAgZmVlZGJhY2tfdGltZXN0YW1wPzogc3RyaW5nO1xuICBmZWVkYmFja191c2VyX2lkPzogc3RyaW5nO1xuICBmZWVkYmFja19tZXNzYWdlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRNZXNzYWdlIHtcbiAgY3JlYXRlX3RpbWU6IG51bWJlcjtcbiAgc3RhcnRfdGltZTogbnVtYmVyO1xuICBlbmRfdGltZTogbnVtYmVyO1xuICBzcGVha2VyOiBcImN1c3RvbWVyXCIgfCBcImFnZW50XCIgfCBcInNwZWNpYWxcIjtcbiAgdGV4dDogc3RyaW5nO1xuICBhdHRhY2htZW50cz86IEF0dGFjaG1lbnRbXTtcbiAgLy8gT3B0aW9uYWwgbWV0YWRhdGFcbiAgbWVzc2FnZV9pZD86IHN0cmluZztcbiAgZmVlZGJhY2s/OiBNZXNzYWdlRmVlZGJhY2tbXTtcbiAgdHlwZT86IHN0cmluZztcbn1cblxuLy8gQXR0YWNobWVudCB0eXBlXG5leHBvcnQgaW50ZXJmYWNlIEF0dGFjaG1lbnQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHR5cGU6IHN0cmluZztcbiAgc2l6ZTogbnVtYmVyO1xuICB1cmw6IHN0cmluZztcbiAgZmlsZV9pZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBdHRhY2htZW50V2l0aEZpbGUge1xuICBmaWxlOiBGaWxlO1xuICBhdHRhY2htZW50OiBBdHRhY2htZW50IHwgbnVsbDtcbn1cblxuLy8gQVBJIFJlc3BvbnNlIHR5cGVzXG5leHBvcnQgaW50ZXJmYWNlIFN0YXJ0Q29udmVyc2F0aW9uUmVzcG9uc2Uge1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIGNvbnZlcnNhdGlvbl9pZDogc3RyaW5nO1xuICBhZ2VudF93ZWxjb21lX21lc3NhZ2U/OiBzdHJpbmc7XG4gIGFnZW50X3Bvc3NpYmxlX3F1ZXJpZXM/OiBzdHJpbmdbXTtcbiAgYWdlbnRfd2VsY29tZV90aXRsZT86IHN0cmluZztcbiAgYWdlbnRfd2VsY29tZV9pbWFnZV91cmw/OiBzdHJpbmc7XG4gIGFnZW50X2lkPzogc3RyaW5nO1xuICBhZ2VudF90aGlua2luZ19waHJhc2VzPzogc3RyaW5nW107XG4gIGFnZW50X3RoaW5raW5nX3BocmFzZV9kZWxheT86IG51bWJlcjsgLy8gc2Vjb25kc1xuICBjcmVhdGVfdGltZT86IG51bWJlcjtcbiAgZ3Vlc3RfdG9rZW4/OiBzdHJpbmc7XG59XG5cbi8vIEFnZW50IHdlbGNvbWUvY29uZmlnIGluZm9cbmV4cG9ydCBpbnRlcmZhY2UgQWdlbnRXZWxjb21lRGF0YSB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgbWVzc2FnZT86IHN0cmluZyB8IG51bGw7XG4gIGltYWdlVXJsPzogc3RyaW5nIHwgbnVsbDtcbiAgcG9zc2libGVRdWVyaWVzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWdlbnRUaGlua2luZ0NvbmZpZyB7XG4gIHBocmFzZXM6IHN0cmluZ1tdO1xuICBkZWxheU1zOiBudW1iZXI7IC8vIHJvdGF0aW9uIGRlbGF5IGluIG1zXG59XG5cbi8vIEludGVyYWN0aXZlIGNvbnRlbnQgdHlwZXNcbmV4cG9ydCBpbnRlcmZhY2UgRHluYW1pY0NoYXRJdGVtIHtcbiAgaWQ6IHN0cmluZztcbiAgaW1hZ2U/OiBzdHJpbmc7XG4gIHR5cGU/OiBzdHJpbmc7XG4gIGNhdGVnb3J5Pzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICB2ZW51ZUlkPzogc3RyaW5nO1xuICBzbG90cz86IHN0cmluZ1tdO1xuICBzZWxlY3RlZFNsb3Q/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZWR1bGVJdGVtIHtcbiAgaWQ6IHN0cmluZztcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICByZXN0YXVyYW50czogRHluYW1pY0NoYXRJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZUl0ZW0ge1xuICB1cmw6IHN0cmluZztcbiAgdHlwZTogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGlkOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIENoYXRDb250ZW50QmxvY2sgPVxuICB8IHsga2luZDogXCJ0ZXh0XCI7IHRleHQ6IHN0cmluZyB9XG4gIHwgeyBraW5kOiBcIml0ZW1zXCI7IGl0ZW1zOiBEeW5hbWljQ2hhdEl0ZW1bXSB9XG4gIHwgeyBraW5kOiBcInNjaGVkdWxlXCI7IHNjaGVkdWxlOiBTY2hlZHVsZUl0ZW0gfVxuICB8IHsga2luZDogXCJvcHRpb25zXCI7IG9wdGlvbnM6IHN0cmluZ1tdIH1cbiAgfCB7IGtpbmQ6IFwiZmlsZVwiOyBkYXRhOiBGaWxlSXRlbSB9O1xuXG4vLyBQcm9wcyBmb3IgdGhlIEdlbkFnZW50Q2hhdCBjb21wb25lbnRcbmV4cG9ydCBpbnRlcmZhY2UgR2VuQWdlbnRDaGF0UHJvcHMge1xuICBiYXNlVXJsOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICB0ZW5hbnQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+OyAvLyBGb3IgcGFzc2luZyB1c2VyIGluZm9ybWF0aW9uIG9yIG90aGVyIG1ldGFkYXRhXG4gIHVzZVdzPzogYm9vbGVhbjtcbiAgb25FcnJvcj86IChlcnJvcjogRXJyb3IpID0+IHZvaWQ7XG4gIG9uVGFrZW92ZXI/OiAoKSA9PiB2b2lkO1xuICBvbkZpbmFsaXplPzogKCkgPT4gdm9pZDtcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIHNlY29uZGFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGZvbnRGYW1pbHk/OiBzdHJpbmc7XG4gICAgZm9udFNpemU/OiBzdHJpbmc7XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICAgIHRleHRDb2xvcj86IHN0cmluZztcbiAgfTtcbiAgaGVhZGVyVGl0bGU/OiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBwbGFjZWhvbGRlcj86IHN0cmluZztcbiAgYWdlbnROYW1lPzogc3RyaW5nOyAvLyBDdXN0b20gYWdlbnQgbmFtZSB0byBkaXNwbGF5IGluc3RlYWQgb2YgXCJBZ2VudFwiXG4gIGxvZ29Vcmw/OiBzdHJpbmc7IC8vIEN1c3RvbSBsb2dvIFVSTCB0byBkaXNwbGF5IGluIGhlYWRlciBpbnN0ZWFkIG9mIGRlZmF1bHQgbG9nb1xuICBtb2RlPzogXCJlbWJlZGRlZFwiIHwgXCJmbG9hdGluZ1wiIHwgXCJmdWxsc2NyZWVuXCI7XG4gIGZsb2F0aW5nQ29uZmlnPzoge1xuICAgIHBvc2l0aW9uPzogXCJib3R0b20tcmlnaHRcIiB8IFwiYm90dG9tLWxlZnRcIiB8IFwidG9wLXJpZ2h0XCIgfCBcInRvcC1sZWZ0XCI7XG4gICAgb2Zmc2V0PzogeyB4PzogbnVtYmVyOyB5PzogbnVtYmVyIH07XG4gICAgdG9nZ2xlQnV0dG9uSWNvbj86IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgICBjbG9zZUJ1dHRvbkljb24/OiBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gIH07XG4gIGxhbmd1YWdlPzogc3RyaW5nOyAvLyBMYW5ndWFnZSBjb2RlIChlLmcuLCAnZW4nLCAnZXMnLCAnZnInKS4gSWYgbm90IHByb3ZpZGVkLCB3aWxsIHVzZSBicm93c2VyIGxhbmd1YWdlXG4gIHRyYW5zbGF0aW9ucz86IFBhcnRpYWw8VHJhbnNsYXRpb25zPjsgLy8gQ3VzdG9tIHRyYW5zbGF0aW9ucy4gSWYgbm90IHByb3ZpZGVkLCB3aWxsIHVzZSBkZWZhdWx0IEVuZ2xpc2ggdHJhbnNsYXRpb25zXG4gIHJlQ2FwdGNoYUtleT86IHN0cmluZzsgLy8gUmVDYXB0Y2hhIGtleSBmb3IgdGhlIGNoYXRcbiAgd2lkZ2V0PzogYm9vbGVhbjsgLy8gSWYgdHJ1ZSwgb3BlbnMgY2hhdCBpbiBmdWxsc2NyZWVuIG1vZGUgb24gZGVza3RvcCAoc2ltaWxhciB0byBtb2JpbGUgYmVoYXZpb3IpXG4gIHVzZUF1ZGlvPzogYm9vbGVhbjsgLy8gSWYgZmFsc2UsIGhpZGVzIHRoZSBtaWMgY29tcG9uZW50IGFuZCB2b2ljZSBpbnB1dC4gRGVmYXVsdHMgdG8gZmFsc2UuXG4gIHVzZUZpbGU/OiBib29sZWFuOyAvLyBJZiBmYWxzZSwgaGlkZXMgdGhlIGZpbGUgYXR0YWNoIGljb24gYW5kIGZpbGUgdXBsb2FkLiBEZWZhdWx0cyB0byBmYWxzZS5cbiAgbm9Db2xvckFuaW1hdGlvbj86IGJvb2xlYW47IC8vIElmIHRydWUsIGhpZGVzIHRoZSBjb2xvciBhbmltYXRpb24gKGJhY2tsaWdodCkgYmVsb3cgdGhlIGNoYXQgaGVhZGVyLiBEZWZhdWx0cyB0byBmYWxzZS5cbiAgc2hvd1dlbGNvbWVCZWZvcmVTdGFydD86IGJvb2xlYW47XG4gIGFsbG93ZWRFeHRlbnNpb25zPzogQWxsb3dlZEV4dGVuc2lvbltdOyAvLyBJZiBwcm92aWRlZCwgb25seSBzaG93IGZpbGUgYXR0YWNobWVudHMgd2l0aCB0aGVzZSBleHRlbnNpb25zLiBEZWZhdWx0cyB0byBhbGwgZXh0ZW5zaW9ucy5cbn1cblxuLy8gTk9URTogVGhlc2UgYXJlIHRoZSBvbmx5IGZpbGUgZXh0ZW5zaW9ucyB0aGF0IGFyZSBzdXBwb3J0ZWQgYnkgdGhlIGNoYXQuXG5leHBvcnQgdHlwZSBBbGxvd2VkRXh0ZW5zaW9uID0gJ2ltYWdlLyonIHwgJ2ltYWdlL3BuZycgfCAnaW1hZ2UvanBlZycgfCAnaW1hZ2UvanBnJyB8ICdpbWFnZS9naWYnIHwgJ2FwcGxpY2F0aW9uL3BkZicgfCAnYXBwbGljYXRpb24vbXN3b3JkJyB8ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQud29yZHByb2Nlc3NpbmdtbC5kb2N1bWVudCc7XG5cbmV4cG9ydCB0eXBlIHsgVHJhbnNsYXRpb25zIH0gZnJvbSAnLi4vdXRpbHMvaTE4bic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZVVwbG9hZFJlc3BvbnNlIHtcbiAgZmlsZW5hbWU6IHN0cmluZztcbiAgb3JpZ2luYWxfZmlsZW5hbWU6IHN0cmluZztcbiAgc3RvcmFnZV9wYXRoOiBzdHJpbmc7XG4gIGZpbGVfcGF0aDogc3RyaW5nO1xuICBmaWxlX3VybDogc3RyaW5nO1xuICBmaWxlX2lkPzogc3RyaW5nO1xufSJdfQ==
@@ -1,3 +1,3 @@
1
1
  import { ChatContentBlock } from "../types";
2
- export declare const parseInteractiveContentBlocks: (text: string) => ChatContentBlock[];
2
+ export declare const parseInteractiveContentBlocks: (text: string, messageType?: "message" | "file") => ChatContentBlock[];
3
3
  export declare const generateMessageContent: (blocks: ChatContentBlock[]) => string;
@@ -12,6 +12,14 @@ var isScheduleItem = function (value) {
12
12
  typeof value.id === "string" &&
13
13
  Array.isArray(value.restaurants));
14
14
  };
15
+ var isFileItem = function (value) {
16
+ return Boolean(value &&
17
+ typeof value === "object" &&
18
+ typeof value.url === "string" &&
19
+ typeof value.type === "string" &&
20
+ typeof value.name === "string" &&
21
+ typeof value.id === "string");
22
+ };
15
23
  var parseJsonBlock = function (jsonString) {
16
24
  try {
17
25
  var parsed = JSON.parse(jsonString);
@@ -27,8 +35,13 @@ var parseJsonBlock = function (jsonString) {
27
35
  }
28
36
  return null;
29
37
  };
30
- export var parseInteractiveContentBlocks = function (text) {
38
+ export var parseInteractiveContentBlocks = function (text, messageType) {
31
39
  var matches = [];
40
+ // case: file item or message type is file
41
+ if (isFileItem(text) || messageType && messageType === 'file') {
42
+ var cleanJson = text.replace(/\\/g, '');
43
+ return [{ kind: "file", data: JSON.parse(cleanJson) }];
44
+ }
32
45
  jsonBlockRegex.lastIndex = 0;
33
46
  var jsonMatch;
34
47
  while ((jsonMatch = jsonBlockRegex.exec(text)) !== null) {
@@ -118,4 +131,4 @@ export var generateMessageContent = function (blocks) {
118
131
  });
119
132
  return content;
120
133
  };
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interactiveContent.js","sourceRoot":"","sources":["../../src/utils/interactiveContent.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChatContentBlock, DynamicChatItem, ScheduleItem } from \"../types\";\n\ntype MatchRecord = {\n  start: number;\n  end: number;\n  type: \"json\" | \"options\";\n  content: string;\n};\n\nconst jsonBlockRegex = /```json\\s*([\\s\\S]*?)\\s*```/g;\nconst optionsRegex = /\\*\\*\\*(.*?)\\*\\*\\*/g;\n\nconst isDynamicChatItem = (value: any): value is DynamicChatItem => {\n  return Boolean(\n    value &&\n    typeof value === \"object\" &&\n    typeof value.id === \"string\" &&\n    typeof value.name === \"string\"\n  );\n};\n\nconst isScheduleItem = (value: any): value is ScheduleItem => {\n  return Boolean(\n    value &&\n    typeof value === \"object\" &&\n    typeof value.id === \"string\" &&\n    Array.isArray((value as any).restaurants)\n  );\n};\n\nconst parseJsonBlock = (jsonString: string): ChatContentBlock | null => {\n  try {\n    const parsed = JSON.parse(jsonString);\n    if (isScheduleItem(parsed)) {\n      return { kind: \"schedule\", schedule: parsed };\n    }\n    if (Array.isArray(parsed) && parsed.every(isDynamicChatItem)) {\n      return { kind: \"items\", items: parsed };\n    }\n  } catch (_error) {\n    // ignore malformed JSON blocks\n  }\n  return null;\n};\n\nexport const parseInteractiveContentBlocks = (\n  text: string\n): ChatContentBlock[] => {\n  const matches: MatchRecord[] = [];\n\n  jsonBlockRegex.lastIndex = 0;\n  let jsonMatch: RegExpExecArray | null;\n  while ((jsonMatch = jsonBlockRegex.exec(text)) !== null) {\n    const fullMatch = jsonMatch[0];\n    const content = jsonMatch[1];\n    if (typeof jsonMatch.index !== \"number\" || !content) continue;\n    matches.push({\n      start: jsonMatch.index,\n      end: jsonMatch.index + fullMatch.length,\n      type: \"json\",\n      content,\n    });\n  }\n\n  optionsRegex.lastIndex = 0;\n  let optionsMatch: RegExpExecArray | null;\n  while ((optionsMatch = optionsRegex.exec(text)) !== null) {\n    const fullMatch = optionsMatch[0];\n    const content = optionsMatch[1];\n    if (typeof optionsMatch.index !== \"number\" || !content) continue;\n    matches.push({\n      start: optionsMatch.index,\n      end: optionsMatch.index + fullMatch.length,\n      type: \"options\",\n      content,\n    });\n  }\n\n  if (matches.length === 0) {\n    const trimmed = text.trim();\n    return trimmed ? [{ kind: \"text\", text: trimmed }] : [];\n  }\n\n  matches.sort((a, b) => a.start - b.start);\n\n  const blocks: ChatContentBlock[] = [];\n  let lastIndex = 0;\n\n  matches.forEach((match) => {\n    if (lastIndex < match.start) {\n      const before = text.slice(lastIndex, match.start).trim();\n      if (before) {\n        blocks.push({ kind: \"text\", text: before });\n      }\n    }\n\n    if (match.type === \"json\") {\n      const block = parseJsonBlock(match.content);\n      if (block) {\n        blocks.push(block);\n      }\n    } else {\n      const options = match.content\n        .split(\";\")\n        .map((opt) => opt.trim())\n        .filter(Boolean);\n      if (options.length) {\n        blocks.push({ kind: \"options\", options });\n      }\n    }\n\n    lastIndex = match.end;\n  });\n\n  if (lastIndex < text.length) {\n    const after = text.slice(lastIndex).trim();\n    if (after) {\n      blocks.push({ kind: \"text\", text: after });\n    }\n  }\n\n  return blocks;\n};\n\nexport const generateMessageContent = (blocks: ChatContentBlock[]): string => {\n  let content = \"\";\n\n  blocks.forEach((block) => {\n    switch (block.kind) {\n      case \"text\":\n        content += block.text;\n        break;\n      case \"items\":\n        content += `\\`\\`\\`json\\n${JSON.stringify(block.items)}\\n\\`\\`\\``;\n        break;\n      case \"schedule\":\n        content += `\\`\\`\\`json\\n${JSON.stringify(block.schedule)}\\n\\`\\`\\``;\n        break;\n      case \"options\":\n        content += `***${block.options.join(\"; \")}***`;\n        break;\n      default:\n        break;\n    }\n  });\n\n  return content;\n};\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interactiveContent.js","sourceRoot":"","sources":["../../src/utils/interactiveContent.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChatContentBlock, DynamicChatItem, FileItem, ScheduleItem } from \"../types\";\n\ntype MatchRecord = {\n  start: number;\n  end: number;\n  type: \"json\" | \"options\" | \"file\";\n  content: string;\n};\n\nconst jsonBlockRegex = /```json\\s*([\\s\\S]*?)\\s*```/g;\nconst optionsRegex = /\\*\\*\\*(.*?)\\*\\*\\*/g;\n\nconst isDynamicChatItem = (value: any): value is DynamicChatItem => {\n  return Boolean(\n    value &&\n    typeof value === \"object\" &&\n    typeof value.id === \"string\" &&\n    typeof value.name === \"string\"\n  );\n};\n\nconst isScheduleItem = (value: any): value is ScheduleItem => {\n  return Boolean(\n    value &&\n    typeof value === \"object\" &&\n    typeof value.id === \"string\" &&\n    Array.isArray((value as any).restaurants)\n  );\n};\n\nconst isFileItem = (value: any): value is FileItem => {\n  return Boolean(\n    value &&\n    typeof value === \"object\" &&\n    typeof value.url === \"string\" &&\n    typeof value.type === \"string\" &&\n    typeof value.name === \"string\" &&\n    typeof value.id === \"string\"\n  );\n};\n\nconst parseJsonBlock = (jsonString: string): ChatContentBlock | null => {\n  try {\n    const parsed = JSON.parse(jsonString);\n    if (isScheduleItem(parsed)) {\n      return { kind: \"schedule\", schedule: parsed };\n    }\n    if (Array.isArray(parsed) && parsed.every(isDynamicChatItem)) {\n      return { kind: \"items\", items: parsed };\n    }\n  } catch (_error) {\n    // ignore malformed JSON blocks\n  }\n  return null;\n};\n\nexport const parseInteractiveContentBlocks = (\n  text: string,\n  messageType?: 'message' | 'file'\n): ChatContentBlock[] => {\n  const matches: MatchRecord[] = [];\n\n  // case: file item or message type is file\n  if (isFileItem(text) || messageType && messageType === 'file') {\n    const cleanJson = text.replace(/\\\\/g, '');\n    return [{ kind: \"file\", data: JSON.parse(cleanJson) as FileItem }];\n  }\n\n  jsonBlockRegex.lastIndex = 0;\n  let jsonMatch: RegExpExecArray | null;\n  while ((jsonMatch = jsonBlockRegex.exec(text)) !== null) {\n    const fullMatch = jsonMatch[0];\n    const content = jsonMatch[1];\n    if (typeof jsonMatch.index !== \"number\" || !content) continue;\n    matches.push({\n      start: jsonMatch.index,\n      end: jsonMatch.index + fullMatch.length,\n      type: \"json\",\n      content,\n    });\n  }\n\n  optionsRegex.lastIndex = 0;\n  let optionsMatch: RegExpExecArray | null;\n  while ((optionsMatch = optionsRegex.exec(text)) !== null) {\n    const fullMatch = optionsMatch[0];\n    const content = optionsMatch[1];\n    if (typeof optionsMatch.index !== \"number\" || !content) continue;\n    matches.push({\n      start: optionsMatch.index,\n      end: optionsMatch.index + fullMatch.length,\n      type: \"options\",\n      content,\n    });\n  }\n\n  if (matches.length === 0) {\n    const trimmed = text.trim();\n    return trimmed ? [{ kind: \"text\", text: trimmed }] : [];\n  }\n\n  matches.sort((a, b) => a.start - b.start);\n\n  const blocks: ChatContentBlock[] = [];\n  let lastIndex = 0;\n\n  matches.forEach((match) => {\n    if (lastIndex < match.start) {\n      const before = text.slice(lastIndex, match.start).trim();\n      if (before) {\n        blocks.push({ kind: \"text\", text: before });\n      }\n    }\n\n    if (match.type === \"json\") {\n      const block = parseJsonBlock(match.content);\n      if (block) {\n        blocks.push(block);\n      }\n    } else {\n      const options = match.content\n        .split(\";\")\n        .map((opt) => opt.trim())\n        .filter(Boolean);\n      if (options.length) {\n        blocks.push({ kind: \"options\", options });\n      }\n    }\n\n    lastIndex = match.end;\n  });\n\n  if (lastIndex < text.length) {\n    const after = text.slice(lastIndex).trim();\n    if (after) {\n      blocks.push({ kind: \"text\", text: after });\n    }\n  }\n\n  return blocks;\n};\n\nexport const generateMessageContent = (blocks: ChatContentBlock[]): string => {\n  let content = \"\";\n\n  blocks.forEach((block) => {\n    switch (block.kind) {\n      case \"text\":\n        content += block.text;\n        break;\n      case \"items\":\n        content += `\\`\\`\\`json\\n${JSON.stringify(block.items)}\\n\\`\\`\\``;\n        break;\n      case \"schedule\":\n        content += `\\`\\`\\`json\\n${JSON.stringify(block.schedule)}\\n\\`\\`\\``;\n        break;\n      case \"options\":\n        content += `***${block.options.join(\"; \")}***`;\n        break;\n      default:\n        break;\n    }\n  });\n\n  return content;\n};\n"]}