Toasts
Push notifications to your visitors with a toast, a lightweight and easily customizable alert message.
Toasts are lightweight notifications designed to mimic the push notifications that have been popularized by mobile and desktop operating systems. They’re built with flexbox, so they’re easy to align and position.
Examples
Basic
To encourage extensible and predictable toasts, we recommend a header and body. Toast headers use display: flex, allowing easy alignment of content thanks to our margin and flexbox utilities.
Toasts are as flexible as you need and have very little required markup. At a minimum, we require a single element to contain your “toasted” content and strongly encourage a dismiss button.
<Toast>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>11 mins ago</small>
</Toast.Header>
<Toast.Body>Hello, world! This is a toast message.</Toast.Body>
</Toast>
Dismissible
function Example() {
const [showA, setShowA] = useState(true);
const [showB, setShowB] = useState(true);
const toggleShowA = () => setShowA(!showA);
const toggleShowB = () => setShowB(!showB);
return (
<Row>
<Col xs={6}>
<Toast show={showA} onClose={toggleShowA}>
<Toast.Header>
<img
src="holder.js/20x20?text=%20"
className="rounded mr-2"
alt=""
/>
<strong className="mr-auto">Bootstrap</strong>
<small>11 mins ago</small>
</Toast.Header>
<Toast.Body>Woohoo, you're reading this text in a Toast!</Toast.Body>
</Toast>
</Col>
<Col xs={6}>
<Button onClick={toggleShowA}>
Toggle Toast <strong>with</strong> Animation
</Button>
</Col>
<Col xs={6} className="my-1">
<Toast onClose={toggleShowB} show={showB} animation={false}>
<Toast.Header>
<img
src="holder.js/20x20?text=%20"
className="rounded mr-2"
alt=""
/>
<strong className="mr-auto">Bootstrap</strong>
<small>11 mins ago</small>
</Toast.Header>
<Toast.Body>Woohoo, you're reading this text in a Toast!</Toast.Body>
</Toast>
</Col>
<Col xs={6}>
<Button onClick={toggleShowB}>
Toggle Toast <strong>without</strong> Animation
</Button>
</Col>
</Row>
);
}
render(<Example />);
Stacking
When you have multiple toasts, we default to vertically stacking them in a readable manner.
<>
<Toast>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>just now</small>
</Toast.Header>
<Toast.Body>See? Just like this.</Toast.Body>
</Toast>
<Toast>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>2 seconds ago</small>
</Toast.Header>
<Toast.Body>Heads up, toasts will stack automatically</Toast.Body>
</Toast>
</>
Placement
Place toasts with custom CSS as you need them. The top right is often used for notifications, as is the top middle.
<div
aria-live="polite"
aria-atomic="true"
style={{
position: 'relative',
minHeight: '100px',
}}
>
<Toast
style={{
position: 'absolute',
top: 0,
right: 0,
}}
>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>just now</small>
</Toast.Header>
<Toast.Body>See? Just like this.</Toast.Body>
</Toast>
</div>
For systems that generate more notifications, consider using a wrapping element so they can easily stack.
<div
aria-live="polite"
aria-atomic="true"
style={{
position: 'relative',
minHeight: '200px',
}}
>
<div
style={{
position: 'absolute',
top: 0,
right: 0,
}}
>
<Toast>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>just now</small>
</Toast.Header>
<Toast.Body>See? Just like this.</Toast.Body>
</Toast>
<Toast>
<Toast.Header>
<img src="holder.js/20x20?text=%20" className="rounded mr-2" alt="" />
<strong className="mr-auto">Bootstrap</strong>
<small>2 seconds ago</small>
</Toast.Header>
<Toast.Body>Heads up, toasts will stack automatically</Toast.Body>
</Toast>
</div>
</div>
Autohide
A Toast can also automatically hide after X milliseconds. For that, use the autohide
prop in combination with delay
the prop to sepecify the delay. But be aware, that it will only trigger the onClose
function, you have to set manually the show property.
function Example() {
const [show, setShow] = useState(false);
return (
<Row>
<Col xs={6}>
<Toast onClose={() => setShow(false)} show={show} delay={3000} autohide>
<Toast.Header>
<img
src="holder.js/20x20?text=%20"
className="rounded mr-2"
alt=""
/>
<strong className="mr-auto">Bootstrap</strong>
<small>11 mins ago</small>
</Toast.Header>
<Toast.Body>Woohoo, you're reading this text in a Toast!</Toast.Body>
</Toast>
</Col>
<Col xs={6}>
<Button onClick={() => setShow(true)}>Show Toast</Button>
</Col>
</Row>
);
}
render(<Example />);
API
Toast
import Toast from 'react-bootstrap/Toast'
Copy import code for the Toast component
Name |
Type |
Default |
Description |
animation |
boolean |
true |
Apply a CSS fade transition to the toast |
autohide |
boolean |
false |
|
delay |
number |
3000 |
Delay hiding the toast (ms) |
onClose |
function |
|
A Callback fired when the close button is clicked. |
show |
boolean |
true |
When true The modal will show itself. |
transition |
elementType |
<Fade> |
A react-transition-group Transition component used to animate the Toast on dismissal. |
bsPrefix |
string |
'toast' |
Change the underlying component CSS base class name and modifier class names prefix. This is an escape hatch for working with heavily customized bootstrap css. |
import ToastHeader from 'react-bootstrap/ToastHeader'
Copy import code for the ToastHeader component
Name |
Type |
Default |
Description |
closeButton |
boolean |
true |
Specify whether the Component should contain a close button |
closeLabel |
string |
'Close' |
Provides an accessible label for the close button. It is used for Assistive Technology when the label text is not readable. |
bsPrefix |
string |
|
Change the underlying component CSS base class name and modifier class names prefix. This is an escape hatch for working with heavily customized bootstrap css. |
ToastBody
import ToastBody from 'react-bootstrap/ToastBody'
Copy import code for the ToastBody component
Name |
Type |
Default |
Description |
as |
elementType |
<div> |
You can use a custom element type for this component. |
bsPrefix required
|
string |
'toast-body' |
Change the underlying component CSS base class name and modifier class names prefix. This is an escape hatch for working with heavily customized bootstrap css. |