feat: 优化项目目录结构

This commit is contained in:
2025-12-12 17:25:26 +08:00
parent ae627d0496
commit b89f83291e
235 changed files with 0 additions and 0 deletions

View File

@@ -0,0 +1,109 @@
'use client';
import { cn } from "@/lib/utils";
import Link from "next/link";
import { usePathname, useRouter } from "next/navigation";
import { useState } from "react";
import {
Drawer,
DrawerContent,
DrawerDescription,
DrawerHeader,
DrawerTitle,
DrawerTrigger,
} from "@/components/ui/drawer"
import { Button } from "@/components/ui/button";
import { X } from "lucide-react";
export default function Header() {
const router = useRouter();
const pathname = usePathname();
const [showMenu, setShowMenu] = useState(false);
const menuItems = [
{ name: '特恩(TONE)', path: '/' },
{ name: '资源', path: '/resource' },
{ name: '博客', path: '/blog' },
{ name: '控制台', path: '/console' },
];
const handleClick = (e: React.MouseEvent<HTMLAnchorElement>, path: string) => {
e.preventDefault();
if (path === '/console') {
const token = typeof window !== 'undefined' ? localStorage.getItem('token') : null;
router.push(token ? '/console' : '/console/login');
} else {
router.push(path);
}
setShowMenu(false);
}
return (
<header className="sticky top-0 z-50 backdrop-blur-sm bg-white/40 shadow">
<div className="flex items-center justify-between px-10 md:h-18 md:px-20 h-14 duration-300">
<Link
href="/"
className={cn(
"cursor-pointer font-medium text-zinc-500 hover:text-zinc-800 border-b-4 border-transparent duration-200",
pathname === "/" && "text-zinc-800"
)}
>
{pathname === "/"
? <div className="text-2xl"> 🍭</div>
: <div className="md:text-lg">(TONE)</div>}
</Link>
<Drawer direction="right" open={showMenu} onOpenChange={(state) => !state && setShowMenu(false)}>
<DrawerTrigger>
<div className="sm:hidden cursor-pointer text-zinc-600" onClick={() => setShowMenu(true)}>
</div>
</DrawerTrigger>
<DrawerContent>
<DrawerHeader>
<DrawerTitle className="flex justify-between">
<span></span>
<X className="cursor-pointer" onClick={() => setShowMenu(false)} />
</DrawerTitle>
<DrawerDescription></DrawerDescription>
</DrawerHeader>
<div className="w-full flex flex-col px-4 gap-2">
{menuItems.slice(1).map((item) => (
<Link
key={item.name}
href={item.path}
onClick={e => handleClick(e, item.path)}
>
<Button className="w-full" size='lg'
variant={pathname.startsWith(item.path) ? 'default' : 'outline'}
>{item.name}</Button>
</Link>
))}
</div>
</DrawerContent>
</Drawer>
<div className={cn(
"sm:flex items-center gap-12 hidden",
)}>
{menuItems.slice(1).map((item) => (
<Link
key={item.name}
href={item.path}
className={cn(
"cursor-pointer md:text-lg font-medium text-zinc-500 hover:text-zinc-800 border-b-4 border-transparent duration-200",
pathname.startsWith(item.path) && "text-zinc-800 border-b-pink-500"
)}
onClick={e => handleClick(e, item.path)}
>
{item.name}
</Link>
))}
</div>
</div>
</header >
)
}