/notific8

Flexible and themeable notification plug-in for JavaScript. The plug-in contains multiple themes, each offering a built in selection of colors and Sass mixins to easily create custom colors to match your site's color scheme.

Primary LanguageTypeScriptMIT LicenseMIT

notific8

Build Status

Notific8 is an on-page notification JavaScript library. Notific8 has built in themes which come with a set of built in colors for each. The library is designed to be easy to create new themes and colors. The library was born from a want for a simply designed yet modern and stylish notification system that was easily customizable and easy to use.

Version 5 included a major rewrite of the library to bring it up to modern standards and make it easier to use with other frameworks and libraries. Other major changes to the library include:

  • Updated the code to Typescript including a typing for for using the library in Typescript-based projects
  • Updated the testing library to use Jest
  • Simplified the build setup

Install with NPM

$ npm install notific8 --save

Demo page

An interactive demo page can be found in the demo directory. The demo is written using the Vue library and the source code serves as an example of how to use Notific8 with other libraries and frameworks.

Features

  • Promise-based functionality for more control
  • Ability to reuse notification objects
  • Notifications slide in and out from the designated corner of the page (default is upper right)
  • Configurable life span of the notification
  • Option to display a heading
  • Built in theme options with ability to create custom themes (see CSS for built in themes)
  • Ability to make the notification sticky
  • Ability to set up custom settings for reuse without having to type them over and over
  • Ability to set which corner the notifications are shown in
  • Ability to set the z-index
  • Ability to queue notifications
  • Ability to add action buttons to notifications

Browser support

Currently supported and tested:

  • Chrome
  • Firefox
  • Safari (Mac only)
  • Edge (Windows desktop only)

While not tested, this library should work on Opera versions released after the swap to Chromium. From version 5 onward, the library no longer supports Internet Explorer and that will not be added.

As a rule of thumb, only the most recent plus one version older of a browser are supported unless marked otherwise.

Future development

All planned features can be viewed by visiting the issues page.

Styles

The styles are written in Scss format and available in the src/sass directory. Development will continue in Scss only - please do not open issues or pull requests to change the default style format. Contributions containing styles must be in Scss format.

Want to help?

Want to file a bug report or contribute some code? That's most awesome! Please view the guidelines for contributing before opening an issue or pull request.

Usage

import { Notific8 } from 'notific8';

Notific8.create('Test notification').then((notification) => {
    // open the notification
    notification.open().then(() => {
        console.log('Notification has been opened!');
    });
});

// async example
(async() => {
    const notification = await Notific8.create('Test notification');
    await notification.open();
    console.log('Notification has been opened!');
})();

Options

None of the options are required. Default values are available in the library and automatically set if not provided.

actionButtons: Notific8ActionButton[]

Provides action buttons to the notification. If an action is not provided, the button's action is set to close the notification. The option is an array of Notific8ActionButton interface.

Definition of Notific8ActionButton:

interface Notific8ActionButton {
  buttonAction: Function;
  buttonText: string;
}

closeHelpText: string

Help text shown when hovering over the close button.

closeReject: Function

The close function returns a promise. This option is used for the rejection of the promise when the notification is closed by the timer or clicking the close button.

closeResolve: Function

The close function returns a promise. This option is used for the resolution of the promise when the notification is closed by the timer or clicking the close button.

horizontalEdge: 'top'|'bottom'

Horizontal edge of the screen to display the notification against. Valid options are the strings 'top' and 'bottom'.

id: string

Queriable ID given to the notification.

imageAltText: string

Alternate text on the image provided with the imageUrl option. If this is provided but imageUrl is not, this option will be ignored.

imageUrl: string

URL of the image to display on the notification.

life: number

Life of the notification until it automatically closes. If the sticky option is applied, this value is ignored.

queue: boolean

Whether or not to add the notification to the queue. The first notification sent in with the queue option true will be automatically opened if there are no notifications on the screen.

queueOpenReject: Function

The open function returns a promise. This option is used for the rejection of the promise when the notification is opened by the queue.

queueOpenResolve: Function

The open function returns a promise. This option is used for the resolution of the promise when the notification is opened by the queue.

sticky: boolean

Whether or not the notification should stay open until the user closes it. If the life option is passed in with this option, the life option will be ignored.

title: string

Heading to apply to the notification.

theme: string

Theme to add to the notification for styling. See the themes page for more information.

themeColor: string

Color of the theme to style the notification. See the themes page for more information.

verticalEdge: 'left'|'right'

Vertical edge of the screen to display the notification against. Valid options are the strings 'left' and 'right'.

zIndex: number

Z-index for layer to display the notification.

Notification API

open(): Promise

Opens the notification object. Returns a promise.

close(): Promise

Closes the notification object. Returns a promise.

Notific8 API

getDefaultOptions(): NotificationOptions

Get the default options set for the library.

setDefaultOptions(newDefaultOptions: Notific8Options): void

Set any number of default options at one time by passing in an object that complies with the Notific8Options interface.

setDefaultOption(option: string, newValue: string|number|boolean|Notific8ActionButton[]): void

Set a specific default option. The passed in option's value must comply with the property in the Notific8Options interface.

isNotific8OptionsObjectValid(optionsToCheck: object): boolean

Returns whether or not the passed in notifcation options object is valid.

create(message: string, notificationOptions: Notific8Options = notific8DefaultOptions): Promise

Creates a new notification with the passed in notification message and optional notification options object.

queueOrAddToContainer(notification: Notific8Notification): void

Determines whether to queue or add the passed in notification to a container.

hasQueuedNotifications(): boolean

Returns whether or not there are notifications in the queue.

triggerQueue(): void

Triggers the queue to fire.

License

The notific8 library is released under the MIT license.

(c) 2013-2019 Pynk Lynn LLC