mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-07-02 08:58:36 +00:00
68 lines
1.8 KiB
TypeScript
68 lines
1.8 KiB
TypeScript
import Link from "next/link"
|
|
import { ChevronLeftIcon, ChevronRightIcon } from "@radix-ui/react-icons"
|
|
import { Doc } from "contentlayer/generated"
|
|
import { NavItem, NavItemWithChildren } from "types/nav"
|
|
|
|
import { docsConfig } from "@/config/docs"
|
|
import { cn } from "@/lib/utils"
|
|
import { buttonVariants } from "@/registry/new-york/ui/button"
|
|
|
|
interface DocsPagerProps {
|
|
doc: Doc
|
|
}
|
|
|
|
export function DocsPager({ doc }: DocsPagerProps) {
|
|
const pager = getPagerForDoc(doc)
|
|
|
|
if (!pager) {
|
|
return null
|
|
}
|
|
|
|
return (
|
|
<div className="flex flex-row items-center justify-between">
|
|
{pager?.prev?.href && (
|
|
<Link
|
|
href={pager.prev.href}
|
|
className={buttonVariants({ variant: "outline" })}
|
|
>
|
|
<ChevronLeftIcon className="mr-2 h-4 w-4" />
|
|
{pager.prev.title}
|
|
</Link>
|
|
)}
|
|
{pager?.next?.href && (
|
|
<Link
|
|
href={pager.next.href}
|
|
className={cn(buttonVariants({ variant: "outline" }), "ml-auto")}
|
|
>
|
|
{pager.next.title}
|
|
<ChevronRightIcon className="ml-2 h-4 w-4" />
|
|
</Link>
|
|
)}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export function getPagerForDoc(doc: Doc) {
|
|
const flattenedLinks = [null, ...flatten(docsConfig.sidebarNav), null]
|
|
const activeIndex = flattenedLinks.findIndex(
|
|
(link) => doc.slug === link?.href
|
|
)
|
|
const prev = activeIndex !== 0 ? flattenedLinks[activeIndex - 1] : null
|
|
const next =
|
|
activeIndex !== flattenedLinks.length - 1
|
|
? flattenedLinks[activeIndex + 1]
|
|
: null
|
|
return {
|
|
prev,
|
|
next,
|
|
}
|
|
}
|
|
|
|
export function flatten(links: NavItemWithChildren[]): NavItem[] {
|
|
return links
|
|
.reduce<NavItem[]>((flat, link) => {
|
|
return flat.concat(link.items?.length ? flatten(link.items) : link)
|
|
}, [])
|
|
.filter((link) => !link?.disabled)
|
|
}
|