Spaces:
Running
Running
| <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/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> | |