Skip to content

Commit

Permalink
refactor(hooks): create used3zoom hook
Browse files Browse the repository at this point in the history
  • Loading branch information
moklick committed Aug 19, 2019
1 parent 0bb555b commit aac214a
Show file tree
Hide file tree
Showing 10 changed files with 46,144 additions and 46,135 deletions.
72,611 changes: 36,307 additions & 36,304 deletions dist/ReactGraph.js

Large diffs are not rendered by default.

8 changes: 0 additions & 8 deletions example/SimpleGraph.js
Original file line number Diff line number Diff line change
Expand Up @@ -97,13 +97,6 @@ class App extends PureComponent {
});
}

onChange(elements) {
if (!this.graphInstance) {
return false;
}
// console.log('graph changed', elements);
}

onFitView() {
this.graphInstance.fitView();
}
Expand Down Expand Up @@ -155,7 +148,6 @@ class App extends PureComponent {
onNodeDragStop={onNodeDragStop}
style={{ width: '100%', height: '100%' }}
onLoad={graphInstance => this.onLoad(graphInstance)}
onChange={(elements) => this.onChange(elements)}
nodeTypes={{
special: SpecialNode,
text: InputNode
Expand Down
19,546 changes: 9,779 additions & 9,767 deletions example/build/example.e31bb0bc.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion example/build/example.e31bb0bc.js.map

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion example/build/index.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion src/GlobalKeyHandler/index.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { useEffect, useContext, memo } from 'react';

import { useKeyPress } from '../hooks';
import useKeyPress from '../hooks/useKeyPress';
import { setNodesSelection } from '../state/actions';
import { GraphContext } from '../GraphContext';
import { isEdge, getConnectedEdges } from '../graph-utils';
Expand Down
50 changes: 4 additions & 46 deletions src/GraphView/index.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
import React, { useEffect, useContext, useRef, memo } from 'react';
import * as d3Zoom from 'd3-zoom';
import { select, event } from 'd3-selection';
import ReactSizeMe from 'react-sizeme';

import { Provider } from '../ConnectionContext';
Expand All @@ -10,49 +8,16 @@ import EdgeRenderer from '../EdgeRenderer';
import UserSelection from '../UserSelection';
import NodesSelection from '../NodesSelection';
import { setNodesSelection } from '../state/actions';
import {
updateTransform, updateSize, initD3, fitView,
zoomIn, zoomOut
} from '../state/view-actions';
import { useKeyPress } from '../hooks';

const d3ZoomInstance = d3Zoom.zoom().scaleExtent([0.5, 2]);
import { updateSize, fitView, zoomIn, zoomOut } from '../state/view-actions';
import useKeyPress from '../hooks/useKeyPress';
import useD3Zoom from '../hooks/useD3Zoom';

const GraphView = memo((props) => {
const zoomPane = useRef(null);
const { state, dispatch } = useContext(GraphContext);
const shiftPressed = useKeyPress('Shift');

useEffect(() => {
const selection = select(zoomPane.current).call(d3ZoomInstance);
dispatch(initD3({ zoom: d3ZoomInstance, selection }));
}, []);

useEffect(() => {
if (shiftPressed) {
d3ZoomInstance.on('zoom', null);
} else {
d3ZoomInstance.on('zoom', () => {
if (event.sourceEvent && event.sourceEvent.target !== zoomPane.current) {
return false;
}

dispatch(updateTransform(event.transform));

props.onMove();
});

if (state.d3Selection) {
// we need to restore the graph transform otherwise d3 zoom transform and graph transform are not synced
const graphTransform = d3Zoom.zoomIdentity
.translate(state.transform[0], state.transform[1])
.scale(state.transform[2]);

state.d3Selection.call(state.d3Zoom.transform, graphTransform);
}
}

}, [shiftPressed]);
useD3Zoom(zoomPane, props.onMove, shiftPressed);

useEffect(
() => dispatch(updateSize(props.size)),
Expand All @@ -71,13 +36,6 @@ const GraphView = memo((props) => {
}
}, [state.d3Initialised]);

useEffect(() => {
props.onChange({
nodes: state.nodes,
edges: state.edges,
});
});

return (
<div className="react-graph__renderer">
<Provider onConnect={props.onConnect}>
Expand Down
8 changes: 3 additions & 5 deletions src/ReactGraph/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { useMemo } from 'react';
import React, { useMemo, memo } from 'react';

if (process.env.NODE_ENV !== 'production') {
const whyDidYouRender = require('@welldone-software/why-did-you-render');
Expand Down Expand Up @@ -26,8 +26,8 @@ const ReactGraph = (props) => {
const edgeTypes = useMemo(() => createEdgeTypes(props.edgeTypes), []);

const {
style, onElementClick, elements, children, onLoad,
onMove, onChange, onElementsRemove, onConnect,
style, onElementClick, elements, children,
onLoad, onMove, onElementsRemove, onConnect,
onNodeDragStop, connectionLineType, connectionLineStyle
} = props;

Expand All @@ -37,7 +37,6 @@ const ReactGraph = (props) => {
<GraphView
onLoad={onLoad}
onMove={onMove}
onChange={onChange}
onElementClick={onElementClick}
onNodeDragStop={onNodeDragStop}
nodeTypes={nodeTypes}
Expand All @@ -64,7 +63,6 @@ ReactGraph.defaultProps = {
onConnect: () => {},
onLoad: () => {},
onMove: () => {},
onChange: () => {},
nodeTypes: {
input: InputNode,
default: DefaultNode,
Expand Down
46 changes: 46 additions & 0 deletions src/hooks/useD3Zoom.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import { useEffect, useContext } from 'react';
import * as d3Zoom from 'd3-zoom';
import { select, event } from 'd3-selection';

import { updateTransform, initD3 } from '../state/view-actions';
import { GraphContext } from '../GraphContext';

const d3ZoomInstance = d3Zoom.zoom().scaleExtent([0.5, 2]);

export default function useD3Zoom(zoomPane, onMove, shiftPressed) {
const { state, dispatch } = useContext(GraphContext);

useEffect(() => {
const selection = select(zoomPane.current).call(d3ZoomInstance);
dispatch(initD3({ zoom: d3ZoomInstance, selection }));
}, []);

useEffect(() => {
if (shiftPressed) {
d3ZoomInstance.on('zoom', null);
} else {
d3ZoomInstance.on('zoom', () => {
if (event.sourceEvent && event.sourceEvent.target !== zoomPane.current) {
return false;
}

dispatch(updateTransform(event.transform));

onMove();
});

if (state.d3Selection) {
// we need to restore the graph transform otherwise d3 zoom transform and graph transform are not synced
const graphTransform = d3Zoom.zoomIdentity
.translate(state.transform[0], state.transform[1])
.scale(state.transform[2]);

state.d3Selection.call(state.d3Zoom.transform, graphTransform);
}
}

return () => {
d3ZoomInstance.on('zoom', null);
};
}, [shiftPressed]);
}
4 changes: 2 additions & 2 deletions src/hooks.js → src/hooks/useKeyPress.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useState, useEffect } from 'react';

const isInput = target => ['INPUT', 'SELECT', 'TEXTAREA'].includes(target.nodeName);

export function useKeyPress(targetKey) {
export default function useKeyPress(targetKey) {
const [keyPressed, setKeyPressed] = useState(false);

function downHandler({ key, target }) {
Expand All @@ -27,4 +27,4 @@ export function useKeyPress(targetKey) {
}, []);

return keyPressed;
}
}

0 comments on commit aac214a

Please sign in to comment.