mirror of
https://github.com/felipegcoutinho/openmonetis.git
synced 2026-06-10 07:16:01 +00:00
feat(navegacao): adiciona atalhos financeiros e seletor mensal
This commit is contained in:
@@ -1,16 +1,85 @@
|
||||
"use client";
|
||||
|
||||
import {
|
||||
RiArrowRightSLine,
|
||||
RiBankCard2Line,
|
||||
RiBankLine,
|
||||
} from "@remixicon/react";
|
||||
import { usePathname } from "next/navigation";
|
||||
import { Badge } from "@/shared/components/ui/badge";
|
||||
import { resolveLogoSrc } from "@/shared/lib/logo";
|
||||
import { formatCurrency } from "@/shared/utils/currency";
|
||||
import { cn } from "@/shared/utils/ui";
|
||||
import type { NavItem } from "./nav-items";
|
||||
import type {
|
||||
NavbarEntityLink,
|
||||
NavbarFinanceLinks,
|
||||
NavItem,
|
||||
} from "./nav-items";
|
||||
import { NavLink } from "./nav-link";
|
||||
|
||||
type NavDropdownProps = {
|
||||
items: NavItem[];
|
||||
financeLinks?: NavbarFinanceLinks;
|
||||
};
|
||||
|
||||
export function NavDropdown({ items }: NavDropdownProps) {
|
||||
function FinanceEntityLinks({
|
||||
type,
|
||||
items,
|
||||
}: {
|
||||
type: keyof NavbarFinanceLinks;
|
||||
items: NavbarEntityLink[];
|
||||
}) {
|
||||
const pathname = usePathname();
|
||||
|
||||
return items.map((item) => {
|
||||
const href =
|
||||
type === "cards"
|
||||
? `/cards/${item.id}/invoice`
|
||||
: `/accounts/${item.id}/statement`;
|
||||
const logoSrc = resolveLogoSrc(item.logo);
|
||||
const isActive = pathname === href;
|
||||
const fallbackIcon =
|
||||
type === "cards" ? (
|
||||
<RiBankCard2Line className="size-5" />
|
||||
) : (
|
||||
<RiBankLine className="size-5" />
|
||||
);
|
||||
|
||||
return (
|
||||
<li key={href}>
|
||||
<NavLink
|
||||
href={href}
|
||||
preservePeriod
|
||||
className={cn(
|
||||
"flex items-center gap-2 rounded-sm px-2 py-2 text-sm transition-colors",
|
||||
isActive
|
||||
? "bg-accent text-primary"
|
||||
: "text-foreground hover:bg-accent hover:text-foreground",
|
||||
)}
|
||||
>
|
||||
{logoSrc ? (
|
||||
<img
|
||||
src={logoSrc}
|
||||
alt=""
|
||||
className="size-5 shrink-0 rounded-full object-contain"
|
||||
/>
|
||||
) : (
|
||||
<span className="shrink-0">{fallbackIcon}</span>
|
||||
)}
|
||||
<span className="flex min-w-0 flex-col">
|
||||
<span className={cn("truncate font-semibold")}>{item.name}</span>
|
||||
<span className="truncate text-xs text-muted-foreground">
|
||||
{type === "cards" ? "Fatura deste mês" : "Saldo"}:{" "}
|
||||
{formatCurrency(item.amount)}
|
||||
</span>
|
||||
</span>
|
||||
</NavLink>
|
||||
</li>
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
export function NavDropdown({ items, financeLinks }: NavDropdownProps) {
|
||||
const pathname = usePathname();
|
||||
|
||||
return (
|
||||
@@ -18,9 +87,22 @@ export function NavDropdown({ items }: NavDropdownProps) {
|
||||
{items.map((item) => {
|
||||
const isActive =
|
||||
pathname === item.href || pathname.startsWith(`${item.href}/`);
|
||||
const entityLinks =
|
||||
item.href === "/cards"
|
||||
? financeLinks?.cards
|
||||
: item.href === "/accounts"
|
||||
? financeLinks?.accounts
|
||||
: undefined;
|
||||
const entityType =
|
||||
item.href === "/cards"
|
||||
? "cards"
|
||||
: item.href === "/accounts"
|
||||
? "accounts"
|
||||
: undefined;
|
||||
const hasEntityLinks = Boolean(entityType && entityLinks?.length);
|
||||
|
||||
return (
|
||||
<li key={item.href}>
|
||||
<li key={item.href} className="group/entity relative">
|
||||
<NavLink
|
||||
href={item.href}
|
||||
preservePeriod={item.preservePeriod}
|
||||
@@ -57,7 +139,20 @@ export function NavDropdown({ items }: NavDropdownProps) {
|
||||
{item.badge}
|
||||
</Badge>
|
||||
) : null}
|
||||
{hasEntityLinks ? (
|
||||
<RiArrowRightSLine
|
||||
className="ml-auto size-4 shrink-0 text-muted-foreground transition-transform group-hover/entity:translate-x-0.5"
|
||||
aria-hidden
|
||||
/>
|
||||
) : null}
|
||||
</NavLink>
|
||||
{hasEntityLinks && entityType && entityLinks ? (
|
||||
<div className="invisible absolute top-0 left-full z-50 pl-1 opacity-0 transition-opacity group-hover/entity:visible group-hover/entity:opacity-100 group-focus-within/entity:visible group-focus-within/entity:opacity-100">
|
||||
<ul className="grid max-h-[calc(100vh-5rem)] w-64 gap-0.5 overflow-y-auto rounded-md border bg-popover p-2 text-popover-foreground">
|
||||
<FinanceEntityLinks type={entityType} items={entityLinks} />
|
||||
</ul>
|
||||
</div>
|
||||
) : null}
|
||||
</li>
|
||||
);
|
||||
})}
|
||||
|
||||
Reference in New Issue
Block a user