continue re-design
This commit is contained in:
@@ -0,0 +1,57 @@
|
||||
"use client";
|
||||
|
||||
import React from "react";
|
||||
import { cn } from "@/utils/cn";
|
||||
import { AsciiExplosion } from "@/components/shared/effects/flame";
|
||||
|
||||
interface EmptyStateProps {
|
||||
title?: string;
|
||||
description?: string;
|
||||
icon?: React.ReactNode;
|
||||
action?: React.ReactNode;
|
||||
showFlame?: boolean;
|
||||
className?: string;
|
||||
}
|
||||
|
||||
export function EmptyState({
|
||||
title = "No data yet",
|
||||
description,
|
||||
icon,
|
||||
action,
|
||||
showFlame = true,
|
||||
className,
|
||||
}: EmptyStateProps) {
|
||||
return (
|
||||
<div
|
||||
className={cn(
|
||||
"relative flex flex-col items-center justify-center py-12 px-4 text-center",
|
||||
"min-h-[300px]",
|
||||
className,
|
||||
)}
|
||||
>
|
||||
{/* Subtle flame background */}
|
||||
{showFlame && (
|
||||
<div className="absolute inset-0 opacity-5">
|
||||
<AsciiExplosion />
|
||||
</div>
|
||||
)}
|
||||
|
||||
<div className="relative z-10 space-y-4">
|
||||
{icon && (
|
||||
<div className="w-12 h-12 mx-auto text-black-alpha-40">{icon}</div>
|
||||
)}
|
||||
|
||||
<div className="space-y-2">
|
||||
<h3 className="text-label-large text-black-alpha-72">{title}</h3>
|
||||
{description && (
|
||||
<p className="text-body-medium text-black-alpha-56 max-w-md mx-auto">
|
||||
{description}
|
||||
</p>
|
||||
)}
|
||||
</div>
|
||||
|
||||
{action && <div className="pt-2">{action}</div>}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user