{"$schema":"https://ui.shadcn.com/schema/registry-item.json","name":"aavya-breadcrumbs","type":"registry:component","title":"Aavya Breadcrumbs","description":"Route-aware breadcrumb navigation for App Router pages.","version":"0.2.0","status":"beta","files":[{"path":"src/components/layout/breadcrumbs.tsx","type":"registry:component","content":"'use client'\n\nimport Link from 'next/link'\nimport { usePathname } from 'next/navigation'\nimport { Fragment } from 'react'\nimport { Home } from 'lucide-react'\nimport {\n  Breadcrumb,\n  BreadcrumbItem,\n  BreadcrumbLink,\n  BreadcrumbList,\n  BreadcrumbPage,\n  BreadcrumbSeparator,\n} from '@/components/ui/breadcrumb'\n\nconst segmentLabels: Record<string, string> = {\n  'brand-guidelines': 'Brand Guidelines',\n  'design-tokens': 'Design Tokens',\n  'border-radius': 'Border Radius',\n  registry: 'Registry',\n  'theme-generator': 'Example UI',\n  'auth': 'Auth',\n  'api': 'API',\n}\n\nfunction getSegmentLabel(segment: string) {\n  return (\n    segmentLabels[segment] ??\n    segment\n      .split('-')\n      .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n      .join(' ')\n  )\n}\n\nexport function Breadcrumbs() {\n  const pathname = usePathname()\n\n  const segments = pathname.split('/').filter(Boolean)\n\n  if (segments.length === 0) {\n    return (\n      <Breadcrumb className=\"mb-5\">\n        <BreadcrumbList>\n          <BreadcrumbItem className=\"font-medium text-foreground\">\n            <Home className=\"h-3.5 w-3.5\" />\n            Home\n          </BreadcrumbItem>\n        </BreadcrumbList>\n      </Breadcrumb>\n    )\n  }\n\n  return (\n    <Breadcrumb className=\"mb-5\">\n      <BreadcrumbList>\n        <BreadcrumbItem>\n          <BreadcrumbLink\n            asChild\n            className=\"inline-flex items-center gap-1.5 rounded-md px-1.5 py-0.5 hover:bg-accent hover:text-accent-foreground\"\n          >\n            <Link href=\"/\">\n              <Home className=\"h-3.5 w-3.5\" />\n              Home\n            </Link>\n          </BreadcrumbLink>\n        </BreadcrumbItem>\n        {segments.map((segment, index) => {\n          const href = `/${segments.slice(0, index + 1).join('/')}`\n          const isLast = index === segments.length - 1\n\n          return (\n            <Fragment key={href}>\n              <BreadcrumbSeparator />\n              <BreadcrumbItem>\n                {isLast ? (\n                  <BreadcrumbPage className=\"font-medium\">\n                    {getSegmentLabel(segment)}\n                  </BreadcrumbPage>\n                ) : (\n                  <BreadcrumbLink\n                    asChild\n                    className=\"rounded-md px-1.5 py-0.5 hover:bg-accent hover:text-accent-foreground\"\n                  >\n                    <Link href={href}>{getSegmentLabel(segment)}</Link>\n                  </BreadcrumbLink>\n                )}\n              </BreadcrumbItem>\n            </Fragment>\n          )\n        })}\n      </BreadcrumbList>\n    </Breadcrumb>\n  )\n}\n"},{"path":"src/components/ui/breadcrumb.tsx","type":"registry:component","content":"import * as React from 'react'\n\nimport { Slot } from '@radix-ui/react-slot'\nimport { ChevronRight, MoreHorizontal } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Breadcrumb({ ...props }: React.ComponentProps<'nav'>) {\n  return <nav aria-label='breadcrumb' data-slot='breadcrumb' {...props} />\n}\n\nfunction BreadcrumbList({ className, ...props }: React.ComponentProps<'ol'>) {\n  return (\n    <ol\n      data-slot='breadcrumb-list'\n      className={cn(\n        'text-muted-foreground flex flex-wrap items-center gap-1.5 text-sm break-words sm:gap-2.5',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction BreadcrumbItem({ className, ...props }: React.ComponentProps<'li'>) {\n  return <li data-slot='breadcrumb-item' className={cn('inline-flex items-center gap-1.5', className)} {...props} />\n}\n\nfunction BreadcrumbLink({\n  asChild,\n  className,\n  ...props\n}: React.ComponentProps<'a'> & {\n  asChild?: boolean\n}) {\n  const Comp = asChild ? Slot : 'a'\n\n  return (\n    <Comp data-slot='breadcrumb-link' className={cn('hover:text-foreground transition-colors', className)} {...props} />\n  )\n}\n\nfunction BreadcrumbPage({ className, ...props }: React.ComponentProps<'span'>) {\n  return (\n    <span\n      data-slot='breadcrumb-page'\n      role='link'\n      aria-disabled='true'\n      aria-current='page'\n      className={cn('text-foreground font-normal', className)}\n      {...props}\n    />\n  )\n}\n\nfunction BreadcrumbSeparator({ children, className, ...props }: React.ComponentProps<'li'>) {\n  return (\n    <li\n      data-slot='breadcrumb-separator'\n      role='presentation'\n      aria-hidden='true'\n      className={cn('[&>svg]:size-3.5', className)}\n      {...props}\n    >\n      {children ?? <ChevronRight />}\n    </li>\n  )\n}\n\nfunction BreadcrumbEllipsis({ className, ...props }: React.ComponentProps<'span'>) {\n  return (\n    <span\n      data-slot='breadcrumb-ellipsis'\n      role='presentation'\n      aria-hidden='true'\n      className={cn('flex size-9 items-center justify-center', className)}\n      {...props}\n    >\n      <MoreHorizontal className='size-4' />\n      <span className='sr-only'>More</span>\n    </span>\n  )\n}\n\nexport {\n  Breadcrumb,\n  BreadcrumbList,\n  BreadcrumbItem,\n  BreadcrumbLink,\n  BreadcrumbPage,\n  BreadcrumbSeparator,\n  BreadcrumbEllipsis\n}\n"}]}