use-config.ts 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. import { useStrategyProviderDetail } from '@/service/use-strategy'
  2. import useNodeCrud from '../_base/hooks/use-node-crud'
  3. import useVarList from '../_base/hooks/use-var-list'
  4. import useOneStepRun from '../_base/hooks/use-one-step-run'
  5. import type { AgentNodeType } from './types'
  6. import {
  7. useNodesReadOnly,
  8. } from '@/app/components/workflow/hooks'
  9. import { useCallback, useMemo } from 'react'
  10. import { type ToolVarInputs, VarType } from '../tool/types'
  11. import { useCheckInstalled, useFetchPluginsInMarketPlaceByIds } from '@/service/use-plugins'
  12. import type { Var } from '../../types'
  13. import { VarType as VarKindType } from '../../types'
  14. import useAvailableVarList from '../_base/hooks/use-available-var-list'
  15. export type StrategyStatus = {
  16. plugin: {
  17. source: 'external' | 'marketplace'
  18. installed: boolean
  19. }
  20. isExistInPlugin: boolean
  21. }
  22. export const useStrategyInfo = (
  23. strategyProviderName?: string,
  24. strategyName?: string,
  25. ) => {
  26. const strategyProvider = useStrategyProviderDetail(
  27. strategyProviderName || '',
  28. { retry: false },
  29. )
  30. const strategy = strategyProvider.data?.declaration.strategies.find(
  31. str => str.identity.name === strategyName,
  32. )
  33. const marketplace = useFetchPluginsInMarketPlaceByIds([strategyProviderName!], {
  34. retry: false,
  35. })
  36. const strategyStatus: StrategyStatus | undefined = useMemo(() => {
  37. if (strategyProvider.isLoading || marketplace.isLoading)
  38. return undefined
  39. const strategyExist = !!strategy
  40. const isPluginInstalled = !strategyProvider.isError
  41. const isInMarketplace = !!marketplace.data?.data.plugins.at(0)
  42. return {
  43. plugin: {
  44. source: isInMarketplace ? 'marketplace' : 'external',
  45. installed: isPluginInstalled,
  46. },
  47. isExistInPlugin: strategyExist,
  48. }
  49. }, [strategy, marketplace, strategyProvider.isError, strategyProvider.isLoading])
  50. const refetch = useCallback(() => {
  51. strategyProvider.refetch()
  52. marketplace.refetch()
  53. }, [marketplace, strategyProvider])
  54. return {
  55. strategyProvider,
  56. strategy,
  57. strategyStatus,
  58. refetch,
  59. }
  60. }
  61. const useConfig = (id: string, payload: AgentNodeType) => {
  62. const { nodesReadOnly: readOnly } = useNodesReadOnly()
  63. const { inputs, setInputs } = useNodeCrud<AgentNodeType>(id, payload)
  64. // variables
  65. const { handleVarListChange, handleAddVariable } = useVarList<AgentNodeType>({
  66. inputs,
  67. setInputs,
  68. })
  69. const {
  70. strategyStatus: currentStrategyStatus,
  71. strategy: currentStrategy,
  72. strategyProvider,
  73. } = useStrategyInfo(
  74. inputs.agent_strategy_provider_name,
  75. inputs.agent_strategy_name,
  76. )
  77. const pluginId = inputs.agent_strategy_provider_name?.split('/').splice(0, 2).join('/')
  78. const pluginDetail = useCheckInstalled({
  79. pluginIds: [pluginId!],
  80. enabled: Boolean(pluginId),
  81. })
  82. const formData = useMemo(() => {
  83. return Object.fromEntries(
  84. Object.entries(inputs.agent_parameters || {}).map(([key, value]) => {
  85. return [key, value.value]
  86. }),
  87. )
  88. }, [inputs.agent_parameters])
  89. const onFormChange = (value: Record<string, any>) => {
  90. const res: ToolVarInputs = {}
  91. Object.entries(value).forEach(([key, val]) => {
  92. res[key] = {
  93. type: VarType.constant,
  94. value: val,
  95. }
  96. })
  97. setInputs({
  98. ...inputs,
  99. agent_parameters: res,
  100. })
  101. }
  102. // vars
  103. const filterMemoryPromptVar = useCallback((varPayload: Var) => {
  104. return [
  105. VarKindType.arrayObject,
  106. VarKindType.array,
  107. VarKindType.number,
  108. VarKindType.string,
  109. VarKindType.secret,
  110. VarKindType.arrayString,
  111. VarKindType.arrayNumber,
  112. VarKindType.file,
  113. VarKindType.arrayFile,
  114. ].includes(varPayload.type)
  115. }, [])
  116. const {
  117. availableVars,
  118. availableNodesWithParent,
  119. } = useAvailableVarList(id, {
  120. onlyLeafNodeVar: false,
  121. filterVar: filterMemoryPromptVar,
  122. })
  123. // single run
  124. const {
  125. isShowSingleRun,
  126. showSingleRun,
  127. hideSingleRun,
  128. toVarInputs,
  129. runningStatus,
  130. handleRun,
  131. handleStop,
  132. runInputData,
  133. setRunInputData,
  134. runResult,
  135. getInputVars,
  136. } = useOneStepRun<AgentNodeType>({
  137. id,
  138. data: inputs,
  139. defaultRunInputData: {},
  140. })
  141. const allVarStrArr = (() => {
  142. const arr = currentStrategy?.parameters.filter(item => item.type === 'string').map((item) => {
  143. return formData[item.name]
  144. }) || []
  145. return arr
  146. })()
  147. const varInputs = (() => {
  148. const vars = getInputVars(allVarStrArr)
  149. return vars
  150. })()
  151. const outputSchema = useMemo(() => {
  152. const res: any[] = []
  153. if (!inputs.output_schema)
  154. return []
  155. Object.keys(inputs.output_schema.properties).forEach((outputKey) => {
  156. const output = inputs.output_schema.properties[outputKey]
  157. res.push({
  158. name: outputKey,
  159. type: output.type === 'array'
  160. ? `Array[${output.items?.type.slice(0, 1).toLocaleUpperCase()}${output.items?.type.slice(1)}]`
  161. : `${output.type.slice(0, 1).toLocaleUpperCase()}${output.type.slice(1)}`,
  162. description: output.description,
  163. })
  164. })
  165. return res
  166. }, [inputs.output_schema])
  167. return {
  168. readOnly,
  169. inputs,
  170. setInputs,
  171. handleVarListChange,
  172. handleAddVariable,
  173. currentStrategy,
  174. formData,
  175. onFormChange,
  176. currentStrategyStatus,
  177. strategyProvider: strategyProvider.data,
  178. pluginDetail: pluginDetail.data?.plugins.at(0),
  179. availableVars,
  180. availableNodesWithParent,
  181. isShowSingleRun,
  182. showSingleRun,
  183. hideSingleRun,
  184. toVarInputs,
  185. runningStatus,
  186. handleRun,
  187. handleStop,
  188. runInputData,
  189. setRunInputData,
  190. runResult,
  191. varInputs,
  192. outputSchema,
  193. }
  194. }
  195. export default useConfig