genassist-chat-react 1.0.17 → 1.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -402,7 +402,7 @@ var ChatService = /** @class */ (function () {
|
|
|
402
402
|
var wsUrl = "".concat(this.baseUrl.replace("http", "ws"), "/api/conversations/ws/").concat(this.conversationId, "?api_key=").concat(this.apiKey, "&lang=en&topics=message&topics=takeover&topics=finalize");
|
|
403
403
|
// Add tenant as query parameter if provided
|
|
404
404
|
if (this.tenant) {
|
|
405
|
-
wsUrl += "&X-Tenant-
|
|
405
|
+
wsUrl += "&X-Tenant-ID=".concat(encodeURIComponent(this.tenant));
|
|
406
406
|
}
|
|
407
407
|
// Use native browser WebSocket factory
|
|
408
408
|
this.webSocket = createWebSocket(wsUrl);
|
|
@@ -595,4 +595,4 @@ var ChatService = /** @class */ (function () {
|
|
|
595
595
|
return ChatService;
|
|
596
596
|
}());
|
|
597
597
|
export { ChatService };
|
|
598
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chatService.js","sourceRoot":"","sources":["../../src/services/chatService.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from \"axios\";\nimport {\n  ChatMessage,\n  StartConversationResponse,\n  Attachment,\n  AgentThinkingConfig,\n  AgentWelcomeData,\n} from \"../types\";\nimport {\n  createWebSocket,\n  createWebSocketDiagnostic,\n} from \"../utils/websocket\";\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler:\n    | ((state: \"connecting\" | \"connected\" | \"disconnected\") => void)\n    | null = null;\n  private welcomeDataHandler: ((data: AgentWelcomeData) => void) | null = null;\n  private storageKeyBase = \"genassist_conversation\";\n  private possibleQueries: string[] = [];\n  private welcomeData: AgentWelcomeData = {};\n  private thinkingConfig: AgentThinkingConfig = { phrases: [], delayMs: 1000 };\n  private welcomeObjectUrl: string | null = null; // to revoke on reset\n  private tenant: string | undefined;\n  private agentId: string | undefined;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string\n  ) {\n    this.baseUrl = baseUrl.endsWith(\"/\") ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    this.tenant = tenant;\n    // Try to load a saved conversation for this apiKey from localStorage\n    this.loadSavedConversation();\n  }\n\n  private getStorageKey(): string {\n    // Pointer to current conversation metadata for this apiKey\n    return `${this.storageKeyBase}:${this.apiKey}`;\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(\n    handler: (state: \"connecting\" | \"connected\" | \"disconnected\") => void\n  ) {\n    this.connectionStateHandler = handler;\n  }\n\n  setWelcomeDataHandler(handler: ((data: AgentWelcomeData) => void) | null) {\n    this.welcomeDataHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  getWelcomeData(): AgentWelcomeData {\n    return this.welcomeData;\n  }\n\n  getThinkingConfig(): AgentThinkingConfig {\n    return this.thinkingConfig;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      let savedConversation = localStorage.getItem(this.getStorageKey());\n      // Backward-compat: check old unscoped key if scoped one missing\n      if (!savedConversation) {\n        savedConversation = localStorage.getItem(this.storageKeyBase);\n      }\n      if (savedConversation) {\n        const {\n          conversationId,\n          createTime,\n          isFinalized,\n          possibleQueries,\n          welcomeData,\n          thinkingConfig,\n          agentId,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.possibleQueries = Array.isArray(possibleQueries)\n          ? possibleQueries\n          : [];\n        this.welcomeData = welcomeData || {};\n        if (!this.welcomeData.possibleQueries) {\n          this.welcomeData.possibleQueries = this.possibleQueries;\n        }\n        this.thinkingConfig = {\n          phrases: (thinkingConfig && thinkingConfig.phrases) || [],\n          delayMs:\n            thinkingConfig && typeof thinkingConfig.delayMs === \"number\"\n              ? thinkingConfig.delayMs\n              : 1000,\n        };\n        this.agentId = agentId;\n        if (!this.welcomeData.imageUrl && this.agentId) {\n          this.fetchWelcomeImage(this.agentId);\n        }\n        if (this.welcomeDataHandler) {\n          this.welcomeDataHandler(this.welcomeData);\n        }\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n          possibleQueries: this.possibleQueries,\n          welcomeData: {\n            ...this.welcomeData,\n            imageUrl:\n              this.welcomeObjectUrl &&\n              this.welcomeData.imageUrl &&\n              this.welcomeData.imageUrl.startsWith(\"blob:\")\n                ? null\n                : this.welcomeData.imageUrl || null,\n          },\n          thinkingConfig: this.thinkingConfig,\n          agentId: this.agentId,\n        };\n        localStorage.setItem(this.getStorageKey(), JSON.stringify(conversationData));\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n\n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    this.welcomeData = {};\n    this.thinkingConfig = { phrases: [], delayMs: 1000 };\n    if (this.welcomeObjectUrl) {\n      try {\n        URL.revokeObjectURL(this.welcomeObjectUrl);\n      } catch {}\n      this.welcomeObjectUrl = null;\n    }\n    this.agentId = undefined;\n\n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.getStorageKey());\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\",\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time\n        ? response.data.create_time / 1000\n        : Date.now() / 1000;\n      this.isFinalized = false;\n\n      // Store possible queries if available\n      if (\n        response.data.agent_possible_queries &&\n        response.data.agent_possible_queries.length > 0\n      ) {\n        this.possibleQueries = response.data.agent_possible_queries.filter(\n          (query) => typeof query === \"string\" && query.trim().length > 0\n        );\n      }\n\n      const anyData: any = response.data as any;\n      const agentId: string | undefined = anyData.agent_id;\n      this.agentId = agentId;\n      const welcomeTitle: string | undefined = anyData.agent_welcome_title;\n      const welcomeImageUrl: string | undefined =\n        anyData.agent_welcome_image_url;\n      const thinkingPhrases: string[] | undefined =\n        anyData.agent_thinking_phrases;\n      const thinkingDelaySec: number | undefined =\n        anyData.agent_thinking_phrase_delay;\n\n      this.welcomeData = {\n        title: welcomeTitle || null,\n        message: null,\n        imageUrl: welcomeImageUrl || null,\n        possibleQueries: this.possibleQueries,\n      };\n\n      if (Array.isArray(thinkingPhrases) && thinkingPhrases.length > 0) {\n        this.thinkingConfig.phrases = thinkingPhrases;\n      }\n      if (typeof thinkingDelaySec === \"number\" && thinkingDelaySec >= 0) {\n        this.thinkingConfig.delayMs = Math.max(\n          250,\n          Math.round(thinkingDelaySec * 1000)\n        );\n      }\n\n      if (!this.welcomeData.imageUrl && agentId) {\n        await this.fetchWelcomeImage(agentId);\n      }\n\n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n          speaker: \"agent\",\n          text: response.data.agent_welcome_message,\n        };\n        this.welcomeData.message = response.data.agent_welcome_message;\n        this.messageHandler(welcomeMessage);\n      }\n\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n\n      this.saveConversation();\n      this.connectWebSocket();\n      return response.data.conversation_id;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  async sendMessage(\n    message: string,\n    attachments?: Attachment[],\n    extraMetadata?: Record<string, any>\n  ): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n      speaker: \"customer\",\n      text: message,\n      attachments: attachments,\n    };\n\n    if (this.messageHandler) {\n      this.messageHandler(chatMessage);\n    }\n\n    try {\n      const requestBody: any = {\n        messages: [chatMessage],\n        recorded_at: new Date().toISOString(),\n      };\n\n      // Include metadata\n      const mergedMetadata = {\n        ...(this.metadata || {}),\n        ...(extraMetadata || {}),\n      };\n      if (Object.keys(mergedMetadata).length > 0) {\n        requestBody.metadata = mergedMetadata;\n      }\n\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n    } catch (error: any) {\n      // Check if this is the agent inactive error\n      if (\n        error.response &&\n        error.response.data &&\n        error.response.data.error_key === \"AGENT_INACTIVE\"\n      ) {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: now - this.conversationCreateTime + 0.01,\n            speaker: \"special\",\n            text: \"The agent is currently offline, please check back later. Thank you!\",\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n\n      throw error;\n    }\n  }\n\n  async uploadFile(chatId: string, file: File): Promise<{ fileUrl: string }> {\n    if (!this.conversationId) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const formData = new FormData();\n    formData.append(\"chat_id\", chatId);\n    formData.append(\"file\", file);\n\n    try {\n      const response = await axios.post<{ fileUrl: string }>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"multipart/form-data\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n      return response.data;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n\n    if (!this.conversationId) {\n      throw new Error(\"Conversation ID is required for WebSocket connection\");\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler(\"connecting\");\n    let wsUrl = `${this.baseUrl.replace(\"http\", \"ws\")}/api/conversations/ws/${\n      this.conversationId\n    }?api_key=${\n      this.apiKey\n    }&lang=en&topics=message&topics=takeover&topics=finalize`;\n    \n    // Add tenant as query parameter if provided\n    if (this.tenant) {\n      wsUrl += `&X-Tenant-Id=${encodeURIComponent(this.tenant)}`;\n    }\n    \n    // Use native browser WebSocket factory\n    this.webSocket = createWebSocket(wsUrl);\n\n\n    this.webSocket.onopen = () => {\n      if (this.connectionStateHandler) this.connectionStateHandler(\"connected\");\n    };\n\n    this.webSocket.onmessage = (event: MessageEvent) => {\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === \"message\" && this.messageHandler) {\n          if (Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[];\n            // Adjust timestamps to be relative to conversation start\n            // Also normalize message_id field (backend might send 'id' instead of 'message_id')\n            const adjustedMessages = messages\n              .map((msg) => {\n                const adjusted = this.adjustMessageTimestamps(msg);\n                // Normalize: if backend sends 'id', use it as 'message_id'\n                if (!adjusted.message_id && (msg as any).id) {\n                  adjusted.message_id = (msg as any).id;\n                }\n                return adjusted;\n              })\n              .filter((msg) => msg.speaker !== \"customer\");\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(\n              data.payload as ChatMessage\n            );\n            // Normalize: if backend sends 'id', use it as 'message_id'\n            if (!adjustedMessage.message_id && (data.payload as any).id) {\n              adjustedMessage.message_id = (data.payload as any).id;\n            }\n            if (adjustedMessage.speaker !== \"customer\") {\n              this.messageHandler(adjustedMessage);\n            }\n          }\n        } else if (data.type === \"takeover\") {\n          // Handle takeover event\n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Supervisor took over\",\n            };\n            this.messageHandler(takeoverMessage);\n          }\n\n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === \"finalize\") {\n          // Handle finalized event\n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Conversation Finalized\",\n            };\n            this.messageHandler(finalizedMessage);\n          }\n\n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        // ignore\n      }\n    };\n\n    this.webSocket.onerror = (error: Event) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      const diagnostic = createWebSocketDiagnostic(error, wsUrl);\n      console.error(`[GenAssist Chat] ${diagnostic}`);\n    };\n\n    this.webSocket.onclose = (event: CloseEvent) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      if (!event.wasClean) {\n        const diagnostic = createWebSocketDiagnostic(event, wsUrl);\n        console.warn(`[GenAssist Chat] ${diagnostic}`);\n      }\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  private async fetchWelcomeImage(agentId: string): Promise<void> {\n    try {\n      const imageResponse = await axios.get(\n        `${this.baseUrl}/api/genagent/agents/configs/${agentId}/welcome-image`,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n          responseType: \"blob\",\n        }\n      );\n      const blobUrl = URL.createObjectURL(imageResponse.data);\n      this.welcomeObjectUrl = blobUrl;\n      this.welcomeData.imageUrl = blobUrl;\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n    } catch (err) {\n      // ignore\n    }\n  }\n\n  // Add feedback to a specific agent message in the conversation\n  async addFeedback(\n    messageId: string,\n    feedback: \"good\" | \"bad\",\n    feedback_message?: string\n  ): Promise<void> {\n    if (!messageId) {\n      throw new Error(\"Message ID is required for feedback\");\n    }\n\n    try {\n      // Use message ID in the URL path, not conversation ID\n      const url = `${this.baseUrl}/api/conversations/message/add-feedback/${messageId}`;\n      // Body should only contain feedback and feedback_message (no message_id)\n      const payload: {\n        feedback: \"good\" | \"bad\";\n        feedback_message?: string;\n      } = {\n        feedback,\n      };\n      \n      if (feedback_message) {\n        payload.feedback_message = feedback_message;\n      }\n      \n      await axios.patch(url, payload, {\n        headers: {\n          \"x-api-key\": this.apiKey,\n          \"Content-Type\": \"application/json\",\n          ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n        },\n      });\n      \n    } catch (error: any) {\n      console.error('Feedback API call failed:', {\n        message: error.message,\n        response: error.response?.data,\n        status: error.response?.status,\n      });\n      throw error;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime,\n    };\n  }\n}\n"]}
|
|
598
|
+
//# 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;IAuBE,qBACE,OAAe,EACf,MAAc,EACd,QAA8B,EAC9B,MAAe;QAvBT,mBAAc,GAAkB,IAAI,CAAC;QACrC,2BAAsB,GAAkB,IAAI,CAAC,CAAC,gCAAgC;QAC9E,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;QAUnE,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,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,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,KAQF,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAP/B,cAAc,oBAAA,EACd,UAAU,gBAAA,EACV,WAAW,iBAAA,EACX,eAAe,qBAAA,EACf,WAAW,iBAAA,EACX,cAAc,oBAAA,EACd,OAAO,aACwB,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,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;iBACtB,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,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;;;;;;;wBAEU,WAAW,GAAQ;4BACvB,QAAQ,EAAE,EAAE;4BACZ,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;4BACrC,cAAc,EAAE,sCAAsC;yBACvD,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,aACL,WAAW,EAAE,IAAI,CAAC,MAAM,EACxB,cAAc,EAAE,kBAAkB,IAC/B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACvD;6BACF,CACF,EAAA;;wBAVK,QAAQ,GAAG,SAUhB;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,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;;;;;;wBAEnC,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;wBAGI,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,aACL,WAAW,EAAE,IAAI,CAAC,MAAM,EACxB,cAAc,EAAE,kBAAkB,IAC/B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACvD;6BACF,CACF,EAAA;;wBAVD,SAUC,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,aACL,WAAW,EAAE,IAAI,CAAC,MAAM,EACxB,cAAc,EAAE,qBAAqB,IAClC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACvD;6BACF,CACF,EAAA;;wBAVK,QAAQ,GAAG,SAUhB;wBACD,sBAAO,QAAQ,CAAC,IAAI,EAAC;;;wBAErB,MAAM,OAAK,CAAC;;;;;KAEf;IAED,sCAAgB,GAAhB;QAAA,iBAqIC;QApIC,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;QAC3E,IAAI,KAAK,GAAG,UAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,mCAC/C,IAAI,CAAC,cAAc,sBAEnB,IAAI,CAAC,MAAM,4DAC4C,CAAC;QAE1D,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,aACL,WAAW,EAAE,IAAI,CAAC,MAAM,IACrB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACvD;gCACD,YAAY,EAAE,MAAM;6BACrB,CACF,EAAA;;wBATK,aAAa,GAAG,SASrB;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,aACL,WAAW,EAAE,IAAI,CAAC,MAAM,EACxB,cAAc,EAAE,kBAAkB,IAC/B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACvD;6BACF,CAAC,EAAA;;wBANF,SAME,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,AAtnBD,IAsnBC","sourcesContent":["import axios from \"axios\";\nimport {\n  ChatMessage,\n  StartConversationResponse,\n  Attachment,\n  AgentThinkingConfig,\n  AgentWelcomeData,\n} from \"../types\";\nimport {\n  createWebSocket,\n  createWebSocketDiagnostic,\n} from \"../utils/websocket\";\n\nexport class ChatService {\n  private baseUrl: string;\n  private apiKey: string;\n  private metadata: Record<string, any> | undefined;\n  private conversationId: string | null = null;\n  private conversationCreateTime: number | null = null; // Track conversation start time\n  private isFinalized: boolean = false;\n  private webSocket: WebSocket | null = null;\n  private messageHandler: ((message: ChatMessage) => void) | null = null;\n  private takeoverHandler: (() => void) | null = null;\n  private finalizedHandler: (() => void) | null = null;\n  private connectionStateHandler:\n    | ((state: \"connecting\" | \"connected\" | \"disconnected\") => void)\n    | null = null;\n  private welcomeDataHandler: ((data: AgentWelcomeData) => void) | null = null;\n  private storageKeyBase = \"genassist_conversation\";\n  private possibleQueries: string[] = [];\n  private welcomeData: AgentWelcomeData = {};\n  private thinkingConfig: AgentThinkingConfig = { phrases: [], delayMs: 1000 };\n  private welcomeObjectUrl: string | null = null; // to revoke on reset\n  private tenant: string | undefined;\n  private agentId: string | undefined;\n\n  constructor(\n    baseUrl: string,\n    apiKey: string,\n    metadata?: Record<string, any>,\n    tenant?: string\n  ) {\n    this.baseUrl = baseUrl.endsWith(\"/\") ? baseUrl.slice(0, -1) : baseUrl;\n    this.apiKey = apiKey;\n    this.metadata = metadata;\n    this.tenant = tenant;\n    // Try to load a saved conversation for this apiKey from localStorage\n    this.loadSavedConversation();\n  }\n\n  private getStorageKey(): string {\n    // Pointer to current conversation metadata for this apiKey\n    return `${this.storageKeyBase}:${this.apiKey}`;\n  }\n\n  setMessageHandler(handler: (message: ChatMessage) => void) {\n    this.messageHandler = handler;\n  }\n\n  setTakeoverHandler(handler: () => void) {\n    this.takeoverHandler = handler;\n  }\n\n  setFinalizedHandler(handler: () => void) {\n    this.finalizedHandler = handler;\n  }\n\n  setConnectionStateHandler(\n    handler: (state: \"connecting\" | \"connected\" | \"disconnected\") => void\n  ) {\n    this.connectionStateHandler = handler;\n  }\n\n  setWelcomeDataHandler(handler: ((data: AgentWelcomeData) => void) | null) {\n    this.welcomeDataHandler = handler;\n  }\n\n  getPossibleQueries(): string[] {\n    return this.possibleQueries;\n  }\n\n  getWelcomeData(): AgentWelcomeData {\n    return this.welcomeData;\n  }\n\n  getThinkingConfig(): AgentThinkingConfig {\n    return this.thinkingConfig;\n  }\n\n  /**\n   * Load a saved conversation ID from localStorage\n   */\n  private loadSavedConversation(): void {\n    try {\n      let savedConversation = localStorage.getItem(this.getStorageKey());\n      // Backward-compat: check old unscoped key if scoped one missing\n      if (!savedConversation) {\n        savedConversation = localStorage.getItem(this.storageKeyBase);\n      }\n      if (savedConversation) {\n        const {\n          conversationId,\n          createTime,\n          isFinalized,\n          possibleQueries,\n          welcomeData,\n          thinkingConfig,\n          agentId,\n        } = JSON.parse(savedConversation);\n        this.conversationId = conversationId;\n        this.conversationCreateTime = createTime;\n        this.isFinalized = isFinalized || false;\n        this.possibleQueries = Array.isArray(possibleQueries)\n          ? possibleQueries\n          : [];\n        this.welcomeData = welcomeData || {};\n        if (!this.welcomeData.possibleQueries) {\n          this.welcomeData.possibleQueries = this.possibleQueries;\n        }\n        this.thinkingConfig = {\n          phrases: (thinkingConfig && thinkingConfig.phrases) || [],\n          delayMs:\n            thinkingConfig && typeof thinkingConfig.delayMs === \"number\"\n              ? thinkingConfig.delayMs\n              : 1000,\n        };\n        this.agentId = agentId;\n        if (!this.welcomeData.imageUrl && this.agentId) {\n          this.fetchWelcomeImage(this.agentId);\n        }\n        if (this.welcomeDataHandler) {\n          this.welcomeDataHandler(this.welcomeData);\n        }\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Save the current conversation ID to localStorage\n   */\n  private saveConversation(): void {\n    try {\n      if (this.conversationId && this.conversationCreateTime) {\n        const conversationData = {\n          conversationId: this.conversationId,\n          createTime: this.conversationCreateTime,\n          isFinalized: this.isFinalized,\n          possibleQueries: this.possibleQueries,\n          welcomeData: {\n            ...this.welcomeData,\n            imageUrl:\n              this.welcomeObjectUrl &&\n              this.welcomeData.imageUrl &&\n              this.welcomeData.imageUrl.startsWith(\"blob:\")\n                ? null\n                : this.welcomeData.imageUrl || null,\n          },\n          thinkingConfig: this.thinkingConfig,\n          agentId: this.agentId,\n        };\n        localStorage.setItem(this.getStorageKey(), JSON.stringify(conversationData));\n      }\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Reset the current conversation by clearing the ID and websocket\n   */\n  resetConversation(): void {\n    // Close the current websocket connection if it exists\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n\n    // Clear the conversation ID\n    this.conversationId = null;\n    this.conversationCreateTime = null;\n    this.isFinalized = false;\n\n    // Clear possible queries\n    this.possibleQueries = [];\n    this.welcomeData = {};\n    this.thinkingConfig = { phrases: [], delayMs: 1000 };\n    if (this.welcomeObjectUrl) {\n      try {\n        URL.revokeObjectURL(this.welcomeObjectUrl);\n      } catch {}\n      this.welcomeObjectUrl = null;\n    }\n    this.agentId = undefined;\n\n    // Remove from local storage\n    try {\n      localStorage.removeItem(this.getStorageKey());\n    } catch (error) {\n      // ignore\n    }\n  }\n\n  /**\n   * Check if there's a current conversation\n   */\n  hasActiveConversation(): boolean {\n    return !!this.conversationId;\n  }\n\n  /**\n   * Get the current conversation ID\n   */\n  getConversationId(): string | null {\n    return this.conversationId;\n  }\n\n  isConversationFinalized(): boolean {\n    return this.isFinalized;\n  }\n\n  async startConversation(): Promise<string> {\n    try {\n      const requestBody: any = {\n        messages: [],\n        recorded_at: new Date().toISOString(),\n        data_source_id: \"00000000-0000-0000-0000-000000000000\",\n      };\n\n      if (this.metadata) {\n        requestBody.metadata = this.metadata;\n      }\n\n      const response = await axios.post<StartConversationResponse>(\n        `${this.baseUrl}/api/conversations/in-progress/start`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n\n      this.conversationId = response.data.conversation_id;\n      // Store conversation create time (use from response if available, otherwise current time)\n      this.conversationCreateTime = response.data.create_time\n        ? response.data.create_time / 1000\n        : Date.now() / 1000;\n      this.isFinalized = false;\n\n      // Store possible queries if available\n      if (\n        response.data.agent_possible_queries &&\n        response.data.agent_possible_queries.length > 0\n      ) {\n        this.possibleQueries = response.data.agent_possible_queries.filter(\n          (query) => typeof query === \"string\" && query.trim().length > 0\n        );\n      }\n\n      const anyData: any = response.data as any;\n      const agentId: string | undefined = anyData.agent_id;\n      this.agentId = agentId;\n      const welcomeTitle: string | undefined = anyData.agent_welcome_title;\n      const welcomeImageUrl: string | undefined =\n        anyData.agent_welcome_image_url;\n      const thinkingPhrases: string[] | undefined =\n        anyData.agent_thinking_phrases;\n      const thinkingDelaySec: number | undefined =\n        anyData.agent_thinking_phrase_delay;\n\n      this.welcomeData = {\n        title: welcomeTitle || null,\n        message: null,\n        imageUrl: welcomeImageUrl || null,\n        possibleQueries: this.possibleQueries,\n      };\n\n      if (Array.isArray(thinkingPhrases) && thinkingPhrases.length > 0) {\n        this.thinkingConfig.phrases = thinkingPhrases;\n      }\n      if (typeof thinkingDelaySec === \"number\" && thinkingDelaySec >= 0) {\n        this.thinkingConfig.delayMs = Math.max(\n          250,\n          Math.round(thinkingDelaySec * 1000)\n        );\n      }\n\n      if (!this.welcomeData.imageUrl && agentId) {\n        await this.fetchWelcomeImage(agentId);\n      }\n\n      // Process agent welcome message if available\n      if (response.data.agent_welcome_message && this.messageHandler) {\n        const now = Date.now() / 1000;\n        const welcomeMessage: ChatMessage = {\n          create_time: now,\n          start_time: now - this.conversationCreateTime, // Relative to conversation start\n          end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n          speaker: \"agent\",\n          text: response.data.agent_welcome_message,\n        };\n        this.welcomeData.message = response.data.agent_welcome_message;\n        this.messageHandler(welcomeMessage);\n      }\n\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n\n      this.saveConversation();\n      this.connectWebSocket();\n      return response.data.conversation_id;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  async sendMessage(\n    message: string,\n    attachments?: Attachment[],\n    extraMetadata?: Record<string, any>\n  ): Promise<void> {\n    if (!this.conversationId || !this.conversationCreateTime) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const now = Date.now() / 1000;\n    const chatMessage: ChatMessage = {\n      create_time: now,\n      start_time: now - this.conversationCreateTime, // Relative to conversation start\n      end_time: now - this.conversationCreateTime + 0.01, // Relative to conversation start\n      speaker: \"customer\",\n      text: message,\n      attachments: attachments,\n    };\n\n    if (this.messageHandler) {\n      this.messageHandler(chatMessage);\n    }\n\n    try {\n      const requestBody: any = {\n        messages: [chatMessage],\n        recorded_at: new Date().toISOString(),\n      };\n\n      // Include metadata\n      const mergedMetadata = {\n        ...(this.metadata || {}),\n        ...(extraMetadata || {}),\n      };\n      if (Object.keys(mergedMetadata).length > 0) {\n        requestBody.metadata = mergedMetadata;\n      }\n\n      await axios.patch(\n        `${this.baseUrl}/api/conversations/in-progress/update/${this.conversationId}`,\n        requestBody,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"application/json\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n    } catch (error: any) {\n      // Check if this is the agent inactive error\n      if (\n        error.response &&\n        error.response.data &&\n        error.response.data.error_key === \"AGENT_INACTIVE\"\n      ) {\n        // Create a custom message for the agent inactive error\n        if (this.messageHandler) {\n          const errorMessage: ChatMessage = {\n            create_time: now,\n            start_time: now - this.conversationCreateTime,\n            end_time: now - this.conversationCreateTime + 0.01,\n            speaker: \"special\",\n            text: \"The agent is currently offline, please check back later. Thank you!\",\n          };\n          this.messageHandler(errorMessage);\n        }\n        // Don't throw the error since we handled it with a message\n        return;\n      }\n\n      throw error;\n    }\n  }\n\n  async uploadFile(chatId: string, file: File): Promise<{ fileUrl: string }> {\n    if (!this.conversationId) {\n      throw new Error(\"Conversation not started\");\n    }\n\n    const formData = new FormData();\n    formData.append(\"chat_id\", chatId);\n    formData.append(\"file\", file);\n\n    try {\n      const response = await axios.post<{ fileUrl: string }>(\n        `${this.baseUrl}/api/genagent/knowledge/upload-chat-file`,\n        formData,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            \"Content-Type\": \"multipart/form-data\",\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n        }\n      );\n      return response.data;\n    } catch (error) {\n      throw error;\n    }\n  }\n\n  connectWebSocket(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n    }\n\n    if (!this.conversationId) {\n      throw new Error(\"Conversation ID is required for WebSocket connection\");\n    }\n\n    if (this.connectionStateHandler) this.connectionStateHandler(\"connecting\");\n    let wsUrl = `${this.baseUrl.replace(\"http\", \"ws\")}/api/conversations/ws/${\n      this.conversationId\n    }?api_key=${\n      this.apiKey\n    }&lang=en&topics=message&topics=takeover&topics=finalize`;\n    \n    // Add tenant as query parameter if provided\n    if (this.tenant) {\n      wsUrl += `&X-Tenant-ID=${encodeURIComponent(this.tenant)}`;\n    }\n    \n    // Use native browser WebSocket factory\n    this.webSocket = createWebSocket(wsUrl);\n\n\n    this.webSocket.onopen = () => {\n      if (this.connectionStateHandler) this.connectionStateHandler(\"connected\");\n    };\n\n    this.webSocket.onmessage = (event: MessageEvent) => {\n      try {\n        const data = JSON.parse(event.data as string);\n        if (data.type === \"message\" && this.messageHandler) {\n          if (Array.isArray(data.payload)) {\n            const messages = data.payload as ChatMessage[];\n            // Adjust timestamps to be relative to conversation start\n            // Also normalize message_id field (backend might send 'id' instead of 'message_id')\n            const adjustedMessages = messages\n              .map((msg) => {\n                const adjusted = this.adjustMessageTimestamps(msg);\n                // Normalize: if backend sends 'id', use it as 'message_id'\n                if (!adjusted.message_id && (msg as any).id) {\n                  adjusted.message_id = (msg as any).id;\n                }\n                return adjusted;\n              })\n              .filter((msg) => msg.speaker !== \"customer\");\n            adjustedMessages.forEach(this.messageHandler);\n          } else {\n            const adjustedMessage = this.adjustMessageTimestamps(\n              data.payload as ChatMessage\n            );\n            // Normalize: if backend sends 'id', use it as 'message_id'\n            if (!adjustedMessage.message_id && (data.payload as any).id) {\n              adjustedMessage.message_id = (data.payload as any).id;\n            }\n            if (adjustedMessage.speaker !== \"customer\") {\n              this.messageHandler(adjustedMessage);\n            }\n          }\n        } else if (data.type === \"takeover\") {\n          // Handle takeover event\n          // Create special message for the takeover indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const takeoverMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Supervisor took over\",\n            };\n            this.messageHandler(takeoverMessage);\n          }\n\n          // Call the takeover handler if provided\n          if (this.takeoverHandler) {\n            this.takeoverHandler();\n          }\n        } else if (data.type === \"finalize\") {\n          // Handle finalized event\n          // Create special message for the finalized indicator\n          if (this.messageHandler) {\n            const now = Date.now() / 1000;\n            const finalizedMessage: ChatMessage = {\n              create_time: now,\n              start_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime\n                : 0,\n              end_time: this.conversationCreateTime\n                ? now - this.conversationCreateTime + 0.01\n                : 0.01,\n              speaker: \"special\",\n              text: \"Conversation Finalized\",\n            };\n            this.messageHandler(finalizedMessage);\n          }\n\n          // Call the finalized handler if provided\n          if (this.finalizedHandler) {\n            this.finalizedHandler();\n          }\n          this.isFinalized = true;\n          this.saveConversation();\n        }\n      } catch (error) {\n        // ignore\n      }\n    };\n\n    this.webSocket.onerror = (error: Event) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      const diagnostic = createWebSocketDiagnostic(error, wsUrl);\n      console.error(`[GenAssist Chat] ${diagnostic}`);\n    };\n\n    this.webSocket.onclose = (event: CloseEvent) => {\n      if (this.connectionStateHandler)\n        this.connectionStateHandler(\"disconnected\");\n      \n      // Log diagnostic\n      if (!event.wasClean) {\n        const diagnostic = createWebSocketDiagnostic(event, wsUrl);\n        console.warn(`[GenAssist Chat] ${diagnostic}`);\n      }\n    };\n  }\n\n  disconnect(): void {\n    if (this.webSocket) {\n      this.webSocket.close();\n      this.webSocket = null;\n    }\n  }\n\n  private async fetchWelcomeImage(agentId: string): Promise<void> {\n    try {\n      const imageResponse = await axios.get(\n        `${this.baseUrl}/api/genagent/agents/configs/${agentId}/welcome-image`,\n        {\n          headers: {\n            \"x-api-key\": this.apiKey,\n            ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n          },\n          responseType: \"blob\",\n        }\n      );\n      const blobUrl = URL.createObjectURL(imageResponse.data);\n      this.welcomeObjectUrl = blobUrl;\n      this.welcomeData.imageUrl = blobUrl;\n      if (this.welcomeDataHandler) {\n        this.welcomeDataHandler(this.welcomeData);\n      }\n    } catch (err) {\n      // ignore\n    }\n  }\n\n  // Add feedback to a specific agent message in the conversation\n  async addFeedback(\n    messageId: string,\n    feedback: \"good\" | \"bad\",\n    feedback_message?: string\n  ): Promise<void> {\n    if (!messageId) {\n      throw new Error(\"Message ID is required for feedback\");\n    }\n\n    try {\n      // Use message ID in the URL path, not conversation ID\n      const url = `${this.baseUrl}/api/conversations/message/add-feedback/${messageId}`;\n      // Body should only contain feedback and feedback_message (no message_id)\n      const payload: {\n        feedback: \"good\" | \"bad\";\n        feedback_message?: string;\n      } = {\n        feedback,\n      };\n      \n      if (feedback_message) {\n        payload.feedback_message = feedback_message;\n      }\n      \n      await axios.patch(url, payload, {\n        headers: {\n          \"x-api-key\": this.apiKey,\n          \"Content-Type\": \"application/json\",\n          ...(this.tenant ? { \"X-Tenant-Id\": this.tenant } : {}),\n        },\n      });\n      \n    } catch (error: any) {\n      console.error('Feedback API call failed:', {\n        message: error.message,\n        response: error.response?.data,\n        status: error.response?.status,\n      });\n      throw error;\n    }\n  }\n\n  // Helper method to adjust message timestamps relative to conversation start\n  private adjustMessageTimestamps(message: ChatMessage): ChatMessage {\n    if (!this.conversationCreateTime) {\n      return message;\n    }\n\n    return {\n      ...message,\n      start_time: message.start_time - this.conversationCreateTime,\n      end_time: message.end_time - this.conversationCreateTime,\n    };\n  }\n}\n"]}
|