From 1a3bc63d2e15776cd4ed7e2d42c92b822ca0ced9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi?= Date: Tue, 7 Jan 2025 17:18:20 +0100 Subject: [PATCH] feat: integrate sidebar state management with user store; replace local open state with sidebarIsOpen from useUserStore --- src/app/components/Sidebar/index.tsx | 38 ++++++++++++++++++---------- src/app/stores/userStore.ts | 6 +++++ 2 files changed, 30 insertions(+), 14 deletions(-) diff --git a/src/app/components/Sidebar/index.tsx b/src/app/components/Sidebar/index.tsx index 76e6577..ed3952a 100644 --- a/src/app/components/Sidebar/index.tsx +++ b/src/app/components/Sidebar/index.tsx @@ -7,6 +7,7 @@ import { } from "react-icons/bs"; import { ThemeSwitcher } from "../ThemeSwitcher/ThemeSwitcher"; import { SidebarItem } from "./item"; +import { useUserStore } from "@/app/stores/userStore"; export const Sidebar = ({ items, @@ -21,11 +22,12 @@ export const Sidebar = ({ const pathName = usePathname(); // State to manage menu openness - const [open, setOpen] = useState(true); + const { setSidebarIsOpen, sidebarIsOpen } = useUserStore(); const [isMobile, setIsMobile] = useState(false); useEffect(() => { const handleResize = () => { + if (sidebarIsOpen) return; if (window.innerWidth <= 1024 && !isMobile) { setIsMobile(true); } else if (window.innerWidth > 1024 && isMobile) { @@ -33,6 +35,8 @@ export const Sidebar = ({ } }; + console.log("sidebarIsOpen", sidebarIsOpen); + handleResize(); window.addEventListener("resize", handleResize); return () => window.removeEventListener("resize", handleResize); @@ -40,25 +44,25 @@ export const Sidebar = ({ useEffect(() => { if (isMobile) { - setOpen(false); + setSidebarIsOpen(false); } + // eslint-disable-next-line react-hooks/exhaustive-deps }, [isMobile]); return (