Skip to content

Commit

Permalink
feat(renderer): change layer order, allow zoom on nodes and user sele…
Browse files Browse the repository at this point in the history
…ction
  • Loading branch information
chrtze committed Oct 6, 2020
1 parent 4f757b8 commit 0373b53
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 6 deletions.
6 changes: 6 additions & 0 deletions example/src/Overview/index.js
Expand Up @@ -4,6 +4,9 @@ import ReactFlow, { removeElements, addEdge, MiniMap, Controls, Background, isNo

const onNodeDragStart = (event, node) => console.log('drag start', node);
const onNodeDragStop = (event, node) => console.log('drag stop', node);
const onPaneClick = (event) => console.log('pane click', event);
const onPaneScroll = (event) => console.log('pane scroll', event);
const onPaneContextMenu = (event) => console.log('pane context menu', event);
const onSelectionDrag = (event, nodes) => console.log('selection drag', nodes);
const onSelectionDragStart = (event, nodes) => console.log('selection drag start', nodes);
const onSelectionDragStop = (event, nodes) => console.log('selection drag stop', nodes);
Expand Down Expand Up @@ -125,6 +128,9 @@ const OverviewFlow = () => {
onElementClick={onElementClick}
onElementsRemove={onElementsRemove}
onConnect={onConnect}
onPaneClick={onPaneClick}
onPaneScroll={onPaneScroll}
onPaneContextMenu={onPaneContextMenu}
onNodeDragStart={onNodeDragStart}
onNodeDragStop={onNodeDragStop}
onSelectionDragStart={onSelectionDragStart}
Expand Down
2 changes: 1 addition & 1 deletion src/container/FlowRenderer/index.tsx
Expand Up @@ -103,7 +103,7 @@ const FlowRenderer = ({
onSelectionContextMenu={onSelectionContextMenu}
/>
)}
<div className="react-flow__zoompane" onClick={onClick} onContextMenu={onContextMenu} onWheel={onWheel} />
<div className="react-flow__pane" onClick={onClick} onContextMenu={onContextMenu} onWheel={onWheel} />
</div>
);
};
Expand Down
16 changes: 14 additions & 2 deletions src/hooks/useD3Zoom.ts
Expand Up @@ -107,7 +107,19 @@ export default ({
useEffect(() => {
if (d3Zoom) {
d3Zoom.filter((event: any) => {
console.log(event);
if (selectionKeyPressed) {
return false;
}

// only allow zoom on nodes
if (event.target.closest('.react-flow__node') && event.type !== 'wheel') {
return false;
}

// only allow zoom on user selection
if (event.target.closest('.react-flow__nodesselection') && event.type !== 'wheel') {
return false;
}

if (!paneMoveable) {
return false;
Expand All @@ -124,5 +136,5 @@ export default ({
return !event.ctrlKey && !event.button;
});
}
}, [d3Zoom, zoomOnScroll, zoomOnDoubleClick, paneMoveable]);
}, [d3Zoom, zoomOnScroll, zoomOnDoubleClick, paneMoveable, selectionKeyPressed]);
};
10 changes: 7 additions & 3 deletions src/style.css
Expand Up @@ -6,7 +6,7 @@
}

.react-flow__renderer,
.react-flow__zoompane,
.react-flow__pane,
.react-flow__selectionpane {
width: 100%;
height: 100%;
Expand All @@ -15,12 +15,16 @@
left: 0;
}

.react-flow__zoompane {
.react-flow__pane {
z-index: 1;
}

.react-flow__renderer {
z-index: 4;
}

.react-flow__selectionpane {
z-index: 2;
z-index: 5;
}

.react-flow__selection {
Expand Down

0 comments on commit 0373b53

Please sign in to comment.