Breadcrumbs
Breadcrumbs display a hierarchy of links to the current page or resource in an application.
Copy and paste the following code into your project.
"use client"
import { ChevronRight } from "lucide-react"
import {
Breadcrumb,
BreadcrumbProps,
Breadcrumbs,
BreadcrumbsProps,
Link,
LinkProps,
} from "react-aria-components"
import { cn, cnv } from "@/lib/utils"
import { buttonVariants } from "./button-variants"
const _Breadcrumbs = <T extends object>({
className,
...props
}: BreadcrumbsProps<T>) => (
<Breadcrumbs className={cn("flex flex-wrap", className)} {...props} />
)
interface BreadcrumbItemProps extends Omit<BreadcrumbProps, "children"> {
linkClassName?: LinkProps["className"]
href?: LinkProps["href"]
linkProps?: Omit<LinkProps, "className" | "href" | "children">
children?: LinkProps["children"]
}
const BreadcrumbItem = ({
className,
linkClassName,
href,
linkProps,
children,
...props
}: BreadcrumbItemProps) => (
<Breadcrumb className="flex items-center" {...props}>
<Link
className={(values) =>
cnv(
values,
buttonVariants({
variant: "link",
className: "data-[disabled]:opacity-100",
}),
"opacity-50 peer px-1 py-1",
"data-[disabled]:opacity-100",
linkClassName
)
}
href={href}
{...linkProps}
>
{children}
</Link>
<ChevronRight
aria-hidden="true"
className="h-4 w-4 peer-data-[current]:hidden"
/>
</Breadcrumb>
)
export { _Breadcrumbs as Breadcrumbs, BreadcrumbItem }
Update the import paths to match your project setup.
Client Side Routing
The <BreadcrumbItem>
component works with frameworks and client side routers like Next.js, Remix and React Router.
As with other React Aria components that support links, this works via the RouterProvider
component at the root of your app.
See the client side routing guide to learn how to set this up.
Usage
Basic
Dynamic Items
Breadcrumbs follows the Collection Components API, accepting both static and dynamic collections. Dynamic collections, as shown below, can be used when the options come from an external data source such as an API call, or update over time.
As seen below, an iterable list of options is passed to the Breadcrumbs using the items prop.
A function provided as children of the <Breadcrumbs>
is called to render each item.
When a breadcrumb is pressed, the onAction event is triggered and the breadcrumbs array is updated
- Home
- Trendy
- March 2022 Assets