3,200+ hardcoded color values replaced with CSS variable-backed Tailwind classes (bg-card, text-foreground, border-border, etc.). Enables light mode via CSS variable swap. Only syntax highlighting colors and intentional one-offs remain hardcoded (~15 values). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
54 lines
1.3 KiB
TypeScript
54 lines
1.3 KiB
TypeScript
import type { ReactNode } from 'react'
|
|
import { Link } from 'react-router-dom'
|
|
import { cn } from '@/lib/utils'
|
|
|
|
interface EmptyStateProps {
|
|
icon?: ReactNode
|
|
illustration?: ReactNode
|
|
title: string
|
|
description?: string
|
|
action?: ReactNode
|
|
learnMoreLink?: string
|
|
learnMoreText?: string
|
|
className?: string
|
|
}
|
|
|
|
export function EmptyState({
|
|
icon,
|
|
illustration,
|
|
title,
|
|
description,
|
|
action,
|
|
learnMoreLink,
|
|
learnMoreText = 'Learn more',
|
|
className,
|
|
}: EmptyStateProps) {
|
|
return (
|
|
<div className={cn('flex flex-col items-center justify-center py-12 text-center', className)}>
|
|
{illustration && (
|
|
<div className="mb-6 opacity-60">
|
|
{illustration}
|
|
</div>
|
|
)}
|
|
{!illustration && icon && (
|
|
<div className="mb-4 text-muted-foreground">{icon}</div>
|
|
)}
|
|
<h3 className="text-lg font-semibold text-foreground">{title}</h3>
|
|
{description && (
|
|
<p className="mt-2 max-w-sm text-sm text-muted-foreground">{description}</p>
|
|
)}
|
|
{action && <div className="mt-4">{action}</div>}
|
|
{learnMoreLink && (
|
|
<Link
|
|
to={learnMoreLink}
|
|
className="mt-3 text-sm text-muted-foreground hover:text-foreground transition-colors"
|
|
>
|
|
{learnMoreText} →
|
|
</Link>
|
|
)}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default EmptyState
|