genassist-chat-react 1.0.21 → 1.0.22

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.
@@ -1,4 +1,4 @@
1
- import { ChatMessage, Attachment, AgentThinkingConfig, AgentWelcomeData } from "../types";
1
+ import { ChatMessage, Attachment, AgentThinkingConfig, AgentWelcomeData, FileUploadResponse } from "../types";
2
2
  export declare class ChatService {
3
3
  private baseUrl;
4
4
  private apiKey;
@@ -21,7 +21,8 @@ export declare class ChatService {
21
21
  private tenant;
22
22
  private agentId;
23
23
  private language;
24
- constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>, tenant?: string, language?: string);
24
+ private useWs;
25
+ constructor(baseUrl: string, apiKey: string, metadata?: Record<string, any>, tenant?: string, language?: string, useWs?: boolean);
25
26
  private getStorageKey;
26
27
  /**
27
28
  * Set the language for Accept-Language header
@@ -72,9 +73,7 @@ export declare class ChatService {
72
73
  isConversationFinalized(): boolean;
73
74
  startConversation(reCaptchaToken: string | undefined): Promise<string>;
74
75
  sendMessage(message: string, attachments?: Attachment[], extraMetadata?: Record<string, any>, reCaptchaToken?: string): Promise<void>;
75
- uploadFile(chatId: string, file: File): Promise<{
76
- fileUrl: string;
77
- }>;
76
+ uploadFile(chatId: string, file: File): Promise<FileUploadResponse | null>;
78
77
  connectWebSocket(): void;
79
78
  disconnect(): void;
80
79
  private fetchWelcomeImage;
@@ -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
  }
@@ -370,7 +372,9 @@ var ChatService = /** @class */ (function () {
370
372
  this.welcomeDataHandler(this.welcomeData);
371
373
  }
372
374
  this.saveConversation();
373
- this.connectWebSocket();
375
+ if (this.useWs) {
376
+ this.connectWebSocket();
377
+ }
374
378
  return [2 /*return*/, response.data.conversation_id];
375
379
  case 4:
376
380
  error_1 = _a.sent();
@@ -382,7 +386,7 @@ var ChatService = /** @class */ (function () {
382
386
  };
383
387
  ChatService.prototype.sendMessage = function (message, attachments, extraMetadata, reCaptchaToken) {
384
388
  return __awaiter(this, void 0, void 0, function () {
385
- var now, chatMessage, requestBody, mergedMetadata, error_2, errorMessage;
389
+ var now, chatMessage, requestBody, mergedMetadata, response, responseData, i, messageData, agentMessage, error_2, errorMessage;
386
390
  return __generator(this, function (_a) {
387
391
  switch (_a.label) {
388
392
  case 0:
@@ -419,7 +423,44 @@ var ChatService = /** @class */ (function () {
419
423
  headers: this.getHeaders(),
420
424
  })];
421
425
  case 2:
422
- _a.sent();
426
+ response = _a.sent();
427
+ // If not using WebSocket, try to retrieve the response message from the update conversation response
428
+ if (!this.useWs && this.messageHandler) {
429
+ try {
430
+ responseData = response.data;
431
+ if (responseData.messages && Array.isArray(responseData.messages)) {
432
+ // Look for the latest agent message in the response
433
+ for (i = responseData.messages.length - 1; i >= 0; i--) {
434
+ messageData = responseData.messages[i];
435
+ if (messageData.speaker === "agent" &&
436
+ messageData.text &&
437
+ messageData.create_time !== undefined &&
438
+ messageData.start_time !== undefined &&
439
+ messageData.end_time !== undefined) {
440
+ agentMessage = {
441
+ create_time: messageData.create_time,
442
+ start_time: this.conversationCreateTime
443
+ ? messageData.start_time - this.conversationCreateTime
444
+ : messageData.start_time,
445
+ end_time: this.conversationCreateTime
446
+ ? messageData.end_time - this.conversationCreateTime
447
+ : messageData.end_time,
448
+ speaker: "agent",
449
+ text: messageData.text,
450
+ message_id: messageData.message_id || messageData.id,
451
+ };
452
+ // Only process if this is a new message we haven't seen before
453
+ // We can't easily check here, so we'll let the handler manage duplicates
454
+ this.messageHandler(agentMessage);
455
+ break;
456
+ }
457
+ }
458
+ }
459
+ }
460
+ catch (parseError) {
461
+ console.error("Failed to parse update conversation response:", parseError);
462
+ }
463
+ }
423
464
  return [3 /*break*/, 4];
424
465
  case 3:
425
466
  error_2 = _a.sent();
@@ -478,6 +519,9 @@ var ChatService = /** @class */ (function () {
478
519
  };
479
520
  ChatService.prototype.connectWebSocket = function () {
480
521
  var _this = this;
522
+ if (!this.useWs) {
523
+ return;
524
+ }
481
525
  if (this.webSocket) {
482
526
  this.webSocket.close();
483
527
  }
@@ -690,4 +734,4 @@ var ChatService = /** @class */ (function () {
690
734
  return ChatService;
691
735
  }());
692
736
  export { ChatService };
693
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from \"axios\";\nimport {\n  ChatMessage,\n  StartConversationResponse,\n  Attachment,\n  AgentThinkingConfig,\n  AgentWelcomeData,\n} from \"../types\";\nimport {\n  createWebSocket,\n  createWebSocketDiagnostic,\n} from \"../utils/websocket\";\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private 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"]}
737
+ //# 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  /**\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) {\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 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) {\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) {\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"]}
@@ -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;
@@ -109,3 +125,11 @@ export interface GenAgentChatProps {
109
125
  widget?: boolean;
110
126
  }
111
127
  export type { Translations } from '../utils/i18n';
128
+ export interface FileUploadResponse {
129
+ filename: string;
130
+ original_filename: string;
131
+ storage_path: string;
132
+ file_path: string;
133
+ file_url: string;
134
+ file_id?: string;
135
+ }
@@ -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/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICBhZ2VudE5hbWU/OiBzdHJpbmc7IC8vIEN1c3RvbSBhZ2VudCBuYW1lIHRvIGRpc3BsYXkgaW5zdGVhZCBvZiBcIkFnZW50XCJcbiAgbG9nb1VybD86IHN0cmluZzsgLy8gQ3VzdG9tIGxvZ28gVVJMIHRvIGRpc3BsYXkgaW4gaGVhZGVyIGluc3RlYWQgb2YgZGVmYXVsdCBsb2dvXG4gIG1vZGU/OiBcImVtYmVkZGVkXCIgfCBcImZsb2F0aW5nXCIgfCBcImZ1bGxzY3JlZW5cIjtcbiAgZmxvYXRpbmdDb25maWc/OiB7XG4gICAgcG9zaXRpb24/OiBcImJvdHRvbS1yaWdodFwiIHwgXCJib3R0b20tbGVmdFwiIHwgXCJ0b3AtcmlnaHRcIiB8IFwidG9wLWxlZnRcIjtcbiAgICBvZmZzZXQ/OiB7IHg/OiBudW1iZXI7IHk/OiBudW1iZXIgfTtcbiAgICB0b2dnbGVCdXR0b25JY29uPzogUmVhY3QuUmVhY3RFbGVtZW50O1xuICAgIGNsb3NlQnV0dG9uSWNvbj86IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgfTtcbiAgbGFuZ3VhZ2U/OiBzdHJpbmc7IC8vIExhbmd1YWdlIGNvZGUgKGUuZy4sICdlbicsICdlcycsICdmcicpLiBJZiBub3QgcHJvdmlkZWQsIHdpbGwgdXNlIGJyb3dzZXIgbGFuZ3VhZ2VcbiAgdHJhbnNsYXRpb25zPzogUGFydGlhbDxUcmFuc2xhdGlvbnM+OyAvLyBDdXN0b20gdHJhbnNsYXRpb25zLiBJZiBub3QgcHJvdmlkZWQsIHdpbGwgdXNlIGRlZmF1bHQgRW5nbGlzaCB0cmFuc2xhdGlvbnNcbiAgcmVDYXB0Y2hhS2V5Pzogc3RyaW5nOyAvLyBSZUNhcHRjaGEga2V5IGZvciB0aGUgY2hhdFxuICB3aWRnZXQ/OiBib29sZWFuOyAvLyBJZiB0cnVlLCBvcGVucyBjaGF0IGluIGZ1bGxzY3JlZW4gbW9kZSBvbiBkZXNrdG9wIChzaW1pbGFyIHRvIG1vYmlsZSBiZWhhdmlvcilcbn1cblxuZXhwb3J0IHR5cGUgeyBUcmFuc2xhdGlvbnMgfSBmcm9tICcuLi91dGlscy9pMThuJztcblxuZXhwb3J0IGludGVyZmFjZSBGaWxlVXBsb2FkUmVzcG9uc2Uge1xuICBmaWxlbmFtZTogc3RyaW5nO1xuICBvcmlnaW5hbF9maWxlbmFtZTogc3RyaW5nO1xuICBzdG9yYWdlX3BhdGg6IHN0cmluZztcbiAgZmlsZV9wYXRoOiBzdHJpbmc7XG4gIGZpbGVfdXJsOiBzdHJpbmc7XG4gIGZpbGVfaWQ/OiBzdHJpbmc7XG59Il19
@@ -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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "genassist-chat-react",
3
- "version": "1.0.21",
3
+ "version": "1.0.22",
4
4
  "description": "React chat component for GenAssist",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.js",