Agnostic and responsive notifications javascript module
npm i js-toaster
With a bundler like webpack:
import 'js-toaster/jsToaster.css'
import { jsToaster } from 'js-toaster';
You can import sources too from unpkg.com:
<link rel="stylesheet" href="https://unpkg.com/js-toaster@0.6.0/jsToaster.css">
<script type="module">
import { jsToaster } from 'https://unpkg.com/js-toaster@0.6.0/jsToaster.min.js';
...
</script>
You can just send a notification with a text (the toast will be sent with the default or override configuration)...
const id = jsToaster.toast('My notification text');
...or passing as a parameter a complete toast object
const id = jsToaster.toast({
message: 'My notification text',
title: 'My notification title',
link: string | boolean //URL or boolean
displayTime: 20, //seconds. 0 if there is no end
dark: true | false, //Toast dark mode
position: 'topLeft' | 'topRight' | 'bottomRight' | 'bottomLeft',
type: 'info' | 'success' | 'warning' | 'danger' //Define the color of the toast
});
Important note: Only the message
is required. The title
and link
can be empty. Other properties are optional and take as value those of the configuration.
About the link
property:
- A URL generates a redirection on clicking the toast.
- A
true
value triggers a click event (see below) on clicking the toast. The toast is closed after the click.
jsToaster.toast
function returns a toast identifier. This id
is a number and is a useful reference when clicking on a toast.
You can override default toaster configuration
jsToaster.conf = {
displayTime: 20, //DEFAULT 20 - seconds. 0 if there is no end
dark: true | false, //DEFAULT false - Toast dark mode
position: 'topLeft' | 'topRight' | 'bottomRight' | 'bottomLeft', //DEFAULT 'topRight'
type: 'info' | 'success' | 'warning' | 'danger', //DEFAULT 'info' - Define the color of the toast
marginTop: 0, //DEFAULT 0 - Allows you to define a top margin for toasts displayed in 'topLeft' and 'topRight' positions
marginBottom: 0, //DEFAULT 0 - Allows you to define a bottom margin for toasts displayed in 'bottomLeft' and 'bottomRight' positions
mobilePosition: 'top' | 'bottom', //DEFAULT 'bottom' - On mobile devices, all toasts are stacked at the top or bottom
mobileMargin: undefined, //DEFAULT `undefined` - Define the top or bottom margin on mobile devices
};
note: all properties are optional.
About the mobileMargin
property:
It overrides the default marginTop
or marginBottom
values on mobile devices.
mobileMargin |
mobilePosition |
css margin-top | css margin-bottom |
---|---|---|---|
undefined | top |
marginTop |
0 |
undefined | bottom |
0 | marginBottom |
number | top |
mobileMargin |
0 |
number | bottom |
0 | mobileMargin |
If you define a true
value for the link
property of a toast, a click on this one triggers a click event.
These events can be captured using the function jsToaster.onClickToast
to register handlers with toast id as parameter.
jsToaster.onClickToast((id) => {
console.log('TOAST CLICKED', id);
})
A toast closed or hidden triggers a close event.
These events can be captured using the function jsToaster.onCloseToast
to register handlers with toast id as parameter.
jsToaster.onCloseToast((id) => {
console.log('TOAST CLOSED', id);
})