102 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * A utility class to create and show toast messages.
 | |
|  */
 | |
| class Toast {
 | |
|     /**
 | |
|      * Creates and shows an info toast.
 | |
|      * @param {String} content The content of the toast.
 | |
|      * @param {Number} timeout The amount of time in miliseconds to show the message, -1 means forever. Default is 4000.
 | |
|      * @param {Boolean} closable Whether or not to show a close button. Default is true.
 | |
|      * @returns {HTMLElement} The toast html element.
 | |
|      */
 | |
|     static info(content, timeout = 4000, closable = true) {
 | |
|         return this.makeToast("?", content, "info", timeout, closable);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates and shows an warning toast.
 | |
|      * @param {String} content The content of the toast.
 | |
|      * @param {Number} timeout The amount of time in miliseconds to show the message, -1 means forever. Default is 4000.
 | |
|      * @param {Boolean} closable Whether or not to show a close button. Default is true.
 | |
|      * @returns {HTMLElement} The toast html element.
 | |
|      */
 | |
|     static warning(content, timeout = 4000, closable = true) {
 | |
|         return this.makeToast("!", content, "warning", timeout, closable);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates and shows an error toast.
 | |
|      * @param {String} content The content of the toast.
 | |
|      * @param {Number} timeout The amount of time in miliseconds to show the message, -1 means forever. Default is 4000.
 | |
|      * @param {Boolean} closable Whether or not to show a close button. Default is true.
 | |
|      * @returns {HTMLElement} The toast html element.
 | |
|      */
 | |
|     static error(content, timeout = 4000, closable = true) {
 | |
|         return this.makeToast("×", content, "error", timeout, closable);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates and shows an success toast.
 | |
|      * @param {String} content The content of the toast.
 | |
|      * @param {Number} timeout The amount of time in miliseconds to show the message, -1 means forever. Default is 4000.
 | |
|      * @param {Boolean} closable Whether or not to show a close button. Default is true.
 | |
|      * @returns {HTMLElement} The toast html element.
 | |
|      */
 | |
|     static success(content, timeout = 4000, closable = true) {
 | |
|         return this.makeToast("✔", content, "success", timeout, closable);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a toast message with an icon, content, type, and timeout and closable settings.
 | |
|      * @param {String} icon The icon to display if any.
 | |
|      * @param {String} content The content of the toast.
 | |
|      * @param {String} type The type of toast being shown, error, warning, info, success, or default.
 | |
|      * @param {Number} timeout The amount of time in miliseconds to show the toast. -1 is forever.
 | |
|      * @param {Boolean} closable Whether or not this toast can be closed.
 | |
|      * @returns {HTMLElement} The toast html element.
 | |
|      */
 | |
|     static makeToast(icon, content, type, timeout, closable) {
 | |
|         var color = "";
 | |
|         if (type == "error") {
 | |
|             color = "#ff7979";
 | |
|         } else if (type == "warning") {
 | |
|             color = "#ffc107";
 | |
|         } else if (type == "info") {
 | |
|             color = "#2196f3";
 | |
|         } else if (type == "success") {
 | |
|             color = "#10c469";
 | |
|         } else {
 | |
|             color = "#000000";
 | |
|         }
 | |
| 
 | |
|         document.querySelectorAll(".ignite-html-toast").forEach(element => element.remove());
 | |
| 
 | |
|         var temp = document.createElement('div');
 | |
|         temp.innerHTML = `
 | |
|             <div class="ignite-html-toast ${type ? type : ""}" style="display: flex; align-items: center; flex-direction: column; left: 50%; top: 100%; position: absolute; transform: translate(-50%, -100%); z-index: 999999; width: 100%; padding: 2em 1em 2em 1em; background-color: transparent;">
 | |
|                 <div style="box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23); border-radius: 7em; display: flex; flex-direction: row; justify-content: center; align-items: center; gap: 1em; padding-left: 1em; padding-right: 1em; padding-top: 0.5em; padding-bottom: 0.5em; background-color: #fff;">
 | |
|                     <div class="icon" style="${!icon ? "display: none;" : "display: flex;"}font-size: 1.5em; background-color: ${color}; border-radius: 100%; min-width: 1.5em; min-height: 1.5em; align-items: center; justify-content: center; color: #fff;">${icon ? icon : ""}</div>
 | |
|                     <div class="message" style="text-align: center;">${content ? content : ""}</div>
 | |
|                     <button class="close" onClick="this.parentElement.parentElement.remove();" style="${!closable ? "display: none;" : ""} background-color: transparent; border: none; font-size: 1.75em; color: rgba(0,0,0,0.5);">×</button>
 | |
|                 </div>
 | |
|             </div>
 | |
|         `.trim();
 | |
|         var toast = temp.firstChild;
 | |
| 
 | |
|         window.document.body.appendChild(toast);
 | |
| 
 | |
|         if (timeout != -1) {
 | |
|             setTimeout(() => {
 | |
|                 toast.remove();
 | |
|             }, timeout);
 | |
|         }
 | |
| 
 | |
|         return toast;
 | |
|     }
 | |
| }
 | |
| 
 | |
| window.Toast = Toast;
 | |
| 
 | |
| export {
 | |
|     Toast
 | |
| } |