mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-27 06:34:12 +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
42 lines
944 B
TypeScript
42 lines
944 B
TypeScript
"use client"
|
|
|
|
import Link from "next/link"
|
|
import { usePathname } from "next/navigation"
|
|
|
|
import { PAGES_NEW } from "@/lib/docs"
|
|
import { cn } from "@/lib/utils"
|
|
import { Button } from "@/registry/new-york-v4/ui/button"
|
|
|
|
export function MainNav({
|
|
items,
|
|
className,
|
|
...props
|
|
}: React.ComponentProps<"nav"> & {
|
|
items: { href: string; label: string }[]
|
|
}) {
|
|
const pathname = usePathname()
|
|
|
|
return (
|
|
<nav className={cn("items-center gap-0", className)} {...props}>
|
|
{items.map((item) => (
|
|
<Button
|
|
key={item.href}
|
|
variant="ghost"
|
|
asChild
|
|
size="sm"
|
|
className="px-2.5"
|
|
>
|
|
<Link
|
|
href={item.href}
|
|
data-active={pathname === item.href}
|
|
data-new={PAGES_NEW.includes(item.href)}
|
|
className="relative items-center"
|
|
>
|
|
{item.label}
|
|
</Link>
|
|
</Button>
|
|
))}
|
|
</nav>
|
|
)
|
|
}
|