|
import { useCallback } from 'react'; |
|
import { Operator } from './constant'; |
|
import useGraphStore from './store'; |
|
|
|
const ExcludedNodesMap = { |
|
|
|
[Operator.Categorize]: [Operator.Categorize, Operator.Answer, Operator.Begin], |
|
[Operator.Relevant]: [Operator.Begin], |
|
[Operator.Generate]: [Operator.Begin], |
|
}; |
|
|
|
export const useBuildFormSelectOptions = ( |
|
operatorName: Operator, |
|
selfId?: string, |
|
) => { |
|
const nodes = useGraphStore((state) => state.nodes); |
|
|
|
const buildCategorizeToOptions = useCallback( |
|
(toList: string[]) => { |
|
const excludedNodes: Operator[] = ExcludedNodesMap[operatorName] ?? []; |
|
return nodes |
|
.filter( |
|
(x) => |
|
excludedNodes.every((y) => y !== x.data.label) && |
|
x.id !== selfId && |
|
!toList.some((y) => y === x.id), |
|
) |
|
.map((x) => ({ label: x.data.name, value: x.id })); |
|
}, |
|
[nodes, operatorName, selfId], |
|
); |
|
|
|
return buildCategorizeToOptions; |
|
}; |
|
|
|
export const useHandleFormSelectChange = (nodeId?: string) => { |
|
const { addEdge, deleteEdgeBySourceAndSourceHandle } = useGraphStore( |
|
(state) => state, |
|
); |
|
const handleSelectChange = useCallback( |
|
(name?: string) => (value?: string) => { |
|
if (nodeId && name) { |
|
if (value) { |
|
addEdge({ |
|
source: nodeId, |
|
target: value, |
|
sourceHandle: name, |
|
targetHandle: null, |
|
}); |
|
} else { |
|
|
|
deleteEdgeBySourceAndSourceHandle({ |
|
source: nodeId, |
|
sourceHandle: name, |
|
}); |
|
} |
|
} |
|
}, |
|
[addEdge, nodeId, deleteEdgeBySourceAndSourceHandle], |
|
); |
|
|
|
return { handleSelectChange }; |
|
}; |
|
|