Files
acad-ia-2/src/components/Header.tsx

77 lines
2.6 KiB
TypeScript

import { Link } from '@tanstack/react-router'
import { Home, Menu, Network, X } from 'lucide-react'
import { useState } from 'react'
export default function Header() {
const [isOpen, setIsOpen] = useState(false)
return (
<>
{/* Cambiar el color de fondo por bg-background/40 y agregar backdrop-blur para efecto glassmorphism */}
<header className="sticky top-0 z-50 flex w-full items-center bg-gray-800 p-4 text-white shadow-lg">
<button
onClick={() => setIsOpen(true)}
className="rounded-lg p-2 transition-colors hover:bg-gray-700"
aria-label="Open menu"
>
<Menu size={24} />
</button>
<h1 className="ml-4 text-xl font-semibold">
<Link to="/">
<img src="/lasalle-logo.svg" alt="La Salle Logo" className="h-10" />
</Link>
</h1>
</header>
<aside
className={`fixed top-0 left-0 z-50 flex h-full w-80 transform flex-col bg-gray-900 text-white shadow-2xl transition-transform duration-300 ease-in-out ${
isOpen ? 'translate-x-0' : '-translate-x-full'
}`}
>
<div className="flex items-center justify-between border-b border-gray-700 p-4">
<h2 className="text-xl font-bold">Navigation</h2>
<button
onClick={() => setIsOpen(false)}
className="rounded-lg p-2 transition-colors hover:bg-gray-800"
aria-label="Close menu"
>
<X size={24} />
</button>
</div>
<nav className="flex-1 overflow-y-auto p-4">
<Link
to="/"
onClick={() => setIsOpen(false)}
className="mb-2 flex items-center gap-3 rounded-lg p-3 transition-colors hover:bg-gray-800"
activeProps={{
className:
'flex items-center gap-3 p-3 rounded-lg bg-cyan-600 hover:bg-cyan-700 transition-colors mb-2',
}}
>
<Home size={20} />
<span className="font-medium">Home</span>
</Link>
{/* Demo Links Start */}
<Link
to="/demo/tanstack-query"
onClick={() => setIsOpen(false)}
className="mb-2 flex items-center gap-3 rounded-lg p-3 transition-colors hover:bg-gray-800"
activeProps={{
className:
'flex items-center gap-3 p-3 rounded-lg bg-cyan-600 hover:bg-cyan-700 transition-colors mb-2',
}}
>
<Network size={20} />
<span className="font-medium">TanStack Query</span>
</Link>
{/* Demo Links End */}
</nav>
</aside>
</>
)
}