//META{"name":"BadgesEverywhere"}*// class BadgesEverywhere { initConstructor () { this.css = ` .BE-badge { display: inline-block; background-position: 50%; background-repeat: no-repeat; background-size: contain; height: 17px; margin: 0 2px; } .BE-badge-chat { margin-bottom: -3px; } .BE-badge-popout { margin-bottom: -2px; } .BE-badge-settings { width: 30px !important; } .BE-badge:first-of-type { margin-left: 5px; } .BE-badge:last-of-type { margin-right: 5px; } .BE-badge.BE-badge-Staff {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-Partner {width:22px !important; min-width:22px !important;} .BE-badge.BE-badge-HypeSquad {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-BugHunter {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-HypeSquadBravery {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-HypeSquadBrilliance {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-HypeSquadBalance {width:17px !important; min-width:17px !important;} .BE-badge.BE-badge-EarlySupporter {width:24px !important; min-width:24px !important;} .BE-badge.BE-badge-Nitro {width:21px !important; min-width:21px !important;}`; this.loading = false; this.updateBadges = false; this.badges = { 1: {name:"Staff", selector:"profileBadgeStaff"}, 2: {name:"Partner", selector:"profileBadgePartner"}, 4: {name:"HypeSquad", selector:"profileBadgeHypeSquad"}, 8: {name:"BugHunter", selector:"profileBadgeBugHunter"}, 16: {name:"MFASMS", selector:false}, 32: {name:"PROMODISMISSED", selector:false}, 64: {name:"HypeSquad Bravery", selector:"profileBadgeHypeSquadOnlineHouse1"}, 128: {name:"HypeSquad Brilliance", selector:"profileBadgeHypeSquadOnlineHouse2"}, 256: {name:"HypeSquad Balance", selector:"profileBadgeHypeSquadOnlineHouse3"}, 512: {name:"Early Supporter", selector:"profileBadgeEarlySupporter"}, 2048: {name:"Nitro", selector:"profileBadgePremium"} }; this.requestedusers = {}; this.loadedusers = {}; this.defaults = { settings: { showInChat: {value:true, description:"Show Badge in Chat Window."}, showInMemberList: {value:true, description:"Show Badge in Member List."}, showInPopout: {value:true, description:"Show Badge in User Popout."}, useColoredVersion: {value:true, description:"Use colored version of the Badges."} } }; } getName () {return "BadgesEverywhere";} getDescription () {return "Displays Badges (Nitro, HypeSquad, etc...) in the chat/memberlist/userpopout. Thanks for Zerebos' help.";} getVersion () {return "1.1.3";} getAuthor () {return "DevilBro";} getSettingsPanel () { if (!this.started || typeof BDFDB !== "object") return; var settings = BDFDB.getAllData(this, "settings"); var blacklist = BDFDB.loadAllData(this, "blacklist"); var settingshtml = `
${this.getName()}
`; for (let key in settings) { settingshtml += `

${this.defaults.settings[key].description}

`; } settingshtml += `

Display Badges:

`; for (let flag in this.badges) { settingshtml += `

${this.badges[flag].name}

`; } settingshtml += `
`; var settingspanel = $(settingshtml)[0]; BDFDB.initElements(settingspanel); $(settingspanel) .on("click", BDFDB.dotCN.switchinner + ".settingsswitch", () => {this.updateSettings(settingspanel);}) .on("click", BDFDB.dotCN.switchinner + ".blacklistswitch", () => {this.updateBlacklist(settingspanel);}); return settingspanel; } //legacy load () {} start () { var libraryScript = null; if (typeof BDFDB !== "object" || typeof BDFDB.isLibraryOutdated !== "function" || BDFDB.isLibraryOutdated()) { libraryScript = document.querySelector('head script[src="https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"]'); if (libraryScript) libraryScript.remove(); libraryScript = document.createElement("script"); libraryScript.setAttribute("type", "text/javascript"); libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"); document.head.appendChild(libraryScript); } this.startTimeout = setTimeout(() => {this.initialize();}, 30000); if (typeof BDFDB === "object" && typeof BDFDB.isLibraryOutdated === "function") this.initialize(); else libraryScript.addEventListener("load", () => {this.initialize();}); } initialize () { if (typeof BDFDB === "object") { BDFDB.loadMessage(this); this.APIModule = BDFDB.WebModules.findByProperties(["getAPIBaseURL"]); this.DiscordConstants = BDFDB.WebModules.findByProperties(["Permissions", "ActivityTypes", "StatusTypes"]); this.BadgeClasses = BDFDB.WebModules.findByProperties(["profileBadgeStaff","profileBadgePremium"]); var observer = null; observer = new MutationObserver((changes, _) => { changes.forEach( (change, i) => { if (change.addedNodes) { change.addedNodes.forEach((node) => { if (node.tagName && node.querySelector(BDFDB.dotCN.memberusername) && BDFDB.getData("showInMemberList", this, "settings")) { this.addBadges(node, "list", false); } }); } } ); }); BDFDB.addObserver(this, BDFDB.dotCN.memberswrap, {name:"userListObserver",instance:observer}, {childList:true, subtree:true}); observer = new MutationObserver((changes, _) => { changes.forEach( (change, i) => { if (change.addedNodes) { change.addedNodes.forEach((node) => { if (BDFDB.getData("showInChat", this, "settings")) { if (node.tagName && node.querySelector(BDFDB.dotCN.messageusername)) { this.addBadges(node, "chat", BDFDB.getDiscordMode() == "compact"); } } }); } } ); }); BDFDB.addObserver(this, BDFDB.dotCN.messages, {name:"chatWindowObserver",instance:observer}, {childList:true, subtree:true}); observer = new MutationObserver((changes, _) => { changes.forEach( (change, i) => { if (change.addedNodes) { change.addedNodes.forEach((node) => { if (node.tagName && node.querySelector(BDFDB.dotCN.userpopout) && BDFDB.getData("showInPopout", this, "settings")) { this.addBadges(node, "popout", false); } }); } } ); }); BDFDB.addObserver(this, BDFDB.dotCN.popouts, {name:"userPopoutObserver",instance:observer}, {childList: true}); observer = new MutationObserver((changes, _) => { changes.forEach( (change, i) => { if (change.removedNodes) { change.removedNodes.forEach((node) => { if (node.tagName && node.getAttribute("layer-id") == "user-settings" && this.updateBadges) { this.updateBadges = false; this.loadBadges(); } }); } } ); }); BDFDB.addObserver(this, BDFDB.dotCN.layers, {name:"settingsWindowObserver",instance:observer}, {childList:true}); for (let flag in this.badges) if (!this.badges[flag].selector) delete this.badges[flag]; this.loadBadges(); } else { console.error(this.getName() + ": Fatal Error: Could not load BD functions!"); } } stop () { if (typeof BDFDB === "object") { document.querySelectorAll(".BE-badges").forEach(node=>{node.remove();}); BDFDB.unloadMessage(this); } } onSwitch () { if (typeof BDFDB === "object") { BDFDB.addObserver(this, BDFDB.dotCN.memberswrap, {name:"userListObserver"}, {childList:true, subtree:true}); BDFDB.addObserver(this, BDFDB.dotCN.messages, {name:"chatWindowObserver"}, {childList:true, subtree:true}); this.loadBadges(); } } // begin of own functions updateSettings (settingspanel) { var settings = {}; for (var input of settingspanel.querySelectorAll(BDFDB.dotCN.switchinner + ".settingsswitch")) { settings[input.value] = input.checked; } BDFDB.saveAllData(settings, this, "settings"); this.updateBadges = true; } updateBlacklist (settingspanel) { var blacklist = {}; for (var input of settingspanel.querySelectorAll(BDFDB.dotCN.switchinner + ".blacklistswitch")) { blacklist[input.value] = !input.checked; } BDFDB.saveAllData(blacklist, this, "blacklist"); this.updateBadges = true; } loadBadges() { document.querySelectorAll(".BE-badge").forEach(node=>{node.remove();}); var settings = BDFDB.getAllData(this, "settings"); if (settings.showInMemberList) { for (let user of document.querySelectorAll(BDFDB.dotCN.member)) { this.addBadges(user, "list", false); } } if (settings.showInChat) { for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcozy)) { this.addBadges(messagegroup, "chat", false); } for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcompact)) { for (let message of messagegroup.querySelectorAll(BDFDB.dotCN.messagemarkup)) { this.addBadges(message, "chat", true); } } } if (settings.showInPopout) { for (let user of document.querySelectorAll(BDFDB.dotCN.userpopout)) { this.addBadges(user.parentElement, "popout", false); } } } addBadges (wrapper, type, compact) { if (!wrapper) return; let user = compact ? BDFDB.getKeyInformation({"node":wrapper.classList.contains(BDFDB.disCN.messagegroup) ? wrapper : $(BDFDB.dotCN.messagegroup).has(wrapper)[0],"key":"message"}).author : BDFDB.getKeyInformation({"node":wrapper,"key":"user"}); if (user && !user.bot) { if (!this.requestedusers[user.id]) { this.requestedusers[user.id] = [[wrapper,type]] this.APIModule.get(this.DiscordConstants.Endpoints.USER_PROFILE(user.id)).then(result => { let usercopy = Object.assign({},result.body.user); if (result.body.premium_since) usercopy.flags += 2048; this.loadedusers[user.id] = usercopy; for (let queredobj of this.requestedusers[user.id]) this.addToWrapper(queredobj[0], user.id, queredobj[1]); }); } else if (!this.loadedusers[user.id]) { this.requestedusers[user.id].push([wrapper,type]); } else { this.addToWrapper(wrapper, user.id, type); } } } addToWrapper (wrapper, id, type) { if (wrapper.querySelector(".BE-badges")) return; let memberwrap = wrapper.querySelector(BDFDB.dotCN.memberusername); if (!memberwrap) memberwrap = wrapper.querySelector(BDFDB.dotCN.messageusername); if (memberwrap) memberwrap = memberwrap.parentElement; if (!memberwrap) memberwrap = wrapper.querySelector(BDFDB.dotCN.nametag); if (memberwrap) { let blacklist = BDFDB.loadAllData(this, "blacklist"); let settings = BDFDB.getAllData(this, "settings"); let badgewrapper = document.createElement("span"); badgewrapper.className = `BE-badges ${settings.useColoredVersion ? BDFDB.disCN.userprofiletopsectionnormal : BDFDB.disCN.userprofiletopsectionplaying}`; badgewrapper.setAttribute("style", "all: unset !important;"); for (let flag in this.badges) { if ((this.loadedusers[id].flags | flag) == this.loadedusers[id].flags && !blacklist[flag]) { let badge = document.createElement("div"); badge.className = `BE-badge BE-badge-${this.badges[flag].name.replace(/ /g, "")} BE-badge-${type} ${this.BadgeClasses[this.badges[flag].selector].split(" ")[0]}`; badgewrapper.appendChild(badge); $(badge).on("mouseenter." + this.getName(), (e) => { BDFDB.createTooltip(this.badges[flag].name, e.currentTarget, {"type":type == "list" ? "left" : "top"}); }); } } if (badgewrapper.firstChild) memberwrap.appendChild(badgewrapper); } } }