From 8e9c095e6f8daebfeb8911fb3d0b2d842d9d09d7 Mon Sep 17 00:00:00 2001 From: Evangelos Skopelitis Date: Fri, 20 Dec 2024 16:12:10 -0500 Subject: [PATCH] frontend: Sidebar: Resize sidebar when overflowing Signed-off-by: Evangelos Skopelitis --- frontend/src/components/Sidebar/Sidebar.tsx | 32 +++++++++++++------ ...idebar.HomeSidebarClosed.stories.storyshot | 2 +- ...r.InClusterSidebarClosed.stories.storyshot | 2 +- 3 files changed, 24 insertions(+), 12 deletions(-) diff --git a/frontend/src/components/Sidebar/Sidebar.tsx b/frontend/src/components/Sidebar/Sidebar.tsx index 532721eb2e..ec9e2bb0f0 100644 --- a/frontend/src/components/Sidebar/Sidebar.tsx +++ b/frontend/src/components/Sidebar/Sidebar.tsx @@ -248,6 +248,9 @@ export const PureSidebar = memo( linkArea, }: PureSidebarProps) => { const { t } = useTranslation(); + const listContainerRef = React.useRef(null); + const [isOverflowing, setIsOverflowing] = React.useState(false); + const adjustedDrawerWidthClosed = isOverflowing ? 84 : 72; const temporarySideBarOpen = open === true && isTemporaryDrawer && openUserSelected === true; // The large sidebar does not open in medium view (600-960px). @@ -276,6 +279,7 @@ export const PureSidebar = memo( })} /> { + const el = listContainerRef.current; + if (!el) { + return; + } + + const observer = new ResizeObserver(() => { + setIsOverflowing(el.scrollHeight > el.clientHeight); + }); + + observer.observe(el); + + setIsOverflowing(el.scrollHeight > el.clientHeight); + + return () => observer.disconnect(); + }, [items]); + return (