| <script lang="ts" module> | |
| import { type VariantProps, tv } from 'tailwind-variants'; | |
| export const alertVariants = tv({ | |
| base: 'relative grid w-full grid-cols-[0_1fr] items-start gap-y-0.5 rounded-lg border px-4 py-3 text-sm has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] has-[>svg]:gap-x-3 [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current', | |
| variants: { | |
| variant: { | |
| default: 'bg-card text-card-foreground', | |
| destructive: | |
| 'text-destructive bg-card *:data-[slot=alert-description]:text-destructive/90 [&>svg]:text-current' | |
| } | |
| }, | |
| defaultVariants: { | |
| variant: 'default' | |
| } | |
| }); | |
| export type AlertVariant = VariantProps<typeof alertVariants>['variant']; | |
| </script> | |
| <script lang="ts"> | |
| import type { HTMLAttributes } from 'svelte/elements'; | |
| import { cn, type WithElementRef } from '$lib/components/ui/utils.js'; | |
| let { | |
| ref = $bindable(null), | |
| class: className, | |
| variant = 'default', | |
| children, | |
| ...restProps | |
| }: WithElementRef<HTMLAttributes<HTMLDivElement>> & { | |
| variant?: AlertVariant; | |
| } = $props(); | |
| </script> | |
| <div | |
| bind:this={ref} | |
| data-slot="alert" | |
| class={cn(alertVariants({ variant }), className)} | |
| {...restProps} | |
| role="alert" | |
| > | |
| {@render children?.()} | |
| </div> | |