UNPKG

reablocks

Version:
53 lines (52 loc) 1.58 kB
import { default as React, FC, ReactNode, JSXElementConstructor } from 'react'; import { NotificationVariants } from './NotificationsContext'; import { NotificationTheme } from './NotificationTheme'; export interface NotificationComponentProps { /** Message text to display in the notification. */ message: string; /** Variant style of the notification. */ variant: NotificationVariants; /** Called when the notification is closed. */ onClose?: () => void; } export interface NotificationsProps { /** * @default 10 */ limit?: number; /** * @default 4000 */ timeout?: number; /** * @default true */ showClose?: boolean; /** * @default true */ preventFlooding?: boolean; /** Children rendered inside the notifications provider. */ children?: ReactNode; /** Additional class name applied to each notification. */ className?: string; /** Custom notification components keyed by variant. */ components?: { [variant in NotificationVariants]?: JSXElementConstructor<NotificationComponentProps>; }; /** * @default { * default: <InfoIcon />, * success: <CheckCircleIcon />, * warning: <WarningIcon />, * error: <ErrorCircleIcon />, * info: <InfoIcon /> * } */ icons?: { [variant in NotificationVariants]?: string | React.JSX.Element | React.JSX.Element[]; }; /** Theme for the notifications. */ theme?: NotificationTheme; } export declare const Notifications: FC<NotificationsProps>;