Files
soul-yongping/components/bottom-nav.tsx
v0 6afb9a143a refactor: redesign homepage and navigation based on trends
Update homepage layout and navigation to match current trends.

#VERCEL_SKIP

Co-authored-by: null <4804959+fnvtk@users.noreply.github.com>
2026-01-14 07:32:08 +00:00

81 lines
2.8 KiB
TypeScript

"use client"
import Link from "next/link"
import { usePathname } from "next/navigation"
import { Home, List, Sparkles, User } from "lucide-react"
export function BottomNav() {
const pathname = usePathname()
// 在文档页面、管理后台、阅读页面和关于页面不显示底部导航
if (
pathname.startsWith("/documentation") ||
pathname.startsWith("/admin") ||
pathname.startsWith("/read") ||
pathname.startsWith("/about")
) {
return null
}
const navItems = [
{ href: "/", icon: Home, label: "首页" },
{ href: "/chapters", icon: List, label: "目录" },
{ href: "/match", icon: Sparkles, label: "匹配", isCenter: true },
{ href: "/my", icon: User, label: "我的" },
]
return (
<>
<nav className="fixed bottom-0 left-0 right-0 z-40 bg-[#1c1c1e]/95 backdrop-blur-xl border-t border-white/5 safe-bottom">
<div className="flex items-center justify-around py-2 max-w-lg mx-auto">
{navItems.map((item, index) => {
const isActive = pathname === item.href
const Icon = item.icon
// 中间的匹配按钮特殊处理
if (item.isCenter) {
return (
<Link key={index} href={item.href} className="flex flex-col items-center py-2 px-6 -mt-4">
<div
className={`w-14 h-14 rounded-full flex items-center justify-center shadow-lg transition-all ${
isActive
? "bg-gradient-to-br from-[#00CED1] to-[#20B2AA] shadow-[#00CED1]/30"
: "bg-gradient-to-br from-[#00CED1] to-[#20B2AA] shadow-[#00CED1]/30"
}`}
>
<Icon className="w-6 h-6 text-white" />
</div>
<span className={`text-xs mt-1 ${isActive ? "text-[#00CED1] font-medium" : "text-gray-500"}`}>
{item.label}
</span>
</Link>
)
}
return (
<Link
key={index}
href={item.href}
className="flex flex-col items-center py-2 px-4 touch-feedback transition-all duration-200"
>
<div
className={`w-6 h-6 flex items-center justify-center mb-1 transition-colors ${
isActive ? "text-[#00CED1]" : "text-gray-500"
}`}
>
<Icon className="w-5 h-5" strokeWidth={isActive ? 2 : 1.5} />
</div>
<span
className={`text-xs transition-colors ${isActive ? "text-[#00CED1] font-medium" : "text-gray-500"}`}
>
{item.label}
</span>
</Link>
)
})}
</div>
</nav>
</>
)
}