mirror of
https://github.com/langgenius/dify.git
synced 2026-04-18 12:28:32 +08:00
Signed-off-by: -LAN- <laipz8200@outlook.com> Signed-off-by: kenwoodjw <blackxin55+@gmail.com> Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: zhanluxianshen <zhanluxianshen@163.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: GuanMu <ballmanjq@gmail.com> Co-authored-by: Davide Delbianco <davide.delbianco@outlook.com> Co-authored-by: NeatGuyCoding <15627489+NeatGuyCoding@users.noreply.github.com> Co-authored-by: kenwoodjw <blackxin55+@gmail.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: Yongtao Huang <99629139+hyongtao-db@users.noreply.github.com> Co-authored-by: Qiang Lee <18018968632@163.com> Co-authored-by: 李强04 <liqiang04@gaotu.cn> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Matri Qi <matrixdom@126.com> Co-authored-by: huayaoyue6 <huayaoyue@163.com> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: znn <jubinkumarsoni@gmail.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: Muke Wang <shaodwaaron@gmail.com> Co-authored-by: wangmuke <wangmuke@kingsware.cn> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: quicksand <quicksandzn@gmail.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: Eric Guo <eric.guocz@gmail.com> Co-authored-by: Zhedong Cen <cenzhedong2@126.com> Co-authored-by: jiangbo721 <jiangbo721@163.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: hjlarry <25834719+hjlarry@users.noreply.github.com> Co-authored-by: lxsummer <35754229+lxjustdoit@users.noreply.github.com> Co-authored-by: 湛露先生 <zhanluxianshen@163.com> Co-authored-by: Guangdong Liu <liugddx@gmail.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Yessenia-d <yessenia.contact@gmail.com> Co-authored-by: huangzhuo1949 <167434202+huangzhuo1949@users.noreply.github.com> Co-authored-by: huangzhuo <huangzhuo1@xiaomi.com> Co-authored-by: 17hz <0x149527@gmail.com> Co-authored-by: Amy <1530140574@qq.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Nite Knite <nkCoding@gmail.com> Co-authored-by: Yeuoly <45712896+Yeuoly@users.noreply.github.com> Co-authored-by: Petrus Han <petrus.hanks@gmail.com> Co-authored-by: iamjoel <2120155+iamjoel@users.noreply.github.com> Co-authored-by: Kalo Chin <frog.beepers.0n@icloud.com> Co-authored-by: Ujjwal Maurya <ujjwalsbx@gmail.com> Co-authored-by: Maries <xh001x@hotmail.com>
103 lines
3.7 KiB
TypeScript
103 lines
3.7 KiB
TypeScript
import { useCallback } from 'react'
|
|
import produce from 'immer'
|
|
import {
|
|
useIsChatMode,
|
|
useNodesReadOnly,
|
|
useWorkflow,
|
|
} from '../../hooks'
|
|
import { VarType } from '../../types'
|
|
import type { ErrorHandleMode, ValueSelector, Var } from '../../types'
|
|
import useNodeCrud from '../_base/hooks/use-node-crud'
|
|
import type { IterationNodeType } from './types'
|
|
import { toNodeOutputVars } from '../_base/components/variable/utils'
|
|
import type { VarType as VarKindType } from '@/app/components/workflow/nodes/tool/types'
|
|
import type { Item } from '@/app/components/base/select'
|
|
import useInspectVarsCrud from '../../hooks/use-inspect-vars-crud'
|
|
import { isEqual } from 'lodash-es'
|
|
|
|
const useConfig = (id: string, payload: IterationNodeType) => {
|
|
const {
|
|
deleteNodeInspectorVars,
|
|
} = useInspectVarsCrud()
|
|
const { nodesReadOnly: readOnly } = useNodesReadOnly()
|
|
const isChatMode = useIsChatMode()
|
|
|
|
const { inputs, setInputs } = useNodeCrud<IterationNodeType>(id, payload)
|
|
|
|
const filterInputVar = useCallback((varPayload: Var) => {
|
|
return [VarType.array, VarType.arrayString, VarType.arrayBoolean, VarType.arrayNumber, VarType.arrayObject, VarType.arrayFile].includes(varPayload.type)
|
|
}, [])
|
|
|
|
const handleInputChange = useCallback((input: ValueSelector | string, _varKindType: VarKindType, varInfo?: Var) => {
|
|
const newInputs = produce(inputs, (draft) => {
|
|
draft.iterator_selector = input as ValueSelector || []
|
|
draft.iterator_input_type = varInfo?.type || VarType.arrayString
|
|
})
|
|
setInputs(newInputs)
|
|
}, [inputs, setInputs])
|
|
|
|
// output
|
|
const { getIterationNodeChildren } = useWorkflow()
|
|
const iterationChildrenNodes = getIterationNodeChildren(id)
|
|
const childrenNodeVars = toNodeOutputVars(iterationChildrenNodes, isChatMode)
|
|
|
|
const handleOutputVarChange = useCallback((output: ValueSelector | string, _varKindType: VarKindType, varInfo?: Var) => {
|
|
if (isEqual(inputs.output_selector, output as ValueSelector))
|
|
return
|
|
|
|
const newInputs = produce(inputs, (draft) => {
|
|
draft.output_selector = output as ValueSelector || []
|
|
const outputItemType = varInfo?.type || VarType.string
|
|
|
|
draft.output_type = ({
|
|
[VarType.string]: VarType.arrayString,
|
|
[VarType.number]: VarType.arrayNumber,
|
|
[VarType.object]: VarType.arrayObject,
|
|
[VarType.file]: VarType.arrayFile,
|
|
// list operator node can output array
|
|
[VarType.array]: VarType.array,
|
|
[VarType.arrayFile]: VarType.arrayFile,
|
|
[VarType.arrayString]: VarType.arrayString,
|
|
[VarType.arrayNumber]: VarType.arrayNumber,
|
|
[VarType.arrayObject]: VarType.arrayObject,
|
|
} as Record<VarType, VarType>)[outputItemType] || VarType.arrayString
|
|
})
|
|
setInputs(newInputs)
|
|
deleteNodeInspectorVars(id)
|
|
}, [deleteNodeInspectorVars, id, inputs, setInputs])
|
|
|
|
const changeParallel = useCallback((value: boolean) => {
|
|
const newInputs = produce(inputs, (draft) => {
|
|
draft.is_parallel = value
|
|
})
|
|
setInputs(newInputs)
|
|
}, [inputs, setInputs])
|
|
|
|
const changeErrorResponseMode = useCallback((item: Item) => {
|
|
const newInputs = produce(inputs, (draft) => {
|
|
draft.error_handle_mode = item.value as ErrorHandleMode
|
|
})
|
|
setInputs(newInputs)
|
|
}, [inputs, setInputs])
|
|
const changeParallelNums = useCallback((num: number) => {
|
|
const newInputs = produce(inputs, (draft) => {
|
|
draft.parallel_nums = num
|
|
})
|
|
setInputs(newInputs)
|
|
}, [inputs, setInputs])
|
|
return {
|
|
readOnly,
|
|
inputs,
|
|
filterInputVar,
|
|
handleInputChange,
|
|
childrenNodeVars,
|
|
iterationChildrenNodes,
|
|
handleOutputVarChange,
|
|
changeParallel,
|
|
changeErrorResponseMode,
|
|
changeParallelNums,
|
|
}
|
|
}
|
|
|
|
export default useConfig
|