Spaces:
Running
Running
"use client" | |
import * as React from "react" | |
import * as AlertDialogPrimitive from "@radix-ui/react-alert-dialog" | |
import { cn } from "@/lib/utils" | |
import { buttonVariants } from "@/components/ui/button" | |
function AlertDialog({ | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Root>) { | |
return <AlertDialogPrimitive.Root data-slot="alert-dialog" {...props} /> | |
} | |
function AlertDialogTrigger({ | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Trigger>) { | |
return ( | |
<AlertDialogPrimitive.Trigger data-slot="alert-dialog-trigger" {...props} /> | |
) | |
} | |
function AlertDialogPortal({ | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Portal>) { | |
return ( | |
<AlertDialogPrimitive.Portal data-slot="alert-dialog-portal" {...props} /> | |
) | |
} | |
function AlertDialogOverlay({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Overlay>) { | |
return ( | |
<AlertDialogPrimitive.Overlay | |
data-slot="alert-dialog-overlay" | |
className={cn( | |
"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50", | |
className | |
)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogContent({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Content>) { | |
return ( | |
<AlertDialogPortal> | |
<AlertDialogOverlay /> | |
<AlertDialogPrimitive.Content | |
data-slot="alert-dialog-content" | |
className={cn( | |
"bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg", | |
className | |
)} | |
{...props} | |
/> | |
</AlertDialogPortal> | |
) | |
} | |
function AlertDialogHeader({ | |
className, | |
...props | |
}: React.ComponentProps<"div">) { | |
return ( | |
<div | |
data-slot="alert-dialog-header" | |
className={cn("flex flex-col gap-2 text-center sm:text-left", className)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogFooter({ | |
className, | |
...props | |
}: React.ComponentProps<"div">) { | |
return ( | |
<div | |
data-slot="alert-dialog-footer" | |
className={cn( | |
"flex flex-col-reverse gap-2 sm:flex-row sm:justify-end", | |
className | |
)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogTitle({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Title>) { | |
return ( | |
<AlertDialogPrimitive.Title | |
data-slot="alert-dialog-title" | |
className={cn("text-lg font-semibold", className)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogDescription({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Description>) { | |
return ( | |
<AlertDialogPrimitive.Description | |
data-slot="alert-dialog-description" | |
className={cn("text-muted-foreground text-sm", className)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogAction({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Action>) { | |
return ( | |
<AlertDialogPrimitive.Action | |
className={cn(buttonVariants(), className)} | |
{...props} | |
/> | |
) | |
} | |
function AlertDialogCancel({ | |
className, | |
...props | |
}: React.ComponentProps<typeof AlertDialogPrimitive.Cancel>) { | |
return ( | |
<AlertDialogPrimitive.Cancel | |
className={cn(buttonVariants({ variant: "outline" }), className)} | |
{...props} | |
/> | |
) | |
} | |
export { | |
AlertDialog, | |
AlertDialogPortal, | |
AlertDialogOverlay, | |
AlertDialogTrigger, | |
AlertDialogContent, | |
AlertDialogHeader, | |
AlertDialogFooter, | |
AlertDialogTitle, | |
AlertDialogDescription, | |
AlertDialogAction, | |
AlertDialogCancel, | |
} | |