React Toast - Flowbite
Push notifications to your website visitors using the toast component and choose from multiple sizes, colors, styles, position and icons based on React and Tailwind CSS
The toast component can be used to show notifications to your users in a non-intrusive way by positioning it to the corner of the screen. It can be used to show simple messages or more complex ones with buttons and other elements.
Choose from one of the examples below that include different layouts, colors, styles, and icons that you can also customize using React props and the utility classes from Tailwind CSS.
To start using the toast component make sure you import it from Flowbite React:
import { Toast } from "flowbite-react";
#
Default toastUse the default <Toast>
React component to show a simple toast message with an icon and a text message.
import { Toast, ToastToggle } from "flowbite-react";
import { HiFire } from "react-icons/hi";
export function Component() {
return (
<Toast>
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-cyan-100 text-cyan-500 dark:bg-cyan-800 dark:text-cyan-200">
<HiFire className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">Set yourself free.</div>
<ToastToggle />
</Toast>
);
}
#
Toast colorsChoose one of the following toast examples based on form submission messages to update the color of the component by using the bg
and text
utility classes from Tailwind CSS.
import { Toast, ToastToggle } from "flowbite-react";
import { HiCheck, HiExclamation, HiX } from "react-icons/hi";
export function Component() {
return (
<div className="flex flex-col gap-4">
<Toast>
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-green-100 text-green-500 dark:bg-green-800 dark:text-green-200">
<HiCheck className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">Item moved successfully.</div>
<ToastToggle />
</Toast>
<Toast>
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-red-100 text-red-500 dark:bg-red-800 dark:text-red-200">
<HiX className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">Item has been deleted.</div>
<ToastToggle />
</Toast>
<Toast>
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-orange-100 text-orange-500 dark:bg-orange-700 dark:text-orange-200">
<HiExclamation className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">Improve password difficulty.</div>
<ToastToggle />
</Toast>
</div>
);
}
#
Feedback toastUse this example to show a message based on form submission to indicate errors or successful actions.
import { Toast } from "flowbite-react";
import { FaTelegramPlane } from "react-icons/fa";
export function Component() {
return (
<Toast>
<FaTelegramPlane className="h-5 w-5 text-cyan-600 dark:text-cyan-500" />
<div className="pl-4 text-sm font-normal">Message sent successfully.</div>
</Toast>
);
}
#
Toast with buttonAdd a button to the toast component to allow the user to perform an action or close the toast.
import { Toast, ToastToggle } from "flowbite-react";
export function Component() {
return (
<Toast>
<div className="text-sm font-normal">Conversation archived.</div>
<div className="ml-auto flex items-center space-x-2">
<a
href="#"
className="rounded-lg p-1.5 text-sm font-medium text-cyan-600 hover:bg-cyan-100 dark:text-cyan-500 dark:hover:bg-gray-700"
>
Undo
</a>
<ToastToggle />
</div>
</Toast>
);
}
#
Interactive toastThis component can be used to show more complex messages with buttons and other elements that can be used to perform actions and use the <ToastToggle>
component to allow the user to close the toast component.
import { Button, Toast, ToastToggle } from "flowbite-react";
import { MdLoop } from "react-icons/md";
export function Component() {
return (
<Toast>
<div className="flex items-start">
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-cyan-100 text-cyan-500 dark:bg-cyan-900 dark:text-cyan-300">
<MdLoop className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">
<span className="mb-1 text-sm font-semibold text-gray-900 dark:text-white">Update available</span>
<div className="mb-2 text-sm font-normal">A new software version is available for download.</div>
<div className="flex gap-2">
<div className="w-auto">
<Button size="xs">Update</Button>
</div>
<div className="w-auto">
<Button color="light" size="xs">
Not now
</Button>
</div>
</div>
</div>
<ToastToggle />
</div>
</Toast>
);
}
#
Custom dismissal handlingBy passing the onDismiss
callback prop to the <ToastToggle>
component, you gain the ability to define your preferred dismissal handling (ex: using other toast libraries like react-toastfy
). When onDismiss
is provided, the internal state of the <Toast />
component will remain unchanged upon clicking <ToastToggle>
.
"use client";
import { Button, Toast, ToastToggle } from "flowbite-react";
import { useState } from "react";
import { HiFire } from "react-icons/hi";
export function Component() {
const [showToast, setShowToast] = useState(false);
return (
<div className="space-y-4">
<Button onClick={() => setShowToast((state) => !state)}>Toggle toast</Button>
{showToast && (
<Toast>
<div className="inline-flex h-8 w-8 shrink-0 items-center justify-center rounded-lg bg-cyan-100 text-cyan-500 dark:bg-cyan-800 dark:text-cyan-200">
<HiFire className="h-5 w-5" />
</div>
<div className="ml-3 text-sm font-normal">Set yourself free.</div>
<ToastToggle onDismiss={() => setShowToast(false)} />
</Toast>
)}
</div>
);
}
#
ThemeTo learn more about how to customize the appearance of components, please see the Theme docs.
{
"root": {
"base": "flex w-full max-w-xs items-center rounded-lg bg-white p-4 text-gray-500 shadow dark:bg-gray-800 dark:text-gray-400",
"closed": "opacity-0 ease-out"
},
"toggle": {
"base": "-m-1.5 ml-auto inline-flex h-8 w-8 rounded-lg bg-white p-1.5 text-gray-400 hover:bg-gray-100 hover:text-gray-900 focus:ring-2 focus:ring-gray-300 dark:bg-gray-800 dark:text-gray-500 dark:hover:bg-gray-700 dark:hover:text-white",
"icon": "h-5 w-5 shrink-0"
}
}