import clsx from "clsx"; import {IconType} from "react-icons"; import {MdSpaceDashboard} from "react-icons/md"; import { BsFileEarmarkText, BsClockHistory, BsPencil, BsGraphUp, BsChevronBarRight, BsChevronBarLeft, BsShieldFill, BsCloudFill, BsCurrencyDollar, BsClipboardData, } 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 {useEffect, useState} from "react"; import usePreferencesStore from "@/stores/preferencesStore"; import {Type} from "@/interfaces/user"; import useTicketsListener from "@/hooks/useTicketsListener"; interface Props { path: string; navDisabled?: boolean; focusMode?: boolean; onFocusLayerMouseEnter?: () => void; className?: string; userType?: Type; userId?: string; } interface NavProps { Icon: IconType; label: string; path: string; keyPath: string; disabled?: boolean; isMinimized?: boolean; badge?: number; } const Nav = ({Icon, label, path, keyPath, disabled = false, isMinimized = false, badge}: NavProps) => { return ( {!isMinimized && {label}} {!!badge && badge > 0 && (
{badge}
)} ); }; export default function Sidebar({path, navDisabled = false, focusMode = false, userType, onFocusLayerMouseEnter, className, userId}: Props) { const router = useRouter(); const [isMinimized, toggleMinimize] = usePreferencesStore((state) => [state.isSidebarMinimized, state.toggleSidebarMinimized]); const {totalAssignedTickets} = useTicketsListener(userId); useEffect(() => console.log(totalAssignedTickets), [totalAssignedTickets]); const logout = async () => { axios.post("/api/logout").finally(() => { setTimeout(() => router.reload(), 500); }); }; const disableNavigation = preventNavigation(navDisabled, focusMode); return (
{isMinimized ? : } {!isMinimized && Minimize}
{} : logout} className={clsx( "hover:text-mti-rose flex cursor-pointer items-center gap-4 rounded-full p-4 text-black transition duration-300 ease-in-out", isMinimized ? "w-fit" : "w-full min-w-[250px] px-8", )}> {!isMinimized && Log Out}
{focusMode && }
); }