A robust, object-oriented toast notification library with zero dependencies.
- π¨ Four pre-styled types: success, error, warning, info
- βοΈ Customizable options
- π Queue management for multiple toasts
- π±οΈ Click to dismiss
- π± Responsive and mobile-friendly
- π₯ No dependencies
- π TypeScript-friendly
you can ins directly in html and also initial npm package
npm i easy-toast-js
<script src="
https://cdn.jsdelivr.net/npm/easy-toast-js@2.0.13/dist/easyToast.min.js
"></script>
- If not install Tailwind Css then add
easy-toast.min.css
orimport easy-toast.min.css
// when install throw npm import like below
import { toast } from "easy-toast-js";
// Use the default instance
toast.success("Operation successful!");
toast.error("Something went wrong");
toast.warning("Be careful");
toast.info("Did you know?");
// Or create a custom instance
const myToast = new ToastManager({
position: "bottom-right",
maxToasts: 5,
});
myToast.show("Custom toast!");
const options = {
position: "top-right", // 'top-right', 'top-left', 'bottom-right', 'bottom-left'
maxToasts: 3, // Maximum number of toasts shown at once
animationDuration: 300, // Animation duration in milliseconds
defaultDuration: 3000, // Default display duration
containerClass: "toast-container", // CSS class for the container
};
const toastManager = new ToastManager(options);
Shows a toast notification.
message
(string): The message to displaytype
(string, optional): 'success', 'error', 'warning', or 'info'. Default: 'info'duration
(number, optional): Time in milliseconds. Default: 3000- Returns:
{ element, removalPromise }
Shows a success toast.
message
(string): The success messageduration
(number, optional): Custom duration
Shows an error toast.
message
(string): The error messageduration
(number, optional): Custom duration
Shows a warning toast.
message
(string): The warning messageduration
(number, optional): Custom duration
Shows an info toast.
message
(string): The info messageduration
(number, optional): Custom duration
const customToast = new ToastManager({
position: "bottom-left",
maxToasts: 5,
defaultDuration: 5000,
});
customToast.success("Custom positioned toast!");
async function showSequentialToasts() {
await toast.success("First toast").removalPromise;
await toast.info("Second toast").removalPromise;
console.log("All toasts have been shown and dismissed");
}
interface ToastOptions {
position?: "top-right" | "top-left" | "bottom-right" | "bottom-left";
maxToasts?: number;
animationDuration?: number;
defaultDuration?: number;
containerClass?: string;
}
declare class ToastManager {
constructor(options?: ToastOptions);
show(message: string, type?: string, duration?: number): ToastResult;
success(message: string, duration?: number): ToastResult;
error(message: string, duration?: number): ToastResult;
warning(message: string, duration?: number): ToastResult;
info(message: string, duration?: number): ToastResult;
}
interface ToastResult {
element: HTMLElement;
removalPromise: Promise<void>;
}
declare const toast: ToastManager;
- Chrome (latest)
- Firefox (latest)
- Safari (latest)
- Edge (latest)
toast.success("File uploaded successfully!");
toast.error("Failed to save changes");
toast.warning("Server maintenance in 5 minutes", 10000);
async function processForm() {
await toast.info("Validating...").removalPromise;
await toast.info("Sending data...").removalPromise;
toast.success("Form submitted!");
}