Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nikitaeverywhere/toaster-js
The vanilla JavaScript ES6 minimalistic toast pup-up messages module for your project.
https://github.com/nikitaeverywhere/toaster-js
alerts css javascript messages notifications scss toast toasts
Last synced: 3 months ago
JSON representation
The vanilla JavaScript ES6 minimalistic toast pup-up messages module for your project.
- Host: GitHub
- URL: https://github.com/nikitaeverywhere/toaster-js
- Owner: nikitaeverywhere
- License: mit
- Created: 2016-04-23T09:12:05.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T20:20:12.000Z (about 2 years ago)
- Last Synced: 2024-04-14T22:46:53.111Z (10 months ago)
- Topics: alerts, css, javascript, messages, notifications, scss, toast, toasts
- Language: HTML
- Homepage: https://www.npmjs.com/package/toaster-js
- Size: 580 KB
- Stars: 25
- Watchers: 4
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
README
# Toaster-JS
[data:image/s3,"s3://crabby-images/30f68/30f684d7af530a48ab6777d3893e8917dcab1f2d" alt="npm"](https://www.npmjs.com/package/toaster-js)
[data:image/s3,"s3://crabby-images/3490e/3490edc0509992954fb7c77815d797246ad3997a" alt="Dependencies"](http://npm.anvaka.com/#/view/2d/toaster-js)
[data:image/s3,"s3://crabby-images/570fa/570fae78a70128f469c7001fb6d6354a763f194d" alt="BundleSize"](https://zitros.github.io/npm-explorer/?p=toaster-js)
[data:image/s3,"s3://crabby-images/98823/98823c3326bd852abded2a9a641047208e050457" alt="npm"](https://www.npmjs.com/package/toaster-js)
[data:image/s3,"s3://crabby-images/91f0d/91f0d4b4e81d64c2e1b3166107872b51402fa20a" alt="License"](LICENSE)The simple vanilla JavaScript toast pop-up notifications module, which is fully CSS-customizable.
The solution which "just works": add the module to your project and go further.Supported by all major browsers. Safe to use with ReactJS and other virtual-dom frameworks.
Preview
-------#### [See the demo here.](https://zitros.github.io/toaster-js)
data:image/s3,"s3://crabby-images/fefb6/fefb66c89fffa2a28da38c5ba42e76a5ec41743d" alt="Screenshot"
Features
--------+ Fully CSS-customizable toast pop-ups for any design;
+ No dependencies and `< 1kb` code;
+ Configurable toasts type and timeout;
+ Fully configurable toast content (HTML, custom elements, etc).Installation & Usage
--------------------Toaster-JS is primarily the uncompiled ES6 module. Install it with npm:
```bash
npm install toaster-js
```Then, include it to your project:
```javascript
import { Toast } from "toaster-js"; // const { Toast } = require("toaster-js/umd.js");
import "toaster-js/default.scss"; // Assuming CSS/SCSS loader is present
// Import styles from SCSS: @import "../node_modules/toaster-js/default.scss";
// Or just copy default styles to your project from node_modules/toaster-js/default.*css.
// Or draw your own styles! For instance, you can make toasts appear on the left by overwriting .toast { left: 0; right: auto; }// Simple toast
new Toast("Welcome!");// Typed toast (just a matter of CSS) with timeout
new Toast("There is a lot of toasts!", Toast.TYPE_ERROR, Toast.TIME_NORMAL);// Custom toast content example (you can also add something like close buttons, etc)
let element = document.createElement("div");
element.textContent = "You can pass any HTML elements to Toast. Clicking on this one deletes it!";
let newToast = new Toast(element, Toast.TYPE_MESSAGE);
element.addEventListener("click", () => newToast.delete()); // delete a toast on message click!
```You can set up additional options if you need. See the [API](#api) section below for more details.
```javascript
import { configureToasts, deleteAllToasts } from "toaster-js";configureToasts({
topOrigin: 0,
deleteDelay: 300
});
deleteAllToasts(); // just deletes all toasts on the screen
```If you need to load ES5 (UMD) module, use the following:
```javascript
const { Toast } = require("toaster-js/umd.js");
```If you need to include the module with a script tag (for example, for demos), use this:
```html
```
API
---+ [toast = new Toast(content, type, timeout)](#toastmessage-type-timeout)
+ `Toast.TIME_SHORT` (2000 ms)
+ `Toast.TIME_NORMAL` (4000 ms)
+ `Toast.TIME_LONG` (8000 ms, default)
+ `Toast.TYPE_INFO`
+ `Toast.TYPE_MESSAGE`
+ `Toast.TYPE_WARNING`
+ `Toast.TYPE_ERROR`
+ `Toast.TYPE_DONE`
+ `toast.delete()` - Deletes this toast from the DOM.
+ [configureToasts(options)](#configuretoastsoptions)
+ `options.topOrigin = 0` - A `number` in pixels of toasts Y-axis origin (negative values move toasts up).
+ `options.deleteDelay = 300` - A `number` representing delay in milliseconds. When toast is deleted, it stays in DOM for `deleteDelay` more milliseconds. Useful with CSS animations.
+ `deleteAllToasts()` - Deletes all toasts on the screen.##### Toast(content, type, timeout)
Creates a new toast notification message on the screen. Pass a string `content` to specify the
message text, `type` = `Toast.TYPE_*` to specify the type and `timeout` = `Toast.TIME_*` to specify
the timeout. Timeout constants are the numbers of milliseconds for message to stay on screen. For
example, `new Toast("Baked!", Toast.TYPE_ERROR, 10000)` message will stay on the screen for 10
seconds.+ `TIME_SHORT` = 2 seconds
+ `TIME_NORMAL` = 4 seconds
+ `TIME_LONG` = 8 seconds
+ `TYPE_INFO` = `"info"`
+ `TYPE_MESSAGE` = `"message"`
+ `TYPE_WARNING` = `"warning"`
+ `TYPE_ERROR` = `"error"`
+ `TYPE_DONE` = `"done"`When `content` is a valid DOM `Element`, it will be attached to the message's body directly,
allowing you to customize toast however you want.##### configureToasts(options)
Allows to configure some options of the toast. The available optional options are listed below:
```js
configureToasts({
topOrigin: -100, // [default=0] Y-axis origin of the messages (better to use CSS `transform` instead).
deleteDelay: 300 // time until the toast is completely removed from the DOM after deleting.
});
```Styles
------Import default toast styles from `node_modules/toaster-js/default.*css` (CSS, SCSS are available).
To style the toast properly, consider that toast elements (for example, `info` toasts) have three
states: empty state (when the toast attaches to the DOM), `displayed` state (when the toast is moved
to its proper position), and `deleted` state, when the toast "fades out" from the DOM. You can
control how much time the toast stays in `deleted` state until it disappears using
[deleteDelay](#api) option. States:```html
.........
```Contributing
------------Feel free to improve this project! Building the `umd.js` and `default.css` requires the following:
```bash
npm install
npm run build
```License
-------MIT © [Nikita Savchenko](https://nikita.tk/developer)