mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-26 14:16:08 +00:00
* feat: init * fix * fix * fix * feat * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: implement icons * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: update init command * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: dialog * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add registry:base item type * feat: rename frame to canva * fix * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fi * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add all colors * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add outfit font * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix
84 lines
3.0 KiB
TypeScript
84 lines
3.0 KiB
TypeScript
import Link from "next/link"
|
|
import { PlusSignIcon } from "@hugeicons/core-free-icons"
|
|
import { HugeiconsIcon } from "@hugeicons/react"
|
|
|
|
import { getColors } from "@/lib/colors"
|
|
import { siteConfig } from "@/lib/config"
|
|
import { source } from "@/lib/source"
|
|
import { CommandMenu } from "@/components/command-menu"
|
|
import { GitHubLink } from "@/components/github-link"
|
|
import { Icons } from "@/components/icons"
|
|
import { MainNav } from "@/components/main-nav"
|
|
import { MobileNav } from "@/components/mobile-nav"
|
|
import { ModeSwitcher } from "@/components/mode-switcher"
|
|
import { SiteConfig } from "@/components/site-config"
|
|
// import blocks from "@/registry/__blocks__.json"
|
|
import { Button } from "@/registry/new-york-v4/ui/button"
|
|
import { Separator } from "@/registry/new-york-v4/ui/separator"
|
|
|
|
export function SiteHeader() {
|
|
const colors = getColors()
|
|
const pageTree = source.pageTree
|
|
|
|
return (
|
|
<header className="bg-background sticky top-0 z-50 w-full">
|
|
<div className="container-wrapper 3xl:fixed:px-0 px-6">
|
|
<div className="3xl:fixed:container flex h-(--header-height) items-center **:data-[slot=separator]:!h-4">
|
|
<MobileNav
|
|
tree={pageTree}
|
|
items={siteConfig.navItems}
|
|
className="flex lg:hidden"
|
|
/>
|
|
<Button
|
|
asChild
|
|
variant="ghost"
|
|
size="icon"
|
|
className="hidden size-8 lg:flex"
|
|
>
|
|
<Link href="/">
|
|
<Icons.logo className="size-5" />
|
|
<span className="sr-only">{siteConfig.name}</span>
|
|
</Link>
|
|
</Button>
|
|
<MainNav items={siteConfig.navItems} className="hidden lg:flex" />
|
|
<div className="ml-auto flex items-center gap-2 md:flex-1 md:justify-end">
|
|
<div className="hidden w-full flex-1 md:flex md:w-auto md:flex-none">
|
|
<CommandMenu
|
|
tree={pageTree}
|
|
colors={colors}
|
|
navItems={siteConfig.navItems}
|
|
/>
|
|
</div>
|
|
<Separator
|
|
orientation="vertical"
|
|
className="ml-2 hidden lg:block"
|
|
/>
|
|
<GitHubLink />
|
|
<Separator orientation="vertical" className="3xl:flex hidden" />
|
|
<SiteConfig className="3xl:flex hidden" />
|
|
<Separator orientation="vertical" />
|
|
<ModeSwitcher />
|
|
<Separator orientation="vertical" className="mr-2" />
|
|
<Button
|
|
asChild
|
|
size="sm"
|
|
className="hidden h-[31px] rounded-lg sm:flex"
|
|
>
|
|
<Link href="/create">
|
|
<HugeiconsIcon icon={PlusSignIcon} />
|
|
New Project
|
|
</Link>
|
|
</Button>
|
|
<Button asChild size="sm" className="h-[31px] rounded-lg sm:hidden">
|
|
<Link href="/create">
|
|
<HugeiconsIcon icon={PlusSignIcon} />
|
|
New
|
|
</Link>
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</header>
|
|
)
|
|
}
|