We recommend implementing a single instance of <Toaster>
in global scope of your app, typically within a root layout. This single instance will manage a toast group with a toaster
instance (via createToaster
). Style props applied to the <Toaster>
component are applied all child toasts created within that instance.
Type
You can use the generic create()
method in combination with a specific type, or opt for the shorthand methods if preferred: info()
, success()
, warning()
, or error()
.
Placement
Use the placement
prop on <Toaster>
to set the position of the toast group.
Promise
Use promise()
to create a toast that is able to be configured based on the state of a promise. The toast will automatically update based on the state of the promise.
Styling for React 18
For React 18 add these styles to your global stylesheet. For React 19+, these styles are set automatically.
[data-scope='toast'][data-part='root'] { translate: var(--x) var(--y); scale: var(--scale); z-index: var(--z-index); height: var(--height); opacity: var(--opacity); will-change: translate, opacity, scale;}
[data-scope='toast'][data-part='root'] { transition: translate 400ms, scale 400ms, opacity 400ms; transition-timing-function: cubic-bezier(0.21, 1.02, 0.73, 1);}
[data-scope='toast'][data-part='root'][data-state='closed'] { transition: translate 400ms, scale 400ms, opacity 200ms; transition-timing-function: cubic-bezier(0.06, 0.71, 0.55, 1);}
API Reference
Toaster
Property | Type | Description |
---|---|---|
toaster * | ToastStore<any> | |
base | string | |
width | string | |
padding | string | |
rounded | string | |
classes | string | |
messageBase | string | |
messageClasses | string | |
titleBase | string | |
titleClasses | string | |
descriptionBase | string | |
descriptionClasses | string | |
btnDismissBase | string | |
btnDismissClasses | string | |
stateInfo | string | |
stateSuccess | string | |
stateWarning | string | |
stateError | string | |
Toast
Property | Type | Description |
---|---|---|
toast * | Options<any> | |
parent * | ToastGroupService | |
base | string | |
width | string | |
padding | string | |
rounded | string | |
classes | string | |
messageBase | string | |
messageClasses | string | |
titleBase | string | |
titleClasses | string | |
descriptionBase | string | |
descriptionClasses | string | |
btnDismissBase | string | |
btnDismissClasses | string | |
stateInfo | string | |
stateSuccess | string | |
stateWarning | string | |
stateError | string | |
Alternatives
If you’re looking for power user features or more control over templates, consider using React-Hot-Toast.