"use client" import type React from "react" import { useState } from "react" import { ExternalLink, Globe, Server, Mail, Zap, Shield, Code, FileText, Search } from "lucide-react" interface Site { domain: string name: string server: string cdn: string url: string } interface Category { title: string icon: React.ReactNode sites: Site[] } const categories: Category[] = [ { title: "博客与主页", icon: , sites: [ { domain: "zhuzihan.com", name: "个人博客", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://zhuzihan.com", }, { domain: "blog.zhuzihan.com", name: "个人博客备份", server: "阿里云Pages", cdn: "ESA加速", url: "https://blog.zhuzihan.com", }, { domain: "www.zhuzihan.com", name: "个人主页", server: "阿里云", cdn: "无加速", url: "https://www.zhuzihan.com", }, { domain: "home.zhuzihan.com", name: "导航页", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://home.zhuzihan.com", }, ], }, { title: "AI 与 API 服务", icon: , sites: [ { domain: "ai.zhuzihan.com", name: "OpenWebUI", server: "狐蒂云-日本", cdn: "EdgeOne加速", url: "https://ai.zhuzihan.com", }, { domain: "api.zhuzihan.com", name: "New-API", server: "DigitalOcean", cdn: "无加速", url: "https://api.zhuzihan.com", }, { domain: "load.zhuzihan.com", name: "GPT-Load", server: "狐蒂云-日本", cdn: "EdgeOne加速", url: "https://load.zhuzihan.com", }, { domain: "api-proxy.zhuzihan.com", name: "AI API转发", server: "狐蒂云-美国", cdn: "ESA API加速", url: "https://api-proxy.zhuzihan.com", }, { domain: "ai-proxy.zhuzihan.com", name: "AI API转发", server: "狐蒂云-美国", cdn: "ESA API加速", url: "https://ai-proxy.zhuzihan.com", }, { domain: "cpa.zhuzihan.com/management.html", name: "codex/Gemini cli反代", server: "狐蒂云-美国", cdn: "无加速", url: "https://cpa.zhuzihan.com/management.html", }, { domain: "crs.zhuzihan.com", name: "Claude轮训", server: "Azure", cdn: "无加速", url: "https://crs.zhuzihan.com", }, { domain: "api-test.zhuzihan.com", name: "API批量测试", server: "GitHub Pages", cdn: "EdgeOne加速", url: "https://api-test.zhuzihan.com", }, { domain: "health.zhuzihan.com/status/ai", name: "AI服务状态查询", server: "青竹云", cdn: "ESA加速", url: "https://health.zhuzihan.com/status/ai", }, ], }, { title: "云服务管理后台", icon: , sites: [ { domain: "admin.zhuzihan.com", name: "DigitalOcean管理后台", server: "DigitalOcean", cdn: "无加速", url: "https://admin.zhuzihan.com", }, { domain: "azure.zhuzihan.com", name: "Azure管理后台", server: "Azure", cdn: "无加速", url: "https://azure.zhuzihan.com", }, { domain: "huawei.zhuzihan.com", name: "华为云管理后台", server: "华为云", cdn: "无加速", url: "https://huawei.zhuzihan.com", }, { domain: "ali.zhuzihan.com", name: "阿里云管理后台", server: "阿里云", cdn: "无加速", url: "https://ali.zhuzihan.com", }, { domain: "qzy.zhuzihan.com", name: "青竹云管理后台", server: "青竹云", cdn: "无加速", url: "https://qzy.zhuzihan.com", }, { domain: "hdy.zhuzihan.com", name: "狐蒂云-日本管理后台", server: "狐蒂云-日本", cdn: "无加速", url: "https://hdy.zhuzihan.com", }, { domain: "hdy2.zhuzihan.com", name: "狐蒂云-美国管理后台", server: "狐蒂云-美国", cdn: "无加速", url: "https://hdy2.zhuzihan.com", }, ], }, { title: "项目与工具", icon: , sites: [ { domain: "qquiz.zhuzihan.com", name: "QQuiz项目", server: "华为云", cdn: "ESA加速", url: "https://qquiz.zhuzihan.com", }, { domain: "wwords.zhuzihan.com", name: "WWords项目", server: "华为云", cdn: "ESA加速", url: "https://wwords.zhuzihan.com", }, { domain: "code.zhuzihan.com", name: "代码小项目", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://code.zhuzihan.com", }, { domain: "state.zhuzihan.com", name: "探针服务器状态检测", server: "华为云", cdn: "EdgeOne加速", url: "https://state.zhuzihan.com", }, { domain: "yummy.zhuzihan.com", name: "倒计时", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://yummy.zhuzihan.com", }, { domain: "file.zhuzihan.com", name: "文件快递柜", server: "华为云", cdn: "无加速", url: "https://file.zhuzihan.com", }, { domain: "2fa.zhuzihan.com", name: "纯前端2FA", server: "阿里云Pages", cdn: "ESA加速", url: "https://2fa.zhuzihan.com", }, { domain: "ieee.zhuzihan.com", name: "IEEE 754二进制计算演示", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://ieee.zhuzihan.com", }, { domain: "bcj.zhuzihan.com", name: "并查集算法演示", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://bcj.zhuzihan.com", }, { domain: "page.zhuzihan.com", name: "搜索页/起始页", server: "EdgeOne Pages", cdn: "EdgeOne Pages并加速", url: "https://page.zhuzihan.com", }, ], }, { title: "邮箱服务", icon: , sites: [ { domain: "@zhuzihan.com", name: "个人顶级邮箱", server: "网易企业邮箱", cdn: "-", url: "https://qiye.163.com" }, { domain: "@mail.zhuzihan.com", name: "个人邮箱", server: "阿里企业邮箱", cdn: "-", url: "https://qiye.aliyun.com", }, { domain: "@webmail.zhuzihan.com", name: "个人备用邮箱", server: "阿里企业邮箱", cdn: "-", url: "https://qiye.aliyun.com", }, ], }, ] function getCdnBadgeStyle(cdn: string) { if (cdn.includes("EdgeOne")) return "bg-emerald-500/20 text-emerald-400" if (cdn.includes("ESA")) return "bg-sky-500/20 text-sky-400" if (cdn.includes("Vercel")) return "bg-foreground/10 text-foreground" return "bg-muted text-muted-foreground" } function getServerBadgeStyle(server: string) { if (server.includes("DigitalOcean")) return "bg-blue-500/20 text-blue-400" if (server.includes("Azure")) return "bg-sky-500/20 text-sky-400" if (server.includes("华为")) return "bg-red-500/20 text-red-400" if (server.includes("阿里")) return "bg-orange-500/20 text-orange-400" if (server.includes("火山")) return "bg-amber-500/20 text-amber-400" if (server.includes("Vercel") || server.includes("v0")) return "bg-foreground/10 text-foreground" if (server.includes("GitHub")) return "bg-foreground/10 text-foreground" if (server.includes("EdgeOne")) return "bg-emerald-500/20 text-emerald-400" if (server.includes("网易") || server.includes("企业邮箱")) return "bg-red-500/20 text-red-400" if (server.includes("狐蒂云-日本")) return "bg-pink-500/20 text-pink-400" if (server.includes("狐蒂云-美国")) return "bg-violet-500/20 text-violet-400" return "bg-muted text-muted-foreground" } export function SiteNavigation() { const [searchQuery, setSearchQuery] = useState("") const filteredCategories = categories .map((category) => ({ ...category, sites: category.sites.filter( (site) => site.name.toLowerCase().includes(searchQuery.toLowerCase()) || site.domain.toLowerCase().includes(searchQuery.toLowerCase()) || site.server.toLowerCase().includes(searchQuery.toLowerCase()), ), })) .filter((category) => category.sites.length > 0) return (
{/* Header */}

站点导航

zhuzihan.com 全部站点与服务管理

{/* Search */}
setSearchQuery(e.target.value)} className="w-full bg-card border border-border rounded-lg py-3 pl-12 pr-4 text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-primary/50 transition-all" />
{/* Categories */}
{filteredCategories.map((category) => (
{category.icon}

{category.title}

({category.sites.length})
))}
{/* Footer */}
) }