mediahub-fe/components/site-breadcrumb.tsx

64 lines
2.3 KiB
TypeScript

'use client';
import React from 'react'
import { Link, usePathname, useRouter } from "@/components/navigation";
import {
Breadcrumb,
BreadcrumbEllipsis,
BreadcrumbItem,
BreadcrumbLink,
BreadcrumbList,
BreadcrumbPage,
BreadcrumbSeparator,
} from "@/components/ui/breadcrumb"
import { Icon } from "@/components/ui/icon"
import { ReactNode } from "react";
const SiteBreadcrumb = ({ children }: { children?: ReactNode }) => {
const location = usePathname();
const locations = location.split('/').filter(path => path)
return (
<div className="flex justify-between gap-3 items-center mb-6">
<div className="flex-1">
<Breadcrumb>
<BreadcrumbList>
<BreadcrumbItem
>
<Link href="/dashboard/analytics">
<Icon icon="heroicons:home" className=" h-5 w-5" />
</Link>
</BreadcrumbItem>
<BreadcrumbSeparator />
{
locations.map((link, index) => {
let href = `/${locations.slice(0, index + 1).join('/')}`
let itemLink = link
const isLast = index === locations.length - 1;
return (
<React.Fragment key={index}>
<BreadcrumbItem className=' capitalize' >
{isLast ? (
itemLink
) : (
<Link href={href} >{itemLink}</Link>
)}
</BreadcrumbItem>
{locations.length !== index + 1 && <BreadcrumbSeparator />}
</React.Fragment>
)
})
}
</BreadcrumbList>
</Breadcrumb>
</div>
<div className=" flex-none flex gap-2">{children}</div>
</div>
);
};
export default SiteBreadcrumb;