BetterDiscordAddons/Plugins/BadgesEverywhere/BadgesEverywhere.plugin.js

309 lines
14 KiB
JavaScript
Raw Normal View History

2018-10-16 21:30:05 +02:00
//META{"name":"BadgesEverywhere"}*//
2018-10-16 21:33:23 +02:00
2018-10-11 10:21:26 +02:00
class BadgesEverywhere {
initConstructor () {
this.css = `
.BE-badge {
display: inline-block;
height: 17px !important;
margin: 0 2px !important;
2018-10-11 10:21:26 +02:00
}
.BE-badge.BE-badge-chat {
margin-bottom: -3px !important;
2018-10-11 10:21:26 +02:00
}
.BE-badge.BE-badge-popout {
margin-bottom: -2px !important;
2018-10-11 10:21:26 +02:00
}
.BE-badge.BE-badge-settings {
2018-11-04 11:40:41 +01:00
width: 30px !important;
}
.BE-badge.BE-badge:first-of-type {
margin-left: 5px !important;
2018-10-11 10:21:26 +02:00
}
.BE-badge.BE-badge:last-of-type {
margin-right: 5px !important;
2018-10-11 10:21:26 +02:00
}
.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;}`;
2018-10-11 10:21:26 +02:00
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"}
2018-10-11 10:21:26 +02:00
};
this.requestedusers = {};
this.loadedusers = {};
this.defaults = {
settings: {
2018-12-12 00:11:53 +01:00
showInPopout: {value:true, description:"Show Badge in User Popout."},
2018-10-11 10:21:26 +02:00
showInChat: {value:true, description:"Show Badge in Chat Window."},
showInMemberList: {value:true, description:"Show Badge in Member List."},
2018-12-12 00:11:53 +01:00
useColoredVersion: {value:true, description:"Use colored version of the Badges for Chat and Members."}
2018-10-11 10:21:26 +02:00
}
};
}
getName () {return "BadgesEverywhere";}
getDescription () {return "Displays Badges (Nitro, HypeSquad, etc...) in the chat/memberlist/userpopout. Thanks for Zerebos' help.";}
getVersion () {return "1.1.5";}
2018-10-11 10:21:26 +02:00
getAuthor () {return "DevilBro";}
getSettingsPanel () {
if (!this.started || typeof BDFDB !== "object") return;
var settings = BDFDB.getAllData(this, "settings");
2018-11-04 11:40:41 +01:00
var blacklist = BDFDB.loadAllData(this, "blacklist");
2018-10-11 10:21:26 +02:00
var settingshtml = `<div class="${this.getName()}-settings DevilBro-settings"><div class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.size18 + BDFDB.disCNS.height24 + BDFDB.disCNS.weightnormal + BDFDB.disCN.marginbottom8}">${this.getName()}</div><div class="DevilBro-settings-inner">`;
for (let key in settings) {
2018-11-04 11:40:41 +01:00
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">${this.defaults.settings[key].description}</h3><div class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style="flex: 0 0 auto;"><input type="checkbox" value="${key}" class="${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} settingsswitch"${settings[key] ? " checked" : ""}></div></div>`;
}
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 0 0 auto;">Display Badges:</h3></div><div class="DevilBro-settings-inner-list">`;
for (let flag in this.badges) {
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">${this.badges[flag].name}</h3><div class="${BDFDB.disCNS.flexchild + "BE-badge-" + this.badges[flag].name.replace(/ /g, "")} BE-badge BE-badge-settings" style="background-image: ${this.badges[flag].color}; flex: 0 0 auto;"></div><div class="${BDFDB.disCNS.flexchild + "BE-badge-" + this.badges[flag].name.replace(/ /g, "")} BE-badge BE-badge-settings" style="background-image: ${this.badges[flag].white}; flex: 0 0 auto;"></div><div class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style="flex: 0 0 auto;"><input type="checkbox" value="${flag}" class="${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} blacklistswitch"${blacklist[flag] ? "" : " checked"}></div></div>`;
2018-10-11 10:21:26 +02:00
}
2018-11-04 11:40:41 +01:00
settingshtml += `</div></div></div>`;
2018-10-11 10:21:26 +02:00
var settingspanel = $(settingshtml)[0];
BDFDB.initElements(settingspanel);
$(settingspanel)
2018-11-04 11:40:41 +01:00
.on("click", BDFDB.dotCN.switchinner + ".settingsswitch", () => {this.updateSettings(settingspanel);})
.on("click", BDFDB.dotCN.switchinner + ".blacklistswitch", () => {this.updateBlacklist(settingspanel);});
2018-10-11 10:21:26 +02:00
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);
2018-12-20 22:54:42 +01:00
this.APIModule = BDFDB.WebModules.findByProperties("getAPIBaseURL");
this.DiscordConstants = BDFDB.WebModules.findByProperties("Permissions", "ActivityTypes", "StatusTypes");
this.BadgeClasses = BDFDB.WebModules.findByProperties("profileBadgeStaff","profileBadgePremium");
2018-10-11 10:21:26 +02:00
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")) {
2018-10-11 10:21:26 +02:00
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) {
2018-10-11 10:21:26 +02:00
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];
2018-10-11 10:21:26 +02:00
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();});
2018-10-11 10:21:26 +02:00
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 = {};
2018-11-04 11:40:41 +01:00
for (var input of settingspanel.querySelectorAll(BDFDB.dotCN.switchinner + ".settingsswitch")) {
2018-10-11 10:21:26 +02:00
settings[input.value] = input.checked;
}
BDFDB.saveAllData(settings, this, "settings");
this.updateBadges = true;
}
2018-11-04 11:40:41 +01:00
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;
}
2018-10-11 10:21:26 +02:00
loadBadges() {
2018-12-12 00:11:53 +01:00
document.querySelectorAll(".BE-badges").forEach(node=>{node.remove();});
2018-10-11 10:21:26 +02:00
var settings = BDFDB.getAllData(this, "settings");
if (settings.showInMemberList) {
for (let user of document.querySelectorAll(BDFDB.dotCN.member)) {
2018-11-04 11:40:41 +01:00
this.addBadges(user, "list", false);
2018-10-11 10:21:26 +02:00
}
}
if (settings.showInChat) {
for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcozy)) {
2018-11-04 11:40:41 +01:00
this.addBadges(messagegroup, "chat", false);
2018-10-11 10:21:26 +02:00
}
for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcompact)) {
for (let message of messagegroup.querySelectorAll(BDFDB.dotCN.messagemarkup)) {
2018-11-04 11:40:41 +01:00
this.addBadges(message, "chat", true);
2018-10-11 10:21:26 +02:00
}
}
}
if (settings.showInPopout) {
for (let user of document.querySelectorAll(BDFDB.dotCN.userpopout)) {
2018-11-04 11:40:41 +01:00
this.addBadges(user.parentElement, "popout", false);
2018-10-11 10:21:26 +02:00
}
}
}
2018-11-04 11:40:41 +01:00
addBadges (wrapper, type, compact) {
2018-10-11 10:21:26 +02:00
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;
2018-11-04 11:40:41 +01:00
for (let queredobj of this.requestedusers[user.id]) this.addToWrapper(queredobj[0], user.id, queredobj[1]);
2018-10-11 10:21:26 +02:00
});
}
else if (!this.loadedusers[user.id]) {
this.requestedusers[user.id].push([wrapper,type]);
}
2018-10-16 21:19:56 +02:00
else {
2018-11-04 11:40:41 +01:00
this.addToWrapper(wrapper, user.id, type);
2018-10-11 10:21:26 +02:00
}
}
}
2018-11-04 11:40:41 +01:00
addToWrapper (wrapper, id, type) {
if (wrapper.querySelector(".BE-badges")) return;
2018-10-11 10:21:26 +02:00
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);
2018-11-04 11:40:41 +01:00
if (memberwrap) {
let blacklist = BDFDB.loadAllData(this, "blacklist");
2018-12-12 00:11:53 +01:00
let settings = BDFDB.getAllData(this, "settings");
let header = wrapper.querySelector(BDFDB.dotCN.userpopoutheader);
let badgewrapper = document.createElement("span");
badgewrapper.className = `BE-badges ${!settings.useColoredVersion || (header && !header.classList.contains(BDFDB.disCN.userpopoutheadernormal)) ? BDFDB.disCN.userprofiletopsectionplaying : BDFDB.disCN.userprofiletopsectionnormal}`;
badgewrapper.setAttribute("style", "all: unset !important;");
2018-11-04 11:40:41 +01:00
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]}`;
badgewrapper.appendChild(badge);
$(badge).on("mouseenter." + this.getName(), (e) => {
BDFDB.createTooltip(this.badges[flag].name, e.currentTarget, {"type":type == "list" ? "left" : "top"});
});
2018-11-04 11:40:41 +01:00
}
2018-10-11 10:21:26 +02:00
}
2018-12-11 20:43:10 +01:00
if (badgewrapper.firstChild) memberwrap.appendChild(badgewrapper);
2018-10-11 10:21:26 +02:00
}
}
2018-11-04 11:40:41 +01:00
}