202 lines
12 KiB
JavaScript
202 lines
12 KiB
JavaScript
module.exports = (Plugin, Api, Vendor) => {
|
|
if (!global.BDFDB || typeof BDFDB != "object") global.BDFDB = {BDv2Api: Api};
|
|
|
|
return class extends Plugin {
|
|
initConstructor () {
|
|
this.patchModules = {
|
|
"NameTag":"componentDidMount",
|
|
"MessageUsername":"componentDidMount"
|
|
};
|
|
|
|
this.css = `
|
|
.BE-badge {
|
|
display: inline-block;
|
|
height: 17px !important;
|
|
margin: 0 2px !important;
|
|
}
|
|
.BE-badge.BE-badge-chat {
|
|
margin-bottom: -3px !important;
|
|
}
|
|
.BE-badge.BE-badge-popout {
|
|
margin-bottom: -2px !important;
|
|
}
|
|
.BE-badge.BE-badge:first-of-type {
|
|
margin-left: 5px !important;
|
|
}
|
|
.BE-badge.BE-badge:last-of-type {
|
|
margin-right: 5px !important;
|
|
}
|
|
.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;}
|
|
.BE-badge.BE-badge-settings {width:30px !important; min-width:30px !important;}`;
|
|
|
|
|
|
this.requestedusers = {};
|
|
this.loadedusers = {};
|
|
|
|
this.defaults = {
|
|
settings: {
|
|
showInPopout: {value:true, description:"Show Badge in User Popout."},
|
|
showInChat: {value:true, description:"Show Badge in Chat Window."},
|
|
showInMemberList: {value:true, description:"Show Badge in Member List."},
|
|
useColoredVersion: {value:true, description:"Use colored version of the Badges for Chat and Members."}
|
|
},
|
|
badges: {
|
|
1: {value:true, name:"Staff", selector:"profileBadgeStaff"},
|
|
2: {value:true, name:"Partner", selector:"profileBadgePartner"},
|
|
4: {value:true, name:"HypeSquad", selector:"profileBadgeHypesquad"},
|
|
8: {value:true, name:"BugHunter", selector:"profileBadgeBugHunter"},
|
|
16: {value:false, name:"MFASMS", selector:false},
|
|
32: {value:false, name:"PROMODISMISSED", selector:false},
|
|
64: {value:true, name:"HypeSquad Bravery", selector:"profileBadgeHypeSquadOnlineHouse1"},
|
|
128: {value:true, name:"HypeSquad Brilliance", selector:"profileBadgeHypeSquadOnlineHouse2"},
|
|
256: {value:true, name:"HypeSquad Balance", selector:"profileBadgeHypeSquadOnlineHouse3"},
|
|
512: {value:true, name:"Early Supporter", selector:"profileBadgeEarlySupporter"},
|
|
2048: {value:true, name:"Nitro", selector:"profileBadgePremium"}
|
|
}
|
|
};
|
|
}
|
|
|
|
onStart () {
|
|
var libraryScript = document.querySelector('head script[src="https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"]');
|
|
if (!libraryScript || performance.now() - libraryScript.getAttribute("date") > 600000) {
|
|
if (libraryScript) libraryScript.remove();
|
|
libraryScript = document.createElement("script");
|
|
libraryScript.setAttribute("type", "text/javascript");
|
|
libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js");
|
|
libraryScript.setAttribute("date", performance.now());
|
|
libraryScript.addEventListener("load", () => {if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();});
|
|
document.head.appendChild(libraryScript);
|
|
}
|
|
else if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();
|
|
this.startTimeout = setTimeout(() => {this.initialize();}, 30000);
|
|
}
|
|
|
|
initialize () {
|
|
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
|
if (this.started) return true;
|
|
BDFDB.loadMessage(this);
|
|
|
|
this.APIModule = BDFDB.WebModules.findByProperties("getAPIBaseURL");
|
|
this.DiscordConstants = BDFDB.WebModules.findByProperties("Permissions", "ActivityTypes", "StatusTypes");
|
|
this.BadgeClasses = BDFDB.WebModules.findByProperties("profileBadgeStaff","profileBadgePremium");
|
|
|
|
for (let flag in this.defaults.badges) if (!this.defaults.badges[flag].selector) delete this.defaults.badges[flag];
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
return true;
|
|
}
|
|
else {
|
|
console.error(`%c[${this.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not load BD functions!');
|
|
return false;
|
|
}
|
|
}
|
|
|
|
onStop () {
|
|
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
|
BDFDB.removeEles(".BE-badges");
|
|
|
|
BDFDB.unloadMessage(this);
|
|
return true;
|
|
}
|
|
else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
// begin of own functions
|
|
|
|
processNameTag (instance, wrapper) {
|
|
if (!wrapper.classList || !instance || !instance.props) return;
|
|
else if (BDFDB.containsClass(wrapper, BDFDB.disCN.membernametag) && BDFDB.getData("showInMemberList", this, "settings")) {
|
|
this.addBadges(instance.props.user, wrapper, "list");
|
|
}
|
|
else if (BDFDB.containsClass(wrapper, BDFDB.disCN.userpopoutheadertag) && BDFDB.getData("showInPopout", this, "settings")) {
|
|
wrapper = BDFDB.containsClass(wrapper, BDFDB.disCN.userpopoutheadertagwithnickname) && wrapper.previousSibling ? wrapper.previousSibling : wrapper;
|
|
this.addBadges(instance.props.user, wrapper, "popout");
|
|
}
|
|
}
|
|
|
|
processMessageUsername (instance, wrapper) {
|
|
let message = BDFDB.getReactValue(instance, "props.message");
|
|
if (message) {
|
|
let username = wrapper.querySelector(BDFDB.dotCN.messageusername);
|
|
if (username && BDFDB.getData("showInChat", this, "settings")) this.addBadges(message.author, wrapper, "chat");
|
|
}
|
|
}
|
|
|
|
addBadges (info, wrapper, type) {
|
|
if (!info || info.bot || !wrapper) return;
|
|
if (!this.requestedusers[info.id]) {
|
|
this.requestedusers[info.id] = [[wrapper,type]];
|
|
this.APIModule.get(this.DiscordConstants.Endpoints.USER_PROFILE(info.id)).then(result => {
|
|
let usercopy = Object.assign({},result.body.user);
|
|
if (result.body.premium_since) usercopy.flags += 2048;
|
|
this.loadedusers[info.id] = usercopy;
|
|
for (let queredobj of this.requestedusers[info.id]) this.addToWrapper(info, queredobj[0], queredobj[1]);
|
|
});
|
|
}
|
|
else if (!this.loadedusers[info.id]) {
|
|
this.requestedusers[info.id].push([wrapper,type]);
|
|
}
|
|
else {
|
|
this.addToWrapper(info, wrapper, type);
|
|
}
|
|
}
|
|
|
|
addToWrapper (info, wrapper, type) {
|
|
BDFDB.removeEles(wrapper.querySelectorAll(".BE-badges"));
|
|
let badges = BDFDB.getAllData(this, "badges");
|
|
let settings = BDFDB.getAllData(this, "settings");
|
|
let header = BDFDB.getParentEle(BDFDB.dotCN.userpopoutheader, wrapper);
|
|
let badgewrapper = BDFDB.htmlToElement(`<span class="BE-badges ${!settings.useColoredVersion || (header && !BDFDB.containsClass(header, BDFDB.disCN.userpopoutheadernormal)) ? BDFDB.disCN.userprofiletopsectionplaying : BDFDB.disCN.userprofiletopsectionnormal}" style="all: unset !important; order: 9 !important;"></span>`);
|
|
for (let flag in this.defaults.badges) {
|
|
if ((this.loadedusers[info.id].flags | flag) == this.loadedusers[info.id].flags && badges[flag]) {
|
|
let badge = BDFDB.htmlToElement(`<div class="BE-badge BE-badge-${this.defaults.badges[flag].name.replace(/ /g, "")} BE-badge-${type} ${this.BadgeClasses[this.defaults.badges[flag].selector]}"></div>`);
|
|
badgewrapper.appendChild(badge);
|
|
badge.addEventListener("mouseenter", () => {BDFDB.createTooltip(this.defaults.badges[flag].name, badge, {"type":type == "list" ? "left" : "top"});});
|
|
}
|
|
}
|
|
if (badgewrapper.firstChild) wrapper.insertBefore(badgewrapper, wrapper.querySelector(".owner-tag,.TRE-tag,svg[name=MobileDevice]"));
|
|
}
|
|
|
|
getSettingsPanel () {
|
|
if (!global.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return;
|
|
var settings = BDFDB.getAllData(this, "settings");
|
|
var badges = BDFDB.getAllData(this, "badges");
|
|
var settingshtml = `<div class="${this.name}-settings DevilBro-settings"><div class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.size18 + BDFDB.disCNS.height24 + BDFDB.disCNS.weightnormal + BDFDB.disCN.marginbottom8}">${this.name}</div><div class="DevilBro-settings-inner">`;
|
|
for (let key in settings) {
|
|
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="settings ${key}" class="${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} settings-switch"${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 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.defaults.badges[flag].name}</h3><span class="BE-badges ${BDFDB.disCN.userprofiletopsectionplaying}" style="all: unset !important;"><div class="BE-badge BE-badge-${this.defaults.badges[flag].name.replace(/ /g, "")} BE-badge-settings ${this.BadgeClasses[this.defaults.badges[flag].selector]}"></div></span><span class="BE-badges ${BDFDB.disCN.userprofiletopsectionnormal}" style="all: unset !important;"><div class="BE-badge BE-badge-${this.defaults.badges[flag].name.replace(/ /g, "")} BE-badge-settings ${this.BadgeClasses[this.defaults.badges[flag].selector]}"></div></span><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="badges ${flag}" class="${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} settings-switch"${badges[flag] ? " checked" : ""}></div></div>`;
|
|
}
|
|
|
|
settingshtml += `</div></div></div>`;
|
|
|
|
let settingspanel = BDFDB.htmlToElement(settingshtml);
|
|
|
|
BDFDB.initElements(settingspanel, this);
|
|
|
|
return settingspanel;
|
|
}
|
|
|
|
onSettingsClosed () {
|
|
if (this.SettingsUpdated) {
|
|
delete this.SettingsUpdated;
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
}
|
|
}
|
|
}
|
|
};
|