- bg-background + border-b (sem cor primária no fundo) - Links: pill arredondado, hover bg-accent suave, sem underline - Link ativo: pill bg-primary/10 text-primary - Trigger aberto: mesma aparência do hover - Mobile: mesmo padrão de ativo com pill primário Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
57 lines
1.3 KiB
TypeScript
57 lines
1.3 KiB
TypeScript
"use client";
|
|
|
|
import Link from "next/link";
|
|
import { usePathname } from "next/navigation";
|
|
import { Badge } from "@/components/ui/badge";
|
|
import { cn } from "@/lib/utils/ui";
|
|
|
|
type MobileNavLinkProps = {
|
|
href: string;
|
|
icon: React.ReactNode;
|
|
children: React.ReactNode;
|
|
onClick?: () => void;
|
|
badge?: number;
|
|
};
|
|
|
|
export function MobileNavLink({
|
|
href,
|
|
icon,
|
|
children,
|
|
onClick,
|
|
badge,
|
|
}: MobileNavLinkProps) {
|
|
const pathname = usePathname();
|
|
const isActive =
|
|
href === "/dashboard"
|
|
? pathname === href
|
|
: pathname === href || pathname.startsWith(`${href}/`);
|
|
|
|
return (
|
|
<Link
|
|
href={href}
|
|
onClick={onClick}
|
|
className={cn(
|
|
"flex items-center gap-3 rounded-md px-3 py-2 text-sm transition-colors",
|
|
"text-muted-foreground hover:text-foreground hover:bg-accent",
|
|
isActive && "bg-primary/10 text-primary font-medium",
|
|
)}
|
|
>
|
|
<span className="text-muted-foreground shrink-0">{icon}</span>
|
|
<span className="flex-1">{children}</span>
|
|
{badge && badge > 0 ? (
|
|
<Badge variant="secondary" className="text-xs px-1.5 py-0">
|
|
{badge}
|
|
</Badge>
|
|
) : null}
|
|
</Link>
|
|
);
|
|
}
|
|
|
|
export function MobileSectionLabel({ label }: { label: string }) {
|
|
return (
|
|
<p className="mt-3 mb-1 px-3 text-[11px] font-semibold uppercase tracking-wider text-muted-foreground">
|
|
{label}
|
|
</p>
|
|
);
|
|
}
|