Spaces:
Running
Running
| 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( | |
| '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, | |
| EmptyHeader, | |
| EmptyTitle, | |
| EmptyDescription, | |
| EmptyContent, | |
| EmptyMedia, | |
| } | |