From b3720b3719808b3465dbdc6914b4d606d65aace7 Mon Sep 17 00:00:00 2001 From: Ritik Ranjan Date: Mon, 16 Dec 2024 07:59:11 +0530 Subject: [PATCH] feature/auto-hide-tab-bar refactored code and updated doc --- docs/docs/config.mdx | 2 +- frontend/app/tab/tabbar.tsx | 10 ++++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/docs/docs/config.mdx b/docs/docs/config.mdx index b5cebb016..0b761ccfb 100644 --- a/docs/docs/config.mdx +++ b/docs/docs/config.mdx @@ -68,7 +68,7 @@ wsh editconfig | window:magnifiedblockblursecondarypx | int | change the blur in CSS pixels that is applied to the visible portions of non-magnified blocks when a block is magnified (see [backdrop-filter](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter) for more info on how this gets applied) | | window:maxtabcachesize | int | number of tabs to cache. when tabs are cached, switching between them is very fast. (defaults to 10) | | window:showmenubar | bool | set to use the OS-native menu bar (Windows and Linux only, requires app restart) | -| window:autohidetabsbar | bool | auto hide tab bar based on true or false +| window:autohidetabsbar | bool | auto hide tab bar based on true or false (requires restart) | window:nativetitlebar | bool | set to use the OS-native title bar, rather than the overlay (Windows and Linux only, requires app restart) | | window:disablehardwareacceleration | bool | set to disable Chromium hardware acceleration to resolve graphical bugs (requires app restart) | | telemetry:enabled | bool | set to enable/disable telemetry | diff --git a/frontend/app/tab/tabbar.tsx b/frontend/app/tab/tabbar.tsx index cc2be80ac..efe662e86 100644 --- a/frontend/app/tab/tabbar.tsx +++ b/frontend/app/tab/tabbar.tsx @@ -174,7 +174,7 @@ const TabBar = memo(({ workspace }: TabBarProps) => { const isFullScreen = useAtomValue(atoms.isFullScreen); const settings = useAtomValue(atoms.settingsAtom); - const autoHideTabsBar = useRef(settings["window:autohidetabsbar"]); + const autoHideTabsBar = settings?.["window:autohidetabsbar"] ?? false; let prevDelta: number; let prevDragDirection: string; @@ -185,13 +185,15 @@ const TabBar = memo(({ workspace }: TabBarProps) => { const tabBarHeight = tabBar.clientHeight + 1; if (currentY < 10) tabBar.style.top = '0px'; - if (autoHideTabsBar.current && currentY > tabBarHeight) tabBar.style.top = `-${tabBarHeight}px`; + if (autoHideTabsBar && currentY > tabBarHeight) tabBar.style.top = `-${tabBarHeight}px`; }; useEffect(() => { + if (!autoHideTabsBar) return; + document.addEventListener("mousemove", handleAutoHideTabsBar); return () => document.removeEventListener("mousemove", handleAutoHideTabsBar); - }, []) + }, [autoHideTabsBar]) // Update refs when tabIds change useEffect(() => { @@ -669,7 +671,7 @@ const TabBar = memo(({ workspace }: TabBarProps) => { title: "Add Tab", }; return ( -
+
{appMenuButton} {devLabel}