JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 67
  • Score
    100M100P100Q81303F
  • License Apache-2.0

A lightweight, zero-dependency toast notification library with CTA support for modern JavaScript applications with production-grade reliability and comprehensive system mechanisms

Package Exports

  • customizable-toast-notification
  • customizable-toast-notification/package.json

Readme

🍞 Customizable Toast Notifications

npm version License: Apache-2.0 Downloads Bundle Size

A lightweight, zero-dependency toast notification library for modern JavaScript applications. Built with production-grade reliability and comprehensive secret mechanisms.

✨ Key Features

  • 🚫 Zero Dependencies - Pure JavaScript with no external requirements Lightweight and fast
  • πŸ›‘οΈ Production Ready - Reliable and scalable for production environments
  • 🎨 Highly Customizable - Colors, positions, animations, progress bars
  • 🌐 Framework Agnostic - Works with React, Vue, Angular, or vanilla JS
  • πŸ“± Responsive - Works on all screen sizes and devices
  • ⚑ CDN Ready - Easy integration via CDN or npm
  • 🎨 Fully Customizable - Colors, positions, animations, and styling
  • β™Ώ Accessible - ARIA live regions and keyboard navigation support
  • πŸ”„ Smart Grouping - Duplicate notifications are automatically grouped with badges
  • ⏸️ Pause on Hover - CTA toasts pause when user hovers or focuses
  • 🎯 Call-to-Action - Built-in support for interactive buttons and links
  • πŸ“Š Queue Management - Maximum 3 visible toasts with intelligent queueing
  • 🌈 Multiple Themes - Success, error, warning, and info styles
  • πŸ”§ TypeScript Ready - TypeScript definitions included Full type support (coming soon)

πŸ“¦ Installation

NPM/Yarn

npm install customizable-toast-notification

or

yarn add customizable-toast-notification

πŸš€ Quick Start

ES Modules

import { createToast, setDefaultColors, setDefaultMessages } from 'customizable-toast-notification';

// Simple usage
createToast({
message: "Hello World!",
type: "success",
duration: 3000
});

CDN/Browser (UMD Build)

Global Variable Name: customizableToast

<script src="https://cdn.jsdelivr.net/npm/customizable-toast-notification@latest/dist/index.umd.js"></script>

<script> customizableToast.createToast({ message: "Hello from CDN!", type: "success", position: "top-right" }); </script>

πŸ“– API Reference

createToast(options)

Creates and displays a toast notification.

Options

Parameter Type Default Description
message string Based on type Toast message content
type string "info" "info", "success", "error", "warning"
duration number 3000 Auto-dismiss time in milliseconds
position string "bottom-right" Toast position on screen
backgroundColor string Based on type Custom background color
textColor string "white" Custom text color
showCloseButton boolean false Show close (Γ—) button
showProgressBar boolean false Show countdown progress bar
animationDuration string "0.5s" CSS animation duration
animationEasing string "ease" CSS animation easing function
progressColor string rgba(255,255,255,0.3) Progress bar color
progressHeight string "4px" Progress bar height
progressPosition string "bottom" Progress bar position: "top" or "bottom"
pauseOnHover boolean auto Pause timer on hover (auto: true for CTA toasts)
cta object null Call-to-action configuration (see CTA)

Position Options

// Corner positions
- "top-left", "top-right", "bottom-left", "bottom-right"

// Edge positions
- "top-center", "bottom-center", "left-center", "right-center"

// Full width
- "top-full-width", "bottom-full-width"

// Center
- "center"

🎯 Call-to-Action (CTA)

Add interactive buttons or links to your toasts:

// Button CTA
createToast({
message: "File uploaded successfully!",
type: "success",
cta: {
label: "View File",
onClick: () => {
window.open('/files/latest');
},
autoClose: true // Close toast after click (default: true)
}
});

// Link CTA
createToast({
message: "New version available!",
cta: {
label: "Download",
href: "https://example.com/download",
variant: "link",
target: "_blank"
}
});

// Advanced CTA with async action
createToast({
message: "Ready to sync your data?",
cta: {
label: "Sync Now",
ariaLabel: "Start data synchronization",
autoClose: false,
onClick: async () => {
await performDataSync();
// Manually close if needed
}
}
});

CTA Options

Parameter Type Default Description
label string required Button/link text
onClick function null Click handler (for buttons)
href string null URL (for links)
variant string "button" "button" or "link"
target string null Link target ("_blank", etc.)
rel string auto Link relationship
autoClose boolean true Close toast after CTA click
ariaLabel string label Accessibility label

🎨 Examples

All Toast Types

setDefaultColors(colors)

Configure default colors for toast types.

setDefaultColors({
success: "#10b981",
error: "#ef4444",
warning: "#f59e0b",
info: "#3b82f6"
});

setDefaultMessages(messages)

Configure default messages for toast types.

setDefaultMessages({
success: "Operation completed successfully!",
error: "Something went wrong!",
warning: "Please check your input!",
info: "Here's some information!"
});

πŸ’‘ Examples

Basic Toast Types

// Success
createToast({ type: "success", message: "Data saved!" });

// Error
createToast({ type: "error", message: "Save failed!" });

// Warning
createToast({ type: "warning", message: "Please confirm!" });

// Info
createToast({ type: "info", message: "New update available!" });

Advanced Customization

createToast({
message: "File uploading...",
type: "info",
duration: 5000,
position: "top-center",
showProgressBar: true,
showCloseButton: true,
backgroundColor: "#6366f1",
textColor: "white",
progressColor: "#e0e7ff",
progressPosition: "top",
animationDuration: "0.8s",
animationEasing: "ease-out"
});

### App-wide Configuration

// Set your brand colors once
setDefaultColors({
success: "#10b981", // Your brand green
error: "#ef4444", // Your brand red
warning: "#f59e0b", // Your brand yellow
info: "#3b82f6" // Your brand blue
});

// Set your app messages
setDefaultMessages({
success: "βœ… Success! Changes saved.",
error: "❌ Error! Please try again.",
warning: "⚠️ Warning! Check your input.",
info: "πŸ’‘ Info! Here's a tip."
});

// Now just use types throughout your app
createToast({ type: "success" }); // Uses your custom colors & messages

πŸ”„ Advanced Features

Smart Grouping

Identical toasts (same type, message, and position) are automatically grouped:

  • Shows a single toast with a badge counter
  • Resets the dismiss timer when new duplicates arrive
  • Maximum of 3 toasts visible at once

Queue Management

  • Only 3 toasts are shown simultaneously
  • Additional toasts are queued automatically
  • Queue is processed as toasts are dismissed

Accessibility

  • ARIA live regions announce new toasts to screen readers
  • Keyboard navigation support (Tab, Enter, Escape)
  • High contrast badge design
  • Semantic HTML structure

πŸ›‘οΈ Reliability Features

Production-Grade System

  • **Rich toast β†’ Basic toast β†’ Emergency alert
  • Zero-Crash Guarantee: Comprehensive error handling prevents application crashes
  • Memory Management: Automatic cleanup prevents memory leaks
  • CDN Cache-Busting: Ensures fresh content delivery

Browser Compatibility

  • βœ… Chrome
  • βœ… Firefox
  • βœ… Safari
  • βœ… Edge
  • βœ… Mobile browsers

πŸ“ Bundle Information

  • Size: ~8KB minified, ~4KB gzipped
  • Dependencies: Zero
  • Formats: UMD, ES Modules
  • TypeScript: Definitions included (full coming soon)

🀝 Contributing

Exciting times ahead! Looking for sponsors and eager to explore new collaborations:) . Contributions are welcome! Please read our Contributing Guidelines for details.

Development Setup

git clone https://github.com/sammy-cool/customizable-toast-notification.git
cd customizable-toast-notification
npm install
npm run build

πŸ“„ License

This project is licensed under the Apache-2.0 License.

πŸ‘¨β€πŸ’» Author

Priyanshu Patel


πŸ’– Support

If this library helped your project, please consider:

⭐ Star this repository to show your support!

πŸ’Œ Share feedback at priyanshu.alt191@gmail.com

β˜• Buy me a coffee if you'd like to support development:

πŸ“± Support via QR Code

Support QR

Thank you for your support! πŸ™


Made with ❀️ for the JavaScript community