Notify.js is a lightweight utility library for creating toast, snackbars, and notifications.
This library does not provide any CSS or base styling for the components / HTML Elements it produces. Example styles can be found at Brixi UI.
- Notifications
- Toast
- Snackbar
- Sonner (coming soon)
Download Notify.js via NPM:
npm i --save @codewithkyle/notifyjs
Or use the CDN version:
import toaster from "https://cdn.jsdelivr.net/npm/@codewithkyle/notifyjs@5/dist/toaster.js";
import snackbar from "https://cdn.jsdelivr.net/npm/@codewithkyle/notifyjs@5/dist/snackbar.js";
import notifications from "https://cdn.jsdelivr.net/npm/@codewithkyle/notifyjs@5/dist/notifications.js";
import sonner from "https://cdn.jsdelivr.net/npm/@codewithkyle/notifyjs@5/dist/sonner.js";
Import the notification type:
import snackbar from "@codewithkyle/notifyjs/snackbar";
snackbar({
message: "All snackbar notifications require a message",
});
// Adds an action button
snackbar({
message: "All snackbar notifications require a message",
buttons: [
{
label: "Update",
callback: () => {
console.log("User clicked the update button");
},
},
],
});
import notifications from "@codewithkyle/notifyjs/notifications";
notifications.push({
title: "Notificaitons require a title",
message: "They also require a message.",
});
// Append custom toast notifications:
class CustomNotificationElement extends HTMLElement {
constructor(message){
super();
this.innerText = message;
setTimeout(() => {
this.remove();
}, 5000);
}
}
notifications.append(new CustomNotificationElement());
import toaster from "@codewithkyle/notifyjs/toaster";
toaster.push({
message: "Toast notifications require a message."
});
import sonner from "@codewithkyle/notifyjs/sonner";
sonner.push({
heading: "Sonner toast example",
message: "Heading and message are optional."
});
As of version 5 you can trigger notifications using custom events dispatched on the window
.
const event = new CustomEvent("notify:sonner", {
detail: {
heading: "Sonner Example",
message: `Example sonner toast message.`,
}
});
window.dispatchEvent(event);
The follow events are supported:
notify:sonner
notify:alert
notify:toast
notify:snackbar
The detail
object accepts the same interfaces as the function versions (see below).
As of version 5 all callback interfaces support event
and eventData
properties. When the user interacts with a button a custom event will be fired on the window
.
import sonner from "@codewithkyle/notifyjs/sonner";
sonner.push({
message: "Heading and message are optional.",
button: {
label: "Test",
event: "test-event",
eventData: "Hi mom!",
}
});
// received when the user clicks the button within the sonner notification
window.addEventListener("test-event", (e)=>{
alert(e.detail);
});
Snackbar notifications are great for quick one-off notifications that require an action.
type SnackbarNotification = {
message: string;
duration?: number; // in seconds
closeable?: boolean;
buttons?: Array<{
label: string;
callback?: Function;
ariaLabel?: string;
classes?: Array<string> | string;
autofocus?: boolean;
event?: string;
eventData?: any;
}>;
force?: boolean; // defaults to true
classes?: Array<string> | string;
autofocus?: boolean; // defaults to true
}
<snackbar-component>
<p>Custom notification message</p>
<snackbar-actions>
<button>Action</button>
<button class="close">
<svg />
</button>
</snackbar-actions>
</snackbar-component>
Notifications are great for application-like notification systems where users will need to recieve warnings, updates, successes, and errors.
type Notification = {
title: string;
message: string;
closeable?: boolean;
icon?: string; // svg or img
duration?: number; // in seconds
classes?: string[];
autofocus?: boolean; // defaults to true
buttons?: Array<{
label: string;
callback?: Function;
ariaLabel?: string;
classes?: Array<string> | string;
autofocus?: boolean;
event?: string;
eventData?: any;
}>;
timer?: "vertical" | "horizontal" | null; // defaults to null
};
<notifications-component>
<notification-component>
<i>
<svg />
</i>
<copy-wrapper>
<h3>Title</h3>
<p>Custom notification message</p>
<notification-actions>
<button>Action</button>
</notification-actions>
</copy-wrapper>
<button class="close">
<svg />
</button>
<notification-timer class="vertical || horizontal"></notification-timer>
</notification-component>
</notifications-component>
Toast notifications are great for simple temporary alerts like "Copied to clipboard" or "Added to playlist".
type ToastNotification = {
message: string;
duration?: number; // in seconds
classes?: string | string[];
};
<toaster-component>
<output role="status">Custom toast message.</output>
</toaster-component>
Sonner notifications are great for simple temporary alerts. The Sonner notification is slightly opinionated due to the custom interaction and animations.
sonner-toast-component {
opacity: var(--opacity);
transform: translateY(var(--y)) translateY(var(--offset)) scale(var(--scale));
transition: transform 300ms var(--ease-in-out), opacity 300ms var(--ease-in-out);
left: 0;
bottom: 0;
}
Note: the sonner components UX is based on the look and feel of the Sonner react package.
type SonnerNotification = {
heading?: string,
message?: string,
duration?: number,
classes?: Array<string>|string,
button?: {
callback?: Function,
label: string,
classes?: Array<string>|string,
event?: string;
eventData?: any;
}
};
<sonner-component>
<sonner-toast-component>
<copy-wrapper>
<h3>Example heading</h3>
<p>This is an example sonner message.</p>
</copy-wrapper>
<button>Click me</button>
</sonner-toast-component>
</sonner-component>