"use client"; import Link from "next/link"; import { usePathname } from "next/navigation"; import { useMemo } from "react"; import { Breadcrumb, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, } from "@/components/ui/breadcrumb"; import { useI18n } from "@/core/i18n/hooks"; import { cn } from "@/lib/utils"; import { GithubIcon } from "./github-icon"; import { Tooltip } from "./tooltip"; export function WorkspaceContainer({ className, children, ...props }: React.ComponentProps<"div">) { return (
{children}
); } export function WorkspaceHeader({ className, children, ...props }: React.ComponentProps<"header">) { const { t } = useI18n(); const pathname = usePathname(); const segments = useMemo(() => { const parts = pathname?.split("/") || []; if (parts.length > 0) { return parts.slice(1, 3); } }, [pathname]); return (
{segments?.[0] && ( {nameOfSegment(segments[0], t)} )} {segments?.[1] && ( <> {segments.length >= 2 ? ( {nameOfSegment(segments[1], t)} ) : ( {nameOfSegment(segments[1], t)} )} )} {children && ( <> {children} )}
); } export function WorkspaceBody({ className, children, ...props }: React.ComponentProps<"main">) { return (
{children}
); } function nameOfSegment( segment: string | undefined, t: ReturnType["t"], ) { if (!segment) return t.common.home; if (segment === "workspace") return t.breadcrumb.workspace; if (segment === "chats") return t.breadcrumb.chats; return segment[0]?.toUpperCase() + segment.slice(1); }