| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- import { useCallback, useEffect, useRef } from 'react'
- import produce from 'immer'
- import useVarList from '../_base/hooks/use-var-list'
- import type { Var, Variable } from '../../types'
- import { VarType } from '../../types'
- import { useStore } from '../../store'
- import type { TemplateTransformNodeType } from './types'
- import useNodeCrud from '@/app/components/workflow/nodes/_base/hooks/use-node-crud'
- import {
- useNodesReadOnly,
- } from '@/app/components/workflow/hooks'
- import useAvailableVarList from '@/app/components/workflow/nodes/_base/hooks/use-available-var-list'
-
- const useConfig = (id: string, payload: TemplateTransformNodeType) => {
- const { nodesReadOnly: readOnly } = useNodesReadOnly()
- const defaultConfig = useStore(s => s.nodesDefaultConfigs)[payload.type]
-
- const { inputs, setInputs: doSetInputs } = useNodeCrud<TemplateTransformNodeType>(id, payload)
- const inputsRef = useRef(inputs)
- const setInputs = useCallback((newPayload: TemplateTransformNodeType) => {
- doSetInputs(newPayload)
- inputsRef.current = newPayload
- }, [doSetInputs])
-
- const { availableVars } = useAvailableVarList(id, {
- onlyLeafNodeVar: false,
- filterVar: () => true,
- })
-
- const { handleAddVariable: handleAddEmptyVariable } = useVarList<TemplateTransformNodeType>({
- inputs,
- setInputs,
- })
-
- const handleVarListChange = useCallback((newList: Variable[]) => {
- const newInputs = produce(inputsRef.current, (draft: any) => {
- draft.variables = newList
- })
- setInputs(newInputs)
- }, [setInputs])
-
- const handleAddVariable = useCallback((payload: Variable) => {
- const newInputs = produce(inputsRef.current, (draft: any) => {
- draft.variables.push(payload)
- })
- setInputs(newInputs)
- }, [setInputs])
-
- // rename var in code
- const handleVarNameChange = useCallback((oldName: string, newName: string) => {
- const newInputs = produce(inputsRef.current, (draft: any) => {
- draft.template = draft.template.replaceAll(`{{ ${oldName} }}`, `{{ ${newName} }}`)
- })
- setInputs(newInputs)
- }, [setInputs])
-
- useEffect(() => {
- if (inputs.template)
- return
-
- const isReady = defaultConfig && Object.keys(defaultConfig).length > 0
- if (isReady) {
- setInputs({
- ...inputs,
- ...defaultConfig,
- })
- }
- // eslint-disable-next-line react-hooks/exhaustive-deps
- }, [defaultConfig])
-
- const handleCodeChange = useCallback((template: string) => {
- const newInputs = produce(inputsRef.current, (draft: any) => {
- draft.template = template
- })
- setInputs(newInputs)
- }, [setInputs])
-
- const filterVar = useCallback((varPayload: Var) => {
- return [VarType.string, VarType.number, VarType.object, VarType.array, VarType.arrayNumber, VarType.arrayString, VarType.arrayObject].includes(varPayload.type)
- }, [])
-
- return {
- readOnly,
- inputs,
- availableVars,
- handleVarListChange,
- handleVarNameChange,
- handleAddVariable,
- handleAddEmptyVariable,
- handleCodeChange,
- filterVar,
- }
- }
-
- export default useConfig
|