/* Creative Tim Modifications Lines: 238, 239 was changed from top: 5px to top: 50% and we added margin-top: -13px. In this way the close button will be aligned vertically Line:222 - modified when the icon is set, we add the class "alert-with-icon", so there will be enough space for the icon. */ /* * Project: Bootstrap Notify = v3.1.5 * Description: Turns standard Bootstrap alerts into "Growl-like" notifications. * Author: Mouse0270 aka Robert McIntosh * License: MIT License * Website: https://github.com/mouse0270/bootstrap-growl */ /* global define:false, require: false, jQuery:false */ ! function(t) { "function" == typeof define && define.amd ? define(["jquery"], t) : "object" == typeof exports ? t(require("jquery")) : t(jQuery) }(function(t) { var s = { element: "body", position: null, type: "info", allow_dismiss: !0, allow_duplicates: !0, newest_on_top: !1, showProgressbar: !1, placement: { from: "top", align: "right" }, offset: 20, spacing: 10, z_index: 1060, delay: 5e3, timer: 1e3, url_target: "_blank", mouse_over: null, animate: { enter: "animated fadeInDown", exit: "animated fadeOutUp" }, onShow: null, onShown: null, onClose: null, onClosed: null, onClick: null, icon_type: "class", template: '' }; function i(i, e, n) { var a, o, r = { content: { message: "object" == typeof e ? e.message : e, title: e.title ? e.title : "", icon: e.icon ? e.icon : "", url: e.url ? e.url : "#", target: e.target ? e.target : "-" } }; n = t.extend(!0, {}, r, n), this.settings = t.extend(!0, {}, s, n), this._defaults = s, "-" === this.settings.content.target && (this.settings.content.target = this.settings.url_target), this.animations = { start: "webkitAnimationStart oanimationstart MSAnimationStart animationstart", end: "webkitAnimationEnd oanimationend MSAnimationEnd animationend" }, "number" == typeof this.settings.offset && (this.settings.offset = { x: this.settings.offset, y: this.settings.offset }), (this.settings.allow_duplicates || !this.settings.allow_duplicates && (a = this, o = !1, t('[data-notify="container"]').each(function(s, i) { var e = t(i), n = e.find('[data-notify="title"]').html().trim(), r = e.find('[data-notify="message"]').html().trim(), l = n === t("
" + a.settings.content.title + "
").html().trim(), d = r === t("
" + a.settings.content.message + "
").html().trim(), c = e.hasClass("alert-" + a.settings.type); return l && d && c && (o = !0), !o }), !o)) && this.init() } String.format = function() { var t = arguments; return arguments[0].replace(/(\{\{\d\}\}|\{\d\})/g, function(s) { if ("{{" === s.substring(0, 2)) return s; var i = parseInt(s.match(/\d/)[0]); return t[i + 1] }) }, t.extend(i.prototype, { init: function() { var t = this; this.buildNotify(), this.settings.content.icon && this.setIcon(), "#" != this.settings.content.url && this.styleURL(), this.styleDismiss(), this.placement(), this.bind(), this.notify = { $ele: this.$ele, update: function(s, i) { var e = {}; "string" == typeof s ? e[s] = i : e = s; for (var n in e) switch (n) { case "type": this.$ele.removeClass("alert-" + t.settings.type), this.$ele.find('[data-notify="progressbar"] > .progress-bar').removeClass("progress-bar-" + t.settings.type), t.settings.type = e[n], this.$ele.addClass("alert-" + e[n]).find('[data-notify="progressbar"] > .progress-bar').addClass("progress-bar-" + e[n]); break; case "icon": var a = this.$ele.find('[data-notify="icon"]'); "class" === t.settings.icon_type.toLowerCase() ? a.removeClass(t.settings.content.icon).addClass(e[n]) : (a.is("img") || a.find("img"), a.attr("src", e[n])), t.settings.content.icon = e[s]; break; case "progress": var o = t.settings.delay - t.settings.delay * (e[n] / 100); this.$ele.data("notify-delay", o), this.$ele.find('[data-notify="progressbar"] > div').attr("aria-valuenow", e[n]).css("width", e[n] + "%"); break; case "url": this.$ele.find('[data-notify="url"]').attr("href", e[n]); break; case "target": this.$ele.find('[data-notify="url"]').attr("target", e[n]); break; default: this.$ele.find('[data-notify="' + n + '"]').html(e[n]) } var r = this.$ele.outerHeight() + parseInt(t.settings.spacing) + parseInt(t.settings.offset.y); t.reposition(r) }, close: function() { t.close() } } }, buildNotify: function() { var s = this.settings.content; this.$ele = t(String.format(this.settings.template, this.settings.type, s.title, s.message, s.url, s.target)), this.$ele.attr("data-notify-position", this.settings.placement.from + "-" + this.settings.placement.align), this.settings.allow_dismiss || this.$ele.find('[data-notify="dismiss"]').css("display", "none"), (this.settings.delay <= 0 && !this.settings.showProgressbar || !this.settings.showProgressbar) && this.$ele.find('[data-notify="progressbar"]').remove() }, setIcon: function() { this.$ele.addClass("alert-with-icon"), "class" === this.settings.icon_type.toLowerCase() ? this.$ele.find('[data-notify="icon"]').addClass(this.settings.content.icon) : this.$ele.find('[data-notify="icon"]').is("img") ? this.$ele.find('[data-notify="icon"]').attr("src", this.settings.content.icon) : this.$ele.find('[data-notify="icon"]').append('Notify Icon') }, styleDismiss: function() { this.$ele.find('[data-notify="dismiss"]').css({ position: "absolute", right: "10px", top: "50%", marginTop: "-13px", zIndex: this.settings.z_index + 2 }) }, styleURL: function() { this.$ele.find('[data-notify="url"]').css({ backgroundImage: "url()", height: "100%", left: 0, position: "absolute", top: 0, width: "100%", zIndex: this.settings.z_index + 1 }) }, placement: function() { var s = this, i = this.settings.offset.y, e = { display: "inline-block", margin: "0px auto", position: this.settings.position ? this.settings.position : "body" === this.settings.element ? "fixed" : "absolute", transition: "all .5s ease-in-out", zIndex: this.settings.z_index }, n = !1, a = this.settings; switch (t('[data-notify-position="' + this.settings.placement.from + "-" + this.settings.placement.align + '"]:not([data-closing="true"])').each(function() { i = Math.max(i, parseInt(t(this).css(a.placement.from)) + parseInt(t(this).outerHeight()) + parseInt(a.spacing)) }), !0 === this.settings.newest_on_top && (i = this.settings.offset.y), e[this.settings.placement.from] = i + "px", this.settings.placement.align) { case "left": case "right": e[this.settings.placement.align] = this.settings.offset.x + "px"; break; case "center": e.left = 0, e.right = 0 } this.$ele.css(e).addClass(this.settings.animate.enter), t.each(Array("webkit-", "moz-", "o-", "ms-", ""), function(t, i) { s.$ele[0].style[i + "AnimationIterationCount"] = 1 }), t(this.settings.element).append(this.$ele), !0 === this.settings.newest_on_top && (i = parseInt(i) + parseInt(this.settings.spacing) + this.$ele.outerHeight(), this.reposition(i)), t.isFunction(s.settings.onShow) && s.settings.onShow.call(this.$ele), this.$ele.one(this.animations.start, function() { n = !0 }).one(this.animations.end, function() { s.$ele.removeClass(s.settings.animate.enter), t.isFunction(s.settings.onShown) && s.settings.onShown.call(this) }), setTimeout(function() { n || t.isFunction(s.settings.onShown) && s.settings.onShown.call(this) }, 600) }, bind: function() { var s = this; if (this.$ele.find('[data-notify="dismiss"]').on("click", function() { s.close() }), t.isFunction(s.settings.onClick) && this.$ele.on("click", function(t) { t.target != s.$ele.find('[data-notify="dismiss"]')[0] && s.settings.onClick.call(this, t) }), this.$ele.mouseover(function() { t(this).data("data-hover", "true") }).mouseout(function() { t(this).data("data-hover", "false") }), this.$ele.data("data-hover", "false"), this.settings.delay > 0) { s.$ele.data("notify-delay", s.settings.delay); var i = setInterval(function() { var t = parseInt(s.$ele.data("notify-delay")) - s.settings.timer; if ("false" === s.$ele.data("data-hover") && "pause" === s.settings.mouse_over || "pause" != s.settings.mouse_over) { var e = (s.settings.delay - t) / s.settings.delay * 100; s.$ele.data("notify-delay", t), s.$ele.find('[data-notify="progressbar"] > div').attr("aria-valuenow", e).css("width", e + "%") } t <= -s.settings.timer && (clearInterval(i), s.close()) }, s.settings.timer) } }, close: function() { var s = this, i = parseInt(this.$ele.css(this.settings.placement.from)), e = !1; this.$ele.attr("data-closing", "true").addClass(this.settings.animate.exit), s.reposition(i), t.isFunction(s.settings.onClose) && s.settings.onClose.call(this.$ele), this.$ele.one(this.animations.start, function() { e = !0 }).one(this.animations.end, function() { t(this).remove(), t.isFunction(s.settings.onClosed) && s.settings.onClosed.call(this) }), setTimeout(function() { e || (s.$ele.remove(), s.settings.onClosed && s.settings.onClosed(s.$ele)) }, 600) }, reposition: function(s) { var i = this, e = '[data-notify-position="' + this.settings.placement.from + "-" + this.settings.placement.align + '"]:not([data-closing="true"])', n = this.$ele.nextAll(e); !0 === this.settings.newest_on_top && (n = this.$ele.prevAll(e)), n.each(function() { t(this).css(i.settings.placement.from, s), s = parseInt(s) + parseInt(i.settings.spacing) + t(this).outerHeight() }) } }), t.notify = function(t, s) { return new i(this, t, s).notify }, t.notifyDefaults = function(i) { return s = t.extend(!0, {}, s, i) }, t.notifyClose = function(s) { void 0 === s || "all" === s ? t("[data-notify]").find('[data-notify="dismiss"]').trigger("click") : "success" === s || "info" === s || "warning" === s || "danger" === s ? t(".alert-" + s + "[data-notify]").find('[data-notify="dismiss"]').trigger("click") : s ? t(s + "[data-notify]").find('[data-notify="dismiss"]').trigger("click") : t('[data-notify-position="' + s + '"]').find('[data-notify="dismiss"]').trigger("click") }, t.notifyCloseExcept = function(s) { "success" === s || "info" === s || "warning" === s || "danger" === s ? t("[data-notify]").not(".alert-" + s).find('[data-notify="dismiss"]').trigger("click") : t("[data-notify]").not(s).find('[data-notify="dismiss"]').trigger("click") } });