| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 | 
							- import { useCallback, useEffect, useRef, useState } from 'react'
 - import produce from 'immer'
 - import type { Memory, MoreInfo, ValueSelector, Var } from '../../types'
 - import { ChangeType, VarType } from '../../types'
 - import { useStore } from '../../store'
 - import {
 -   useIsChatMode,
 -   useNodesReadOnly,
 -   useWorkflow,
 - } from '../../hooks'
 - import useConfigVision from '../../hooks/use-config-vision'
 - import type { Param, ParameterExtractorNodeType, ReasoningModeType } from './types'
 - import { useModelListAndDefaultModelAndCurrentProviderAndModel, useTextGenerationCurrentProviderAndModelAndModelList } from '@/app/components/header/account-setting/model-provider-page/hooks'
 - import { ModelTypeEnum } from '@/app/components/header/account-setting/model-provider-page/declarations'
 - import useNodeCrud from '@/app/components/workflow/nodes/_base/hooks/use-node-crud'
 - import { checkHasQueryBlock } from '@/app/components/base/prompt-editor/constants'
 - import useAvailableVarList from '@/app/components/workflow/nodes/_base/hooks/use-available-var-list'
 - import { supportFunctionCall } from '@/utils/tool-call'
 - import useInspectVarsCrud from '../../hooks/use-inspect-vars-crud'
 - 
 - const useConfig = (id: string, payload: ParameterExtractorNodeType) => {
 -   const {
 -     deleteNodeInspectorVars,
 -     renameInspectVarName,
 -   } = useInspectVarsCrud()
 -   const { nodesReadOnly: readOnly } = useNodesReadOnly()
 -   const { handleOutVarRenameChange } = useWorkflow()
 -   const isChatMode = useIsChatMode()
 - 
 -   const defaultConfig = useStore(s => s.nodesDefaultConfigs)[payload.type]
 - 
 -   const [defaultRolePrefix, setDefaultRolePrefix] = useState<{ user: string; assistant: string }>({ user: '', assistant: '' })
 -   const { inputs, setInputs: doSetInputs } = useNodeCrud<ParameterExtractorNodeType>(id, payload)
 -   const inputRef = useRef(inputs)
 - 
 -   const setInputs = useCallback((newInputs: ParameterExtractorNodeType) => {
 -     if (newInputs.memory && !newInputs.memory.role_prefix) {
 -       const newPayload = produce(newInputs, (draft) => {
 -         draft.memory!.role_prefix = defaultRolePrefix
 -       })
 -       doSetInputs(newPayload)
 -       inputRef.current = newPayload
 -       return
 -     }
 -     doSetInputs(newInputs)
 -     inputRef.current = newInputs
 -   }, [doSetInputs, defaultRolePrefix])
 - 
 -   const filterVar = useCallback((varPayload: Var) => {
 -     return [VarType.string].includes(varPayload.type)
 -   }, [])
 - 
 -   const handleInputVarChange = useCallback((newInputVar: ValueSelector | string) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.query = newInputVar as ValueSelector || []
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   const handleExactParamsChange = useCallback((newParams: Param[], moreInfo?: MoreInfo) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.parameters = newParams
 -     })
 -     setInputs(newInputs)
 - 
 -     if (moreInfo && moreInfo?.type === ChangeType.changeVarName && moreInfo.payload) {
 -       handleOutVarRenameChange(id, [id, moreInfo.payload.beforeKey], [id, moreInfo.payload.afterKey!])
 -       renameInspectVarName(id, moreInfo.payload.beforeKey, moreInfo.payload.afterKey!)
 -     }
 -     else {
 -       deleteNodeInspectorVars(id)
 -     }
 -   }, [deleteNodeInspectorVars, handleOutVarRenameChange, id, inputs, renameInspectVarName, setInputs])
 - 
 -   const addExtractParameter = useCallback((payload: Param) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       if (!draft.parameters)
 -         draft.parameters = []
 -       draft.parameters.push(payload)
 -     })
 -     setInputs(newInputs)
 -     deleteNodeInspectorVars(id)
 -   }, [deleteNodeInspectorVars, id, inputs, setInputs])
 - 
 -   // model
 -   const model = inputs.model || {
 -     provider: '',
 -     name: '',
 -     mode: 'chat',
 -     completion_params: {
 -       temperature: 0.7,
 -     },
 -   }
 -   const modelMode = inputs.model?.mode
 -   const isChatModel = modelMode === 'chat'
 -   const isCompletionModel = !isChatModel
 - 
 -   const {
 -     isVisionModel,
 -     handleVisionResolutionEnabledChange,
 -     handleVisionResolutionChange,
 -     handleModelChanged: handleVisionConfigAfterModelChanged,
 -   } = useConfigVision(model, {
 -     payload: inputs.vision,
 -     onChange: (newPayload) => {
 -       const newInputs = produce(inputs, (draft) => {
 -         draft.vision = newPayload
 -       })
 -       setInputs(newInputs)
 -     },
 -   })
 - 
 -   const appendDefaultPromptConfig = useCallback((draft: ParameterExtractorNodeType, defaultConfig: any, _passInIsChatMode?: boolean) => {
 -     const promptTemplates = defaultConfig.prompt_templates
 -     if (!isChatModel) {
 -       setDefaultRolePrefix({
 -         user: promptTemplates.completion_model.conversation_histories_role.user_prefix,
 -         assistant: promptTemplates.completion_model.conversation_histories_role.assistant_prefix,
 -       })
 -     }
 -   }, [isChatModel])
 - 
 -   const [modelChanged, setModelChanged] = useState(false)
 -   const {
 -     currentProvider,
 -     currentModel,
 -   } = useModelListAndDefaultModelAndCurrentProviderAndModel(ModelTypeEnum.textGeneration)
 - 
 -   const handleModelChanged = useCallback((model: { provider: string; modelId: string; mode?: string }) => {
 -     const newInputs = produce(inputRef.current, (draft) => {
 -       draft.model.provider = model.provider
 -       draft.model.name = model.modelId
 -       draft.model.mode = model.mode!
 -       const isModeChange = model.mode !== inputRef.current.model?.mode
 -       if (isModeChange && defaultConfig && Object.keys(defaultConfig).length > 0)
 -         appendDefaultPromptConfig(draft, defaultConfig, model.mode === 'chat')
 -     })
 -     setInputs(newInputs)
 -     setModelChanged(true)
 -   }, [setInputs, defaultConfig, appendDefaultPromptConfig])
 - 
 -   useEffect(() => {
 -     if (currentProvider?.provider && currentModel?.model && !model.provider) {
 -       handleModelChanged({
 -         provider: currentProvider?.provider,
 -         modelId: currentModel?.model,
 -         mode: currentModel?.model_properties?.mode as string,
 -       })
 -     }
 -   }, [model?.provider, currentProvider, currentModel, handleModelChanged])
 - 
 -   // change to vision model to set vision enabled, else disabled
 -   useEffect(() => {
 -     if (!modelChanged)
 -       return
 -     setModelChanged(false)
 -     handleVisionConfigAfterModelChanged()
 -     // eslint-disable-next-line react-hooks/exhaustive-deps
 -   }, [isVisionModel, modelChanged])
 - 
 -   const {
 -     currentModel: currModel,
 -   } = useTextGenerationCurrentProviderAndModelAndModelList(
 -     {
 -       provider: model.provider,
 -       model: model.name,
 -     },
 -   )
 - 
 -   const isSupportFunctionCall = supportFunctionCall(currModel?.features)
 - 
 -   const filterInputVar = useCallback((varPayload: Var) => {
 -     return [VarType.number, VarType.string].includes(varPayload.type)
 -   }, [])
 - 
 -   const {
 -     availableVars,
 -     availableNodesWithParent,
 -   } = useAvailableVarList(id, {
 -     onlyLeafNodeVar: false,
 -     filterVar: filterInputVar,
 -   })
 - 
 -   const handleCompletionParamsChange = useCallback((newParams: Record<string, any>) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.model.completion_params = newParams
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   const handleInstructionChange = useCallback((newInstruction: string) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.instruction = newInstruction
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   const hasSetBlockStatus = {
 -     history: false,
 -     query: isChatMode ? checkHasQueryBlock(inputs.instruction) : false,
 -     context: false,
 -   }
 - 
 -   const handleMemoryChange = useCallback((newMemory?: Memory) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.memory = newMemory
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   const handleReasoningModeChange = useCallback((newReasoningMode: ReasoningModeType) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.reasoning_mode = newReasoningMode
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   const handleImportFromTool = useCallback((params: Param[]) => {
 -     const newInputs = produce(inputs, (draft) => {
 -       draft.parameters = params
 -     })
 -     setInputs(newInputs)
 -   }, [inputs, setInputs])
 - 
 -   return {
 -     readOnly,
 -     handleInputVarChange,
 -     filterVar,
 -     isChatMode,
 -     inputs,
 -     isChatModel,
 -     isCompletionModel,
 -     handleModelChanged,
 -     handleCompletionParamsChange,
 -     handleImportFromTool,
 -     handleExactParamsChange,
 -     addExtractParameter,
 -     handleInstructionChange,
 -     hasSetBlockStatus,
 -     availableVars,
 -     availableNodesWithParent,
 -     isSupportFunctionCall,
 -     handleReasoningModeChange,
 -     handleMemoryChange,
 -     isVisionModel,
 -     handleVisionResolutionEnabledChange,
 -     handleVisionResolutionChange,
 -   }
 - }
 - 
 - export default useConfig
 
 
  |