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
nuxt-notify relies entirely on Tailwind utility classes. Without Tailwind, toasts will render but appear unstyled.notify.showIcon is true, @nuxt/icon must be installed.top-right, top-left, bottom-right, bottom-left, top-center, bottom-center)nuxt.config.tsmaxToasts stack overridenpx nuxt module add nuxt-notify
Or manually:
npm install nuxt-notify
# pnpm add nuxt-notify
# yarn add nuxt-notify
Choose ONE option.
npx nuxi@latest module add tailwindcss
export default defineNuxtConfig({
modules: ["@nuxtjs/tailwindcss", "nuxt-notify"],
});
@tailwind base;
@tailwind components;
@tailwind utilities;
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.
npx nuxi@latest module add icon
export default defineNuxtConfig({
modules: ["nuxt-notify"],
notify: {
position: "top-right",
duration: 5000,
maxToasts: 5,
theme: "dark",
showIcon: true,
},
});
The toast container is mounted automatically.
<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>
toast.add({
title: "Replace stack",
maxToasts: 1,
});
Overrides the global stack size for that toast only.
toast.add({
title: "Custom UI",
ui: {
root: "rounded-2xl border border-dashed",
title: "text-base font-semibold",
description: "text-xs opacity-80",
},
});
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 *));
MIT
Nizam Omer
Website: https://www.nizaamomer.com
GitHub: https://github.com/nizaamomer
Made with 💚 by Nizam Omer