@stack-spot/ai-chat-widget 1.0.0-dev.1769003015775 → 1.0.0-dev.1769120820021

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.
Files changed (79) hide show
  1. package/dist/app-metadata.json +3 -3
  2. package/dist/chat-interceptors/send-message.d.ts.map +1 -1
  3. package/dist/chat-interceptors/send-message.js +5 -1
  4. package/dist/chat-interceptors/send-message.js.map +1 -1
  5. package/dist/components/Selector/SelectVersion.d.ts +12 -0
  6. package/dist/components/Selector/SelectVersion.d.ts.map +1 -0
  7. package/dist/components/Selector/SelectVersion.js +33 -0
  8. package/dist/components/Selector/SelectVersion.js.map +1 -0
  9. package/dist/components/Selector/index.d.ts +2 -0
  10. package/dist/components/Selector/index.d.ts.map +1 -1
  11. package/dist/components/Selector/index.js +5 -2
  12. package/dist/components/Selector/index.js.map +1 -1
  13. package/dist/components/Selector/styled.d.ts +2 -0
  14. package/dist/components/Selector/styled.d.ts.map +1 -1
  15. package/dist/components/Selector/styled.js +45 -0
  16. package/dist/components/Selector/styled.js.map +1 -1
  17. package/dist/hooks/enabled-feature-flags.d.ts +5 -0
  18. package/dist/hooks/enabled-feature-flags.d.ts.map +1 -0
  19. package/dist/hooks/enabled-feature-flags.js +28 -0
  20. package/dist/hooks/enabled-feature-flags.js.map +1 -0
  21. package/dist/state/types.d.ts +1 -0
  22. package/dist/state/types.d.ts.map +1 -1
  23. package/dist/utils/tools.d.ts +5 -5
  24. package/dist/utils/tools.d.ts.map +1 -1
  25. package/dist/utils/tools.js +2 -2
  26. package/dist/utils/tools.js.map +1 -1
  27. package/dist/views/Agents/AgentDescription.d.ts +6 -2
  28. package/dist/views/Agents/AgentDescription.d.ts.map +1 -1
  29. package/dist/views/Agents/AgentDescription.js +25 -10
  30. package/dist/views/Agents/AgentDescription.js.map +1 -1
  31. package/dist/views/Agents/AgentsTab.d.ts.map +1 -1
  32. package/dist/views/Agents/AgentsTab.js +21 -4
  33. package/dist/views/Agents/AgentsTab.js.map +1 -1
  34. package/dist/views/Agents/dictionary.d.ts +1 -1
  35. package/dist/views/Agents/dictionary.d.ts.map +1 -1
  36. package/dist/views/Agents/dictionary.js +2 -0
  37. package/dist/views/Agents/dictionary.js.map +1 -1
  38. package/dist/views/Chat/ChatMessage.d.ts.map +1 -1
  39. package/dist/views/Chat/ChatMessage.js +6 -5
  40. package/dist/views/Chat/ChatMessage.js.map +1 -1
  41. package/dist/views/ChatHistory/utils.d.ts.map +1 -1
  42. package/dist/views/ChatHistory/utils.js +14 -7
  43. package/dist/views/ChatHistory/utils.js.map +1 -1
  44. package/dist/views/Home/CustomAgent.js +3 -3
  45. package/dist/views/Home/CustomAgent.js.map +1 -1
  46. package/dist/views/MessageInput/AgentSelector.d.ts.map +1 -1
  47. package/dist/views/MessageInput/AgentSelector.js +11 -1
  48. package/dist/views/MessageInput/AgentSelector.js.map +1 -1
  49. package/dist/views/MessageInput/ModelSwitcher/index.d.ts.map +1 -1
  50. package/dist/views/MessageInput/ModelSwitcher/index.js +3 -1
  51. package/dist/views/MessageInput/ModelSwitcher/index.js.map +1 -1
  52. package/dist/views/MessageInput/ModelSwitcher/utils.d.ts +2 -2
  53. package/dist/views/MessageInput/ModelSwitcher/utils.d.ts.map +1 -1
  54. package/dist/views/MessageInput/ModelSwitcher/utils.js +6 -6
  55. package/dist/views/MessageInput/ModelSwitcher/utils.js.map +1 -1
  56. package/dist/views/Resources.js +8 -5
  57. package/dist/views/Resources.js.map +1 -1
  58. package/dist/views/Tools.js +3 -2
  59. package/dist/views/Tools.js.map +1 -1
  60. package/package.json +2 -2
  61. package/src/app-metadata.json +3 -3
  62. package/src/chat-interceptors/send-message.ts +6 -2
  63. package/src/components/Selector/SelectVersion.tsx +55 -0
  64. package/src/components/Selector/index.tsx +11 -2
  65. package/src/components/Selector/styled.ts +47 -0
  66. package/src/hooks/enabled-feature-flags.ts +31 -0
  67. package/src/state/types.ts +1 -0
  68. package/src/utils/tools.ts +4 -4
  69. package/src/views/Agents/AgentDescription.tsx +48 -14
  70. package/src/views/Agents/AgentsTab.tsx +31 -13
  71. package/src/views/Agents/dictionary.ts +2 -1
  72. package/src/views/Chat/ChatMessage.tsx +8 -6
  73. package/src/views/ChatHistory/utils.ts +18 -10
  74. package/src/views/Home/CustomAgent.tsx +4 -4
  75. package/src/views/MessageInput/AgentSelector.tsx +15 -5
  76. package/src/views/MessageInput/ModelSwitcher/index.tsx +3 -2
  77. package/src/views/MessageInput/ModelSwitcher/utils.tsx +9 -8
  78. package/src/views/Resources.tsx +10 -6
  79. package/src/views/Tools.tsx +5 -4
@@ -15,8 +15,9 @@ export const ModelSwitcher = () => {
15
15
  const chat = useCurrentChat()
16
16
  const [filter, setFilter] = useState('')
17
17
  const [visibleMenu, setVisibleMenu] = useState(false)
18
- const [agentData, isLoadingAgentData] = agentToolsClient.agent.useStatefulQuery({ agentId: agentCurrentChat?.id || '' },
19
- { enabled: !!agentCurrentChat?.id })
18
+ const [agentData, isLoadingAgentData] = agentToolsClient.agentV2.useStatefulQuery({
19
+ agentCoreId: agentCurrentChat?.id || '', versionNumber: agentCurrentChat?.agent_version_number },
20
+ { enabled: !!agentCurrentChat?.id })
20
21
  const [models, isLoadingModels] =
21
22
  genAiInferenceClient.listModels.useStatefulQuery({ pageSize: 999, active: true })
22
23
 
@@ -1,6 +1,6 @@
1
1
  import { CitricIconOutline, CitricIconSocial } from '@stack-spot/citric-icons'
2
2
  import { IconBox } from '@stack-spot/citric-react'
3
- import { AgentModel } from '@stack-spot/portal-network/api/agent-tools'
3
+ import { AgentCoreWithSingleVersionResponse2 } from '@stack-spot/portal-network/api/agent-tools'
4
4
  import { LlmModelsResponse, PaginatedResponseLlmModelsResponse } from '@stack-spot/portal-network/api/genAiInference'
5
5
  import { theme } from '@stack-spot/portal-theme'
6
6
  import { Dispatch, ReactElement } from 'react'
@@ -27,19 +27,20 @@ export const providerIcon: Record<string, CitricIconSocial | CitricIconOutline>
27
27
  export function getListModelsData(
28
28
  chat: ChatState,
29
29
  setVisibleMenu: Dispatch<React.SetStateAction<boolean>>,
30
- agent?: AgentModel,
30
+ agent?: AgentCoreWithSingleVersionResponse2,
31
31
  models?: PaginatedResponseLlmModelsResponse) {
32
32
 
33
33
  const chatSelectedModelId = chat.get('selected_model_id')
34
34
 
35
- const listModelsToShow = agent?.visibility_level !== 'built_in' && !!agent?.model_id ?
36
- models?.items.filter((model) => agent?.available_llm_models?.find((modelAvailable) => modelAvailable.model_id === model.id)) :
35
+ const listModelsToShow = agent?.visibility_level !== 'built_in' && !!agent?.version?.model_id ?
36
+ models?.items.filter((model) => agent?.version?.available_llm_models?.find((modelAvailable) => modelAvailable.model_id === model.id)) :
37
37
  models?.items
38
38
 
39
- const modelAvailableDefault = agent?.available_llm_models?.find((model) => (model.is_default || model.model_id === agent.model_id))
39
+ const modelAvailableDefault = agent?.version?.available_llm_models?.find((model) =>
40
+ (model.is_default || model.model_id === agent.version?.model_id))
40
41
  const modelListData = parseModelList(chat, setVisibleMenu, listModelsToShow, modelAvailableDefault?.model_id)
41
42
 
42
- if (agent?.visibility_level === 'built_in' || !agent?.model_id) {
43
+ if (agent?.visibility_level === 'built_in' || !agent?.version?.model_id) {
43
44
 
44
45
  const modelDefaultProviderType = models?.items.find((modelAccount) =>
45
46
  chatSelectedModelId ? modelAccount.id === chatSelectedModelId :
@@ -50,9 +51,9 @@ export function getListModelsData(
50
51
  return { modelName: modelDefaultActive?.label, modelProviderType: modelDefaultProviderType, listItemsData: modelListData }
51
52
  }
52
53
 
53
- const modelAccount = models?.items.find((modelAccount) => modelAccount.id === (chatSelectedModelId || agent.model_id))
54
+ const modelAccount = models?.items.find((modelAccount) => modelAccount.id === (chatSelectedModelId || agent.version?.model_id))
54
55
  const modelProviderType = modelAccount?.model_configuration.provider.provider_type
55
- const modelSelectedName = modelAccount?.display_name || modelAvailableDefault?.model_name || agent?.model_name
56
+ const modelSelectedName = modelAccount?.display_name || modelAvailableDefault?.model_name || agent?.version?.model_name
56
57
 
57
58
  const listItemsData =
58
59
  modelListData && modelListData?.length > 0 ? modelListData :
@@ -46,15 +46,19 @@ const ResourcesPanel = () => {
46
46
  const chat = widget.chatTabs.getAll().find(c => c.id === chatId)
47
47
  return chat?.getMessages().find(m => m.id === messageId)?.getValue()
48
48
  }, [messageId])
49
- const [agent] = agentToolsClient.agent.useStatefulQuery({ agentId: message?.agent?.id || '' },
50
- { enabled: !!message?.agent?.id })
49
+
50
+ const [agent] = agentToolsClient.agentV2.useStatefulQuery({
51
+ agentCoreId: message?.agent?.id || '', versionNumber: message?.agent?.agent_version_number },
52
+ { enabled: !!message?.agent?.id })
51
53
  const toolkits = useMemo(() => [
52
- ...agent?.toolkits?.builtin_toolkits ?? [],
53
- ...agent?.toolkits?.custom_toolkits ?? [],
54
- ...agent?.toolkits?.mcp_toolkits ?? [],
54
+ ...agent?.version?.toolkits?.builtin_toolkits ?? [],
55
+ ...agent?.version?.toolkits?.custom_toolkits ?? [],
56
+ ...agent?.version?.toolkits?.mcp_toolkits ?? [],
55
57
  ], [agent])
56
58
  const tools = useMemo(() => message?.tools?.map(id => toolById(id, toolkits)), [messageId, toolkits])
57
- const [agentsTools] = agentToolsClient.agentsByIds.useStatefulQuery({ searchAgentsRequest:{ ids: message?.tools || [] } })
59
+ const agentsSearch = message?.tools?.map((id) => ({ agent_core_id: id })) ?? []
60
+ const [agentsTools] = agentToolsClient.agentsByIdsV2.useStatefulQuery(
61
+ { searchAgentsRequestV2: { agents: agentsSearch } })
58
62
  const hasAgentTool = useMemo(() => message?.tools?.some(id => agentsTools?.find((agent) => agent.id === id)), [messageId])
59
63
 
60
64
  const header = (image?: string, label?: string) => (
@@ -42,11 +42,12 @@ const ToolsPanel = () => {
42
42
  }, [messageId])
43
43
 
44
44
  const [toolKits] = agentToolsClient.tools.useStatefulQuery({}, { enabled: !!message?.agent?.id })
45
- const [agent] = agentToolsClient.agent.useStatefulQuery({ agentId: message?.agent?.id || '' },
46
- { enabled: !!message?.agent?.id })
45
+ const [agent] = agentToolsClient.agentV2.useStatefulQuery({ agentCoreId: message?.agent?.id || '',
46
+ versionNumber: message?.agent?.agent_version_number },
47
+ { enabled: !!message?.agent?.id })
47
48
  const tools = useMemo(() => message?.tools?.map(id => toolById(id, toolKits)), [messageId, toolKits])
48
- const customTools = useMemo(() => message?.tools?.map(id => toolById(id, agent?.toolkits?.custom_toolkits)),
49
- [messageId, agent?.toolkits?.custom_toolkits])
49
+ const customTools = useMemo(() => message?.tools?.map(id => toolById(id, agent?.version?.toolkits?.custom_toolkits)),
50
+ [messageId, agent?.version?.toolkits?.custom_toolkits])
50
51
  return !!(tools?.length || customTools?.length) && (
51
52
  <ToolList>
52
53
  {[...(tools || []), ...(customTools || [])].map(