mirror of
https://github.com/documenso/documenso.git
synced 2025-11-12 15:53:02 +10:00
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
import type { LucideIcon } from 'lucide-react/dist/lucide-react';
|
|
|
|
import { cn } from '@documenso/ui/lib/utils';
|
|
|
|
export type CardMetricProps = {
|
|
icon?: LucideIcon;
|
|
title: string;
|
|
value: string | number;
|
|
className?: string;
|
|
};
|
|
|
|
export const CardMetric = ({ icon: Icon, title, value, className }: CardMetricProps) => {
|
|
return (
|
|
<div
|
|
className={cn(
|
|
'border-border bg-background hover:shadow-border/80 h-32 max-h-32 max-w-full overflow-hidden rounded-lg border shadow shadow-transparent duration-200',
|
|
className,
|
|
)}
|
|
>
|
|
<div className="flex h-full max-h-full flex-col px-4 pb-6 pt-4 sm:px-4 sm:pb-8 sm:pt-4">
|
|
<div className="flex items-start">
|
|
{Icon && (
|
|
<div className="mr-2 h-4 w-4">
|
|
<Icon className="text-muted-foreground h-4 w-4" />
|
|
</div>
|
|
)}
|
|
|
|
<h3 className="text-primary-forground mb-2 flex items-end text-sm font-medium leading-tight">
|
|
{title}
|
|
</h3>
|
|
</div>
|
|
|
|
<p className="text-foreground mt-auto text-4xl font-semibold leading-8">
|
|
{typeof value === 'number' ? value.toLocaleString('en-US') : value}
|
|
</p>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|