Nuevo componente "Empty"

This commit is contained in:
David Arranz 2025-10-12 13:03:24 +02:00
parent 78cc422d9a
commit 9fb2955d30
2 changed files with 103 additions and 0 deletions

View File

@ -0,0 +1,101 @@
import { type VariantProps, cva } from "class-variance-authority"
import { cn } from '../lib/utils.ts'
function Empty({ className, ...props }: React.ComponentProps<"div">) {
return (
<div
data-slot="empty"
className={cn(
"flex min-w-0 flex-1 flex-col items-center justify-center gap-6 rounded-lg border-dashed p-6 text-center text-balance md:p-12",
className
)}
{...props}
/>
)
}
function EmptyHeader({ className, ...props }: React.ComponentProps<"div">) {
return (
<div
data-slot="empty-header"
className={cn(
"flex max-w-sm flex-col items-center gap-2 text-center",
className
)}
{...props}
/>
)
}
const emptyMediaVariants = cva(
"flex shrink-0 items-center justify-center mb-2 [&_svg]:pointer-events-none [&_svg]:shrink-0",
{
variants: {
variant: {
default: "bg-transparent",
icon: "bg-muted text-foreground flex size-10 shrink-0 items-center justify-center rounded-lg [&_svg:not([class*='size-'])]:size-6",
},
},
defaultVariants: {
variant: "default",
},
}
)
function EmptyMedia({
className,
variant = "default",
...props
}: React.ComponentProps<"div"> & VariantProps<typeof emptyMediaVariants>) {
return (
<div
data-slot="empty-icon"
data-variant={variant}
className={cn(emptyMediaVariants({ variant, className }))}
{...props}
/>
)
}
function EmptyTitle({ className, ...props }: React.ComponentProps<"div">) {
return (
<div
data-slot="empty-title"
className={cn("text-lg font-medium tracking-tight", className)}
{...props}
/>
)
}
function EmptyDescription({ className, ...props }: React.ComponentProps<"p">) {
return (
<div
data-slot="empty-description"
className={cn(
"text-muted-foreground [&>a:hover]:text-primary text-sm/relaxed [&>a]:underline [&>a]:underline-offset-4",
className
)}
{...props}
/>
)
}
function EmptyContent({ className, ...props }: React.ComponentProps<"div">) {
return (
<div
data-slot="empty-content"
className={cn(
"flex w-full max-w-sm min-w-0 flex-col items-center gap-4 text-sm text-balance",
className
)}
{...props}
/>
)
}
export {
Empty, EmptyContent, EmptyDescription, EmptyHeader, EmptyMedia, EmptyTitle
}

View File

@ -16,6 +16,7 @@ export * from "./context-menu.tsx";
export * from "./dialog.tsx";
export * from "./drawer.tsx";
export * from "./dropdown-menu.tsx";
export * from "./empty.tsx";
export * from "./form.tsx";
export * from "./hover-card.tsx";
export * from "./input.tsx";
@ -42,3 +43,4 @@ export * from "./textarea.tsx";
export * from "./toggle-group.tsx";
export * from "./toggle.tsx";
export * from "./tooltip.tsx";