registry:component
Empty
v1.0.0ga
Empty-state primitive with title, body, and actions.
Registry Endpoint
Open JSONhttps://registry.aavya.com/r/ui-empty.json
npx shadcn@latest add https://registry.aavya.com/r/ui-empty.json
Live Preview
No results
Try adjusting your filters or search term.
Usage Snippet
import Empty from '@/components/ui/empty.tsx'
export default function Example() {
return (
<div className="p-6">
<Empty />
</div>
)
}
Source Preview
import { cva, type VariantProps } from 'class-variance-authority'
import { cn } from '@/lib/utils'
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(
'mb-2 flex shrink-0 items-center justify-center [&_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}