{
	"$schema": "https://shadcn-svelte.com/schema/registry-item.json",
	"name": "alert",
	"title": "Alert",
	"type": "registry:ui",
	"description": "Kura Alert component source.",
	"devDependencies": [
		"tailwind-variants@^3.2.2"
	],
	"registryDependencies": [
		"utils"
	],
	"files": [
		{
			"content": "<script lang=\"ts\">\n  import type { HTMLAttributes } from 'svelte/elements';\n  import { cn, type WithElementRef } from '$UTILS$.js';\n\n  let {\n    ref = $bindable(null),\n    class: className,\n    children,\n    ...restProps\n  }: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();\n</script>\n\n<div\n  bind:this={ref}\n  data-slot=\"alert-action\"\n  class={cn('absolute top-2.5 right-3 [&_[data-slot=button]]:rounded-full', className)}\n  {...restProps}\n>\n  {@render children?.()}\n</div>\n",
			"type": "registry:file",
			"target": "alert/alert-action.svelte"
		},
		{
			"content": "<script lang=\"ts\">\n  import type { HTMLAttributes } from 'svelte/elements';\n  import { cn, type WithElementRef } from '$UTILS$.js';\n\n  let {\n    ref = $bindable(null),\n    class: className,\n    children,\n    ...restProps\n  }: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();\n</script>\n\n<div\n  bind:this={ref}\n  data-slot=\"alert-description\"\n  class={cn(\n    'text-sm leading-relaxed text-zinc-400 text-balance md:text-pretty [&_p:not(:last-child)]:mb-4 [&_a]:text-[#d0e891] [&_a]:underline [&_a]:underline-offset-3 [&_a]:hover:text-zinc-50',\n    className\n  )}\n  {...restProps}\n>\n  {@render children?.()}\n</div>\n",
			"type": "registry:file",
			"target": "alert/alert-description.svelte"
		},
		{
			"content": "<script lang=\"ts\">\n  import type { HTMLAttributes } from 'svelte/elements';\n  import { cn, type WithElementRef } from '$UTILS$.js';\n\n  let {\n    ref = $bindable(null),\n    class: className,\n    children,\n    ...restProps\n  }: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();\n</script>\n\n<div\n  bind:this={ref}\n  data-slot=\"alert-title\"\n  class={cn(\n    'font-mono text-xs font-semibold uppercase tracking-[0.08em] text-zinc-50 group-has-[>svg]/alert:col-start-2 [&_a]:text-[#d0e891] [&_a]:underline [&_a]:underline-offset-3 [&_a]:hover:text-zinc-50',\n    className\n  )}\n  {...restProps}\n>\n  {@render children?.()}\n</div>\n",
			"type": "registry:file",
			"target": "alert/alert-title.svelte"
		},
		{
			"content": "<script lang=\"ts\" module>\n  import { type VariantProps, tv } from 'tailwind-variants';\n\n  export const alertVariants = tv({\n    base: \"relative grid w-full gap-1 border border-[#222225] bg-[#09090b] px-4 py-3 text-left text-sm shadow-none after:absolute after:-inset-y-px after:-left-px after:w-0.5 has-data-[slot=alert-action]:relative has-data-[slot=alert-action]:pr-18 has-[>svg]:grid-cols-[auto_1fr] has-[>svg]:gap-x-2.5 *:[svg]:row-span-2 *:[svg]:translate-y-0.5 *:[svg]:text-current *:[svg:not([class*='size-'])]:size-4 group/alert\",\n    variants: {\n      variant: {\n        default: 'text-zinc-50 after:bg-[#d0e891]',\n        destructive:\n          'border-[#d1242f]/60 text-[#f85149] *:data-[slot=alert-description]:text-[#f85149]/90 after:bg-[#f85149] *:[svg]:text-current'\n      }\n    },\n    defaultVariants: {\n      variant: 'default'\n    }\n  });\n\n  export type AlertVariant = VariantProps<typeof alertVariants>['variant'];\n</script>\n\n<script lang=\"ts\">\n  import type { HTMLAttributes } from 'svelte/elements';\n  import { cn, type WithElementRef } from '$UTILS$.js';\n\n  let {\n    ref = $bindable(null),\n    class: className,\n    variant = 'default',\n    children,\n    ...restProps\n  }: WithElementRef<HTMLAttributes<HTMLDivElement>> & {\n    variant?: AlertVariant;\n  } = $props();\n</script>\n\n<div\n  bind:this={ref}\n  data-slot=\"alert\"\n  role=\"alert\"\n  class={cn(alertVariants({ variant }), className)}\n  {...restProps}\n>\n  {@render children?.()}\n</div>\n",
			"type": "registry:file",
			"target": "alert/alert.svelte"
		},
		{
			"content": "import Root from './alert.svelte';\nimport Description from './alert-description.svelte';\nimport Title from './alert-title.svelte';\nimport Action from './alert-action.svelte';\nexport { alertVariants, type AlertVariant } from './alert.svelte';\n\nexport {\n  Root,\n  Description,\n  Title,\n  Action,\n  //\n  Root as Alert,\n  Description as AlertDescription,\n  Title as AlertTitle,\n  Action as AlertAction\n};\n",
			"type": "registry:file",
			"target": "alert/index.ts"
		}
	]
}