// // Copyright 2023 DXOS.org // import { Primitive } from '@radix-ui/react-primitive'; import { Slot } from '@radix-ui/react-slot'; import { ToastProvider as ToastProviderPrimitive, type ToastProviderProps as ToastProviderPrimitiveProps, ToastViewport as ToastViewportPrimitive, type ToastViewportProps as ToastViewportPrimitiveProps, Root as ToastRootPrimitive, type ToastProps as ToastRootPrimitiveProps, ToastTitle as ToastTitlePrimitive, type ToastTitleProps as ToastTitlePrimitiveProps, ToastDescription as ToastDescriptionPrimitive, type ToastDescriptionProps as ToastDescriptionPrimitiveProps, ToastAction as ToastActionPrimitive, type ToastActionProps as ToastActionPrimitiveProps, ToastClose as ToastClosePrimitive, type ToastCloseProps as ToastClosePrimitiveProps, } from '@radix-ui/react-toast'; import React, { type ComponentPropsWithRef, forwardRef, type FunctionComponent } from 'react'; import { useThemeContext } from '../../hooks'; import { type ThemedClassName } from '../../util'; import { ElevationProvider } from '../ElevationProvider'; type ToastProviderProps = ToastProviderPrimitiveProps; const ToastProvider: FunctionComponent = ToastProviderPrimitive; type ToastViewportProps = ThemedClassName; const ToastViewport = forwardRef(({ classNames, ...props }, forwardedRef) => { const { tx } = useThemeContext(); return ( ); }); type ToastRootProps = ThemedClassName; const ToastRoot = forwardRef(({ classNames, children, ...props }, forwardedRef) => { const { tx } = useThemeContext(); return ( {children} ); }); type ToastBodyProps = ThemedClassName>; const ToastBody = forwardRef(({ asChild, classNames, ...props }, forwardedRef) => { const { tx } = useThemeContext(); const Root = asChild ? Slot : Primitive.div; return ; }); type ToastTitleProps = ThemedClassName; const ToastTitle = forwardRef( ({ asChild, classNames, ...props }, forwardedRef) => { const { tx } = useThemeContext(); const Root = asChild ? Slot : ToastTitlePrimitive; return ; }, ); type ToastDescriptionProps = ThemedClassName; const ToastDescription = forwardRef( ({ asChild, classNames, ...props }, forwardedRef) => { const { tx } = useThemeContext(); const Root = asChild ? Slot : ToastDescriptionPrimitive; return ( ); }, ); type ToastActionsProps = ThemedClassName>; const ToastActions = forwardRef( ({ asChild, classNames, ...props }, forwardedRef) => { const { tx } = useThemeContext(); const Root = asChild ? Slot : Primitive.div; return ; }, ); type ToastActionProps = ToastActionPrimitiveProps; const ToastAction: FunctionComponent = ToastActionPrimitive; type ToastCloseProps = ToastClosePrimitiveProps; const ToastClose: FunctionComponent = ToastClosePrimitive; export const Toast = { Provider: ToastProvider, Viewport: ToastViewport, Root: ToastRoot, Body: ToastBody, Title: ToastTitle, Description: ToastDescription, Actions: ToastActions, Action: ToastAction, Close: ToastClose, }; export type { ToastProviderProps, ToastViewportProps, ToastRootProps, ToastBodyProps, ToastTitleProps, ToastDescriptionProps, ToastActionsProps, ToastActionProps, ToastCloseProps, };