split hooks

This commit is contained in:
StyleZhang
2024-03-13 11:53:21 +08:00
parent 64fa343d16
commit a55a7603dd
25 changed files with 586 additions and 491 deletions

View File

@ -0,0 +1,43 @@
import { useCallback } from 'react'
import produce from 'immer'
import { useStoreApi } from 'reactflow'
import { useStore } from '../store'
import { useNodesSyncDraft } from './use-nodes-sync-draft'
type NodeDataUpdatePayload = {
id: string
data: Record<string, any>
}
export const useNodeDataUpdate = () => {
const store = useStoreApi()
const { handleSyncWorkflowDraft } = useNodesSyncDraft()
const handleNodeDataUpdate = useCallback(({ id, data }: NodeDataUpdatePayload) => {
const {
getNodes,
setNodes,
} = store.getState()
const newNodes = produce(getNodes(), (draft) => {
const currentNode = draft.find(node => node.id === id)!
currentNode.data = { ...currentNode.data, ...data }
})
setNodes(newNodes)
}, [store])
const handleNodeDataUpdateWithSyncDraft = useCallback((payload: NodeDataUpdatePayload) => {
const { runningStatus } = useStore.getState()
if (runningStatus)
return
handleNodeDataUpdate(payload)
handleSyncWorkflowDraft(true)
}, [handleSyncWorkflowDraft, handleNodeDataUpdate])
return {
handleNodeDataUpdate,
handleNodeDataUpdateWithSyncDraft,
}
}