@elqnt/agents 3.0.5 → 3.2.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.
- package/README.md +77 -4
- package/dist/api/index.d.mts +211 -1
- package/dist/api/index.d.ts +211 -1
- package/dist/api/index.js +64 -2
- package/dist/api/index.js.map +1 -1
- package/dist/api/index.mjs +63 -1
- package/dist/{chunk-XYJDCUUG.mjs → chunk-FR422IHO.mjs} +265 -2
- package/dist/chunk-FR422IHO.mjs.map +1 -0
- package/dist/{chunk-SKZS3AIT.js → chunk-IUKM3T2S.js} +265 -2
- package/dist/chunk-IUKM3T2S.js.map +1 -0
- package/dist/chunk-RGVWAFZP.js +771 -0
- package/dist/chunk-RGVWAFZP.js.map +1 -0
- package/dist/{chunk-CYOI5YBB.mjs → chunk-V5GHDXSW.mjs} +340 -3
- package/dist/chunk-V5GHDXSW.mjs.map +1 -0
- package/dist/hooks/index.d.mts +211 -2
- package/dist/hooks/index.d.ts +211 -2
- package/dist/hooks/index.js +15 -3
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/index.mjs +14 -2
- package/dist/index.d.mts +4 -3
- package/dist/index.d.ts +4 -3
- package/dist/index.js +77 -3
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +76 -2
- package/dist/models/index.d.mts +2 -879
- package/dist/models/index.d.ts +2 -879
- package/dist/sandbox-BHeWPjLU.d.mts +881 -0
- package/dist/sandbox-BHeWPjLU.d.ts +881 -0
- package/package.json +3 -3
- package/dist/chunk-CYOI5YBB.mjs.map +0 -1
- package/dist/chunk-REBFGDVA.js +0 -434
- package/dist/chunk-REBFGDVA.js.map +0 -1
- package/dist/chunk-SKZS3AIT.js.map +0 -1
- package/dist/chunk-XYJDCUUG.mjs.map +0 -1
|
@@ -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 // Sandbox\n createSandboxApi,\n getSandboxApi,\n updateSandboxApi,\n listSandboxesApi,\n deleteSandboxApi,\n // Scheduler\n listSchedulerTasksApi,\n createSchedulerTaskApi,\n getSchedulerTaskApi,\n updateSchedulerTaskApi,\n deleteSchedulerTaskApi,\n snoozeSchedulerTaskApi,\n completeSchedulerTaskApi,\n startSchedulerTaskApi,\n listSchedulesApi,\n createScheduleApi,\n getScheduleApi,\n updateScheduleApi,\n deleteScheduleApi,\n pauseScheduleApi,\n resumeScheduleApi,\n runScheduleApi,\n type SchedulerTask,\n type SchedulerSchedule,\n} from \"../api\";\nimport type {\n Sandbox,\n CreateSandboxRequest,\n} from \"../models\";\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// USE SANDBOX HOOK\n// =============================================================================\n\n/**\n * Hook for sandbox operations (AI-generated HTML sandboxes)\n *\n * @example\n * ```tsx\n * const { createSandbox, getSandbox, listSandboxes, loading, error } = useSandbox({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const result = await createSandbox({ prompt: \"Create a bar chart showing sales data\" });\n * console.log(result.url); // sandbox URL\n * ```\n */\nexport function useSandbox(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: createSandbox, loading: createLoading, error: createError } = useApiAsync(\n (request: Omit<CreateSandboxRequest, \"orgId\">) => createSandboxApi(request, optionsRef.current),\n (data) => ({ id: data.id, url: data.url, sandbox: data.sandbox }),\n null as { id: string; url: string; sandbox?: Sandbox } | null\n );\n\n const { execute: getSandbox, loading: getLoading, error: getError } = useApiAsync(\n (sandboxId: string) => getSandboxApi(sandboxId, optionsRef.current),\n (data) => data.sandbox || null,\n null as Sandbox | null\n );\n\n const { execute: updateSandbox, loading: updateLoading, error: updateError } = useApiAsync(\n (sandboxId: string, request: { prompt: string; title?: string }) =>\n updateSandboxApi(sandboxId, request, optionsRef.current),\n (data) => ({ id: data.id, url: data.url, sandbox: data.sandbox }),\n null as { id: string; url: string; sandbox?: Sandbox } | null\n );\n\n const { execute: listSandboxes, loading: listLoading, error: listError } = useApiAsync(\n (limit?: number) => listSandboxesApi({ ...optionsRef.current, limit }),\n (data) => ({ sandboxes: data.sandboxes, total: data.total }),\n { sandboxes: [] as Sandbox[], total: 0 }\n );\n\n const { execute: deleteSandbox, loading: deleteLoading, error: deleteError } = useApiAsync(\n (sandboxId: string) => deleteSandboxApi(sandboxId, optionsRef.current),\n (data) => data.success,\n false\n );\n\n const loading = createLoading || getLoading || updateLoading || listLoading || deleteLoading;\n const error = createError || getError || updateError || listError || deleteError;\n\n return useMemo(\n () => ({\n loading,\n error,\n createSandbox,\n getSandbox,\n updateSandbox,\n listSandboxes,\n deleteSandbox,\n }),\n [loading, error, createSandbox, getSandbox, updateSandbox, listSandboxes, deleteSandbox]\n );\n}\n\n// =============================================================================\n// USE SCHEDULER TASKS HOOK\n// =============================================================================\n\n/**\n * Hook for scheduler task operations\n *\n * @example\n * ```tsx\n * const { listTasks, createTask, snoozeTask, loading, error } = useSchedulerTasks({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const tasks = await listTasks();\n * await snoozeTask(taskId, { amount: 30, unit: \"minutes\" });\n * ```\n */\nexport function useSchedulerTasks(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listTasks, loading: listLoading, error: listError } = useApiAsync(\n (params?: { status?: string; limit?: number; offset?: number }) =>\n listSchedulerTasksApi({ ...optionsRef.current, ...params }),\n (data) => data.tasks,\n [] as SchedulerTask[]\n );\n\n const { execute: createTask, loading: createLoading, error: createError } = useApiAsync(\n (task: Partial<SchedulerTask>) => createSchedulerTaskApi(task, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const { execute: getTask, loading: getLoading, error: getError } = useApiAsync(\n (taskId: string) => getSchedulerTaskApi(taskId, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const { execute: updateTask, loading: updateLoading, error: updateError } = useApiAsync(\n (taskId: string, task: Partial<SchedulerTask>) =>\n updateSchedulerTaskApi(taskId, task, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const { execute: deleteTask, loading: deleteLoading, error: deleteError } = useApiAsync(\n (taskId: string) => deleteSchedulerTaskApi(taskId, optionsRef.current),\n (data) => data.success,\n false\n );\n\n const { execute: snoozeTask, loading: snoozeLoading, error: snoozeError } = useApiAsync(\n (taskId: string, delay: { amount: number; unit: string }) =>\n snoozeSchedulerTaskApi(taskId, delay, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const { execute: completeTask, loading: completeLoading, error: completeError } = useApiAsync(\n (taskId: string) => completeSchedulerTaskApi(taskId, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const { execute: startTask, loading: startLoading, error: startError } = useApiAsync(\n (taskId: string) => startSchedulerTaskApi(taskId, optionsRef.current),\n (data) => data.task || null,\n null as SchedulerTask | null\n );\n\n const loading = listLoading || createLoading || getLoading || updateLoading || deleteLoading || snoozeLoading || completeLoading || startLoading;\n const error = listError || createError || getError || updateError || deleteError || snoozeError || completeError || startError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listTasks,\n createTask,\n getTask,\n updateTask,\n deleteTask,\n snoozeTask,\n completeTask,\n startTask,\n }),\n [loading, error, listTasks, createTask, getTask, updateTask, deleteTask, snoozeTask, completeTask, startTask]\n );\n}\n\n// =============================================================================\n// USE SCHEDULER SCHEDULES HOOK\n// =============================================================================\n\n/**\n * Hook for scheduler schedule operations (recurring jobs)\n *\n * @example\n * ```tsx\n * const { listSchedules, createSchedule, pauseSchedule, loading, error } = useSchedulerSchedules({\n * baseUrl: apiGatewayUrl,\n * orgId: selectedOrgId,\n * });\n *\n * const schedules = await listSchedules();\n * await pauseSchedule(scheduleId);\n * ```\n */\nexport function useSchedulerSchedules(options: UseAgentsOptions) {\n const optionsRef = useOptionsRef(options);\n\n const { execute: listSchedules, loading: listLoading, error: listError } = useApiAsync(\n (params?: { status?: string; limit?: number; offset?: number }) =>\n listSchedulesApi({ ...optionsRef.current, ...params }),\n (data) => data.schedules,\n [] as SchedulerSchedule[]\n );\n\n const { execute: createSchedule, loading: createLoading, error: createError } = useApiAsync(\n (schedule: Partial<SchedulerSchedule>) => createScheduleApi(schedule, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const { execute: getSchedule, loading: getLoading, error: getError } = useApiAsync(\n (scheduleId: string) => getScheduleApi(scheduleId, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const { execute: updateSchedule, loading: updateLoading, error: updateError } = useApiAsync(\n (scheduleId: string, schedule: Partial<SchedulerSchedule>) =>\n updateScheduleApi(scheduleId, schedule, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const { execute: deleteSchedule, loading: deleteLoading, error: deleteError } = useApiAsync(\n (scheduleId: string) => deleteScheduleApi(scheduleId, optionsRef.current),\n (data) => data.success,\n false\n );\n\n const { execute: pauseSchedule, loading: pauseLoading, error: pauseError } = useApiAsync(\n (scheduleId: string) => pauseScheduleApi(scheduleId, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const { execute: resumeSchedule, loading: resumeLoading, error: resumeError } = useApiAsync(\n (scheduleId: string) => resumeScheduleApi(scheduleId, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const { execute: runSchedule, loading: runLoading, error: runError } = useApiAsync(\n (scheduleId: string) => runScheduleApi(scheduleId, optionsRef.current),\n (data) => data.schedule || null,\n null as SchedulerSchedule | null\n );\n\n const loading = listLoading || createLoading || getLoading || updateLoading || deleteLoading || pauseLoading || resumeLoading || runLoading;\n const error = listError || createError || getError || updateError || deleteError || pauseError || resumeError || runError;\n\n return useMemo(\n () => ({\n loading,\n error,\n listSchedules,\n createSchedule,\n getSchedule,\n updateSchedule,\n deleteSchedule,\n pauseSchedule,\n resumeSchedule,\n runSchedule,\n }),\n [loading, error, listSchedules, createSchedule, getSchedule, updateSchedule, deleteSchedule, pauseSchedule, resumeSchedule, runSchedule]\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"]}
|
package/dist/hooks/index.d.mts
CHANGED
|
@@ -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 { ba as UserIntegration, ap as IntegrationProviderTS, aA as IntegrationTypeTS, h as CreateSandboxRequest, aW as Sandbox } from '../sandbox-BHeWPjLU.mjs';
|
|
4
|
+
import { DateFilter, SchedulerSchedule, SchedulerTask } from '../api/index.mjs';
|
|
3
5
|
import '@elqnt/types';
|
|
4
6
|
|
|
5
7
|
interface UseAsyncOptions {
|
|
@@ -182,5 +184,212 @@ 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
|
+
};
|
|
294
|
+
/**
|
|
295
|
+
* Hook for sandbox operations (AI-generated HTML sandboxes)
|
|
296
|
+
*
|
|
297
|
+
* @example
|
|
298
|
+
* ```tsx
|
|
299
|
+
* const { createSandbox, getSandbox, listSandboxes, loading, error } = useSandbox({
|
|
300
|
+
* baseUrl: apiGatewayUrl,
|
|
301
|
+
* orgId: selectedOrgId,
|
|
302
|
+
* });
|
|
303
|
+
*
|
|
304
|
+
* const result = await createSandbox({ prompt: "Create a bar chart showing sales data" });
|
|
305
|
+
* console.log(result.url); // sandbox URL
|
|
306
|
+
* ```
|
|
307
|
+
*/
|
|
308
|
+
declare function useSandbox(options: UseAgentsOptions): {
|
|
309
|
+
loading: boolean;
|
|
310
|
+
error: string | null;
|
|
311
|
+
createSandbox: (request: Omit<CreateSandboxRequest, "orgId">) => Promise<{
|
|
312
|
+
id: string;
|
|
313
|
+
url: string;
|
|
314
|
+
sandbox?: Sandbox;
|
|
315
|
+
} | null>;
|
|
316
|
+
getSandbox: (sandboxId: string) => Promise<Sandbox | null>;
|
|
317
|
+
updateSandbox: (sandboxId: string, request: {
|
|
318
|
+
prompt: string;
|
|
319
|
+
title?: string;
|
|
320
|
+
}) => Promise<{
|
|
321
|
+
id: string;
|
|
322
|
+
url: string;
|
|
323
|
+
sandbox?: Sandbox;
|
|
324
|
+
} | null>;
|
|
325
|
+
listSandboxes: (limit?: number | undefined) => Promise<{
|
|
326
|
+
sandboxes: Sandbox[];
|
|
327
|
+
total: number;
|
|
328
|
+
}>;
|
|
329
|
+
deleteSandbox: (sandboxId: string) => Promise<boolean>;
|
|
330
|
+
};
|
|
331
|
+
/**
|
|
332
|
+
* Hook for scheduler task operations
|
|
333
|
+
*
|
|
334
|
+
* @example
|
|
335
|
+
* ```tsx
|
|
336
|
+
* const { listTasks, createTask, snoozeTask, loading, error } = useSchedulerTasks({
|
|
337
|
+
* baseUrl: apiGatewayUrl,
|
|
338
|
+
* orgId: selectedOrgId,
|
|
339
|
+
* });
|
|
340
|
+
*
|
|
341
|
+
* const tasks = await listTasks();
|
|
342
|
+
* await snoozeTask(taskId, { amount: 30, unit: "minutes" });
|
|
343
|
+
* ```
|
|
344
|
+
*/
|
|
345
|
+
declare function useSchedulerTasks(options: UseAgentsOptions): {
|
|
346
|
+
loading: boolean;
|
|
347
|
+
error: string | null;
|
|
348
|
+
listTasks: (params?: {
|
|
349
|
+
status?: string;
|
|
350
|
+
limit?: number;
|
|
351
|
+
offset?: number;
|
|
352
|
+
} | undefined) => Promise<SchedulerTask[]>;
|
|
353
|
+
createTask: (task: Partial<SchedulerTask>) => Promise<SchedulerTask | null>;
|
|
354
|
+
getTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
355
|
+
updateTask: (taskId: string, task: Partial<SchedulerTask>) => Promise<SchedulerTask | null>;
|
|
356
|
+
deleteTask: (taskId: string) => Promise<boolean>;
|
|
357
|
+
snoozeTask: (taskId: string, delay: {
|
|
358
|
+
amount: number;
|
|
359
|
+
unit: string;
|
|
360
|
+
}) => Promise<SchedulerTask | null>;
|
|
361
|
+
completeTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
362
|
+
startTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
363
|
+
};
|
|
364
|
+
/**
|
|
365
|
+
* Hook for scheduler schedule operations (recurring jobs)
|
|
366
|
+
*
|
|
367
|
+
* @example
|
|
368
|
+
* ```tsx
|
|
369
|
+
* const { listSchedules, createSchedule, pauseSchedule, loading, error } = useSchedulerSchedules({
|
|
370
|
+
* baseUrl: apiGatewayUrl,
|
|
371
|
+
* orgId: selectedOrgId,
|
|
372
|
+
* });
|
|
373
|
+
*
|
|
374
|
+
* const schedules = await listSchedules();
|
|
375
|
+
* await pauseSchedule(scheduleId);
|
|
376
|
+
* ```
|
|
377
|
+
*/
|
|
378
|
+
declare function useSchedulerSchedules(options: UseAgentsOptions): {
|
|
379
|
+
loading: boolean;
|
|
380
|
+
error: string | null;
|
|
381
|
+
listSchedules: (params?: {
|
|
382
|
+
status?: string;
|
|
383
|
+
limit?: number;
|
|
384
|
+
offset?: number;
|
|
385
|
+
} | undefined) => Promise<SchedulerSchedule[]>;
|
|
386
|
+
createSchedule: (schedule: Partial<SchedulerSchedule>) => Promise<SchedulerSchedule | null>;
|
|
387
|
+
getSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
388
|
+
updateSchedule: (scheduleId: string, schedule: Partial<SchedulerSchedule>) => Promise<SchedulerSchedule | null>;
|
|
389
|
+
deleteSchedule: (scheduleId: string) => Promise<boolean>;
|
|
390
|
+
pauseSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
391
|
+
resumeSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
392
|
+
runSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
393
|
+
};
|
|
185
394
|
|
|
186
|
-
export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useApiAsync, useAsync, useOptionsRef, useSkills, useSubAgents, useToolDefinitions, useWidgets };
|
|
395
|
+
export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useAnalytics, useApiAsync, useAsync, useIntegrations, useOptionsRef, useSandbox, useSchedulerSchedules, useSchedulerTasks, useSkillUserConfig, useSkills, useSubAgents, useToolDefinitions, useWidgets };
|
package/dist/hooks/index.d.ts
CHANGED
|
@@ -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.js';
|
|
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.js';
|
|
3
|
+
import { ba as UserIntegration, ap as IntegrationProviderTS, aA as IntegrationTypeTS, h as CreateSandboxRequest, aW as Sandbox } from '../sandbox-BHeWPjLU.js';
|
|
4
|
+
import { DateFilter, SchedulerSchedule, SchedulerTask } from '../api/index.js';
|
|
3
5
|
import '@elqnt/types';
|
|
4
6
|
|
|
5
7
|
interface UseAsyncOptions {
|
|
@@ -182,5 +184,212 @@ 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
|
+
};
|
|
294
|
+
/**
|
|
295
|
+
* Hook for sandbox operations (AI-generated HTML sandboxes)
|
|
296
|
+
*
|
|
297
|
+
* @example
|
|
298
|
+
* ```tsx
|
|
299
|
+
* const { createSandbox, getSandbox, listSandboxes, loading, error } = useSandbox({
|
|
300
|
+
* baseUrl: apiGatewayUrl,
|
|
301
|
+
* orgId: selectedOrgId,
|
|
302
|
+
* });
|
|
303
|
+
*
|
|
304
|
+
* const result = await createSandbox({ prompt: "Create a bar chart showing sales data" });
|
|
305
|
+
* console.log(result.url); // sandbox URL
|
|
306
|
+
* ```
|
|
307
|
+
*/
|
|
308
|
+
declare function useSandbox(options: UseAgentsOptions): {
|
|
309
|
+
loading: boolean;
|
|
310
|
+
error: string | null;
|
|
311
|
+
createSandbox: (request: Omit<CreateSandboxRequest, "orgId">) => Promise<{
|
|
312
|
+
id: string;
|
|
313
|
+
url: string;
|
|
314
|
+
sandbox?: Sandbox;
|
|
315
|
+
} | null>;
|
|
316
|
+
getSandbox: (sandboxId: string) => Promise<Sandbox | null>;
|
|
317
|
+
updateSandbox: (sandboxId: string, request: {
|
|
318
|
+
prompt: string;
|
|
319
|
+
title?: string;
|
|
320
|
+
}) => Promise<{
|
|
321
|
+
id: string;
|
|
322
|
+
url: string;
|
|
323
|
+
sandbox?: Sandbox;
|
|
324
|
+
} | null>;
|
|
325
|
+
listSandboxes: (limit?: number | undefined) => Promise<{
|
|
326
|
+
sandboxes: Sandbox[];
|
|
327
|
+
total: number;
|
|
328
|
+
}>;
|
|
329
|
+
deleteSandbox: (sandboxId: string) => Promise<boolean>;
|
|
330
|
+
};
|
|
331
|
+
/**
|
|
332
|
+
* Hook for scheduler task operations
|
|
333
|
+
*
|
|
334
|
+
* @example
|
|
335
|
+
* ```tsx
|
|
336
|
+
* const { listTasks, createTask, snoozeTask, loading, error } = useSchedulerTasks({
|
|
337
|
+
* baseUrl: apiGatewayUrl,
|
|
338
|
+
* orgId: selectedOrgId,
|
|
339
|
+
* });
|
|
340
|
+
*
|
|
341
|
+
* const tasks = await listTasks();
|
|
342
|
+
* await snoozeTask(taskId, { amount: 30, unit: "minutes" });
|
|
343
|
+
* ```
|
|
344
|
+
*/
|
|
345
|
+
declare function useSchedulerTasks(options: UseAgentsOptions): {
|
|
346
|
+
loading: boolean;
|
|
347
|
+
error: string | null;
|
|
348
|
+
listTasks: (params?: {
|
|
349
|
+
status?: string;
|
|
350
|
+
limit?: number;
|
|
351
|
+
offset?: number;
|
|
352
|
+
} | undefined) => Promise<SchedulerTask[]>;
|
|
353
|
+
createTask: (task: Partial<SchedulerTask>) => Promise<SchedulerTask | null>;
|
|
354
|
+
getTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
355
|
+
updateTask: (taskId: string, task: Partial<SchedulerTask>) => Promise<SchedulerTask | null>;
|
|
356
|
+
deleteTask: (taskId: string) => Promise<boolean>;
|
|
357
|
+
snoozeTask: (taskId: string, delay: {
|
|
358
|
+
amount: number;
|
|
359
|
+
unit: string;
|
|
360
|
+
}) => Promise<SchedulerTask | null>;
|
|
361
|
+
completeTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
362
|
+
startTask: (taskId: string) => Promise<SchedulerTask | null>;
|
|
363
|
+
};
|
|
364
|
+
/**
|
|
365
|
+
* Hook for scheduler schedule operations (recurring jobs)
|
|
366
|
+
*
|
|
367
|
+
* @example
|
|
368
|
+
* ```tsx
|
|
369
|
+
* const { listSchedules, createSchedule, pauseSchedule, loading, error } = useSchedulerSchedules({
|
|
370
|
+
* baseUrl: apiGatewayUrl,
|
|
371
|
+
* orgId: selectedOrgId,
|
|
372
|
+
* });
|
|
373
|
+
*
|
|
374
|
+
* const schedules = await listSchedules();
|
|
375
|
+
* await pauseSchedule(scheduleId);
|
|
376
|
+
* ```
|
|
377
|
+
*/
|
|
378
|
+
declare function useSchedulerSchedules(options: UseAgentsOptions): {
|
|
379
|
+
loading: boolean;
|
|
380
|
+
error: string | null;
|
|
381
|
+
listSchedules: (params?: {
|
|
382
|
+
status?: string;
|
|
383
|
+
limit?: number;
|
|
384
|
+
offset?: number;
|
|
385
|
+
} | undefined) => Promise<SchedulerSchedule[]>;
|
|
386
|
+
createSchedule: (schedule: Partial<SchedulerSchedule>) => Promise<SchedulerSchedule | null>;
|
|
387
|
+
getSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
388
|
+
updateSchedule: (scheduleId: string, schedule: Partial<SchedulerSchedule>) => Promise<SchedulerSchedule | null>;
|
|
389
|
+
deleteSchedule: (scheduleId: string) => Promise<boolean>;
|
|
390
|
+
pauseSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
391
|
+
resumeSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
392
|
+
runSchedule: (scheduleId: string) => Promise<SchedulerSchedule | null>;
|
|
393
|
+
};
|
|
185
394
|
|
|
186
|
-
export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useApiAsync, useAsync, useOptionsRef, useSkills, useSubAgents, useToolDefinitions, useWidgets };
|
|
395
|
+
export { type UseAgentsOptions, type UseAsyncOptions, type UseAsyncReturn, type UseWidgetsOptions, useAgentJobs, useAgents, useAnalytics, useApiAsync, useAsync, useIntegrations, useOptionsRef, useSandbox, useSchedulerSchedules, useSchedulerTasks, useSkillUserConfig, useSkills, useSubAgents, useToolDefinitions, useWidgets };
|
package/dist/hooks/index.js
CHANGED
|
@@ -10,17 +10,29 @@
|
|
|
10
10
|
|
|
11
11
|
|
|
12
12
|
|
|
13
|
-
var _chunkREBFGDVAjs = require('../chunk-REBFGDVA.js');
|
|
14
|
-
require('../chunk-SKZS3AIT.js');
|
|
15
13
|
|
|
16
14
|
|
|
17
15
|
|
|
18
16
|
|
|
19
17
|
|
|
20
18
|
|
|
19
|
+
var _chunkRGVWAFZPjs = require('../chunk-RGVWAFZP.js');
|
|
20
|
+
require('../chunk-IUKM3T2S.js');
|
|
21
21
|
|
|
22
22
|
|
|
23
23
|
|
|
24
24
|
|
|
25
|
-
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
exports.useAgentJobs = _chunkRGVWAFZPjs.useAgentJobs; exports.useAgents = _chunkRGVWAFZPjs.useAgents; exports.useAnalytics = _chunkRGVWAFZPjs.useAnalytics; exports.useApiAsync = _chunkRGVWAFZPjs.useApiAsync; exports.useAsync = _chunkRGVWAFZPjs.useAsync; exports.useIntegrations = _chunkRGVWAFZPjs.useIntegrations; exports.useOptionsRef = _chunkRGVWAFZPjs.useOptionsRef; exports.useSandbox = _chunkRGVWAFZPjs.useSandbox; exports.useSchedulerSchedules = _chunkRGVWAFZPjs.useSchedulerSchedules; exports.useSchedulerTasks = _chunkRGVWAFZPjs.useSchedulerTasks; exports.useSkillUserConfig = _chunkRGVWAFZPjs.useSkillUserConfig; exports.useSkills = _chunkRGVWAFZPjs.useSkills; exports.useSubAgents = _chunkRGVWAFZPjs.useSubAgents; exports.useToolDefinitions = _chunkRGVWAFZPjs.useToolDefinitions; exports.useWidgets = _chunkRGVWAFZPjs.useWidgets;
|
|
26
38
|
//# sourceMappingURL=index.js.map
|
package/dist/hooks/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/eloquent/eloquent/packages/@elqnt/agents/dist/hooks/index.js"],"names":[],"mappings":"AAAA,qFAAY;AACZ,YAAY;AACZ;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/eloquent/eloquent/packages/@elqnt/agents/dist/hooks/index.js"],"names":[],"mappings":"AAAA,qFAAY;AACZ,YAAY;AACZ;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,u0BAAC","file":"/home/runner/work/eloquent/eloquent/packages/@elqnt/agents/dist/hooks/index.js"}
|
package/dist/hooks/index.mjs
CHANGED
|
@@ -3,21 +3,33 @@
|
|
|
3
3
|
import {
|
|
4
4
|
useAgentJobs,
|
|
5
5
|
useAgents,
|
|
6
|
+
useAnalytics,
|
|
6
7
|
useApiAsync,
|
|
7
8
|
useAsync,
|
|
9
|
+
useIntegrations,
|
|
8
10
|
useOptionsRef,
|
|
11
|
+
useSandbox,
|
|
12
|
+
useSchedulerSchedules,
|
|
13
|
+
useSchedulerTasks,
|
|
14
|
+
useSkillUserConfig,
|
|
9
15
|
useSkills,
|
|
10
16
|
useSubAgents,
|
|
11
17
|
useToolDefinitions,
|
|
12
18
|
useWidgets
|
|
13
|
-
} from "../chunk-
|
|
14
|
-
import "../chunk-
|
|
19
|
+
} from "../chunk-V5GHDXSW.mjs";
|
|
20
|
+
import "../chunk-FR422IHO.mjs";
|
|
15
21
|
export {
|
|
16
22
|
useAgentJobs,
|
|
17
23
|
useAgents,
|
|
24
|
+
useAnalytics,
|
|
18
25
|
useApiAsync,
|
|
19
26
|
useAsync,
|
|
27
|
+
useIntegrations,
|
|
20
28
|
useOptionsRef,
|
|
29
|
+
useSandbox,
|
|
30
|
+
useSchedulerSchedules,
|
|
31
|
+
useSchedulerTasks,
|
|
32
|
+
useSkillUserConfig,
|
|
21
33
|
useSkills,
|
|
22
34
|
useSubAgents,
|
|
23
35
|
useToolDefinitions,
|