frigate/web/src/components/card/EmptyCard.tsx

57 lines
1.2 KiB
TypeScript
Raw Normal View History

import React from "react";
import { Button } from "../ui/button";
import Heading from "../ui/heading";
2025-10-20 16:03:22 +03:00
import { Link } from "react-router-dom";
import { cn } from "@/lib/utils";
type EmptyCardProps = {
className?: string;
icon: React.ReactNode;
title: string;
titleHeading?: boolean;
description?: string;
buttonText?: string;
2025-10-20 16:03:22 +03:00
link?: string;
2026-05-10 21:35:33 +03:00
onClick?: () => void;
};
export function EmptyCard({
className,
icon,
title,
titleHeading = true,
description,
buttonText,
2025-10-20 16:03:22 +03:00
link,
2026-05-10 21:35:33 +03:00
onClick,
}: EmptyCardProps) {
let TitleComponent;
if (titleHeading) {
TitleComponent = <Heading as="h4">{title}</Heading>;
} else {
TitleComponent = <div>{title}</div>;
}
return (
<div className={cn("flex flex-col items-center gap-2", className)}>
{icon}
{TitleComponent}
{description && (
<div className="mb-3 text-center text-secondary-foreground">
{description}
</div>
)}
2026-05-10 21:35:33 +03:00
{buttonText?.length &&
(onClick ? (
<Button size="sm" variant="select" onClick={onClick}>
{buttonText}
</Button>
) : (
<Button size="sm" variant="select">
<Link to={link ?? "#"}>{buttonText}</Link>
</Button>
))}
</div>
);
}