mirror of
https://github.com/felipegcoutinho/openmonetis.git
synced 2026-05-09 19:01:47 +00:00
83 lines
1.6 KiB
TypeScript
83 lines
1.6 KiB
TypeScript
import Image from "next/image";
|
|
import { cn } from "@/lib/utils/ui";
|
|
import { version } from "@/package.json";
|
|
|
|
interface LogoProps {
|
|
variant?: "full" | "small" | "compact";
|
|
className?: string;
|
|
showVersion?: boolean;
|
|
invertTextOnDark?: boolean;
|
|
}
|
|
|
|
export function Logo({
|
|
variant = "full",
|
|
className,
|
|
showVersion = false,
|
|
invertTextOnDark = true,
|
|
}: LogoProps) {
|
|
if (variant === "compact") {
|
|
return (
|
|
<div className={cn("flex items-center gap-1", className)}>
|
|
<Image
|
|
src="/imagens/logo_small.png"
|
|
alt="OpenMonetis"
|
|
width={32}
|
|
height={32}
|
|
className="object-contain brightness-0 saturate-0"
|
|
priority
|
|
/>
|
|
<Image
|
|
src="/imagens/logo_text.png"
|
|
alt="OpenMonetis"
|
|
width={110}
|
|
height={32}
|
|
className={cn(
|
|
"hidden object-contain sm:block",
|
|
invertTextOnDark && "dark:invert",
|
|
)}
|
|
priority
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
if (variant === "small") {
|
|
return (
|
|
<Image
|
|
src="/imagens/logo_small.png"
|
|
alt="OpenMonetis"
|
|
width={32}
|
|
height={32}
|
|
className={cn("object-contain", className)}
|
|
priority
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className={cn("flex items-center gap-1.5 py-4", className)}>
|
|
<Image
|
|
src="/imagens/logo_small.png"
|
|
alt="OpenMonetis"
|
|
width={28}
|
|
height={28}
|
|
className="object-contain"
|
|
priority
|
|
/>
|
|
<Image
|
|
src="/imagens/logo_text.png"
|
|
alt="OpenMonetis"
|
|
width={100}
|
|
height={32}
|
|
className={cn("object-contain", invertTextOnDark && "dark:invert")}
|
|
priority
|
|
/>
|
|
{showVersion && (
|
|
<span className="text-[9px] font-medium text-muted-foreground">
|
|
{version}
|
|
</span>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|