JavaScript package for displaying flash messages in various types with full customization capabilities.
This package is designed to be simple and easy to use. It provides a simple way to display flash messages in your web applications.
It can be used in pure JavaScript or TypeScript projects, or any other JavaScript framework like React, Vue, Angular etc.
- Using CDN:
<!-- Current version -->
<script src="https://unpkg.com/js-flash@1.4.6"></script>
<!-- Always the latest version -->
<script src="https://unpkg.com/js-flash"></script>
- Install the package using
npm
:
npm i js-flash
Import the package in your project and use it:
import Flash from 'js-flash';
new Flash('Hello World!', 'info');
[!NOTE] If you are using CDN, you don't need to import anything, just use it.
You can pass the following parameters to the Flash
constructor:
-
message
(string): The message to display. -
type
(string): The type of the message. The following types are available:'info'
'success'
'warning'
'error'
-
config
(object): An optional object for configuration.
The following options are available for configuration:
Option | Type | Default | Description |
---|---|---|---|
icon |
boolean |
true |
Whether to display an icon with the message. |
animation |
boolean |
true |
Whether to enable animations for message. |
closeByClick |
boolean |
true |
Whether to close the message by clicking on it. |
closeTimeout |
number |
5000 |
The time in milliseconds after which the message will be automatically closed. (If set to 0 , the message will not be closed automatically) |
pauseOnHover |
boolean |
true |
Whether to pause the closeTimout on message hover. |
loading |
boolean |
true |
Whether to display loading bar for closeTimout . |
direction |
string |
'ltr' |
The direction of the message. ('ltr' or 'rtl' ) |
position |
string |
'top-left' |
Position of the message on the page. |
borderRadius |
number |
8 |
The border radius of the message. |
fontFamily |
string |
undefined |
The font family of the message. If not set, the body font will be applied. |
These positions are available:
'top'
'top-left'
'top-right'
'bottom'
'bottom-left'
'bottom-right'
Example with options:
new Flash('Hello World!', 'info', {
animation: false,
closeTimeout: 0,
position: 'bottom-left'
});
[!NOTE] You can configure the default options for each message in the Configuring item defaults section.
Flash messages look like this. (In ltr
and rtl
mode)
[!NOTE] You can customize the style of the flash messages in the types configuration.
You can add an action button to the message by passing the action
object to the constructor:
new Flash('Post deleted!', 'info', {
position: 'bottom',
action: {
text: 'Undo',
handler: () => {
console.log('Undo clicked.');
}
}
});
The action
object have the following properties:
Property | Type | Description |
---|---|---|
text |
string |
The button text. |
handler |
function |
The click event handler. |
[!NOTE] You can customize the style of the action buttons in the types configuration.
You can access the following properties of the flash message:
Property | Type | Description |
---|---|---|
element |
HTMLDivElement |
The message element. |
messageText |
string |
The message text. |
messageType |
string |
The message type. |
itemConfig |
object |
The message configuration. |
closed |
boolean |
Whether the message is closed. |
whenClosed |
Promise<void> |
The promise that resolves when the message is closed. |
example:
const flash = new Flash('Hello World!', 'info');
flash.element.classList.add('custom-class');
flash.element.style.opacity = "0.5";
flash.whenClosed.then(() => {
console.log('Message closed');
});
[!IMPORTANT] All properties are read-only.
You can use the following methods to interact with the flash message:
Method | Description |
---|---|
close() |
Closes the message. |
pauseTimout() |
Pause closeTimout . |
playTimout() |
Play closeTimout . |
example:
const flash = new Flash('Hello World!', 'info', {
closeTimeout: 0, // Disable auto close
closeByClick: false // Disable close by click
});
function myFnc() {
flash.close();
}
Also these methods are available as static methods:
Method | Description |
---|---|
closeAll() |
Closes all messages. |
closeFirst() |
Closes the first message. |
closeLast() |
Closes the last message. |
closeByType(type) |
Closes all messages of the specified type. |
closeByPosition(position) |
Closes all messages of the specified position. |
[!NOTE] Obviously, all of these methods apply to live messages.
example:
Flash.closeAll();
Flash.closeByType('warning');
Flash.closeByPosition('bottom-right');
You can configure the base settings of the flash messages by setBaseConfig
method:
Flash.setBaseConfig({
offset: 25,
gap: 15
});
The following options are available:
Option | Type | Default | Description |
---|---|---|---|
offset |
number |
20 |
The offset from the edge of the screen. (px) |
gap |
number |
10 |
The gap between messages. (px) |
types |
object |
(Types section) | The properties for different message types. |
You can set these properties for different message types in base configuration:
Property | Description |
---|---|
icon |
Icon data URL. (data:image/svg+xml ) |
color |
Text and icon color. |
backgroundColor |
Background color. |
borderColor |
Border color. |
loadingColor |
Loading color. |
button |
Button styles. |
Example:
Flash.setBaseConfig({
types: {
info: {
backgroundColor: '#3498db',
color: '#fff'
},
success: {
borderColor: '#27ae60',
button: {
backgroundColor: '#27ae60',
color: '#fff'
}
}
}
});
The above code changes the default values mentioned.
Default values are:
types = {
info: {
icon: 'data:image/svg+xml,...',
color: '#2196F3',
backgroundColor: '#E3F2FD',
borderColor: '#BBDEFB',
loadingColor: '#BBDEFB',
button: {
color: '#2196F3',
backgroundColor: 'transparent',
borderColor: '#BBDEFB',
}
},
success: {
icon: 'data:image/svg+xml,...',
color: '#4CAF50',
backgroundColor: '#E8F5E9',
borderColor: '#C8E6C9',
loadingColor: '#C8E6C9',
button: {
color: '#4CAF50',
backgroundColor: 'transparent',
borderColor: '#C8E6C9',
}
},
warning: {
icon: 'data:image/svg+xml,...',
color: '#BD8F04',
backgroundColor: '#FFF8E1',
borderColor: '#FFDC74',
loadingColor: '#FFDC74',
button: {
color: '#BD8F04',
backgroundColor: 'transparent',
borderColor: '#FFDC74',
}
},
error: {
icon: 'data:image/svg+xml,...',
color: '#F44336',
backgroundColor: '#FFEBEE',
borderColor: '#FFCDD2',
loadingColor: '#FFCDD2',
button: {
color: '#F44336',
backgroundColor: 'transparent',
borderColor: '#FFCDD2',
}
}
}
You can configure the default settings for each message. (Constructor options)
Flash.setDefaultItemConfig({
icon: false,
animation: false,
closeByClick: false,
closeTimeout: 0,
pauseOnHover: false,
loading: false,
position: 'bottom-right',
borderRadius: 12,
fontFamily: 'Arial'
});
This package is written in TypeScript and includes type definitions. You can use it in TypeScript projects.
import type { BaseConfig, ItemConfig } from 'js-flash';
The following types are available:
Type | Description |
---|---|
FlashType |
The flash message types. |
FlashPosition |
The flash message positions. |
ItemConfig |
Configuration object for each item. |
BaseConfig |
Base configuration object. |
DeepPartial |
The utitily type to make objects optional in depth. |
example:
import Flash from 'js-flash';
import type { BaseConfig, DeepPartial } from 'js-flash';
const obj: DeepPartial<BaseConfig> = {
offset: 25,
gap: 15,
types: {
info: {
backgroundColor: '#3498db',
color: '#fff'
},
success: {
borderColor: '#27ae60'
}
}
}
Flash.setBaseConfig(obj);
The project is designed to be scalable. If you have any suggestions, feel free to contribute or create an issue.
We welcome contributions to expand this project. If you'd like to improve this project, please create a pull request.
If this project was helpful, please consider giving it a star. Your support helps us grow!