1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
| "use client"
import React, { useState } from 'react' import { usePathname,useRouter } from 'next/navigation'; import { useMedia } from 'react-use'; import { Menu } from 'lucide-react';
import NavButton from './nav-buttion'; import { Button } from './ui/button';
import { Sheet, SheetContent, SheetTrigger, } from "@/components/ui/sheet"
const routes = [ { href: '/', label: 'Overview', }, { href: '/transactions', label: 'Transactions', }, { href: '/accounts', label: 'Accounts', }, { href: '/categories', label: 'Categories', }, { href: '/settings', label: 'Settings', }, ]
export default function Navigation() { const [isOpen, setIsOpen] = useState(false);
const pathName = usePathname(); const router = useRouter(); const isMobile = useMedia("(max-width:1024px)",false);
const onClick = (href: string) => { router.push(href); setIsOpen(false); };
if (isMobile){ return ( <Sheet open={isOpen} onOpenChange={setIsOpen}> <SheetTrigger> <Button variant="outline" size="sm" className='font-normal bg-white/10 hover:bg-white/20 hover:text-white border-none focus-visible:ring-offset-0 focus-visible:ring-transparent outline-none-none text-white focus:bg-white/30 transition' > <Menu className='size-4' /> </Button> </SheetTrigger> <SheetContent side='left' className='px-2'> <nav className='flex flex-col gap-y-2 pt-6'> {routes.map((route)=>( <Button key={route.href} variant={route.href === pathName ? "secondary" : "ghost"} onClick={()=> onClick(route.href)} className='w-full justify-start' > {route.label} </Button> ))} </nav> </SheetContent> </Sheet> ) }
return ( <nav className='hidden lg:flex items-center gap-x-2 overflow-x-auto'> { routes.map((route)=>( <NavButton key= {route.href} href={route.href} label={route.label} isActive={pathName === route.href} /> ))} </nav> ) }
|