mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
Feat: The delete button is displayed only when the cursor is hovered over the connection line #3221 (#8422)
### What problem does this PR solve? Feat: The delete button is displayed only when the cursor is hovered over the connection line #3221 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
This commit is contained in:
@ -4,6 +4,7 @@ import {
|
||||
Connection,
|
||||
Edge,
|
||||
EdgeChange,
|
||||
EdgeMouseHandler,
|
||||
OnConnect,
|
||||
OnEdgesChange,
|
||||
OnNodesChange,
|
||||
@ -27,6 +28,7 @@ import {
|
||||
generateNodeNamesWithIncreasingIndex,
|
||||
getOperatorIndex,
|
||||
isEdgeEqual,
|
||||
mapEdgeMouseEvent,
|
||||
} from './utils';
|
||||
|
||||
export type RFState = {
|
||||
@ -38,6 +40,9 @@ export type RFState = {
|
||||
clickedToolId: string; // currently selected tool id
|
||||
onNodesChange: OnNodesChange<RAGFlowNodeType>;
|
||||
onEdgesChange: OnEdgesChange;
|
||||
onEdgeMouseEnter?: EdgeMouseHandler<Edge>;
|
||||
/** This event handler is called when mouse of a user leaves an edge */
|
||||
onEdgeMouseLeave?: EdgeMouseHandler<Edge>;
|
||||
onConnect: OnConnect;
|
||||
setNodes: (nodes: RAGFlowNodeType[]) => void;
|
||||
setEdges: (edges: Edge[]) => void;
|
||||
@ -98,6 +103,20 @@ const useGraphStore = create<RFState>()(
|
||||
edges: applyEdgeChanges(changes, get().edges),
|
||||
});
|
||||
},
|
||||
onEdgeMouseEnter: (event, edge) => {
|
||||
const { edges, setEdges } = get();
|
||||
const edgeId = edge.id;
|
||||
|
||||
// Updates edge
|
||||
setEdges(mapEdgeMouseEvent(edges, edgeId, true));
|
||||
},
|
||||
onEdgeMouseLeave: (event, edge) => {
|
||||
const { edges, setEdges } = get();
|
||||
const edgeId = edge.id;
|
||||
|
||||
// Updates edge
|
||||
setEdges(mapEdgeMouseEvent(edges, edgeId, false));
|
||||
},
|
||||
onConnect: (connection: Connection) => {
|
||||
const {
|
||||
deletePreviousEdgeOfClassificationNode,
|
||||
|
||||
Reference in New Issue
Block a user