nuxt-notify
Nuxt Notify ๐
Advanced toast notifications for Nuxt 3 / Nuxt 4 using Tailwind CSS and Nuxt Icon โ clean UI, actions, avatars, progress, themes, and per-toast Tailwind overrides.
Maintained by Nizam Omer (
nizaamomer)
Official site: https://nuxt-notify.nizaamomer.com/
Website: https://www.nizaamomer.com
GitHub: https://github.com/nizaamomer/nuxt-notify
Requirements
- Tailwind CSS is required
nuxt-notifyrelies entirely on Tailwind utility classes. Without Tailwind, toasts will render but appear unstyled. - @nuxt/icon is required for icons
Icons are enabled by default. Ifnotify.showIconistrue,@nuxt/iconmust be installed.
Features
- โจ Nuxt 3 & Nuxt 4 compatible
- ๐ Auto-mounts the toast container (no manual component setup)
- ๐จ Works with Tailwind v3 and Tailwind v4
- ๐ Automatic Tailwind component scanning
- ๐ญ Nuxt Icon integration
- ๐ Multiple positions (
top-right,top-left,bottom-right,bottom-left,top-center,bottom-center) - โ๏ธ Global configuration via
nuxt.config.ts - ๐ฏ Global + per-toast icon control
- ๐ Actions (vertical & horizontal layouts)
- ๐ค Avatars (image / icon / text)
- โฑ๏ธ Progress bar with pause on hover
- ๐จ Per-toast Tailwind UI overrides
- ๐ฆ Per-toast
maxToastsstack override
Installation
1) Install the module
npx nuxt module add nuxt-notify
Or manually:
npm install nuxt-notify
# pnpm add nuxt-notify
# yarn add nuxt-notify
Tailwind CSS Setup
Choose ONE option.
Option A: Tailwind v3 (Recommended)
npx nuxi@latest module add tailwindcss
export default defineNuxtConfig({
modules: ["@nuxtjs/tailwindcss", "nuxt-notify"],
});
@tailwind base;
@tailwind components;
@tailwind utilities;
Option B: Tailwind v4 (Vite Plugin)
npm install tailwindcss @tailwindcss/vite
import tailwindcss from "@tailwindcss/vite";
export default defineNuxtConfig({
modules: ["nuxt-notify"],
vite: {
plugins: [tailwindcss()],
},
css: ["~/assets/css/main.css"],
});
@import "tailwindcss";
@import "nuxt-notify/styles";
โ ๏ธ Required for Tailwind v4 component scanning.
Install Nuxt Icon
npx nuxi@latest module add icon
Quick Start
export default defineNuxtConfig({
modules: ["nuxt-notify"],
notify: {
position: "top-right",
duration: 5000,
maxToasts: 5,
theme: "dark",
showIcon: true,
},
});
The toast container is mounted automatically.
Usage
<script setup>
const toast = useToast();
toast.success("Saved", "Your changes were saved.");
toast.error("Error", "Something went wrong.");
toast.info("Heads up", "New version is available.");
toast.warning("Careful", "This action cannot be undone.");
</script>
Per-Toast maxToasts
toast.add({
title: "Replace stack",
maxToasts: 1,
});
Overrides the global stack size for that toast only.
Custom UI Overrides
toast.add({
title: "Custom UI",
ui: {
root: "rounded-2xl border border-dashed",
title: "text-base font-semibold",
description: "text-xs opacity-80",
},
});
Troubleshooting
Tailwind v4 dark mode not working
If you are using Tailwind v4 and dark: classes are not applying even though html.dark is present (for example when notify.theme: "system"), add this line to your main CSS file:
@custom-variant dark (&:where(.dark, .dark *));
Example (assets/css/main.css):
@import "tailwindcss";
@import "nuxt-notify/styles";
/* Ensure Tailwind v4 dark: utilities follow html.dark */
@custom-variant dark (&:where(.dark, .dark *));
Documentation & Changelog
- ๐ Documentation & Playground: https://nuxt-notify.nizaamomer.com/
- ๐งพ Changelog: CHANGELOG.md
License
MIT
Author
Nizam Omer
Website: https://www.nizaamomer.com
GitHub: https://github.com/nizaamomer
Made with ๐ by Nizam Omer