45 lines
1.3 KiB
TypeScript
Raw Normal View History

2025-05-23 11:50:36 +08:00
import { useCallback } from 'react'
import { useStoreApi } from 'reactflow'
import { useNodeDataUpdate } from '@/app/components/workflow/hooks'
2025-05-27 17:42:02 +08:00
import type { InputVar } from '@/models/pipeline'
2025-05-23 11:50:36 +08:00
import type { DataSourceNodeType } from '../types'
2025-05-22 16:43:04 +08:00
export const useConfig = (id: string) => {
2025-05-23 11:50:36 +08:00
const store = useStoreApi()
const { handleNodeDataUpdateWithSyncDraft } = useNodeDataUpdate()
const getNodeData = useCallback(() => {
const { getNodes } = store.getState()
const nodes = getNodes()
return nodes.find(node => node.id === id)
}, [store, id])
const handleNodeDataUpdate = useCallback((data: Partial<DataSourceNodeType>) => {
handleNodeDataUpdateWithSyncDraft({
id,
data,
})
}, [id, handleNodeDataUpdateWithSyncDraft])
const handleFileExtensionsChange = useCallback((fileExtensions: string[]) => {
const nodeData = getNodeData()
handleNodeDataUpdate({
...nodeData?.data,
fileExtensions,
})
}, [handleNodeDataUpdate, getNodeData])
2025-05-27 17:42:02 +08:00
const handleInputFieldVariablesChange = useCallback((variables: InputVar[]) => {
const nodeData = getNodeData()
handleNodeDataUpdate({
...nodeData?.data,
variables,
})
}, [handleNodeDataUpdate, getNodeData])
2025-05-22 16:43:04 +08:00
return {
2025-05-23 11:50:36 +08:00
handleFileExtensionsChange,
2025-05-27 17:42:02 +08:00
handleInputFieldVariablesChange,
2025-05-22 16:43:04 +08:00
}
}