From 30ddab2b003358546c0723b30ac7a578eb9f1efc Mon Sep 17 00:00:00 2001 From: dukenv0307 Date: Thu, 28 Mar 2024 10:27:05 +0700 Subject: [PATCH 1/2] Only switch position if it is possible --- src/libs/PopoverWithMeasuredContentUtils.ts | 7 +++++-- .../report/ContextMenu/PopoverReportActionContextMenu.tsx | 4 +++- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/libs/PopoverWithMeasuredContentUtils.ts b/src/libs/PopoverWithMeasuredContentUtils.ts index 1f42d741bdbd..8004e8a7f0a5 100644 --- a/src/libs/PopoverWithMeasuredContentUtils.ts +++ b/src/libs/PopoverWithMeasuredContentUtils.ts @@ -37,15 +37,18 @@ function computeHorizontalShift(anchorLeftEdge: number, menuWidth: number, windo */ function computeVerticalShift(anchorTopEdge: number, menuHeight: number, windowHeight: number, anchorHeight: number, shoudSwitchPositionIfOverflow = false): number { const popoverBottomEdge = anchorTopEdge + menuHeight; + let canSwitchPosition = false; if (anchorTopEdge < 0) { // Anchor is in top window Edge, shift bottom by a multiple of four. - return roundToNearestMultipleOfFour(shoudSwitchPositionIfOverflow ? menuHeight + anchorHeight : 0 - anchorTopEdge); + canSwitchPosition = popoverBottomEdge + menuHeight + anchorHeight <= windowHeight; + return roundToNearestMultipleOfFour(shoudSwitchPositionIfOverflow && canSwitchPosition ? menuHeight + anchorHeight : 0 - anchorTopEdge); } if (popoverBottomEdge > windowHeight) { // Anchor is in Bottom window Edge, shift top by a multiple of four. - return roundToNearestMultipleOfFour(shoudSwitchPositionIfOverflow ? -(menuHeight + anchorHeight) : windowHeight - popoverBottomEdge); + canSwitchPosition = popoverBottomEdge - menuHeight - anchorHeight >= 0; + return roundToNearestMultipleOfFour(shoudSwitchPositionIfOverflow && canSwitchPosition ? -(menuHeight + anchorHeight) : windowHeight - popoverBottomEdge); } // Anchor is not in the gutter, so no need to shift it vertically diff --git a/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.tsx b/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.tsx index fcd291e55882..6cb688ff2558 100644 --- a/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.tsx +++ b/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.tsx @@ -62,6 +62,7 @@ function PopoverReportActionContextMenu(_props: unknown, ref: ForwardedRef([]); + const [shoudSwitchPositionIfOverflow, setShoudSwitchPositionIfOverflow] = useState(false); const contentRef = useRef(null); const anchorRef = useRef(null); @@ -218,6 +219,7 @@ function PopoverReportActionContextMenu(_props: unknown, ref: ForwardedRef Date: Thu, 28 Mar 2024 10:33:37 +0700 Subject: [PATCH 2/2] update correct check --- src/libs/PopoverWithMeasuredContentUtils.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libs/PopoverWithMeasuredContentUtils.ts b/src/libs/PopoverWithMeasuredContentUtils.ts index 8004e8a7f0a5..0bef469744dc 100644 --- a/src/libs/PopoverWithMeasuredContentUtils.ts +++ b/src/libs/PopoverWithMeasuredContentUtils.ts @@ -47,7 +47,7 @@ function computeVerticalShift(anchorTopEdge: number, menuHeight: number, windowH if (popoverBottomEdge > windowHeight) { // Anchor is in Bottom window Edge, shift top by a multiple of four. - canSwitchPosition = popoverBottomEdge - menuHeight - anchorHeight >= 0; + canSwitchPosition = anchorTopEdge - menuHeight - anchorHeight >= 0; return roundToNearestMultipleOfFour(shoudSwitchPositionIfOverflow && canSwitchPosition ? -(menuHeight + anchorHeight) : windowHeight - popoverBottomEdge); }