"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 | 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: "狐蒂云-日本",
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: ["狐蒂云-美国", "Google-Iowa", "Google-Oregon", "Google-Taiwan"],
cdn: "ESA API加速",
url: "https://api-proxy.zhuzihan.com",
},
{
domain: "ai-proxy.zhuzihan.com",
name: "AI API转发",
server: ["狐蒂云-美国", "Google-Iowa", "Google-Oregon", "Google-Taiwan"],
cdn: "ESA API加速",
url: "https://ai-proxy.zhuzihan.com",
},
{
domain: "grok.zhuzihan.com",
name: "Grok2API",
server: "狐蒂云-美国",
cdn: "无加速",
url: "https://grok.zhuzihan.com",
},
{
domain: "git.zhuzihan.com",
name: "Gitea自托管Git",
server: "狐蒂云-美国-2",
cdn: "无加速",
url: "https://git.zhuzihan.com",
},
{
domain: "pro.zhuzihan.com",
name: "AxonHub专业API网关",
server: "狐蒂云-美国-2",
cdn: "无加速",
url: "https://pro.zhuzihan.com",
},
{
domain: "codex.zhuzihan.com",
name: "公益New-API",
server: "青瑞云",
cdn: "EdgeOne加速",
url: "https://codex.zhuzihan.com",
},
{
domain: "ai.zzhdsgsss.xyz",
name: "LINUXDO公益New-API",
server: "青瑞云",
cdn: "CloudFlare加速",
url: "https://ai.zzhdsgsss.xyz",
},
{
domain: "apitool.zzhdsgsss.xyz",
name: "LINUXDO公益New-API监控",
server: "青瑞云",
cdn: "CloudFlare加速",
url: "https://apitool.zzhdsgsss.xyz",
},
{
domain: "cpa.zhuzihan.com/management.html",
name: "CliProxyAPI",
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",
},
],
},
{
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: "google1.zhuzihan.com",
name: "Google-Iowa管理后台",
server: "Google-Iowa",
cdn: "无加速",
url: "https://google1.zhuzihan.com",
},
{
domain: "google2.zhuzihan.com",
name: "Google-Oregon管理后台",
server: "Google-Oregon",
cdn: "无加速",
url: "https://google2.zhuzihan.com",
},
{
domain: "google3.zhuzihan.com",
name: "Google-Taiwan管理后台",
server: "Google-Taiwan",
cdn: "无加速",
url: "https://google3.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",
},
{
domain: "hdy3.zhuzihan.com",
name: "狐蒂云-美国-2管理后台",
server: "狐蒂云-美国-2",
cdn: "无加速",
url: "https://hdy3.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 Pages")) return "bg-emerald-500/20 text-emerald-400"
if (cdn.includes("EdgeOne")) return "bg-green-500/20 text-green-400"
if (cdn.includes("ESA API")) return "bg-indigo-500/20 text-indigo-400"
if (cdn.includes("ESA")) return "bg-sky-500/20 text-sky-400"
if (cdn.includes("CloudFlare")) return "bg-orange-500/20 text-orange-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 Pages")) return "bg-emerald-500/20 text-emerald-400"
if (server.includes("EdgeOne")) return "bg-green-500/20 text-green-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("狐蒂云-美国-2")) return "bg-purple-500/20 text-purple-400"
if (server.includes("狐蒂云-美国")) return "bg-violet-500/20 text-violet-400"
if (server.includes("青瑞云")) return "bg-lime-500/20 text-lime-400"
if (server.includes("Google-Iowa")) return "bg-green-500/20 text-green-400"
if (server.includes("Google-Oregon")) return "bg-teal-500/20 text-teal-400"
if (server.includes("Google-Taiwan")) return "bg-cyan-500/20 text-cyan-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()) ||
(Array.isArray(site.server)
? site.server.some((s) => s.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 */}
)
}