mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-17 20:51:55 +01:00
Fix nodeRefs dependency, since map is not a reliable dependency (#31)
This commit is contained in:
parent
4f878eb681
commit
45a9a95e38
@ -45,6 +45,7 @@ export const TileLayout = <T,>({ layoutTreeStateAtom, className, renderContent,
|
|||||||
|
|
||||||
const [layoutTreeState, dispatch] = useLayoutTreeStateReducerAtom(layoutTreeStateAtom);
|
const [layoutTreeState, dispatch] = useLayoutTreeStateReducerAtom(layoutTreeStateAtom);
|
||||||
const [nodeRefs, setNodeRefs] = useState<Map<string, RefObject<HTMLDivElement>>>(new Map());
|
const [nodeRefs, setNodeRefs] = useState<Map<string, RefObject<HTMLDivElement>>>(new Map());
|
||||||
|
const [nodeRefsGen, setNodeRefsGen] = useState<number>(0);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
console.log("layoutTreeState changed", layoutTreeState);
|
console.log("layoutTreeState changed", layoutTreeState);
|
||||||
@ -56,6 +57,7 @@ export const TileLayout = <T,>({ layoutTreeStateAtom, className, renderContent,
|
|||||||
prev.set(id, ref);
|
prev.set(id, ref);
|
||||||
return prev;
|
return prev;
|
||||||
});
|
});
|
||||||
|
setNodeRefsGen((prev) => prev + 1);
|
||||||
},
|
},
|
||||||
[setNodeRefs]
|
[setNodeRefs]
|
||||||
);
|
);
|
||||||
@ -67,6 +69,7 @@ export const TileLayout = <T,>({ layoutTreeStateAtom, className, renderContent,
|
|||||||
prev.delete(id);
|
prev.delete(id);
|
||||||
return prev;
|
return prev;
|
||||||
});
|
});
|
||||||
|
setNodeRefsGen((prev) => prev + 1);
|
||||||
} else {
|
} else {
|
||||||
console.log("deleteRef id not found", id);
|
console.log("deleteRef id not found", id);
|
||||||
}
|
}
|
||||||
@ -133,13 +136,13 @@ export const TileLayout = <T,>({ layoutTreeStateAtom, className, renderContent,
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}, 30),
|
}, 30),
|
||||||
[activeDrag, overlayContainerRef, displayContainerRef, layoutTreeState.leafs, nodeRefs]
|
[activeDrag, overlayContainerRef, displayContainerRef, layoutTreeState.leafs, nodeRefsGen]
|
||||||
);
|
);
|
||||||
|
|
||||||
// Update the transforms whenever we drag something and whenever the layout updates.
|
// Update the transforms whenever we drag something and whenever the layout updates.
|
||||||
useLayoutEffect(() => {
|
useLayoutEffect(() => {
|
||||||
updateTransforms();
|
updateTransforms();
|
||||||
}, [activeDrag, layoutTreeState, updateTransforms]);
|
}, [updateTransforms]);
|
||||||
|
|
||||||
useResizeObserver(overlayContainerRef, () => updateTransforms());
|
useResizeObserver(overlayContainerRef, () => updateTransforms());
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user