mirror of
https://github.com/MichMich/MagicMirror.git
synced 2025-06-27 17:01:08 -04:00
Signed-off-by: naveen <172697+naveensrinivasan@users.noreply.github.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Karsten Hassel <hassel@gmx.de> Co-authored-by: Malte Hallström <46646495+SkySails@users.noreply.github.com> Co-authored-by: Veeck <github@veeck.de> Co-authored-by: veeck <michael@veeck.de> Co-authored-by: dWoolridge <dwoolridge@charter.net> Co-authored-by: Johan <jojjepersson@yahoo.se> Co-authored-by: Dario Mratovich <dario_mratovich@hotmail.com> Co-authored-by: Dario Mratovich <dario.mratovich@outlook.com> Co-authored-by: Magnus <34011212+MagMar94@users.noreply.github.com> Co-authored-by: Naveen <172697+naveensrinivasan@users.noreply.github.com> Co-authored-by: buxxi <buxxi@omfilm.net> Co-authored-by: Thomas Hirschberger <47733292+Tom-Hirschberger@users.noreply.github.com> Co-authored-by: Kristjan ESPERANTO <35647502+KristjanESPERANTO@users.noreply.github.com> Co-authored-by: Andrés Vanegas Jiménez <142350+angeldeejay@users.noreply.github.com> Co-authored-by: Dave Child <dave@addedbytes.com> Co-authored-by: grenagit <46225780+grenagit@users.noreply.github.com> Co-authored-by: Grena <grena@grenabox.fr> Co-authored-by: Magnus Marthinsen <magmar@online.no> Co-authored-by: Patrick <psieg@users.noreply.github.com> Co-authored-by: Piotr Rajnisz <56397164+rajniszp@users.noreply.github.com> Co-authored-by: Suthep Yonphimai <tomzt@users.noreply.github.com> Co-authored-by: CarJem Generations (Carter Wallace) <cwallacecs@gmail.com> Co-authored-by: Nicholas Fogal <nfogal.misc@gmail.com> Co-authored-by: JakeBinney <126349119+JakeBinney@users.noreply.github.com> Co-authored-by: OWL4C <124401812+OWL4C@users.noreply.github.com> Co-authored-by: Oscar Björkman <17575446+oscarb@users.noreply.github.com> Co-authored-by: Ismar Slomic <ismar@slomic.no> Co-authored-by: Jørgen Veum-Wahlberg <jorgen.wahlberg@amedia.no> Co-authored-by: Eddie Hung <6740044+eddiehung@users.noreply.github.com> Co-authored-by: Bugsounet - Cédric <github@bugsounet.fr> Co-authored-by: bugsounet <bugsounet@bugsounet.fr> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
156 lines
3.8 KiB
JavaScript
156 lines
3.8 KiB
JavaScript
/**
|
||
* Based on work by
|
||
*
|
||
* notificationFx.js v1.0.0
|
||
* https://tympanus.net/codrops/
|
||
*
|
||
* Licensed under the MIT license.
|
||
* https://opensource.org/licenses/mit-license.php
|
||
*
|
||
* Copyright 2014, Codrops
|
||
* https://tympanus.net/codrops/
|
||
* @param {object} window The window object
|
||
*/
|
||
(function (window) {
|
||
/**
|
||
* Extend one object with another one
|
||
* @param {object} a The object to extend
|
||
* @param {object} b The object which extends the other, overwrites existing keys
|
||
* @returns {object} The merged object
|
||
*/
|
||
function extend(a, b) {
|
||
for (let key in b) {
|
||
if (b.hasOwnProperty(key)) {
|
||
a[key] = b[key];
|
||
}
|
||
}
|
||
return a;
|
||
}
|
||
|
||
/**
|
||
* NotificationFx constructor
|
||
* @param {object} options The configuration options
|
||
* @class
|
||
*/
|
||
function NotificationFx(options) {
|
||
this.options = extend({}, this.options);
|
||
extend(this.options, options);
|
||
this._init();
|
||
}
|
||
|
||
/**
|
||
* NotificationFx options
|
||
*/
|
||
NotificationFx.prototype.options = {
|
||
// element to which the notification will be appended
|
||
// defaults to the document.body
|
||
wrapper: document.body,
|
||
// the message
|
||
message: "yo!",
|
||
// layout type: growl|attached|bar|other
|
||
layout: "growl",
|
||
// effects for the specified layout:
|
||
// for growl layout: scale|slide|genie|jelly
|
||
// for attached layout: flip|bouncyflip
|
||
// for other layout: boxspinner|cornerexpand|loadingcircle|thumbslider
|
||
// ...
|
||
effect: "slide",
|
||
// notice, warning, error, success
|
||
// will add class ns-type-warning, ns-type-error or ns-type-success
|
||
type: "notice",
|
||
// if the user doesn´t close the notification then we remove it
|
||
// after the following time
|
||
ttl: 6000,
|
||
al_no: "ns-box",
|
||
// callbacks
|
||
onClose: function () {
|
||
return false;
|
||
},
|
||
onOpen: function () {
|
||
return false;
|
||
}
|
||
};
|
||
|
||
/**
|
||
* Initialize and cache some vars
|
||
*/
|
||
NotificationFx.prototype._init = function () {
|
||
// create HTML structure
|
||
this.ntf = document.createElement("div");
|
||
this.ntf.className = `${this.options.al_no} ns-${this.options.layout} ns-effect-${this.options.effect} ns-type-${this.options.type}`;
|
||
let strinner = '<div class="ns-box-inner">';
|
||
strinner += this.options.message;
|
||
strinner += "</div>";
|
||
this.ntf.innerHTML = strinner;
|
||
|
||
// append to body or the element specified in options.wrapper
|
||
this.options.wrapper.insertBefore(this.ntf, this.options.wrapper.nextSibling);
|
||
|
||
// dismiss after [options.ttl]ms
|
||
if (this.options.ttl) {
|
||
this.dismissttl = setTimeout(() => {
|
||
if (this.active) {
|
||
this.dismiss();
|
||
}
|
||
}, this.options.ttl);
|
||
}
|
||
|
||
// init events
|
||
this._initEvents();
|
||
};
|
||
|
||
/**
|
||
* Init events
|
||
*/
|
||
NotificationFx.prototype._initEvents = function () {
|
||
// dismiss notification by tapping on it if someone has a touchscreen
|
||
this.ntf.querySelector(".ns-box-inner").addEventListener("click", () => {
|
||
this.dismiss();
|
||
});
|
||
};
|
||
|
||
/**
|
||
* Show the notification
|
||
*/
|
||
NotificationFx.prototype.show = function () {
|
||
this.active = true;
|
||
this.ntf.classList.remove("ns-hide");
|
||
this.ntf.classList.add("ns-show");
|
||
this.options.onOpen();
|
||
};
|
||
|
||
/**
|
||
* Dismiss the notification
|
||
* @param {boolean} [close] call the onClose callback at the end
|
||
*/
|
||
NotificationFx.prototype.dismiss = function (close = true) {
|
||
this.active = false;
|
||
clearTimeout(this.dismissttl);
|
||
this.ntf.classList.remove("ns-show");
|
||
setTimeout(() => {
|
||
this.ntf.classList.add("ns-hide");
|
||
|
||
// callback
|
||
if (close) this.options.onClose();
|
||
}, 25);
|
||
|
||
// after animation ends remove ntf from the DOM
|
||
const onEndAnimationFn = (ev) => {
|
||
if (ev.target !== this.ntf) {
|
||
return false;
|
||
}
|
||
this.ntf.removeEventListener("animationend", onEndAnimationFn);
|
||
|
||
if (ev.target.parentNode === this.options.wrapper) {
|
||
this.options.wrapper.removeChild(this.ntf);
|
||
}
|
||
};
|
||
|
||
this.ntf.addEventListener("animationend", onEndAnimationFn);
|
||
};
|
||
|
||
/**
|
||
* Add to global namespace
|
||
*/
|
||
window.NotificationFx = NotificationFx;
|
||
})(window);
|