@elqnt/agents 3.0.5 → 3.1.0

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.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/eloquent/eloquent/packages/@elqnt/agents/dist/chunk-RWFVHX2J.js","../hooks/index.ts","../hooks/use-async.ts","../hooks/use-options-ref.ts"],"names":["useRef"],"mappings":"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","file":"/home/runner/work/eloquent/eloquent/packages/@elqnt/agents/dist/chunk-RWFVHX2J.js","sourcesContent":[null,"\"use client\";\n\n/**\n * Agent hooks for React applications\n *\n * Provides React hooks for agent CRUD operations with loading/error states.\n *\n * @packageDocumentation\n */\n\nimport { useMemo } from \"react\";\nimport type { ApiClientOptions } from \"@elqnt/api-client\";\nimport type {\n Agent, AgentSummary, Skill, SubAgent, ToolDefinition, AgentJob, AgentWidget, SkillUserConfig, ResolveSkillConfigResponse,\n UserIntegration, IntegrationProviderTS, IntegrationTypeTS,\n} from \"../models\";\nimport {\n // Agents\n listAgentsApi,\n listAgentsSummaryApi,\n getAgentApi,\n createAgentApi,\n updateAgentApi,\n deleteAgentApi,\n getDefaultAgentApi,\n // Skills\n listSkillsApi,\n getSkillApi,\n createSkillApi,\n updateSkillApi,\n deleteSkillApi,\n getSkillCategoriesApi,\n // Skill User Config\n getSkillUserConfigApi,\n updateSkillUserConfigApi,\n deleteSkillUserConfigApi,\n listSkillUserConfigsApi,\n resolveSkillConfigApi,\n // Sub-Agents\n listSubAgentsApi,\n getSubAgentApi,\n createSubAgentApi,\n updateSubAgentApi,\n deleteSubAgentApi,\n // Tool Definitions\n listToolDefinitionsApi,\n getToolDefinitionApi,\n createToolDefinitionApi,\n updateToolDefinitionApi,\n deleteToolDefinitionApi,\n getToolDefinitionsByIdsApi,\n // Agent Jobs\n listAgentJobsApi,\n getAgentJobApi,\n createAgentJobApi,\n updateAgentJobApi,\n deleteAgentJobApi,\n pauseAgentJobApi,\n resumeAgentJobApi,\n // Widgets\n listWidgetsApi,\n getWidgetApi,\n createWidgetApi,\n updateWidgetApi,\n deleteWidgetApi,\n getDefaultWidgetApi,\n setDefaultWidgetApi,\n // Analytics\n getAgentChatsAnalyticsApi,\n getAgentCSATAnalyticsApi,\n getAgentListAnalyticsApi,\n getTaskOutcomesApi,\n type DateFilter,\n // Integrations\n listIntegrationsApi,\n getIntegrationApi,\n connectIntegrationApi,\n disconnectIntegrationApi,\n refreshIntegrationApi,\n updateIntegrationTriageApi,\n runEmailTriageApi,\n} from \"../api\";\nimport { useApiAsync } from \"./use-async\";\nimport { useOptionsRef } from \"./use-options-ref\";\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type UseAgentsOptions = ApiClientOptions;\n\n// =============================================================================\n// USE AGENTS HOOK\n// =============================================================================\n\n/**\n * Hook for agent CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listAgents, createAgent } = useAgents({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const agents = await listAgents();\n * ```\n */\nexport function useAgents(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listAgents, loading: listLoading, error: listError } = useApiAsync(\n () => listAgentsApi(optionsRef.current),\n (data) => data.agents,\n [] as Agent[]\n );\n\n const { execute: listAgentSummaries, loading: listSummaryLoading, error: listSummaryError } = useApiAsync(\n () => listAgentsSummaryApi(optionsRef.current),\n (data) => data.agents,\n [] as AgentSummary[]\n );\n\n const { execute: getAgent, loading: getLoading, error: getError } = useApiAsync(\n (agentId: string) => getAgentApi(agentId, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: createAgent, loading: createLoading, error: createError } = useApiAsync(\n (agent: Partial<Agent>) => createAgentApi(agent, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: updateAgent, loading: updateLoading, error: updateError } = useApiAsync(\n (agentId: string, agent: Partial<Agent>) => updateAgentApi(agentId, agent, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: deleteAgent, loading: deleteLoading, error: deleteError } = useApiAsync(\n (agentId: string) => deleteAgentApi(agentId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: getDefaultAgent, loading: defaultLoading, error: defaultError } = useApiAsync(\n () => getDefaultAgentApi(optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const loading = listLoading || listSummaryLoading || getLoading || createLoading || updateLoading || deleteLoading || defaultLoading;\n const error = listError || listSummaryError || getError || createError || updateError || deleteError || defaultError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listAgents,\n listAgentSummaries,\n getAgent,\n createAgent,\n updateAgent,\n deleteAgent,\n getDefaultAgent,\n }),\n [loading, error, listAgents, listAgentSummaries, getAgent, createAgent, updateAgent, deleteAgent, getDefaultAgent]\n );\n}\n\n// =============================================================================\n// USE SKILLS HOOK\n// =============================================================================\n\n/**\n * Hook for skill CRUD operations\n */\nexport function useSkills(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listSkills, loading: listLoading, error: listError } = useApiAsync(\n () => listSkillsApi(optionsRef.current),\n (data) => data.skills,\n [] as Skill[]\n );\n\n const { execute: getSkill, loading: getLoading, error: getError } = useApiAsync(\n (skillId: string) => getSkillApi(skillId, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: createSkill, loading: createLoading, error: createError } = useApiAsync(\n (skill: Partial<Skill>) => createSkillApi(skill, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: updateSkill, loading: updateLoading, error: updateError } = useApiAsync(\n (skillId: string, skill: Partial<Skill>) => updateSkillApi(skillId, skill, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: deleteSkill, loading: deleteLoading, error: deleteError } = useApiAsync(\n (skillId: string) => deleteSkillApi(skillId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: getCategories, loading: categoriesLoading, error: categoriesError } = useApiAsync(\n () => getSkillCategoriesApi(optionsRef.current),\n (data) => data.categories,\n [] as string[]\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading || categoriesLoading;\n const error = listError || getError || createError || updateError || deleteError || categoriesError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listSkills,\n getSkill,\n createSkill,\n updateSkill,\n deleteSkill,\n getCategories,\n }),\n [loading, error, listSkills, getSkill, createSkill, updateSkill, deleteSkill, getCategories]\n );\n}\n\n// =============================================================================\n// USE SUB-AGENTS HOOK\n// =============================================================================\n\n/**\n * Hook for sub-agent CRUD operations\n */\nexport function useSubAgents(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listSubAgents, loading: listLoading, error: listError } = useApiAsync(\n () => listSubAgentsApi(optionsRef.current),\n (data) => data.subAgents,\n [] as SubAgent[]\n );\n\n const { execute: getSubAgent, loading: getLoading, error: getError } = useApiAsync(\n (subAgentId: string) => getSubAgentApi(subAgentId, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: createSubAgent, loading: createLoading, error: createError } = useApiAsync(\n (subAgent: Partial<SubAgent>) => createSubAgentApi(subAgent, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: updateSubAgent, loading: updateLoading, error: updateError } = useApiAsync(\n (subAgentId: string, subAgent: Partial<SubAgent>) => updateSubAgentApi(subAgentId, subAgent, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: deleteSubAgent, loading: deleteLoading, error: deleteError } = useApiAsync(\n (subAgentId: string) => deleteSubAgentApi(subAgentId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading;\n const error = listError || getError || createError || updateError || deleteError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listSubAgents,\n getSubAgent,\n createSubAgent,\n updateSubAgent,\n deleteSubAgent,\n }),\n [loading, error, listSubAgents, getSubAgent, createSubAgent, updateSubAgent, deleteSubAgent]\n );\n}\n\n// =============================================================================\n// USE TOOL DEFINITIONS HOOK\n// =============================================================================\n\n/**\n * Hook for tool definition CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listToolDefinitions, createToolDefinition } = useToolDefinitions({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const toolDefs = await listToolDefinitions();\n * ```\n */\nexport function useToolDefinitions(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listToolDefinitions, loading: listLoading, error: listError } = useApiAsync(\n () => listToolDefinitionsApi(optionsRef.current),\n (data) => data.toolDefinitions,\n [] as ToolDefinition[]\n );\n\n const { execute: getToolDefinition, loading: getLoading, error: getError } = useApiAsync(\n (toolDefId: string) => getToolDefinitionApi(toolDefId, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: getToolDefinitionsByIds, loading: getByIdsLoading, error: getByIdsError } = useApiAsync(\n (ids: string[]) => getToolDefinitionsByIdsApi(ids, optionsRef.current),\n (data) => data.toolDefinitions,\n [] as ToolDefinition[]\n );\n\n const { execute: createToolDefinition, loading: createLoading, error: createError } = useApiAsync(\n (toolDefinition: Partial<ToolDefinition>) => createToolDefinitionApi(toolDefinition, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: updateToolDefinition, loading: updateLoading, error: updateError } = useApiAsync(\n (toolDefId: string, toolDefinition: Partial<ToolDefinition>) => updateToolDefinitionApi(toolDefId, toolDefinition, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: deleteToolDefinition, loading: deleteLoading, error: deleteError } = useApiAsync(\n (toolDefId: string) => deleteToolDefinitionApi(toolDefId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || getByIdsLoading || createLoading || updateLoading || deleteLoading;\n const error = listError || getError || getByIdsError || createError || updateError || deleteError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listToolDefinitions,\n getToolDefinition,\n getToolDefinitionsByIds,\n createToolDefinition,\n updateToolDefinition,\n deleteToolDefinition,\n }),\n [loading, error, listToolDefinitions, getToolDefinition, getToolDefinitionsByIds, createToolDefinition, updateToolDefinition, deleteToolDefinition]\n );\n}\n\n// =============================================================================\n// USE AGENT JOBS HOOK\n// =============================================================================\n\n/**\n * Hook for agent job CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listAgentJobs, createAgentJob, pauseAgentJob } = useAgentJobs({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const jobs = await listAgentJobs();\n * await pauseAgentJob(jobId);\n * ```\n */\nexport function useAgentJobs(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listAgentJobs, loading: listLoading, error: listError } = useApiAsync(\n () => listAgentJobsApi(optionsRef.current),\n (data) => data.jobs,\n [] as AgentJob[]\n );\n\n const { execute: getAgentJob, loading: getLoading, error: getError } = useApiAsync(\n (jobId: string) => getAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: createAgentJob, loading: createLoading, error: createError } = useApiAsync(\n (job: Partial<AgentJob>) => createAgentJobApi(job, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: updateAgentJob, loading: updateLoading, error: updateError } = useApiAsync(\n (jobId: string, job: Partial<AgentJob>) => updateAgentJobApi(jobId, job, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: deleteAgentJob, loading: deleteLoading, error: deleteError } = useApiAsync(\n (jobId: string) => deleteAgentJobApi(jobId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: pauseAgentJob, loading: pauseLoading, error: pauseError } = useApiAsync(\n (jobId: string) => pauseAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: resumeAgentJob, loading: resumeLoading, error: resumeError } = useApiAsync(\n (jobId: string) => resumeAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading || pauseLoading || resumeLoading;\n const error = listError || getError || createError || updateError || deleteError || pauseError || resumeError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listAgentJobs,\n getAgentJob,\n createAgentJob,\n updateAgentJob,\n deleteAgentJob,\n pauseAgentJob,\n resumeAgentJob,\n }),\n [loading, error, listAgentJobs, getAgentJob, createAgentJob, updateAgentJob, deleteAgentJob, pauseAgentJob, resumeAgentJob]\n );\n}\n\n// =============================================================================\n// USE WIDGETS HOOK\n// =============================================================================\n\nexport interface UseWidgetsOptions extends UseAgentsOptions {\n agentId: string;\n}\n\n/**\n * Hook for widget CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listWidgets, createWidget } = useWidgets({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * agentId: selectedAgentId,\n * });\n *\n * const widgets = await listWidgets();\n * ```\n */\nexport function useWidgets(options: UseWidgetsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listWidgets, loading: listLoading, error: listError } = useApiAsync(\n () => listWidgetsApi(optionsRef.current.agentId, optionsRef.current),\n (data) => data.widgets,\n [] as AgentWidget[]\n );\n\n const { execute: getWidget, loading: getLoading, error: getError } = useApiAsync(\n (widgetId: string) => getWidgetApi(widgetId, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: getDefaultWidget, loading: defaultLoading, error: defaultError } = useApiAsync(\n () => getDefaultWidgetApi(optionsRef.current.agentId, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: createWidget, loading: createLoading, error: createError } = useApiAsync(\n (widget: Partial<AgentWidget>) => createWidgetApi(optionsRef.current.agentId, widget, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: updateWidget, loading: updateLoading, error: updateError } = useApiAsync(\n (widgetId: string, widget: Partial<AgentWidget>) => updateWidgetApi(widgetId, widget, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: deleteWidget, loading: deleteLoading, error: deleteError } = useApiAsync(\n (widgetId: string) => deleteWidgetApi(widgetId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: setDefaultWidget, loading: setDefaultLoading, error: setDefaultError } = useApiAsync(\n (widgetId: string) => setDefaultWidgetApi(widgetId, optionsRef.current.agentId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || defaultLoading || createLoading || updateLoading || deleteLoading || setDefaultLoading;\n const error = listError || getError || defaultError || createError || updateError || deleteError || setDefaultError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listWidgets,\n getWidget,\n getDefaultWidget,\n createWidget,\n updateWidget,\n deleteWidget,\n setDefaultWidget,\n }),\n [loading, error, listWidgets, getWidget, getDefaultWidget, createWidget, updateWidget, deleteWidget, setDefaultWidget]\n );\n}\n\n// =============================================================================\n// USE SKILL USER CONFIG HOOK\n// =============================================================================\n\n/**\n * Hook for skill user configuration operations\n *\n * @example\n * ```tsx\n * const { loading, error, getSkillUserConfig, updateSkillUserConfig } = useSkillUserConfig({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const config = await getSkillUserConfig(skillId);\n * await updateSkillUserConfig(skillId, { enabled: true });\n * ```\n */\nexport function useSkillUserConfig(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: getSkillUserConfig, loading: getLoading, error: getError } = useApiAsync(\n (skillId: string, agentId?: string) =>\n getSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),\n (data) => data.userConfig || null,\n null as SkillUserConfig | null\n );\n\n const { execute: updateSkillUserConfig, loading: updateLoading, error: updateError } = useApiAsync(\n (\n skillId: string,\n data: { enabled?: boolean; displayOrder?: number; config?: Record<string, unknown>; agentId?: string }\n ) => updateSkillUserConfigApi(skillId, data, optionsRef.current),\n (data) => data.userConfig || null,\n null as SkillUserConfig | null\n );\n\n const { execute: deleteSkillUserConfig, loading: deleteLoading, error: deleteError } = useApiAsync(\n (skillId: string, agentId?: string) =>\n deleteSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),\n () => true,\n false\n );\n\n const { execute: listSkillUserConfigs, loading: listLoading, error: listError } = useApiAsync(\n (params?: { agentId?: string; limit?: number; offset?: number }) =>\n listSkillUserConfigsApi({ ...optionsRef.current, ...params }),\n (data) => data.userConfigs || [],\n [] as SkillUserConfig[]\n );\n\n const { execute: resolveSkillConfig, loading: resolveLoading, error: resolveError } = useApiAsync(\n (skillId: string, agentId: string) => resolveSkillConfigApi(skillId, agentId, optionsRef.current),\n (data) => data,\n null as ResolveSkillConfigResponse | null\n );\n\n const loading = getLoading || updateLoading || deleteLoading || listLoading || resolveLoading;\n const error = getError || updateError || deleteError || listError || resolveError;\n\n return useMemo(\n () => ({\n loading,\n error,\n getSkillUserConfig,\n updateSkillUserConfig,\n deleteSkillUserConfig,\n listSkillUserConfigs,\n resolveSkillConfig,\n }),\n [loading, error, getSkillUserConfig, updateSkillUserConfig, deleteSkillUserConfig, listSkillUserConfigs, resolveSkillConfig]\n );\n}\n\n// =============================================================================\n// USE ANALYTICS HOOK\n// =============================================================================\n\n/**\n * Hook for agent analytics operations\n *\n * @example\n * ```tsx\n * const { loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics } = useAnalytics({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const chatsData = await getAgentChatsAnalytics({ from: '2024-01-01', to: '2024-12-31' });\n * ```\n */\nexport function useAnalytics(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: getAgentChatsAnalytics, loading: chatsLoading, error: chatsError } = useApiAsync(\n (params: { date_filter: DateFilter; agent_id?: string }) =>\n getAgentChatsAnalyticsApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getAgentCSATAnalytics, loading: csatLoading, error: csatError } = useApiAsync(\n (params: { date_filter: DateFilter; agent_id?: string }) =>\n getAgentCSATAnalyticsApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getAgentListAnalytics, loading: listLoading, error: listError } = useApiAsync(\n () => getAgentListAnalyticsApi(optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getTaskOutcomes, loading: taskLoading, error: taskError } = useApiAsync(\n (params: { date_filter: DateFilter }) => getTaskOutcomesApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const loading = chatsLoading || csatLoading || listLoading || taskLoading;\n const error = chatsError || csatError || listError || taskError;\n\n return useMemo(\n () => ({\n loading,\n error,\n getAgentChatsAnalytics,\n getAgentCSATAnalytics,\n getAgentListAnalytics,\n getTaskOutcomes,\n }),\n [loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics, getAgentListAnalytics, getTaskOutcomes]\n );\n}\n\n// =============================================================================\n// USE INTEGRATIONS HOOK\n// =============================================================================\n\n/**\n * Hook for user integration operations (OAuth connections)\n *\n * @example\n * ```tsx\n * const { loading, error, listIntegrations, connectIntegration, disconnectIntegration } = useIntegrations({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const integrations = await listIntegrations();\n * const { auth_url } = await connectIntegration({ provider: 'google', integrationType: 'email', redirectUri: '/callback' });\n * ```\n */\nexport function useIntegrations(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listIntegrations, loading: listLoading, error: listError } = useApiAsync(\n () => listIntegrationsApi(optionsRef.current),\n (data) => data.integrations,\n [] as UserIntegration[]\n );\n\n const { execute: getIntegration, loading: getLoading, error: getError } = useApiAsync(\n (provider: IntegrationProviderTS, integrationType: IntegrationTypeTS) =>\n getIntegrationApi(provider, integrationType, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: connectIntegration, loading: connectLoading, error: connectError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS; redirectUri: string }) =>\n connectIntegrationApi(params, optionsRef.current),\n (data) => ({ authUrl: data.auth_url, state: data.state }),\n null as { authUrl: string; state: string } | null\n );\n\n const { execute: disconnectIntegration, loading: disconnectLoading, error: disconnectError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS }) =>\n disconnectIntegrationApi(params, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: refreshIntegration, loading: refreshLoading, error: refreshError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS }) =>\n refreshIntegrationApi(params, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: updateTriage, loading: updateTriageLoading, error: updateTriageError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS; triageEnabled: boolean }) =>\n updateIntegrationTriageApi(params, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: runEmailTriage, loading: runTriageLoading, error: runTriageError } = useApiAsync(\n () => runEmailTriageApi(optionsRef.current),\n (data) => ({ success: data.success, emailsFound: data.emails_found, instancesCreated: data.instances_created }),\n null as { success: boolean; emailsFound: number; instancesCreated: number } | null\n );\n\n const loading = listLoading || getLoading || connectLoading || disconnectLoading || refreshLoading || updateTriageLoading || runTriageLoading;\n const error = listError || getError || connectError || disconnectError || refreshError || updateTriageError || runTriageError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listIntegrations,\n getIntegration,\n connectIntegration,\n disconnectIntegration,\n refreshIntegration,\n updateTriage,\n runEmailTriage,\n }),\n [loading, error, listIntegrations, getIntegration, connectIntegration, disconnectIntegration, refreshIntegration, updateTriage, runEmailTriage]\n );\n}\n\n// =============================================================================\n// EXPORTS\n// =============================================================================\n\n// Re-export hook utilities for advanced usage\nexport { useApiAsync, useAsync } from \"./use-async\";\nexport { useOptionsRef } from \"./use-options-ref\";\nexport type { UseAsyncOptions, UseAsyncReturn } from \"./use-async\";\n","\"use client\";\n\n/**\n * Async operation utilities for React hooks\n *\n * Provides a generic pattern for handling async operations with loading/error states.\n * Uses a request counter for accurate concurrent loading state.\n */\n\nimport { useState, useCallback, useRef } from \"react\";\nimport type { ApiResponse } from \"@elqnt/api-client\";\n\nexport interface UseAsyncOptions {\n onError?: (error: string) => void;\n}\n\nexport interface UseAsyncReturn<TResult, TArgs extends unknown[] = []> {\n execute: (...args: TArgs) => Promise<TResult>;\n loading: boolean;\n error: string | null;\n clearError: () => void;\n}\n\n/**\n * Generic async hook for any promise-returning function.\n * Uses a request counter to properly track concurrent requests.\n */\nexport function useAsync<TResult, TArgs extends unknown[] = []>(\n asyncFn: (...args: TArgs) => Promise<TResult>,\n options?: UseAsyncOptions\n): UseAsyncReturn<TResult, TArgs> {\n const [error, setError] = useState<string | null>(null);\n const requestCountRef = useRef(0);\n const [loading, setLoading] = useState(false);\n\n const execute = useCallback(\n async (...args: TArgs): Promise<TResult> => {\n requestCountRef.current += 1;\n setLoading(true);\n setError(null);\n\n try {\n return await asyncFn(...args);\n } catch (err) {\n const message = err instanceof Error ? err.message : \"An error occurred\";\n setError(message);\n options?.onError?.(message);\n throw err;\n } finally {\n requestCountRef.current -= 1;\n if (requestCountRef.current === 0) {\n setLoading(false);\n }\n }\n },\n [asyncFn, options]\n );\n\n const clearError = useCallback(() => setError(null), []);\n\n return { execute, loading, error, clearError };\n}\n\n/**\n * Specialized async hook for API operations that return ApiResponse.\n * Automatically extracts data and handles API errors.\n *\n * @param asyncFn - Function that returns ApiResponse<TResponse>\n * @param extractor - Function to extract the desired result from response data\n * @param defaultValue - Default value to return on error\n * @param options - Optional configuration\n *\n * @example\n * ```tsx\n * const { execute: listAgents, loading, error } = useApiAsync(\n * () => listAgentsApi(optionsRef.current),\n * (data) => data.agents,\n * []\n * );\n * ```\n */\nexport function useApiAsync<TResponse, TResult, TArgs extends unknown[] = []>(\n asyncFn: (...args: TArgs) => Promise<ApiResponse<TResponse>>,\n extractor: (data: TResponse) => TResult,\n defaultValue: TResult,\n options?: UseAsyncOptions\n): UseAsyncReturn<TResult, TArgs> {\n const [error, setError] = useState<string | null>(null);\n const requestCountRef = useRef(0);\n const [loading, setLoading] = useState(false);\n\n const execute = useCallback(\n async (...args: TArgs): Promise<TResult> => {\n requestCountRef.current += 1;\n setLoading(true);\n setError(null);\n\n try {\n const response = await asyncFn(...args);\n if (response.error) {\n setError(response.error);\n options?.onError?.(response.error);\n return defaultValue;\n }\n return response.data ? extractor(response.data) : defaultValue;\n } catch (err) {\n const message = err instanceof Error ? err.message : \"An error occurred\";\n setError(message);\n options?.onError?.(message);\n return defaultValue;\n } finally {\n requestCountRef.current -= 1;\n if (requestCountRef.current === 0) {\n setLoading(false);\n }\n }\n },\n [asyncFn, extractor, defaultValue, options]\n );\n\n const clearError = useCallback(() => setError(null), []);\n\n return { execute, loading, error, clearError };\n}\n","\"use client\";\n\n/**\n * Options reference utility for React hooks\n *\n * Keeps a mutable ref synchronized with options to avoid\n * stale closures in callbacks while preventing unnecessary re-renders.\n */\n\nimport { useRef, useEffect } from \"react\";\n\n/**\n * Creates a ref that stays synchronized with the provided options.\n * Useful for accessing current options values in callbacks without\n * causing re-renders or stale closure issues.\n *\n * @param options - The options object to track\n * @returns A ref that always contains the latest options\n *\n * @example\n * ```tsx\n * const optionsRef = useOptionsRef(options);\n *\n * const fetchData = useCallback(async () => {\n * // Always has the latest options, no stale closure\n * const result = await api.fetch(optionsRef.current);\n * }, []); // No need to include options in deps\n * ```\n */\nexport function useOptionsRef<T>(options: T): React.MutableRefObject<T> {\n const optionsRef = useRef(options);\n\n useEffect(() => {\n optionsRef.current = options;\n }, [options]);\n\n return optionsRef;\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  "use client";
2
2
  import {
3
+ connectIntegrationApi,
3
4
  createAgentApi,
4
5
  createAgentJobApi,
5
6
  createSkillApi,
@@ -9,36 +10,51 @@ import {
9
10
  deleteAgentApi,
10
11
  deleteAgentJobApi,
11
12
  deleteSkillApi,
13
+ deleteSkillUserConfigApi,
12
14
  deleteSubAgentApi,
13
15
  deleteToolDefinitionApi,
14
16
  deleteWidgetApi,
17
+ disconnectIntegrationApi,
15
18
  getAgentApi,
19
+ getAgentCSATAnalyticsApi,
20
+ getAgentChatsAnalyticsApi,
16
21
  getAgentJobApi,
22
+ getAgentListAnalyticsApi,
17
23
  getDefaultAgentApi,
18
24
  getDefaultWidgetApi,
25
+ getIntegrationApi,
19
26
  getSkillApi,
20
27
  getSkillCategoriesApi,
28
+ getSkillUserConfigApi,
21
29
  getSubAgentApi,
30
+ getTaskOutcomesApi,
22
31
  getToolDefinitionApi,
23
32
  getToolDefinitionsByIdsApi,
24
33
  getWidgetApi,
25
34
  listAgentJobsApi,
26
35
  listAgentsApi,
27
36
  listAgentsSummaryApi,
37
+ listIntegrationsApi,
38
+ listSkillUserConfigsApi,
28
39
  listSkillsApi,
29
40
  listSubAgentsApi,
30
41
  listToolDefinitionsApi,
31
42
  listWidgetsApi,
32
43
  pauseAgentJobApi,
44
+ refreshIntegrationApi,
45
+ resolveSkillConfigApi,
33
46
  resumeAgentJobApi,
47
+ runEmailTriageApi,
34
48
  setDefaultWidgetApi,
35
49
  updateAgentApi,
36
50
  updateAgentJobApi,
51
+ updateIntegrationTriageApi,
37
52
  updateSkillApi,
53
+ updateSkillUserConfigApi,
38
54
  updateSubAgentApi,
39
55
  updateToolDefinitionApi,
40
56
  updateWidgetApi
41
- } from "./chunk-XYJDCUUG.mjs";
57
+ } from "./chunk-NF6PGOXP.mjs";
42
58
 
43
59
  // hooks/index.ts
44
60
  import { useMemo } from "react";
@@ -419,6 +435,138 @@ function useWidgets(options) {
419
435
  [loading, error, listWidgets, getWidget, getDefaultWidget, createWidget, updateWidget, deleteWidget, setDefaultWidget]
420
436
  );
421
437
  }
438
+ function useSkillUserConfig(options) {
439
+ const optionsRef = useOptionsRef(options);
440
+ const { execute: getSkillUserConfig, loading: getLoading, error: getError } = useApiAsync(
441
+ (skillId, agentId) => getSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),
442
+ (data) => data.userConfig || null,
443
+ null
444
+ );
445
+ const { execute: updateSkillUserConfig, loading: updateLoading, error: updateError } = useApiAsync(
446
+ (skillId, data) => updateSkillUserConfigApi(skillId, data, optionsRef.current),
447
+ (data) => data.userConfig || null,
448
+ null
449
+ );
450
+ const { execute: deleteSkillUserConfig, loading: deleteLoading, error: deleteError } = useApiAsync(
451
+ (skillId, agentId) => deleteSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),
452
+ () => true,
453
+ false
454
+ );
455
+ const { execute: listSkillUserConfigs, loading: listLoading, error: listError } = useApiAsync(
456
+ (params) => listSkillUserConfigsApi({ ...optionsRef.current, ...params }),
457
+ (data) => data.userConfigs || [],
458
+ []
459
+ );
460
+ const { execute: resolveSkillConfig, loading: resolveLoading, error: resolveError } = useApiAsync(
461
+ (skillId, agentId) => resolveSkillConfigApi(skillId, agentId, optionsRef.current),
462
+ (data) => data,
463
+ null
464
+ );
465
+ const loading = getLoading || updateLoading || deleteLoading || listLoading || resolveLoading;
466
+ const error = getError || updateError || deleteError || listError || resolveError;
467
+ return useMemo(
468
+ () => ({
469
+ loading,
470
+ error,
471
+ getSkillUserConfig,
472
+ updateSkillUserConfig,
473
+ deleteSkillUserConfig,
474
+ listSkillUserConfigs,
475
+ resolveSkillConfig
476
+ }),
477
+ [loading, error, getSkillUserConfig, updateSkillUserConfig, deleteSkillUserConfig, listSkillUserConfigs, resolveSkillConfig]
478
+ );
479
+ }
480
+ function useAnalytics(options) {
481
+ const optionsRef = useOptionsRef(options);
482
+ const { execute: getAgentChatsAnalytics, loading: chatsLoading, error: chatsError } = useApiAsync(
483
+ (params) => getAgentChatsAnalyticsApi(params, optionsRef.current),
484
+ (data) => data.data,
485
+ []
486
+ );
487
+ const { execute: getAgentCSATAnalytics, loading: csatLoading, error: csatError } = useApiAsync(
488
+ (params) => getAgentCSATAnalyticsApi(params, optionsRef.current),
489
+ (data) => data.data,
490
+ []
491
+ );
492
+ const { execute: getAgentListAnalytics, loading: listLoading, error: listError } = useApiAsync(
493
+ () => getAgentListAnalyticsApi(optionsRef.current),
494
+ (data) => data.data,
495
+ []
496
+ );
497
+ const { execute: getTaskOutcomes, loading: taskLoading, error: taskError } = useApiAsync(
498
+ (params) => getTaskOutcomesApi(params, optionsRef.current),
499
+ (data) => data.data,
500
+ []
501
+ );
502
+ const loading = chatsLoading || csatLoading || listLoading || taskLoading;
503
+ const error = chatsError || csatError || listError || taskError;
504
+ return useMemo(
505
+ () => ({
506
+ loading,
507
+ error,
508
+ getAgentChatsAnalytics,
509
+ getAgentCSATAnalytics,
510
+ getAgentListAnalytics,
511
+ getTaskOutcomes
512
+ }),
513
+ [loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics, getAgentListAnalytics, getTaskOutcomes]
514
+ );
515
+ }
516
+ function useIntegrations(options) {
517
+ const optionsRef = useOptionsRef(options);
518
+ const { execute: listIntegrations, loading: listLoading, error: listError } = useApiAsync(
519
+ () => listIntegrationsApi(optionsRef.current),
520
+ (data) => data.integrations,
521
+ []
522
+ );
523
+ const { execute: getIntegration, loading: getLoading, error: getError } = useApiAsync(
524
+ (provider, integrationType) => getIntegrationApi(provider, integrationType, optionsRef.current),
525
+ (data) => data.integration || null,
526
+ null
527
+ );
528
+ const { execute: connectIntegration, loading: connectLoading, error: connectError } = useApiAsync(
529
+ (params) => connectIntegrationApi(params, optionsRef.current),
530
+ (data) => ({ authUrl: data.auth_url, state: data.state }),
531
+ null
532
+ );
533
+ const { execute: disconnectIntegration, loading: disconnectLoading, error: disconnectError } = useApiAsync(
534
+ (params) => disconnectIntegrationApi(params, optionsRef.current),
535
+ () => true,
536
+ false
537
+ );
538
+ const { execute: refreshIntegration, loading: refreshLoading, error: refreshError } = useApiAsync(
539
+ (params) => refreshIntegrationApi(params, optionsRef.current),
540
+ (data) => data.integration || null,
541
+ null
542
+ );
543
+ const { execute: updateTriage, loading: updateTriageLoading, error: updateTriageError } = useApiAsync(
544
+ (params) => updateIntegrationTriageApi(params, optionsRef.current),
545
+ (data) => data.integration || null,
546
+ null
547
+ );
548
+ const { execute: runEmailTriage, loading: runTriageLoading, error: runTriageError } = useApiAsync(
549
+ () => runEmailTriageApi(optionsRef.current),
550
+ (data) => ({ success: data.success, emailsFound: data.emails_found, instancesCreated: data.instances_created }),
551
+ null
552
+ );
553
+ const loading = listLoading || getLoading || connectLoading || disconnectLoading || refreshLoading || updateTriageLoading || runTriageLoading;
554
+ const error = listError || getError || connectError || disconnectError || refreshError || updateTriageError || runTriageError;
555
+ return useMemo(
556
+ () => ({
557
+ loading,
558
+ error,
559
+ listIntegrations,
560
+ getIntegration,
561
+ connectIntegration,
562
+ disconnectIntegration,
563
+ refreshIntegration,
564
+ updateTriage,
565
+ runEmailTriage
566
+ }),
567
+ [loading, error, listIntegrations, getIntegration, connectIntegration, disconnectIntegration, refreshIntegration, updateTriage, runEmailTriage]
568
+ );
569
+ }
422
570
 
423
571
  export {
424
572
  useAsync,
@@ -429,6 +577,9 @@ export {
429
577
  useSubAgents,
430
578
  useToolDefinitions,
431
579
  useAgentJobs,
432
- useWidgets
580
+ useWidgets,
581
+ useSkillUserConfig,
582
+ useAnalytics,
583
+ useIntegrations
433
584
  };
434
- //# sourceMappingURL=chunk-CYOI5YBB.mjs.map
585
+ //# sourceMappingURL=chunk-X4MSBDTZ.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../hooks/index.ts","../hooks/use-async.ts","../hooks/use-options-ref.ts"],"sourcesContent":["\"use client\";\n\n/**\n * Agent hooks for React applications\n *\n * Provides React hooks for agent CRUD operations with loading/error states.\n *\n * @packageDocumentation\n */\n\nimport { useMemo } from \"react\";\nimport type { ApiClientOptions } from \"@elqnt/api-client\";\nimport type {\n Agent, AgentSummary, Skill, SubAgent, ToolDefinition, AgentJob, AgentWidget, SkillUserConfig, ResolveSkillConfigResponse,\n UserIntegration, IntegrationProviderTS, IntegrationTypeTS,\n} from \"../models\";\nimport {\n // Agents\n listAgentsApi,\n listAgentsSummaryApi,\n getAgentApi,\n createAgentApi,\n updateAgentApi,\n deleteAgentApi,\n getDefaultAgentApi,\n // Skills\n listSkillsApi,\n getSkillApi,\n createSkillApi,\n updateSkillApi,\n deleteSkillApi,\n getSkillCategoriesApi,\n // Skill User Config\n getSkillUserConfigApi,\n updateSkillUserConfigApi,\n deleteSkillUserConfigApi,\n listSkillUserConfigsApi,\n resolveSkillConfigApi,\n // Sub-Agents\n listSubAgentsApi,\n getSubAgentApi,\n createSubAgentApi,\n updateSubAgentApi,\n deleteSubAgentApi,\n // Tool Definitions\n listToolDefinitionsApi,\n getToolDefinitionApi,\n createToolDefinitionApi,\n updateToolDefinitionApi,\n deleteToolDefinitionApi,\n getToolDefinitionsByIdsApi,\n // Agent Jobs\n listAgentJobsApi,\n getAgentJobApi,\n createAgentJobApi,\n updateAgentJobApi,\n deleteAgentJobApi,\n pauseAgentJobApi,\n resumeAgentJobApi,\n // Widgets\n listWidgetsApi,\n getWidgetApi,\n createWidgetApi,\n updateWidgetApi,\n deleteWidgetApi,\n getDefaultWidgetApi,\n setDefaultWidgetApi,\n // Analytics\n getAgentChatsAnalyticsApi,\n getAgentCSATAnalyticsApi,\n getAgentListAnalyticsApi,\n getTaskOutcomesApi,\n type DateFilter,\n // Integrations\n listIntegrationsApi,\n getIntegrationApi,\n connectIntegrationApi,\n disconnectIntegrationApi,\n refreshIntegrationApi,\n updateIntegrationTriageApi,\n runEmailTriageApi,\n} from \"../api\";\nimport { useApiAsync } from \"./use-async\";\nimport { useOptionsRef } from \"./use-options-ref\";\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type UseAgentsOptions = ApiClientOptions;\n\n// =============================================================================\n// USE AGENTS HOOK\n// =============================================================================\n\n/**\n * Hook for agent CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listAgents, createAgent } = useAgents({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const agents = await listAgents();\n * ```\n */\nexport function useAgents(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listAgents, loading: listLoading, error: listError } = useApiAsync(\n () => listAgentsApi(optionsRef.current),\n (data) => data.agents,\n [] as Agent[]\n );\n\n const { execute: listAgentSummaries, loading: listSummaryLoading, error: listSummaryError } = useApiAsync(\n () => listAgentsSummaryApi(optionsRef.current),\n (data) => data.agents,\n [] as AgentSummary[]\n );\n\n const { execute: getAgent, loading: getLoading, error: getError } = useApiAsync(\n (agentId: string) => getAgentApi(agentId, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: createAgent, loading: createLoading, error: createError } = useApiAsync(\n (agent: Partial<Agent>) => createAgentApi(agent, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: updateAgent, loading: updateLoading, error: updateError } = useApiAsync(\n (agentId: string, agent: Partial<Agent>) => updateAgentApi(agentId, agent, optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const { execute: deleteAgent, loading: deleteLoading, error: deleteError } = useApiAsync(\n (agentId: string) => deleteAgentApi(agentId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: getDefaultAgent, loading: defaultLoading, error: defaultError } = useApiAsync(\n () => getDefaultAgentApi(optionsRef.current),\n (data) => data.agent || null,\n null as Agent | null\n );\n\n const loading = listLoading || listSummaryLoading || getLoading || createLoading || updateLoading || deleteLoading || defaultLoading;\n const error = listError || listSummaryError || getError || createError || updateError || deleteError || defaultError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listAgents,\n listAgentSummaries,\n getAgent,\n createAgent,\n updateAgent,\n deleteAgent,\n getDefaultAgent,\n }),\n [loading, error, listAgents, listAgentSummaries, getAgent, createAgent, updateAgent, deleteAgent, getDefaultAgent]\n );\n}\n\n// =============================================================================\n// USE SKILLS HOOK\n// =============================================================================\n\n/**\n * Hook for skill CRUD operations\n */\nexport function useSkills(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listSkills, loading: listLoading, error: listError } = useApiAsync(\n () => listSkillsApi(optionsRef.current),\n (data) => data.skills,\n [] as Skill[]\n );\n\n const { execute: getSkill, loading: getLoading, error: getError } = useApiAsync(\n (skillId: string) => getSkillApi(skillId, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: createSkill, loading: createLoading, error: createError } = useApiAsync(\n (skill: Partial<Skill>) => createSkillApi(skill, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: updateSkill, loading: updateLoading, error: updateError } = useApiAsync(\n (skillId: string, skill: Partial<Skill>) => updateSkillApi(skillId, skill, optionsRef.current),\n (data) => data.skill || null,\n null as Skill | null\n );\n\n const { execute: deleteSkill, loading: deleteLoading, error: deleteError } = useApiAsync(\n (skillId: string) => deleteSkillApi(skillId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: getCategories, loading: categoriesLoading, error: categoriesError } = useApiAsync(\n () => getSkillCategoriesApi(optionsRef.current),\n (data) => data.categories,\n [] as string[]\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading || categoriesLoading;\n const error = listError || getError || createError || updateError || deleteError || categoriesError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listSkills,\n getSkill,\n createSkill,\n updateSkill,\n deleteSkill,\n getCategories,\n }),\n [loading, error, listSkills, getSkill, createSkill, updateSkill, deleteSkill, getCategories]\n );\n}\n\n// =============================================================================\n// USE SUB-AGENTS HOOK\n// =============================================================================\n\n/**\n * Hook for sub-agent CRUD operations\n */\nexport function useSubAgents(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listSubAgents, loading: listLoading, error: listError } = useApiAsync(\n () => listSubAgentsApi(optionsRef.current),\n (data) => data.subAgents,\n [] as SubAgent[]\n );\n\n const { execute: getSubAgent, loading: getLoading, error: getError } = useApiAsync(\n (subAgentId: string) => getSubAgentApi(subAgentId, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: createSubAgent, loading: createLoading, error: createError } = useApiAsync(\n (subAgent: Partial<SubAgent>) => createSubAgentApi(subAgent, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: updateSubAgent, loading: updateLoading, error: updateError } = useApiAsync(\n (subAgentId: string, subAgent: Partial<SubAgent>) => updateSubAgentApi(subAgentId, subAgent, optionsRef.current),\n (data) => data.subAgent || null,\n null as SubAgent | null\n );\n\n const { execute: deleteSubAgent, loading: deleteLoading, error: deleteError } = useApiAsync(\n (subAgentId: string) => deleteSubAgentApi(subAgentId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading;\n const error = listError || getError || createError || updateError || deleteError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listSubAgents,\n getSubAgent,\n createSubAgent,\n updateSubAgent,\n deleteSubAgent,\n }),\n [loading, error, listSubAgents, getSubAgent, createSubAgent, updateSubAgent, deleteSubAgent]\n );\n}\n\n// =============================================================================\n// USE TOOL DEFINITIONS HOOK\n// =============================================================================\n\n/**\n * Hook for tool definition CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listToolDefinitions, createToolDefinition } = useToolDefinitions({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const toolDefs = await listToolDefinitions();\n * ```\n */\nexport function useToolDefinitions(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listToolDefinitions, loading: listLoading, error: listError } = useApiAsync(\n () => listToolDefinitionsApi(optionsRef.current),\n (data) => data.toolDefinitions,\n [] as ToolDefinition[]\n );\n\n const { execute: getToolDefinition, loading: getLoading, error: getError } = useApiAsync(\n (toolDefId: string) => getToolDefinitionApi(toolDefId, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: getToolDefinitionsByIds, loading: getByIdsLoading, error: getByIdsError } = useApiAsync(\n (ids: string[]) => getToolDefinitionsByIdsApi(ids, optionsRef.current),\n (data) => data.toolDefinitions,\n [] as ToolDefinition[]\n );\n\n const { execute: createToolDefinition, loading: createLoading, error: createError } = useApiAsync(\n (toolDefinition: Partial<ToolDefinition>) => createToolDefinitionApi(toolDefinition, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: updateToolDefinition, loading: updateLoading, error: updateError } = useApiAsync(\n (toolDefId: string, toolDefinition: Partial<ToolDefinition>) => updateToolDefinitionApi(toolDefId, toolDefinition, optionsRef.current),\n (data) => data.toolDefinition || null,\n null as ToolDefinition | null\n );\n\n const { execute: deleteToolDefinition, loading: deleteLoading, error: deleteError } = useApiAsync(\n (toolDefId: string) => deleteToolDefinitionApi(toolDefId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || getByIdsLoading || createLoading || updateLoading || deleteLoading;\n const error = listError || getError || getByIdsError || createError || updateError || deleteError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listToolDefinitions,\n getToolDefinition,\n getToolDefinitionsByIds,\n createToolDefinition,\n updateToolDefinition,\n deleteToolDefinition,\n }),\n [loading, error, listToolDefinitions, getToolDefinition, getToolDefinitionsByIds, createToolDefinition, updateToolDefinition, deleteToolDefinition]\n );\n}\n\n// =============================================================================\n// USE AGENT JOBS HOOK\n// =============================================================================\n\n/**\n * Hook for agent job CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listAgentJobs, createAgentJob, pauseAgentJob } = useAgentJobs({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const jobs = await listAgentJobs();\n * await pauseAgentJob(jobId);\n * ```\n */\nexport function useAgentJobs(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listAgentJobs, loading: listLoading, error: listError } = useApiAsync(\n () => listAgentJobsApi(optionsRef.current),\n (data) => data.jobs,\n [] as AgentJob[]\n );\n\n const { execute: getAgentJob, loading: getLoading, error: getError } = useApiAsync(\n (jobId: string) => getAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: createAgentJob, loading: createLoading, error: createError } = useApiAsync(\n (job: Partial<AgentJob>) => createAgentJobApi(job, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: updateAgentJob, loading: updateLoading, error: updateError } = useApiAsync(\n (jobId: string, job: Partial<AgentJob>) => updateAgentJobApi(jobId, job, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: deleteAgentJob, loading: deleteLoading, error: deleteError } = useApiAsync(\n (jobId: string) => deleteAgentJobApi(jobId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: pauseAgentJob, loading: pauseLoading, error: pauseError } = useApiAsync(\n (jobId: string) => pauseAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const { execute: resumeAgentJob, loading: resumeLoading, error: resumeError } = useApiAsync(\n (jobId: string) => resumeAgentJobApi(jobId, optionsRef.current),\n (data) => data.job || null,\n null as AgentJob | null\n );\n\n const loading = listLoading || getLoading || createLoading || updateLoading || deleteLoading || pauseLoading || resumeLoading;\n const error = listError || getError || createError || updateError || deleteError || pauseError || resumeError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listAgentJobs,\n getAgentJob,\n createAgentJob,\n updateAgentJob,\n deleteAgentJob,\n pauseAgentJob,\n resumeAgentJob,\n }),\n [loading, error, listAgentJobs, getAgentJob, createAgentJob, updateAgentJob, deleteAgentJob, pauseAgentJob, resumeAgentJob]\n );\n}\n\n// =============================================================================\n// USE WIDGETS HOOK\n// =============================================================================\n\nexport interface UseWidgetsOptions extends UseAgentsOptions {\n agentId: string;\n}\n\n/**\n * Hook for widget CRUD operations\n *\n * @example\n * ```tsx\n * const { loading, error, listWidgets, createWidget } = useWidgets({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * agentId: selectedAgentId,\n * });\n *\n * const widgets = await listWidgets();\n * ```\n */\nexport function useWidgets(options: UseWidgetsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listWidgets, loading: listLoading, error: listError } = useApiAsync(\n () => listWidgetsApi(optionsRef.current.agentId, optionsRef.current),\n (data) => data.widgets,\n [] as AgentWidget[]\n );\n\n const { execute: getWidget, loading: getLoading, error: getError } = useApiAsync(\n (widgetId: string) => getWidgetApi(widgetId, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: getDefaultWidget, loading: defaultLoading, error: defaultError } = useApiAsync(\n () => getDefaultWidgetApi(optionsRef.current.agentId, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: createWidget, loading: createLoading, error: createError } = useApiAsync(\n (widget: Partial<AgentWidget>) => createWidgetApi(optionsRef.current.agentId, widget, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: updateWidget, loading: updateLoading, error: updateError } = useApiAsync(\n (widgetId: string, widget: Partial<AgentWidget>) => updateWidgetApi(widgetId, widget, optionsRef.current),\n (data) => data.widget || null,\n null as AgentWidget | null\n );\n\n const { execute: deleteWidget, loading: deleteLoading, error: deleteError } = useApiAsync(\n (widgetId: string) => deleteWidgetApi(widgetId, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: setDefaultWidget, loading: setDefaultLoading, error: setDefaultError } = useApiAsync(\n (widgetId: string) => setDefaultWidgetApi(widgetId, optionsRef.current.agentId, optionsRef.current),\n () => true,\n false\n );\n\n const loading = listLoading || getLoading || defaultLoading || createLoading || updateLoading || deleteLoading || setDefaultLoading;\n const error = listError || getError || defaultError || createError || updateError || deleteError || setDefaultError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listWidgets,\n getWidget,\n getDefaultWidget,\n createWidget,\n updateWidget,\n deleteWidget,\n setDefaultWidget,\n }),\n [loading, error, listWidgets, getWidget, getDefaultWidget, createWidget, updateWidget, deleteWidget, setDefaultWidget]\n );\n}\n\n// =============================================================================\n// USE SKILL USER CONFIG HOOK\n// =============================================================================\n\n/**\n * Hook for skill user configuration operations\n *\n * @example\n * ```tsx\n * const { loading, error, getSkillUserConfig, updateSkillUserConfig } = useSkillUserConfig({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const config = await getSkillUserConfig(skillId);\n * await updateSkillUserConfig(skillId, { enabled: true });\n * ```\n */\nexport function useSkillUserConfig(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: getSkillUserConfig, loading: getLoading, error: getError } = useApiAsync(\n (skillId: string, agentId?: string) =>\n getSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),\n (data) => data.userConfig || null,\n null as SkillUserConfig | null\n );\n\n const { execute: updateSkillUserConfig, loading: updateLoading, error: updateError } = useApiAsync(\n (\n skillId: string,\n data: { enabled?: boolean; displayOrder?: number; config?: Record<string, unknown>; agentId?: string }\n ) => updateSkillUserConfigApi(skillId, data, optionsRef.current),\n (data) => data.userConfig || null,\n null as SkillUserConfig | null\n );\n\n const { execute: deleteSkillUserConfig, loading: deleteLoading, error: deleteError } = useApiAsync(\n (skillId: string, agentId?: string) =>\n deleteSkillUserConfigApi(skillId, { ...optionsRef.current, agentId }),\n () => true,\n false\n );\n\n const { execute: listSkillUserConfigs, loading: listLoading, error: listError } = useApiAsync(\n (params?: { agentId?: string; limit?: number; offset?: number }) =>\n listSkillUserConfigsApi({ ...optionsRef.current, ...params }),\n (data) => data.userConfigs || [],\n [] as SkillUserConfig[]\n );\n\n const { execute: resolveSkillConfig, loading: resolveLoading, error: resolveError } = useApiAsync(\n (skillId: string, agentId: string) => resolveSkillConfigApi(skillId, agentId, optionsRef.current),\n (data) => data,\n null as ResolveSkillConfigResponse | null\n );\n\n const loading = getLoading || updateLoading || deleteLoading || listLoading || resolveLoading;\n const error = getError || updateError || deleteError || listError || resolveError;\n\n return useMemo(\n () => ({\n loading,\n error,\n getSkillUserConfig,\n updateSkillUserConfig,\n deleteSkillUserConfig,\n listSkillUserConfigs,\n resolveSkillConfig,\n }),\n [loading, error, getSkillUserConfig, updateSkillUserConfig, deleteSkillUserConfig, listSkillUserConfigs, resolveSkillConfig]\n );\n}\n\n// =============================================================================\n// USE ANALYTICS HOOK\n// =============================================================================\n\n/**\n * Hook for agent analytics operations\n *\n * @example\n * ```tsx\n * const { loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics } = useAnalytics({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const chatsData = await getAgentChatsAnalytics({ from: '2024-01-01', to: '2024-12-31' });\n * ```\n */\nexport function useAnalytics(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: getAgentChatsAnalytics, loading: chatsLoading, error: chatsError } = useApiAsync(\n (params: { date_filter: DateFilter; agent_id?: string }) =>\n getAgentChatsAnalyticsApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getAgentCSATAnalytics, loading: csatLoading, error: csatError } = useApiAsync(\n (params: { date_filter: DateFilter; agent_id?: string }) =>\n getAgentCSATAnalyticsApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getAgentListAnalytics, loading: listLoading, error: listError } = useApiAsync(\n () => getAgentListAnalyticsApi(optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const { execute: getTaskOutcomes, loading: taskLoading, error: taskError } = useApiAsync(\n (params: { date_filter: DateFilter }) => getTaskOutcomesApi(params, optionsRef.current),\n (data) => data.data,\n [] as unknown[]\n );\n\n const loading = chatsLoading || csatLoading || listLoading || taskLoading;\n const error = chatsError || csatError || listError || taskError;\n\n return useMemo(\n () => ({\n loading,\n error,\n getAgentChatsAnalytics,\n getAgentCSATAnalytics,\n getAgentListAnalytics,\n getTaskOutcomes,\n }),\n [loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics, getAgentListAnalytics, getTaskOutcomes]\n );\n}\n\n// =============================================================================\n// USE INTEGRATIONS HOOK\n// =============================================================================\n\n/**\n * Hook for user integration operations (OAuth connections)\n *\n * @example\n * ```tsx\n * const { loading, error, listIntegrations, connectIntegration, disconnectIntegration } = useIntegrations({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const integrations = await listIntegrations();\n * const { auth_url } = await connectIntegration({ provider: 'google', integrationType: 'email', redirectUri: '/callback' });\n * ```\n */\nexport function useIntegrations(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listIntegrations, loading: listLoading, error: listError } = useApiAsync(\n () => listIntegrationsApi(optionsRef.current),\n (data) => data.integrations,\n [] as UserIntegration[]\n );\n\n const { execute: getIntegration, loading: getLoading, error: getError } = useApiAsync(\n (provider: IntegrationProviderTS, integrationType: IntegrationTypeTS) =>\n getIntegrationApi(provider, integrationType, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: connectIntegration, loading: connectLoading, error: connectError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS; redirectUri: string }) =>\n connectIntegrationApi(params, optionsRef.current),\n (data) => ({ authUrl: data.auth_url, state: data.state }),\n null as { authUrl: string; state: string } | null\n );\n\n const { execute: disconnectIntegration, loading: disconnectLoading, error: disconnectError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS }) =>\n disconnectIntegrationApi(params, optionsRef.current),\n () => true,\n false\n );\n\n const { execute: refreshIntegration, loading: refreshLoading, error: refreshError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS }) =>\n refreshIntegrationApi(params, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: updateTriage, loading: updateTriageLoading, error: updateTriageError } = useApiAsync(\n (params: { provider: IntegrationProviderTS; integrationType: IntegrationTypeTS; triageEnabled: boolean }) =>\n updateIntegrationTriageApi(params, optionsRef.current),\n (data) => data.integration || null,\n null as UserIntegration | null\n );\n\n const { execute: runEmailTriage, loading: runTriageLoading, error: runTriageError } = useApiAsync(\n () => runEmailTriageApi(optionsRef.current),\n (data) => ({ success: data.success, emailsFound: data.emails_found, instancesCreated: data.instances_created }),\n null as { success: boolean; emailsFound: number; instancesCreated: number } | null\n );\n\n const loading = listLoading || getLoading || connectLoading || disconnectLoading || refreshLoading || updateTriageLoading || runTriageLoading;\n const error = listError || getError || connectError || disconnectError || refreshError || updateTriageError || runTriageError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listIntegrations,\n getIntegration,\n connectIntegration,\n disconnectIntegration,\n refreshIntegration,\n updateTriage,\n runEmailTriage,\n }),\n [loading, error, listIntegrations, getIntegration, connectIntegration, disconnectIntegration, refreshIntegration, updateTriage, runEmailTriage]\n );\n}\n\n// =============================================================================\n// EXPORTS\n// =============================================================================\n\n// Re-export hook utilities for advanced usage\nexport { useApiAsync, useAsync } from \"./use-async\";\nexport { useOptionsRef } from \"./use-options-ref\";\nexport type { UseAsyncOptions, UseAsyncReturn } from \"./use-async\";\n","\"use client\";\n\n/**\n * Async operation utilities for React hooks\n *\n * Provides a generic pattern for handling async operations with loading/error states.\n * Uses a request counter for accurate concurrent loading state.\n */\n\nimport { useState, useCallback, useRef } from \"react\";\nimport type { ApiResponse } from \"@elqnt/api-client\";\n\nexport interface UseAsyncOptions {\n onError?: (error: string) => void;\n}\n\nexport interface UseAsyncReturn<TResult, TArgs extends unknown[] = []> {\n execute: (...args: TArgs) => Promise<TResult>;\n loading: boolean;\n error: string | null;\n clearError: () => void;\n}\n\n/**\n * Generic async hook for any promise-returning function.\n * Uses a request counter to properly track concurrent requests.\n */\nexport function useAsync<TResult, TArgs extends unknown[] = []>(\n asyncFn: (...args: TArgs) => Promise<TResult>,\n options?: UseAsyncOptions\n): UseAsyncReturn<TResult, TArgs> {\n const [error, setError] = useState<string | null>(null);\n const requestCountRef = useRef(0);\n const [loading, setLoading] = useState(false);\n\n const execute = useCallback(\n async (...args: TArgs): Promise<TResult> => {\n requestCountRef.current += 1;\n setLoading(true);\n setError(null);\n\n try {\n return await asyncFn(...args);\n } catch (err) {\n const message = err instanceof Error ? err.message : \"An error occurred\";\n setError(message);\n options?.onError?.(message);\n throw err;\n } finally {\n requestCountRef.current -= 1;\n if (requestCountRef.current === 0) {\n setLoading(false);\n }\n }\n },\n [asyncFn, options]\n );\n\n const clearError = useCallback(() => setError(null), []);\n\n return { execute, loading, error, clearError };\n}\n\n/**\n * Specialized async hook for API operations that return ApiResponse.\n * Automatically extracts data and handles API errors.\n *\n * @param asyncFn - Function that returns ApiResponse<TResponse>\n * @param extractor - Function to extract the desired result from response data\n * @param defaultValue - Default value to return on error\n * @param options - Optional configuration\n *\n * @example\n * ```tsx\n * const { execute: listAgents, loading, error } = useApiAsync(\n * () => listAgentsApi(optionsRef.current),\n * (data) => data.agents,\n * []\n * );\n * ```\n */\nexport function useApiAsync<TResponse, TResult, TArgs extends unknown[] = []>(\n asyncFn: (...args: TArgs) => Promise<ApiResponse<TResponse>>,\n extractor: (data: TResponse) => TResult,\n defaultValue: TResult,\n options?: UseAsyncOptions\n): UseAsyncReturn<TResult, TArgs> {\n const [error, setError] = useState<string | null>(null);\n const requestCountRef = useRef(0);\n const [loading, setLoading] = useState(false);\n\n const execute = useCallback(\n async (...args: TArgs): Promise<TResult> => {\n requestCountRef.current += 1;\n setLoading(true);\n setError(null);\n\n try {\n const response = await asyncFn(...args);\n if (response.error) {\n setError(response.error);\n options?.onError?.(response.error);\n return defaultValue;\n }\n return response.data ? extractor(response.data) : defaultValue;\n } catch (err) {\n const message = err instanceof Error ? err.message : \"An error occurred\";\n setError(message);\n options?.onError?.(message);\n return defaultValue;\n } finally {\n requestCountRef.current -= 1;\n if (requestCountRef.current === 0) {\n setLoading(false);\n }\n }\n },\n [asyncFn, extractor, defaultValue, options]\n );\n\n const clearError = useCallback(() => setError(null), []);\n\n return { execute, loading, error, clearError };\n}\n","\"use client\";\n\n/**\n * Options reference utility for React hooks\n *\n * Keeps a mutable ref synchronized with options to avoid\n * stale closures in callbacks while preventing unnecessary re-renders.\n */\n\nimport { useRef, useEffect } from \"react\";\n\n/**\n * Creates a ref that stays synchronized with the provided options.\n * Useful for accessing current options values in callbacks without\n * causing re-renders or stale closure issues.\n *\n * @param options - The options object to track\n * @returns A ref that always contains the latest options\n *\n * @example\n * ```tsx\n * const optionsRef = useOptionsRef(options);\n *\n * const fetchData = useCallback(async () => {\n * // Always has the latest options, no stale closure\n * const result = await api.fetch(optionsRef.current);\n * }, []); // No need to include options in deps\n * ```\n */\nexport function useOptionsRef<T>(options: T): React.MutableRefObject<T> {\n const optionsRef = useRef(options);\n\n useEffect(() => {\n optionsRef.current = options;\n }, [options]);\n\n return optionsRef;\n}\n"],"mappings":"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","names":["useRef"]}
@@ -1,5 +1,7 @@
1
1
  import { ApiResponse, ApiClientOptions } from '@elqnt/api-client';
2
- import { Z as AgentJob, A as Agent, aF as AgentSummary, dk as Skill, dO as SubAgent, e9 as ToolDefinition, aY as AgentWidget } from '../agent-models-C36pvpUb.mjs';
2
+ import { Z as AgentJob, A as Agent, aF as AgentSummary, dw as SkillUserConfig, dd as ResolveSkillConfigResponse, dk as Skill, dO as SubAgent, e9 as ToolDefinition, aY as AgentWidget } from '../agent-models-C36pvpUb.mjs';
3
+ import { aW as UserIntegration, ag as IntegrationProviderTS, ar as IntegrationTypeTS } from '../integration-21IuOOeV.mjs';
4
+ import { DateFilter } from '../api/index.mjs';
3
5
  import '@elqnt/types';
4
6
 
5
7
  interface UseAsyncOptions {
@@ -182,5 +184,112 @@ declare function useWidgets(options: UseWidgetsOptions): {
182
184
  deleteWidget: (widgetId: string) => Promise<boolean>;
183
185
  setDefaultWidget: (widgetId: string) => Promise<boolean>;
184
186
  };
187
+ /**
188
+ * Hook for skill user configuration operations
189
+ *
190
+ * @example
191
+ * ```tsx
192
+ * const { loading, error, getSkillUserConfig, updateSkillUserConfig } = useSkillUserConfig({
193
+ * baseUrl: apiGatewayUrl,
194
+ * orgId: selectedOrgId,
195
+ * });
196
+ *
197
+ * const config = await getSkillUserConfig(skillId);
198
+ * await updateSkillUserConfig(skillId, { enabled: true });
199
+ * ```
200
+ */
201
+ declare function useSkillUserConfig(options: UseAgentsOptions): {
202
+ loading: boolean;
203
+ error: string | null;
204
+ getSkillUserConfig: (skillId: string, agentId?: string | undefined) => Promise<SkillUserConfig | null>;
205
+ updateSkillUserConfig: (skillId: string, data: {
206
+ enabled?: boolean;
207
+ displayOrder?: number;
208
+ config?: Record<string, unknown>;
209
+ agentId?: string;
210
+ }) => Promise<SkillUserConfig | null>;
211
+ deleteSkillUserConfig: (skillId: string, agentId?: string | undefined) => Promise<boolean>;
212
+ listSkillUserConfigs: (params?: {
213
+ agentId?: string;
214
+ limit?: number;
215
+ offset?: number;
216
+ } | undefined) => Promise<SkillUserConfig[]>;
217
+ resolveSkillConfig: (skillId: string, agentId: string) => Promise<ResolveSkillConfigResponse | null>;
218
+ };
219
+ /**
220
+ * Hook for agent analytics operations
221
+ *
222
+ * @example
223
+ * ```tsx
224
+ * const { loading, error, getAgentChatsAnalytics, getAgentCSATAnalytics } = useAnalytics({
225
+ * baseUrl: apiGatewayUrl,
226
+ * orgId: selectedOrgId,
227
+ * });
228
+ *
229
+ * const chatsData = await getAgentChatsAnalytics({ from: '2024-01-01', to: '2024-12-31' });
230
+ * ```
231
+ */
232
+ declare function useAnalytics(options: UseAgentsOptions): {
233
+ loading: boolean;
234
+ error: string | null;
235
+ getAgentChatsAnalytics: (params: {
236
+ date_filter: DateFilter;
237
+ agent_id?: string;
238
+ }) => Promise<unknown[]>;
239
+ getAgentCSATAnalytics: (params: {
240
+ date_filter: DateFilter;
241
+ agent_id?: string;
242
+ }) => Promise<unknown[]>;
243
+ getAgentListAnalytics: () => Promise<unknown[]>;
244
+ getTaskOutcomes: (params: {
245
+ date_filter: DateFilter;
246
+ }) => Promise<unknown[]>;
247
+ };
248
+ /**
249
+ * Hook for user integration operations (OAuth connections)
250
+ *
251
+ * @example
252
+ * ```tsx
253
+ * const { loading, error, listIntegrations, connectIntegration, disconnectIntegration } = useIntegrations({
254
+ * baseUrl: apiGatewayUrl,
255
+ * orgId: selectedOrgId,
256
+ * });
257
+ *
258
+ * const integrations = await listIntegrations();
259
+ * const { auth_url } = await connectIntegration({ provider: 'google', integrationType: 'email', redirectUri: '/callback' });
260
+ * ```
261
+ */
262
+ declare function useIntegrations(options: UseAgentsOptions): {
263
+ loading: boolean;
264
+ error: string | null;
265
+ listIntegrations: () => Promise<UserIntegration[]>;
266
+ getIntegration: (provider: IntegrationProviderTS, integrationType: IntegrationTypeTS) => Promise<UserIntegration | null>;
267
+ connectIntegration: (params: {
268
+ provider: IntegrationProviderTS;
269
+ integrationType: IntegrationTypeTS;
270
+ redirectUri: string;
271
+ }) => Promise<{
272
+ authUrl: string;
273
+ state: string;
274
+ } | null>;
275
+ disconnectIntegration: (params: {
276
+ provider: IntegrationProviderTS;
277
+ integrationType: IntegrationTypeTS;
278
+ }) => Promise<boolean>;
279
+ refreshIntegration: (params: {
280
+ provider: IntegrationProviderTS;
281
+ integrationType: IntegrationTypeTS;
282
+ }) => Promise<UserIntegration | null>;
283
+ updateTriage: (params: {
284
+ provider: IntegrationProviderTS;
285
+ integrationType: IntegrationTypeTS;
286
+ triageEnabled: boolean;
287
+ }) => Promise<UserIntegration | null>;
288
+ runEmailTriage: () => Promise<{
289
+ success: boolean;
290
+ emailsFound: number;
291
+ instancesCreated: number;
292
+ } | null>;
293
+ };
185
294
 
186
- export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useApiAsync, useAsync, useOptionsRef, useSkills, useSubAgents, useToolDefinitions, useWidgets };
295
+ export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useAnalytics, useApiAsync, useAsync, useIntegrations, useOptionsRef, useSkillUserConfig, useSkills, useSubAgents, useToolDefinitions, useWidgets };