import clsx from "clsx"; import {IconType} from "react-icons"; import {MdSpaceDashboard} from "react-icons/md"; import {BsFileEarmarkText, BsClockHistory, BsPencil, BsGraphUp, BsChevronBarRight, BsChevronBarLeft, BsShieldFill, BsCloudFill} from "react-icons/bs"; import {RiLogoutBoxFill} from "react-icons/ri"; import {SlPencil} from "react-icons/sl"; import {FaAward} from "react-icons/fa"; import Link from "next/link"; import {useRouter} from "next/router"; import axios from "axios"; import FocusLayer from "@/components/FocusLayer"; import {preventNavigation} from "@/utils/navigation.disabled"; import {useState} from "react"; import usePreferencesStore from "@/stores/preferencesStore"; import {Type} from "@/interfaces/user"; interface Props { path: string; navDisabled?: boolean; focusMode?: boolean; onFocusLayerMouseEnter?: () => void; className?: string; userType?: Type; } interface NavProps { Icon: IconType; label: string; path: string; keyPath: string; disabled?: boolean; isMinimized?: boolean; } const Nav = ({Icon, label, path, keyPath, disabled = false, isMinimized = false}: NavProps) => ( {!isMinimized && {label}} ); export default function Sidebar({path, navDisabled = false, focusMode = false, userType, onFocusLayerMouseEnter, className}: Props) { const router = useRouter(); const [isMinimized, toggleMinimize] = usePreferencesStore((state) => [state.isSidebarMinimized, state.toggleSidebarMinimized]); const logout = async () => { axios.post("/api/logout").finally(() => { setTimeout(() => router.reload(), 500); }); }; const disableNavigation = preventNavigation(navDisabled, focusMode); return (
{isMinimized ? : } {!isMinimized && Minimize}
{} : logout} className={clsx( "p-4 rounded-full flex gap-4 items-center cursor-pointer text-black hover:text-mti-rose transition duration-300 ease-in-out", isMinimized ? "w-fit" : "w-full min-w-[250px] px-8", )}> {!isMinimized && Log Out}
{focusMode && }
); }