import { cva } from 'class-variance-authority';

import { cn } from '@/lib/utils';

function Empty({ className, ...props }) {
	return (
		<div
			data-slot="empty"
			className={cn(
				'flex min-w-0 flex-1 flex-col items-center justify-center gap-6 text-balance bg-accent rounded-lg border p-6 text-center md:p-12',
				className
			)}
			{...props}
		/>
	);
}

function EmptyHeader({ className, ...props }) {
	return (
		<div
			data-slot="empty-header"
			className={cn(
				'flex 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-neutral-200 text-foreground flex size-10 shrink-0 items-center justify-center rounded-lg [&_svg:not([class*='size-'])]:size-5",
			},
		},
		defaultVariants: {
			variant: 'default',
		},
	}
);

function EmptyMedia({ className, variant = 'default', ...props }) {
	return (
		<div
			data-slot="empty-icon"
			data-variant={variant}
			className={cn(emptyMediaVariants({ variant, className }))}
			{...props}
		/>
	);
}

function EmptyTitle({ className, ...props }) {
	return (
		<div
			data-slot="empty-title"
			className={cn('text-lg font-medium tracking-tight', className)}
			{...props}
		/>
	);
}

function EmptyDescription({ className, ...props }) {
	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 }) {
	return (
		<div
			data-slot="empty-content"
			className={cn(
				'flex w-full min-w-0 max-w-sm flex-col items-center gap-4 text-balance text-sm',
				className
			)}
			{...props}
		/>
	);
}

export {
	Empty,
	EmptyHeader,
	EmptyTitle,
	EmptyDescription,
	EmptyContent,
	EmptyMedia,
};
