Toast
Toasts are temporary notifications that provide concise feedback about an action or event.
Installation
The above command is for individual installation only. You may skip this step if @heroui/react
is already installed globally.
Import
Requirement
The ToastProvider must be added to the application's root (or the relevant part of it) before using the addToast function. This is required to initialize the context for managing toasts.
Usage
With Description
Colors
Toast comes with 6 color variants to convey different meanings.
Variants
Radius
Custom Icon
By default, Toast displays an appropriate icon based on the color
prop. You can override this by providing a custom icon using the icon
prop.
Icon Hidden
You can hide the icon by setting the hideIcon
prop to true
.
With Action
Toast supports an endContent
prop for additional actions.
With Timeout
Toast supports an endContent
prop for additional actions.
Toast Placement
Promise
Custom Styles
You can customize the alert by passing custom Tailwind CSS classes to the component slots.
Data Attributes
Toast has the following attributes on the base
element:
- data-has-title: When the toast has a title
- data-has-description: When the toast has a description
- data-animation: Shows the current animation of toast ("entering", "queued", "exiting", "undefined")
- data-placement: Where the toast is placed on the view-port.
- data-drag-value: Value by which the toast is dragged from it's original position. (This remains "0" in case of disabledAnimation)
Slots
Toast has the following slots:
base
: The main toast container elementtitle
: The title elementdescription
: The description elementicon
: The icon elementloadingIcon
: The icon to be displayed untilpromise
is resolved/rejected.content
: The wrapper for the title, description and icon contentprogressTrack
: The track of the progressBar.progressIndicator
: The indicator of the progressBar.closeButton
: The close button elementcloseIcon
: The icon which resides in the close button.
Accessibility
- Toast has role of
alert
- All Toasts are present in ToastRegion.
- Close button has aria-label="Close" by default
- When no toast are present, ToastRegion is removed from the DOM
API
Toast Props
Prop | Type | Default |
title |
| |
icon |
| |
description |
| |
color |
| "default" |
variant |
| "flat" |
radius |
| "md" |
endContent |
| |
timeout |
| "undefined" |
promise |
| "undefined" |
loadingIcon |
| |
priority |
| "undefined" |
hideIcon |
| false |
ToastProvider Props
Prop | Type | Default |
maxVisibleToasts |
| "5" |
placement |
| "right-bottom" |
disableAnimation |
| false |
toastOffset |
| "0" |
Toast Events
Prop | Type | Default |
onClose |
|