Function.noop = () => {}; var _n_counter = 0; var counter = 0; window.addEventListener("focus", () => { document.title = document.title.replace(/^\([0-9]+\) /, ""); // remove notification counter xD }); function NewNotification(title, body, avatar = null, callback = () => {}, time = 5000, count = true) { if(avatar != null) { avatar = '<avatar>' + '<img src="' + avatar + '">' + '</avatar>'; } else { avatar = ''; } _n_counter += 1; let id = _n_counter; let notification = u( `<div class="notification_ballon notification_ballon_wrap" id="n${id}"> <notification_title> ${title} <a class="close">X</a> </notification_title> <wrap> ${avatar} <content> ${body} </content> </wrap> </div> `); u(".notifications_global_wrap").append(notification); function getPrototype() { return u("#n"+id); } function __closeNotification() { if(document.visibilityState != "visible") return setTimeout(() => {__closeNotification()}, time); // delay notif deletion getPrototype().addClass('disappears'); return setTimeout(() => {getPrototype().remove()}, 500); } if(count == true) { counter++; document.title = `(${counter}) ${document.title}`; } setTimeout(() => {__closeNotification()}, time); notification.children('notification_title').children('a.close').on('click', function(e) { __closeNotification(); }); notification.on('click', function(e) { if (!notification.hasClass('disappears')) { Reflect.apply(callback, { closeNotification: () => __closeNotification(), $notification: () => getPrototype() }, [e]); __closeNotification(); } }); }