51 lines
1.5 KiB
TypeScript
Raw Normal View History

2025-05-23 11:50:36 +08:00
import { useCallback } from 'react'
import { useStoreApi } from 'reactflow'
2025-06-04 11:39:04 +08:00
import { useTranslation } from 'react-i18next'
2025-05-23 11:50:36 +08:00
import { useNodeDataUpdate } from '@/app/components/workflow/hooks'
2025-06-04 11:39:04 +08:00
import type {
DataSourceNodeType,
ToolVarInputs,
} from '../types'
import { useToastContext } from '@/app/components/base/toast'
2025-05-23 11:50:36 +08:00
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()
2025-06-04 11:39:04 +08:00
const { notify } = useToastContext()
const { t } = useTranslation()
2025-05-23 11:50:36 +08:00
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-06-04 11:39:04 +08:00
const handleParametersChange = useCallback((datasource_parameters: ToolVarInputs) => {
2025-05-27 17:42:02 +08:00
const nodeData = getNodeData()
handleNodeDataUpdate({
...nodeData?.data,
2025-06-04 11:39:04 +08:00
datasource_parameters,
2025-05-27 17:42:02 +08:00
})
}, [handleNodeDataUpdate, getNodeData])
2025-05-22 16:43:04 +08:00
return {
2025-05-23 11:50:36 +08:00
handleFileExtensionsChange,
2025-06-04 11:39:04 +08:00
handleParametersChange,
2025-05-22 16:43:04 +08:00
}
}