mirror of
https://github.com/LukeHagar/better-auth.git
synced 2025-12-11 04:19:31 +00:00
39 lines
1.8 KiB
TypeScript
39 lines
1.8 KiB
TypeScript
import type { ToastRootProps } from 'radix-vue'
|
|
import type { HTMLAttributes } from 'vue'
|
|
|
|
export { default as Toaster } from './Toaster.vue'
|
|
export { default as Toast } from './Toast.vue'
|
|
export { default as ToastViewport } from './ToastViewport.vue'
|
|
export { default as ToastAction } from './ToastAction.vue'
|
|
export { default as ToastClose } from './ToastClose.vue'
|
|
export { default as ToastTitle } from './ToastTitle.vue'
|
|
export { default as ToastDescription } from './ToastDescription.vue'
|
|
export { default as ToastProvider } from './ToastProvider.vue'
|
|
export { toast, useToast } from './use-toast'
|
|
|
|
import { type VariantProps, cva } from 'class-variance-authority'
|
|
|
|
export const toastVariants = cva(
|
|
'group pointer-events-auto relative flex w-full items-center justify-between space-x-2 overflow-hidden rounded-md border p-4 pr-6 shadow-lg transition-all data-[swipe=cancel]:translate-x-0 data-[swipe=end]:translate-x-[var(--radix-toast-swipe-end-x)] data-[swipe=move]:translate-x-[var(--radix-toast-swipe-move-x)] data-[swipe=move]:transition-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[swipe=end]:animate-out data-[state=closed]:fade-out-80 data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-top-full data-[state=open]:sm:slide-in-from-bottom-full',
|
|
{
|
|
variants: {
|
|
variant: {
|
|
default: 'border bg-background text-foreground',
|
|
destructive:
|
|
'destructive group border-destructive bg-destructive text-destructive-foreground',
|
|
},
|
|
},
|
|
defaultVariants: {
|
|
variant: 'default',
|
|
},
|
|
},
|
|
)
|
|
|
|
type ToastVariants = VariantProps<typeof toastVariants>
|
|
|
|
export interface ToastProps extends ToastRootProps {
|
|
class?: HTMLAttributes['class']
|
|
variant?: ToastVariants['variant']
|
|
onOpenChange?: ((value: boolean) => void) | undefined
|
|
}
|