"use client"; import { usePathname, useRouter } from "next/navigation"; import { useMemo } from "react"; import Link from "next/link"; import PropTypes from "prop-types"; import ProviderIcon from "@/shared/components/ProviderIcon"; import { ThemeToggle, LanguageSwitcher } from "@/shared/components"; import NineRemoteButton from "@/shared/components/NineRemoteButton"; import { OAUTH_PROVIDERS, APIKEY_PROVIDERS } from "@/shared/constants/config"; import { translate } from "@/i18n/runtime"; const getPageInfo = (pathname) => { if (!pathname) return { title: "", description: "", breadcrumbs: [] }; // Provider detail page: /dashboard/providers/[id] const providerMatch = pathname.match(/\/providers\/([^/]+)$/); if (providerMatch) { const providerId = providerMatch[1]; const providerInfo = OAUTH_PROVIDERS[providerId] || APIKEY_PROVIDERS[providerId]; if (providerInfo) { return { title: providerInfo.name, description: "", breadcrumbs: [ { label: "Providers", href: "/dashboard/providers" }, { label: providerInfo.name, image: `/providers/${providerInfo.id}.png`, }, ], }; } } if (pathname.includes("/providers")) return { title: "Providers", description: "Manage your AI provider connections", icon: "dns", breadcrumbs: [], }; if (pathname.includes("/combos")) return { title: "Combos", description: "Model combos with fallback", icon: "layers", breadcrumbs: [], }; if (pathname.includes("/usage")) return { title: "Usage & Analytics", description: "Monitor your API usage, token consumption, and request logs", icon: "bar_chart", breadcrumbs: [], }; if (pathname.includes("/quota")) return { title: "Quota Tracker", description: "Track and manage your API quota limits", icon: "data_usage", breadcrumbs: [], }; if (pathname.includes("/mitm")) return { title: "MITM Proxy", description: "Intercept CLI tool traffic and route through 9Router", icon: "security", breadcrumbs: [], }; if (pathname.includes("/cli-tools")) return { title: "CLI Tools", description: "Configure CLI tools", icon: "terminal", breadcrumbs: [], }; if (pathname.includes("/proxy-pools")) return { title: "Proxy Pools", description: "Manage your proxy pool configurations", icon: "lan", breadcrumbs: [], }; if (pathname.includes("/endpoint")) return { title: "Endpoint", description: "API endpoint configuration", icon: "api", breadcrumbs: [], }; if (pathname.includes("/profile")) return { title: "Settings", description: "Manage your preferences", icon: "settings", breadcrumbs: [], }; if (pathname.includes("/translator")) return { title: "Translator", description: "Debug translation flow between formats", icon: "translate", breadcrumbs: [], }; if (pathname.includes("/console-log")) return { title: "Console Log", description: "Live server console output", icon: "monitor", breadcrumbs: [], }; if (pathname === "/dashboard") return { title: "Endpoint", description: "API endpoint configuration", icon: "api", breadcrumbs: [], }; return { title: "", description: "", breadcrumbs: [] }; }; export default function Header({ onMenuClick, showMenuButton = true }) { const pathname = usePathname(); const router = useRouter(); // Memoize page info to prevent unnecessary recalculations const pageInfo = useMemo(() => getPageInfo(pathname), [pathname]); const { title, description, icon, breadcrumbs } = pageInfo; const handleLogout = async () => { try { const res = await fetch("/api/auth/logout", { method: "POST" }); if (res.ok) { router.push("/login"); router.refresh(); } } catch (err) { console.error("Failed to logout:", err); } }; return (
{/* Mobile menu button */}
{showMenuButton && ( )}
{/* Page title with breadcrumbs - desktop */}
{breadcrumbs.length > 0 ? (
{breadcrumbs.map((crumb, index) => (
{index > 0 && ( chevron_right )} {crumb.href ? ( {crumb.label} ) : (
{crumb.image && ( )}

{translate(crumb.label)}

)}
))}
) : title ? (
{icon && ( {icon} )}

{translate(title)}

{description && (

{translate(description)}

)}
) : null}
{/* Right actions */}
{/* 9Remote button */} {/* Language switcher */} {/* Theme toggle */} {/* Logout button */}
); } Header.propTypes = { onMenuClick: PropTypes.func, showMenuButton: PropTypes.bool, };