Skip to content

Commit

Permalink
update(perfomance): Fix node perfomance
Browse files Browse the repository at this point in the history
  • Loading branch information
bcakmakoglu committed Aug 17, 2021
1 parent ec17f8a commit f6f7564
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 54 deletions.
56 changes: 29 additions & 27 deletions src/components/Nodes/Node.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { computed, defineComponent, h, inject, PropType, provide } from 'vue';
import { templateRef, tryOnMounted, useResizeObserver } from '@vueuse/core';
import { computed, defineComponent, h, inject, onMounted, PropType, provide } from 'vue';
import { templateRef, useResizeObserver } from '@vueuse/core';
import { DraggableCore, DraggableEventListener } from '@braks/revue-draggable';
import { Node, NodeDimensionUpdate, NodeType, RevueFlowStore } from '../../types';
import { RevueFlowHooks } from '../../hooks/RevueFlowHooks';
Expand Down Expand Up @@ -56,66 +56,66 @@ export default defineComponent({
() => props.node.connectable || (store.nodesConnectable && typeof props.node.connectable === 'undefined')
);

const node = computed(
() =>
({
id: props.node.id,
type: props.node.type,
position: { x: props.node.__rf.position.x, y: props.node.__rf.position.y },
data: props.node.data
} as Node)
);
const node = () =>
({
id: props.node.id,
type: props.node.type,
position: { x: props.node.__rf.position.x, y: props.node.__rf.position.y },
data: props.node.data
} as Node);

const onMouseEnterHandler = () => {
if (props.node.__rf.isDragging) {
return;
}

return (event: MouseEvent) => hooks.nodeMouseEnter.trigger({ event, node: node.value });
return (event: MouseEvent) => hooks.nodeMouseEnter.trigger({ event, node: node() });
};

const onMouseMoveHandler = () => {
if (props.node.__rf.isDragging) {
return;
}

return (event: MouseEvent) => hooks.nodeMouseMove.trigger({ event, node: node.value });
return (event: MouseEvent) => hooks.nodeMouseMove.trigger({ event, node: node() });
};

const onMouseLeaveHandler = () => {
if (props.node.__rf.isDragging) {
return;
}

return (event: MouseEvent) => hooks.nodeMouseLeave.trigger({ event, node: node.value });
return (event: MouseEvent) => hooks.nodeMouseLeave.trigger({ event, node: node() });
};

const onContextMenuHandler = () => {
return (event: MouseEvent) => hooks.nodeContextMenu.trigger({ event, node: node.value });
return (event: MouseEvent) => hooks.nodeContextMenu.trigger({ event, node: node() });
};

const onSelectNodeHandler = (event: MouseEvent) => {
if (!isDraggable.value) {
const n = node();
if (isSelectable.value) {
store.unsetNodesSelection();

if (!selected.value) {
store.addSelectedElements([node.value]);
store.addSelectedElements([n]);
}
}

hooks.nodeClick.trigger({ event, node: node.value });
hooks.nodeClick.trigger({ event, node: n });
}
};

const onDragStart: DraggableEventListener = ({ event }) => {
hooks.nodeDragStart.trigger({ event, node: node.value });
const n = node();
hooks.nodeDragStart.trigger({ event, node: n });

if (props.selectNodesOnDrag && isSelectable.value) {
store.unsetNodesSelection();

if (!selected.value) {
store.addSelectedElements([node.value]);
store.addSelectedElements([n]);
}
} else if (!props.selectNodesOnDrag && !selected.value && isSelectable.value) {
store.unsetNodesSelection();
Expand All @@ -124,9 +124,10 @@ export default defineComponent({
};

const onDrag: DraggableEventListener = ({ event, data }) => {
node.value.position.x += data.deltaX;
node.value.position.y += data.deltaY;
hooks.nodeDrag.trigger({ event, node: node.value });
const n = node();
n.position.x += data.deltaX;
n.position.y += data.deltaY;
hooks.nodeDrag.trigger({ event, node: n });

store?.updateNodePosDiff({
id: props.node.id as string,
Expand All @@ -139,24 +140,25 @@ export default defineComponent({
};

const onDragStop: DraggableEventListener = ({ event }) => {
const n = node();
// onDragStop also gets called when user just clicks on a node.
// Because of that we set dragging to true inside the onDrag handler and handle the click here
if (!props.node.__rf.isDragging) {
if (isSelectable.value && !props.selectNodesOnDrag && !selected.value) {
store.addSelectedElements([node.value]);
store.addSelectedElements([n]);
}

hooks.nodeClick.trigger({ event, node: node.value });
hooks.nodeClick.trigger({ event, node: n });

return;
}

store.updateNodePosDiff({
id: node.value.id || '',
id: n.id || '',
isDragging: false
});

hooks.nodeDragStop.trigger({ event, node: node.value });
hooks.nodeDragStop.trigger({ event, node: n });
};

useResizeObserver(nodeElement, (entries) => {
Expand All @@ -168,7 +170,7 @@ export default defineComponent({
store.updateNodeDimensions(updates);
});

tryOnMounted(() => {
onMounted(() => {
store.updateNodeDimensions([
{
id: props.node.id || '',
Expand Down
58 changes: 31 additions & 27 deletions src/container/NodeRenderer/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { computed, defineComponent, inject, PropType } from 'vue';
import { defineComponent, inject, PropType } from 'vue';
import Node from '../../components/Nodes/Node';
import { getNodesInside } from '../../utils/graph';
import { NodeType, RevueFlowStore } from '../../types';
Expand Down Expand Up @@ -44,7 +44,7 @@ export default defineComponent({
setup(props) {
const store = inject<RevueFlowStore>('store')!;

const visibleNodes = computed(() => {
const getNodes = () => {
return props.onlyRenderVisibleElements
? store.nodes &&
getNodesInside(
Expand All @@ -59,34 +59,38 @@ export default defineComponent({
true
)
: store.nodes;
});
};

const transformStyle = computed(() => ({
transform: `translate(${store.transform[0]}px,${store.transform[1]}px) scale(${store.transform[2]})`
}));
const visibleNodes = () =>
getNodes().map((node, i) => {
const nodeType = node.type || 'default';
if (props.nodeTypes) {
const type = props.nodeTypes[nodeType] || props.nodeTypes.default;
if (!props.nodeTypes[nodeType]) {
console.warn(`Node type "${nodeType}" not found. Using fallback type "default".`);
}

return () => (
<div class="revue-flow__nodes" style={transformStyle.value}>
{visibleNodes.value?.map((node) => {
const nodeType = node.type || 'default';
if (props.nodeTypes) {
const type = props.nodeTypes[nodeType] || props.nodeTypes.default;
if (!props.nodeTypes[nodeType]) {
console.warn(`Node type "${nodeType}" not found. Using fallback type "default".`);
}
return (
<Node
node={node}
snapGrid={props.snapGrid}
snapToGrid={props.snapToGrid}
selectNodesOnDrag={props.selectNodesOnDrag}
type={type}
key={node.id + i}
/>
);
}
});

return (
<Node
node={node}
snapGrid={props.snapGrid}
snapToGrid={props.snapToGrid}
selectNodesOnDrag={props.selectNodesOnDrag}
type={type}
key={node.id}
/>
);
}
})}
return () => (
<div
class="revue-flow__nodes"
style={{
transform: `translate(${store.transform[0]}px,${store.transform[1]}px) scale(${store.transform[2]})`
}}
>
{visibleNodes()}
</div>
);
}
Expand Down

0 comments on commit f6f7564

Please sign in to comment.