
Product
Introducing Webhook Events for Alert Changes
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.
notify-util
Advanced tools
Very simple notification system for JS/TS projects.
npm i notify-util
Alternatively, you can include the bundled js file in dist, where notifyUtil is available in the window.
Have a div with attribute sn-notification-container.
You can use the built in class if you want. It puts it in the top right of the page and adds gap between each notification.
<div nu_notification-container class="nu_notification-container"></div>
import notifyUtil from 'notify-util'
notifyUtil.configure({});
new notifyUtil.Notification({
type: "success",
heading: "Wow that was fast!",
body: "Skrt skrt",
});
import notifyUtil from 'notify-util'
notifyUtil.configure({
// options here
});
You must run configure before using the Notification class.
To run without customization, pass an empty object as argument.
You can override any of default settings by following the structure below.

| Option | Description |
|---|---|
| containerSelector | Selector for notification container. Attribute, ID, class as string with # or . as needed |
| classes | Override the default CSS classes by providing your own |
| → notificationClass | CSS class as string, no prefixed . |
| → headingWrapperClass | CSS class as string, no prefixed . |
| → iconClass | CSS class as string, no prefixed . |
| → headingClass | CSS class as string, no prefixed . |
| → bodyClass | CSS class as string, no prefixed . |
| → progressBarClass | CSS class as string, no prefixed . |
| icons | Override the default icons by providing your own. |
| → success | string injected as HTML |
| → warning | string injected as HTML |
| → error | string injected as HTML |
| → debug | string injected as HTML |
| → loading | string injected as HTML |
| → spinner | string injected as HTML |
| Theme | string light / dark / auto / none |
configureNotification({
containerSelector: '[nu_notification-container]',
classes: {
notificationClass: 'nu_notification',
headingWrapperClass: 'nu_notification-heading-wrapper',
iconClass: 'nu_notification-icon',
headingClass: 'nu_notification-heading',
bodyClass: 'nu_notification-body',
progressBarClass: 'nu_notification-progress-bar'
},
icons: {
success: icons.svg.success,
warning: icons.svg.warning,
error: icons.svg.error,
debug: icons.svg.debug,
spinner: icons.svg.spinner,
info: icons.svg.info
},
theme: 'light'
});
Displays a notification with a heading and message. Can be closed by clicking on it when enabled.
Returns an object if you need to remove it programmatically. e.g.: myNotification.remove().
For spinner, clickToClose is forced false and duration is forced null.
new notifyUtil.Notification({
type: 'success' | 'warning' | 'error' | 'debug' | 'info' | 'spinner', // Required
heading: string, // Required
body: string,
duration: number | null, // Default: 3500 (ms), null for infinite
clickToClose: boolean // Default: true
});
new notifyUtil.Notification({
type: 'success',
heading: 'Success heading',
body: 'Success message'
});
const loadingIndicator = new notifyUtil.Notification({
type: 'spinner',
heading: 'Loading...',
body: 'Working on it'
});
// some time passes
loadingIndicator.update({
heading: 'Loading...',
body: 'Almost there'
});
// some time passes
loadingIndicator.close();
// some time passes
myLoaderMessage.close();
FAQs
Very simple notification system for JS/TS projects.
We found that notify-util demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.

Security News
ENISA has become a CVE Program Root, giving the EU a central authority for coordinating vulnerability reporting, disclosure, and cross-border response.

Product
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.