fix(timeline): stabilize overlay lifecycle
This commit is contained in:
@@ -355,6 +355,7 @@ function TimelineViewContent({
|
||||
anchorEl: HTMLElement;
|
||||
} | null>(null);
|
||||
const resourceHoverTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);
|
||||
const previousViewModeRef = useRef(viewMode);
|
||||
|
||||
const invalidateTimelineInner = useInvalidateTimeline();
|
||||
const batchDeleteMutation = trpc.allocation.batchDelete.useMutation({
|
||||
@@ -386,6 +387,26 @@ function TimelineViewContent({
|
||||
setResourceHover(null);
|
||||
}, [hasActivePointerOverlay]);
|
||||
|
||||
useEffect(() => {
|
||||
if (previousViewModeRef.current === viewMode) {
|
||||
return;
|
||||
}
|
||||
|
||||
previousViewModeRef.current = viewMode;
|
||||
setPopover(null);
|
||||
setDemandPopover(null);
|
||||
setNewAllocPopover(null);
|
||||
setResourceHover(null);
|
||||
}, [viewMode, setNewAllocPopover]);
|
||||
|
||||
useEffect(() => {
|
||||
if (!isInitialLoading) return;
|
||||
setPopover(null);
|
||||
setDemandPopover(null);
|
||||
setNewAllocPopover(null);
|
||||
setResourceHover(null);
|
||||
}, [isInitialLoading, setNewAllocPopover]);
|
||||
|
||||
// ─── Keep selection overlay visible while popover is open ───────────────────
|
||||
const effectiveRangeState: typeof rangeState = rangeState.isSelecting
|
||||
? rangeState
|
||||
|
||||
Reference in New Issue
Block a user