JavaScript/CSS/HTML || Notice.js – Simple Notification Message With Success, Warning & Error Icons Using Vanilla JavaScript
The following is a module with functions that demonstrates how to display a simple notification message with success, warning & error icons.
Using vanilla JavaScript, the message fades in and is displayed to the page, and fades out after a delay (in milliseconds). It’s look and feel can also be adjusted via CSS.
Contents
1. Basic Usage
2. Notice HTML
3. Notice.js & CSS Source
4. More Examples
1. Basic Usage
Syntax is very straightforward. The following demonstrates the JavaScript used to show the notification message. The message fades away after a specified amount of time (in milliseconds).
1 2 3 4 5 6 7 8 9 10 |
<!-- Display Message. --> <div class="notice hide"></div> <script> document.addEventListener("DOMContentLoaded", function(eventLoaded) { // Display Message Notice.display(document.querySelector('.notice'), 'Success', Notice.type.success, 3000); }); </script> |
2. Notice HTML
If you wish to show the messages without using JavaScript, the following is an example of the HTML used to display the notices.
1 2 3 |
<!-- // HTML - Success --> <div class="notice"> Success </div> |
1 2 3 |
<!-- // HTML - Warning --> <div class="notice warning"> Warning </div> |
1 2 3 |
<!-- // HTML - Error --> <div class="notice error"> Error </div> |
3. Notice.js & CSS Source
The following is the Notice.js Namespace & CSS Source. Include this in your project to start using!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 |
// ============================================================================ // Author: Kenneth Perkins // Date: Oct 31, 2020 // Taken From: http://programmingnotes.org/ // File: Notice.js // Description: Javascript that displays a Notice to the screen // ============================================================================ /** * NAMESPACE: Notice * USE: Displays a Notice to the screen. */ var Notice = Notice || {}; (function(namespace) { 'use strict'; // -- Public data -- // Property to hold public variables and functions let exposed = namespace; // Set class names and other shared data const settings = { classNameNotice: '.notice', classNameSuccess: '', classNameWarning: '.warning', classNameError: '.error', classNameShow: '.show', classNameHide: '.hide', cleanClassName: function(str) { return str ? str.trim().replace('.', '') : ''; }, }; exposed.settings = settings; // Notice type enum const NoticeType = Object.freeze({success:1, warning:2, error:3}); exposed.type = NoticeType; /** * FUNCTION: display * USE: Displays a message to the page with the given text. * @param text: Text to be displayed to the page. * @param type: The message type. The type determines the style of the notice. * @param duration: The length the notice is displayed to the page (in milliseconds). * Set value to null to display the notice indefinitely. * @return: N/A. */ exposed.display = (element, text, type = Notice.type.success, duration = 3000) => { // Make sure the notice element exists if (!element) { throw new Error('Notice element does not exist'); } let id = getId(element); // Remove any previously existing notice duration delay if (noticeClearTimeout[id]) { clearTimeout(noticeClearTimeout[id]); } // Style the notice depending on the notice type applyStyleType(element, type); // Set the notice text element.innerHTML = text; // Fade in the notice to make it visible fadeIn(element); // Set the notice display duration if (duration) { noticeClearTimeout[id] = setTimeout(() => { // Fade out the notice to make it invisible fadeOut(element); delete noticeClearTimeout[id]; }, duration); } } // -- Private data -- // Holds the notice duration timeout delay let noticeClearTimeout = {}; let applyStyleType = (element, type) => { // Define the css classes for the different notice types let styles = getStyles(); // Remove previous styles for the notice and set the new one for (const style of styles) { if (style.class.length < 1) { continue; } // Check if the class is applied let classExists = hasClass(element, style.class); // Add the selected class if (type && type === style.type) { if (!classExists) { addClass(element, style.class); } } else if (classExists) { // Remove class if exists removeClass(element, style.class); } } } let getId = (element) => { if (!element.id || element.id.trim().length < 1) { element.id = `notice_${randomFromTo(1271991, 7281987)}`; } return element.id; } let randomFromTo = (from, to) => { return Math.floor(Math.random() * (to - from + 1) + from); } let getStyles = () => { let styles = [ {type: NoticeType.success, class: settings.classNameSuccess}, {type: NoticeType.warning, class: settings.classNameWarning}, {type: NoticeType.error, class: settings.classNameError} ]; return styles; } let fadeIn = (element) => { removeClass(element, settings.classNameHide); addClass(element, settings.classNameShow); } let fadeOut = (element) => { removeClass(element, settings.classNameShow); addClass(element, settings.classNameHide); } let addClass = (element, cssClass) => { cssClass = settings.cleanClassName(cssClass); let modified = false; if (cssClass.length > 0 && !hasClass(element, cssClass)) { element.classList.add(cssClass) modified = true; } return modified; } let removeClass = (element, cssClass) => { cssClass = settings.cleanClassName(cssClass); let modified = false; if (cssClass.length > 0 && hasClass(element, cssClass)) { element.classList.remove(cssClass); modified = true; } return modified; } let hasClass = (element, cssClass) => { cssClass = settings.cleanClassName(cssClass); return element.classList.contains(cssClass); } (function (factory) { if (typeof define === 'function' && define.amd) { define([], factory); } else if (typeof exports === 'object') { module.exports = factory(); } }(function() { return namespace; })); }(Notice)); // http://programmingnotes.org/ |
The following is Notice.css.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
/* // ============================================================================ // Author: Kenneth Perkins // Date: Oct 31, 2020 // Taken From: http://programmingnotes.org/ // File: Notice.css // Description: CSS for the notifiaction display // ============================================================================ */ .notice { border: 1px solid #d6dadb; border-left: 4.5px solid #32b032; background-color: #f1f5f6; text-align:left; padding: 8px; font-family: helvetica,arial,sans-serif; transition: opacity 400ms ease-in-out; } /* Background url source: http://icons.iconarchive.com/icons/custom-icon-design/flatastic-9/256/Accept-icon.png */ .notice:before { width: 18px; height: 18px; margin-right: 10px; content: ""; display: inline-block; vertical-align: middle; background-image: url(''); background-size: 100%; background-repeat: no-repeat; transform: translateY(-10%); } .notice.error { border-left-color: red; } /* Background url source: http://icons.iconarchive.com/icons/papirus-team/papirus-status/256/dialog-error-icon.png */ .notice.error:before { background-image: url(''); } .notice.warning { border-left-color: #ff8000; } /* Background url source: http://icons.iconarchive.com/icons/papirus-team/papirus-status/256/dialog-warning-icon.png */ .notice.warning:before { background-image: url(''); } .notice.show { opacity: 1; } .notice.hide { opacity: 0; } /* http://programmingnotes.org/ */ |
4. More Examples
Below are more examples demonstrating the use of ‘Notice.js‘. Don’t forget to include the module when running the examples!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 |
<!-- // ============================================================================ // Author: Kenneth Perkins // Date: Oct 31, 2020 // Taken From: http://programmingnotes.org/ // File: Notification.html // Description: Demonstrates how to display a notification div message to // the page with icons. // ============================================================================ --> <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title>My Programming Notes Notification Display Demo</title> <style> .button { padding: 8px; background-color: #d2d2d2; height:100%; text-align:center; text-decoration:none; color:black; display: flex; justify-content: center; align-items: center; flex-direction: column; border-radius: 15px; cursor: pointer; } .button:hover { background-color:#bdbdbd; } .buttonSection { border-top: 1px solid #a3a3a3; border-bottom: 1px solid #a3a3a3; padding:8px; margin-bottom:10px; text-align:center; margin-top: 10px; } .inline { display:inline-block; } .main { text-align:center; margin-left:auto; margin-right:auto; } </style> <!-- // Include module --> <link type="text/css" rel="stylesheet" href="./Notice.css"> <script type="text/javascript" src="./Notice.js"></script> </head> <body> <div class="main"> <div class="notice-message notice hide"></div> <br /> <div class="notice"> Success </div> <br /> <div class="notice warning"> Warning </div> <br /> <div class="notice error"> Error </div> <br /> <div class="buttonSection"> <div id="btnSuccessMessage" class="inline button"> Success Message </div> <div id="btnWarningMessage" class="inline button"> Warning Message </div> <div id="btnErrorMessage" class="inline button"> Error Message </div> <div style="margin-top: 5px;"> Click a button to see the different message styles! </div> </div> </div> <script> document.addEventListener('DOMContentLoaded', function(eventLoaded) { document.querySelector('#btnSuccessMessage').addEventListener('click', (e) => { Notice.display(document.querySelector('.notice-message'), 'Success!', Notice.type.success); }); document.querySelector('#btnWarningMessage').addEventListener('click', (e) => { Notice.display(document.querySelector('.notice-message'), 'Warning!', Notice.type.warning); }); document.querySelector('#btnErrorMessage').addEventListener('click', (e) => { Notice.display(document.querySelector('.notice-message'), 'Error!', Notice.type.error); }); }); </script> </body> </html><!-- // http://programmingnotes.org/ --> |
QUICK NOTES:
The highlighted lines are sections of interest to look out for.
The code is heavily commented, so no further insight is necessary. If you have any questions, feel free to leave a comment below.
Leave a Reply