import { TrendingUp, AlertCircle, Clock, CheckCircle2, Settings2 } from 'lucide-react'; import { cn, fmt } from '@/lib/utils'; const CARD_DEFS = { starting: { label: 'Starting', icon: TrendingUp, bar: 'from-slate-400 to-slate-300', glow: '', valueClass: 'text-foreground', activateWhen: () => true, }, paid: { label: 'Total Paid', icon: CheckCircle2, bar: 'from-emerald-500 to-emerald-300', glow: 'shadow-[0_4px_20px_rgba(16,185,129,0.15)]', borderActive: 'border-emerald-400/40', valueClass: 'text-emerald-600 dark:text-emerald-200', activateWhen: (v) => v > 0, }, remaining: { label: 'Remaining', icon: Clock, bar: 'from-blue-400 to-indigo-300', glow: '', valueClass: 'text-foreground', activateWhen: () => true, }, overdue: { label: 'Overdue', icon: AlertCircle, bar: 'from-rose-400 to-orange-300', glow: 'shadow-[0_4px_20px_rgba(251,113,133,0.10)]', borderActive: 'border-rose-400/35', valueClass: 'text-red-500 dark:text-rose-200', activateWhen: (v) => v > 0, }, }; export function TrendIndicator({ trend }) { if (!trend) return null; const { direction, percent_change } = trend; let icon, color, text; switch (direction) { case 'up': icon = '↑'; color = 'text-emerald-500'; text = `${icon} ${percent_change}%`; break; case 'down': icon = '↓'; color = 'text-red-500'; text = `${icon} ${Math.abs(percent_change)}%`; break; default: icon = '→'; color = 'text-muted-foreground'; text = `${icon} ${percent_change}%`; } return (
{displayLabel}
{type === 'starting' && onEdit && ( )}{fmt(value)}
{hint &&{hint}
}3-Month Trend