BetterDiscordAddons/Plugins/EmojiStatistics/EmojiStatistics.plugin.js

541 lines
25 KiB
JavaScript
Raw Normal View History

2019-09-20 22:32:52 +02:00
//META{"name":"EmojiStatistics","website":"https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/EmojiStatistics","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/EmojiStatistics/EmojiStatistics.plugin.js"}*//
2018-10-11 10:21:26 +02:00
class EmojiStatistics {
2019-01-17 23:48:29 +01:00
getName () {return "EmojiStatistics";}
2019-09-18 10:19:56 +02:00
getVersion () {return "2.8.6";}
2019-01-17 23:48:29 +01:00
getAuthor () {return "DevilBro";}
getDescription () {return "Adds some helpful options to show you more information about emojis and emojiservers.";}
2019-01-26 22:45:19 +01:00
2019-09-04 12:34:02 +02:00
constructor () {
2019-05-24 15:32:58 +02:00
this.changelog = {
2019-09-11 12:14:43 +02:00
"fixed":[["Light Theme Update","Fixed bugs for the Light Theme Update, which broke 99% of my plugins"]]
2019-05-24 15:32:58 +02:00
};
2019-09-04 12:34:02 +02:00
2018-10-11 10:21:26 +02:00
this.labels = {};
2019-01-26 22:45:19 +01:00
this.patchModules = {
2019-02-26 10:36:51 +01:00
"EmojiPicker":"componentDidMount"
};
2019-09-04 12:34:02 +02:00
}
2019-01-26 22:45:19 +01:00
2019-09-04 12:34:02 +02:00
initConstructor () {
2018-10-11 10:21:26 +02:00
this.css = `
2019-01-24 13:37:08 +01:00
.${this.name}-modal .titles {
2018-10-11 10:21:26 +02:00
height: 20px;
}
2019-01-24 13:37:08 +01:00
.${this.name}-modal .emojiserver-entry {
2018-10-11 10:21:26 +02:00
height: 50px;
padding-top: 5px;
padding-bottom: 5px;
}
2019-09-18 10:19:56 +02:00
.${this.name}-modal .titles-entry .title-label,
.${this.name}-modal .emojiserver-entry .emojiserver-label {
2018-10-11 10:21:26 +02:00
font-size: 12px;
font-weight: 600;
overflow: hidden;
text-transform: uppercase;
}
2019-09-18 10:19:56 +02:00
.${this.name}-modal .titles-entry .sorttitle-label {
2018-10-11 10:21:26 +02:00
cursor: pointer;
}
2019-09-18 10:19:56 +02:00
.${this.name}-modal .titles-entry .sorttitle-label,
.${this.name}-modal .emojiserver-entry .emojiserver-label {
margin-left: 10px;
2018-10-11 10:21:26 +02:00
text-align: center;
2019-05-28 10:41:04 +02:00
width: 122px;
}
2019-09-18 10:19:56 +02:00
.${this.name}-modal .titles-entry .titlesname-label,
.${this.name}-modal .emojiserver-entry .emojiname-label {
2019-05-28 10:41:04 +02:00
text-align: left;
2019-09-18 10:19:56 +02:00
white-space: no-wrap;
2019-05-28 10:41:04 +02:00
width: 300px;
2018-10-11 10:21:26 +02:00
}
2019-09-18 10:19:56 +02:00
.${this.name}-modal .titles-entry .titlesicon-label,
.${this.name}-modal .emojiserver-entry .emojiserver-icon {
text-align: center;
width: 48px;
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
.emojistatistics-button {
background-image: url("/assets/f24711dae4f6d6b28335e866a93e9d9b.png");
background-position: -770px -374px;
background-size: 924px 704px;
cursor: pointer;
height: 22px;
margin-right: 10px;
width: 22px;
}`;
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
this.emojiInformationModalMarkup =
2019-04-18 09:28:20 +02:00
`<span class="${this.name}-modal BDFDB-modal">
2018-10-11 10:21:26 +02:00
<div class="${BDFDB.disCN.backdrop}"></div>
<div class="${BDFDB.disCN.modal}">
<div class="${BDFDB.disCN.modalinner}">
<div class="${BDFDB.disCNS.modalsub + BDFDB.disCN.modalsizelarge}">
2019-10-08 11:51:41 +02:00
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.modalheader}" style="flex: 0 0 auto;">
2018-10-11 10:21:26 +02:00
<div class="${BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">
2019-09-11 12:14:43 +02:00
<h4 class="${BDFDB.disCNS.h4 + BDFDB.disCNS.defaultcolor + BDFDB.disCN.h4defaultmargin}">REPLACE_modal_header_text</h4>
2019-10-09 14:18:28 +02:00
<div class="${BDFDB.disCNS.modalguildname + BDFDB.disCNS.small + BDFDB.disCNS.titlesize12 + BDFDB.disCNS.height16 + BDFDB.disCN.primary}"></div>
2018-10-11 10:21:26 +02:00
</div>
2019-01-22 20:15:31 +01:00
<button type="button" class="${BDFDB.disCNS.modalclose + BDFDB.disCNS.flexchild + BDFDB.disCNS.button + BDFDB.disCNS.buttonlookblank + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCN.buttongrow}">
<div class="${BDFDB.disCN.buttoncontents}">
<svg name="Close" width="18" height="18" viewBox="0 0 12 12" style="flex: 0 1 auto;">
<g fill="none" fill-rule="evenodd">
<path d="M0 0h12v12H0"></path>
<path class="fill" fill="currentColor" d="M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6"></path>
</g>
</svg>
</div>
</button>
2018-10-11 10:21:26 +02:00
</div>
2019-10-08 11:51:41 +02:00
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.modalsubinner} titles" style="flex: 0 0 auto;"></div>
2019-10-09 14:18:28 +02:00
<div class="${BDFDB.disCNS.scrollerwrap + BDFDB.disCNS.modalcontent + BDFDB.disCNS.scrollerthemed + BDFDB.disCN.scrollerthemeghosthairline}">
2018-10-11 10:21:26 +02:00
<div class="${BDFDB.disCNS.scroller + BDFDB.disCN.modalsubinner} entries"></div>
</div>
2019-09-18 10:19:56 +02:00
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontalreverse + BDFDB.disCNS.horizontalreverse2 + BDFDB.disCNS.directionrowreverse + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.modalfooter}">
2018-10-11 10:21:26 +02:00
<button type="button" class="btn-ok ${BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCNS.buttonsizemedium + BDFDB.disCN.buttongrow}">
2019-09-11 12:14:43 +02:00
<div class="${BDFDB.disCN.buttoncontents}"></div>
2018-10-11 10:21:26 +02:00
</button>
</div>
</div>
</div>
</div>
</span>`;
this.emojiserverTitlesMarkup =
2019-10-08 11:51:41 +02:00
`<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCN.nowrap} titles-entry" style="flex: 1 1 auto;">
2019-09-18 10:19:56 +02:00
<div class="title-label titlesicon-label ${BDFDB.disCN.description}">REPLACE_modal_titlesicon-label</div>
<div class="title-label sorttitle-label titlesname-label ${BDFDB.disCN.description}" sortkey="name">REPLACE_modal_titlesname_text</div>
<div class="title-label sorttitle-label titlestotal-label ${BDFDB.disCN.description}" sortkey="total">REPLACE_modal_titlestotal_text</div>
<div class="title-label sorttitle-label titlesglobal-label ${BDFDB.disCN.description}" sortkey="global">REPLACE_modal_titlesglobal_text</div>
<div class="title-label sorttitle-label titleslocal-label ${BDFDB.disCN.description}" sortkey="local">REPLACE_modal_titleslocal_text</div>
<div class="title-label sorttitle-label titlescopies-label ${BDFDB.disCN.description}" sortkey="copies">REPLACE_modal_titlescopies_text</div>
2018-10-11 10:21:26 +02:00
</div>`;
this.emojiserverEntryMarkup =
2019-10-08 11:51:41 +02:00
`<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCNS.margintop4 + BDFDB.disCN.marginbottom4} emojiserver-entry" style="flex: 1 1 auto;">
2019-09-18 10:19:56 +02:00
<div class="emojiserver-icon"></div>
<div class="emojiserver-label emojiname-label ${BDFDB.disCN.primary}">emojiname-label</div>
<div class="emojiserver-label emojitotal-label ${BDFDB.disCN.primary}">emojitotal-label</div>
<div class="emojiserver-label emojiglobal-label ${BDFDB.disCN.primary}">emojiglobal-label</div>
<div class="emojiserver-label emojilocal-label ${BDFDB.disCN.primary}">emojilocal-label</div>
<div class="emojiserver-label emojicopies-label ${BDFDB.disCN.primary}">emojicopies-label</div>
2018-10-11 10:21:26 +02:00
</div>`;
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
this.defaults = {
settings: {
enableEmojiHovering: {value:true, description:"Show Information about Emojis on hover over an Emoji in the Emojipicker."},
enableEmojiStatisticsButton: {value:true, description:"Add a Button in the Emojipicker to open the Statistics Overview."}
},
amounts: {
2019-02-26 12:16:08 +01:00
hoverDelay: {value:1000, min:0, description:"Tooltip delay in millisec:"}
2018-10-11 10:21:26 +02:00
}
};
}
getSettingsPanel () {
2019-01-22 11:28:32 +01:00
if (!global.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return;
2019-10-22 23:04:35 +02:00
let settings = BDFDB.DataUtils.get(this, "settings");
2019-10-22 19:49:57 +02:00
var amounts = BDFDB.DataUtils.get(this, "amounts");
2019-10-09 14:18:28 +02:00
var settingshtml = `<div class="${this.name}-settings BDFDB-settings"><div class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.titlesize18 + BDFDB.disCNS.height24 + BDFDB.disCNS.weightnormal + BDFDB.disCN.marginbottom8}">${this.name}</div><div class="BDFDB-settings-inner">`;
2018-10-11 10:21:26 +02:00
for (let key in settings) {
2019-10-09 14:18:28 +02:00
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.titlesize16 + 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>`;
2018-10-11 10:21:26 +02:00
}
for (let key in amounts) {
2019-10-09 14:18:28 +02:00
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.weightmedium + BDFDB.disCNS.titlesize16 + BDFDB.disCN.flexchild}" style="flex: 0 0 50%;">${this.defaults.amounts[key].description}</h3><div class="${BDFDB.disCN.inputwrapper} inputNumberWrapper ${BDFDB.disCNS.vertical}" style="flex: 1 1 auto;"><span class="numberinput-buttons-zone"><span class="numberinput-button-up"></span><span class="numberinput-button-down"></span></span><input type="number"${(!isNaN(this.defaults.amounts[key].min) && this.defaults.amounts[key].min !== null ? ' min="' + this.defaults.amounts[key].min + '"' : '') + (!isNaN(this.defaults.amounts[key].max) && this.defaults.amounts[key].max !== null ? ' max="' + this.defaults.amounts[key].max + '"' : '')} option="${key}" value="${amounts[key]}" class="${BDFDB.disCNS.inputdefault + BDFDB.disCNS.input + BDFDB.disCN.titlesize16} amount-input"></div></div>`;
}
2018-10-11 10:21:26 +02:00
settingshtml += `</div></div>`;
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
let settingspanel = BDFDB.htmlToElement(settingshtml);
2018-10-11 10:21:26 +02:00
2019-01-17 23:48:29 +01:00
BDFDB.initElements(settingspanel, this);
2018-10-11 10:21:26 +02:00
return settingspanel;
}
//legacy
load () {}
start () {
2019-02-04 09:13:15 +01:00
if (!global.BDFDB) global.BDFDB = {myPlugins:{}};
if (global.BDFDB && global.BDFDB.myPlugins && typeof global.BDFDB.myPlugins == "object") global.BDFDB.myPlugins[this.getName()] = this;
2019-05-26 13:55:26 +02:00
var libraryScript = document.querySelector('head script#BDFDBLibraryScript');
if (!libraryScript || (performance.now() - libraryScript.getAttribute("date")) > 600000) {
2018-10-11 10:21:26 +02:00
if (libraryScript) libraryScript.remove();
libraryScript = document.createElement("script");
2019-05-26 13:55:26 +02:00
libraryScript.setAttribute("id", "BDFDBLibraryScript");
2018-10-11 10:21:26 +02:00
libraryScript.setAttribute("type", "text/javascript");
2019-10-18 10:56:41 +02:00
libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js");
2019-01-17 23:48:29 +01:00
libraryScript.setAttribute("date", performance.now());
2019-05-26 13:55:26 +02:00
libraryScript.addEventListener("load", () => {this.initialize();});
2018-10-11 10:21:26 +02:00
document.head.appendChild(libraryScript);
2019-05-26 13:55:26 +02:00
}
else if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();
2018-10-11 10:21:26 +02:00
this.startTimeout = setTimeout(() => {this.initialize();}, 30000);
}
initialize () {
2019-01-17 23:48:29 +01:00
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
2019-01-22 11:05:54 +01:00
if (this.started) return;
2019-10-22 18:55:25 +02:00
BDFDB.PluginUtils.init(this);
2019-01-26 22:45:19 +01:00
2019-10-22 18:55:25 +02:00
BDFDB.ModuleUtils.forceAllUpdates(this);
2018-10-11 10:21:26 +02:00
}
2019-10-22 18:55:25 +02:00
else console.error(`%c[${this.getName()}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not load BD functions!');
2018-10-11 10:21:26 +02:00
}
stop () {
2019-01-17 23:48:29 +01:00
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
2019-10-22 11:37:23 +02:00
this.stopping = true;
BDFDB.removeEles(".emoji-tooltip",".emojistatistics-button");
2019-10-22 18:55:25 +02:00
BDFDB.PluginUtils.clear(this);
2018-10-11 10:21:26 +02:00
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
// begin of own functions
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
changeLanguageStrings () {
this.emojiInformationModalMarkup = this.emojiInformationModalMarkup.replace("REPLACE_modal_header_text", this.labels.modal_header_text);
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titlesicon-label", this.labels.modal_titlesicon_text);
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titlesname_text", this.labels.modal_titlesname_text);
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titlestotal_text", this.labels.modal_titlestotal_text);
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titlesglobal_text", this.labels.modal_titlesglobal_text);
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titleslocal_text", this.labels.modal_titleslocal_text);
this.emojiserverTitlesMarkup = this.emojiserverTitlesMarkup.replace("REPLACE_modal_titlescopies_text", this.labels.modal_titlescopies_text);
}
2019-01-26 22:45:19 +01:00
2019-09-11 12:14:43 +02:00
processEmojiPicker (instance, wrapper, returnvalue) {
if (!wrapper.querySelector(".emojistatistics-button")) {
2019-01-17 23:48:29 +01:00
let emojipickerdiversityselector = document.querySelector(BDFDB.dotCN.emojipickerdiversityselector);
if (!emojipickerdiversityselector) return;
this.loadEmojiList();
2019-10-22 19:49:57 +02:00
let settings = BDFDB.DataUtils.get(this, "settings");
if (settings.enableEmojiStatisticsButton) {
2019-01-17 23:48:29 +01:00
let emojiStatisticsButton = BDFDB.htmlToElement(`<div class="emojistatistics-button"></div>`);
emojipickerdiversityselector.parentElement.insertBefore(emojiStatisticsButton, emojipickerdiversityselector);
emojiStatisticsButton.addEventListener("click", () => {
2019-10-22 18:55:25 +02:00
let close = BDFDB.ReactUtils.getValue(instance, "_reactInternalFiber.return.return.return.return.stateNode.close");
2019-02-26 10:55:41 +01:00
if (close) close();
2019-02-27 11:20:13 +01:00
this.showEmojiInformationModal();
2019-01-17 23:48:29 +01:00
});
emojiStatisticsButton.addEventListener("mouseenter", e => {
2019-10-22 18:55:25 +02:00
BDFDB.TooltipUtils.create(emojiStatisticsButton, "Emoji Statistics", {type:"top",selector:"emojistatistics-tooltip"});
2019-01-17 23:48:29 +01:00
});
}
if (settings.enableEmojiHovering) {
2019-10-22 18:55:25 +02:00
BDFDB.ListenerUtils.add(this, wrapper, "mouseenter", BDFDB.dotCN.emojipickeremojiitem, e => {
2019-01-17 23:48:29 +01:00
let data = this.emojiToServerList[e.target.style.getPropertyValue("background-image").replace('url("',"").replace('")',"")];
2019-10-22 20:16:05 +02:00
if (data) BDFDB.TooltipUtils.create(e.target, `${BDFDB.encodeToHTML(data.emoji)}\n${BDFDB.encodeToHTML(data.server)}`, {type:"right",selector:"emoji-tooltip",delay:BDFDB.DataUtils.get(this, "amounts")}, "hoverDelay");
2019-01-17 23:48:29 +01:00
});
}
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
loadEmojiList () {
this.emojiReplicaList = {};
this.emojiToServerList = {};
2019-10-22 18:55:25 +02:00
for (let serverObj of BDFDB.GuildUtils.getAll()) {
2019-09-11 12:14:43 +02:00
for (let emoji of BDFDB.LibraryModules.GuildEmojiStore.getGuildEmoji(serverObj.id)) {
2018-10-11 10:21:26 +02:00
this.emojiToServerList[emoji.url] = {emoji:emoji.allNamesString, server:serverObj.name};
if (emoji.managed) this.emojiReplicaList[emoji.name] = this.emojiReplicaList[emoji.name] != undefined;
2018-10-11 10:21:26 +02:00
}
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
showEmojiInformationModal () {
2019-01-17 23:48:29 +01:00
var emojiInformationModal = BDFDB.htmlToElement(this.emojiInformationModalMarkup);
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
let titlescontainer = emojiInformationModal.querySelector(".titles");
let entriescontainer = emojiInformationModal.querySelector(".entries");
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
if (!titlescontainer || !entriescontainer) return;
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
var titleEntry = BDFDB.htmlToElement(this.emojiserverTitlesMarkup);
titlescontainer.appendChild(titleEntry);
2019-05-28 10:41:04 +02:00
var entries = [], index = 0, totalGlobal = 0, totalLocal = 0, totalCopies = 0;
2019-10-22 18:55:25 +02:00
BDFDB.ListenerUtils.addToChildren(titleEntry, "click", ".sorttitle-label ", e => {
2019-01-17 23:48:29 +01:00
var oldTitle = e.currentTarget.innerText;
2019-09-04 12:34:02 +02:00
2019-05-28 10:41:04 +02:00
this.resetTitles(titleEntry, totalGlobal, totalLocal, totalCopies);
2019-09-04 12:34:02 +02:00
2019-05-28 10:41:04 +02:00
var reverse = oldTitle.indexOf("▼") < 0 ? false : true, sortKey = "index";
2019-01-17 23:48:29 +01:00
if (oldTitle.indexOf("▲") < 0) {
sortKey = e.currentTarget.getAttribute("sortkey");
2019-05-28 10:41:04 +02:00
e.currentTarget.innerText = oldTitle.indexOf("▼") < 0 ? e.currentTarget.innerText + "▼" : e.currentTarget.innerText + "▲";
2019-01-17 23:48:29 +01:00
}
2019-01-26 22:45:19 +01:00
2019-10-22 18:55:25 +02:00
BDFDB.ArrayUtils.keySort(entries, sortKey);
2019-01-17 23:48:29 +01:00
if (reverse) entries.reverse();
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
this.updateAllEntries(entriescontainer, entries);
});
2019-01-26 22:45:19 +01:00
2019-10-22 18:55:25 +02:00
for (let info of BDFDB.GuildUtils.getAll()) {
2018-10-11 10:21:26 +02:00
let amountGlobal = 0, amountLocal = 0, amountCopies = 0;
2019-09-11 12:14:43 +02:00
for (let emoji of BDFDB.LibraryModules.GuildEmojiStore.getGuildEmoji(info.id)) {
2018-10-11 10:21:26 +02:00
if (emoji.managed) {
amountGlobal++;
if (this.emojiReplicaList[emoji.name]) amountCopies++;
}
else {
amountLocal++;
}
}
2019-01-17 23:48:29 +01:00
var emojiEntry = BDFDB.htmlToElement(this.emojiserverEntryMarkup);
2019-10-22 18:55:25 +02:00
emojiEntry.querySelector(".emojiserver-icon").appendChild(BDFDB.GuildUtils.createCopy(info, {click: () => {BDFDB.removeEles(emojiInformationModal);}, menu: true, size: 48}));
2019-09-18 10:19:56 +02:00
emojiEntry.querySelector(".emojiname-label").innerText = info.name || "";
emojiEntry.querySelector(".emojitotal-label").innerText = amountGlobal + amountLocal;
emojiEntry.querySelector(".emojiglobal-label").innerText = amountGlobal;
emojiEntry.querySelector(".emojilocal-label").innerText = amountLocal;
emojiEntry.querySelector(".emojicopies-label").innerText = amountCopies;
2019-01-17 23:48:29 +01:00
entries.push({div:emojiEntry, index:index++, name:info.name || "", total:amountGlobal+amountLocal, global:amountGlobal, local:amountLocal, copies:amountCopies});
2019-05-28 10:41:04 +02:00
totalGlobal += amountGlobal;
totalLocal += amountLocal;
totalCopies += amountCopies;
2018-10-11 10:21:26 +02:00
}
2019-09-04 12:34:02 +02:00
2019-05-28 10:41:04 +02:00
this.resetTitles(titleEntry, totalGlobal, totalLocal, totalCopies);
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
BDFDB.appendModal(emojiInformationModal);
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
this.updateAllEntries(entriescontainer, entries);
2018-10-11 10:21:26 +02:00
}
2019-09-04 12:34:02 +02:00
2019-05-28 10:41:04 +02:00
resetTitles (titleEntry, totalGlobal, totalLocal, totalCopies) {
2019-09-18 10:19:56 +02:00
titleEntry.querySelector(".titlesname-label").innerText = this.labels.modal_titlesname_text;
titleEntry.querySelector(".titlestotal-label").innerText = `${this.labels.modal_titlestotal_text} (${totalGlobal + totalLocal})`;
titleEntry.querySelector(".titlesglobal-label").innerText = `${this.labels.modal_titlesglobal_text} (${totalGlobal})`;
titleEntry.querySelector(".titleslocal-label").innerText = `${this.labels.modal_titleslocal_text} (${totalLocal})`;
titleEntry.querySelector(".titlescopies-label").innerText = `${this.labels.modal_titlescopies_text} (${totalCopies})`;
2019-05-28 10:41:04 +02:00
}
2019-01-26 22:45:19 +01:00
2019-01-17 23:48:29 +01:00
updateAllEntries (entriescontainer, entries) {
BDFDB.removeEles(entriescontainer.childNodes);
for (let entry of entries) {
2019-10-15 11:46:37 +02:00
if (entriescontainer.childElementCount) entriescontainer.appendChild(BDFDB.htmlToElement(`<div class="${BDFDB.disCN.divider}"></div>`));
2019-01-17 23:48:29 +01:00
entriescontainer.appendChild(entry.div);
2018-10-11 10:21:26 +02:00
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
setLabelsByLanguage () {
switch (BDFDB.getDiscordLanguage().id) {
case "hr": //croatian
return {
modal_header_text: "Statistike o emojima",
modal_titlesicon_text: "Ikona",
modal_titlesname_text: "Naziv poslužitelja",
modal_titlestotal_text: "Cjelokupni:",
modal_titlesglobal_text: "Globalno:",
modal_titleslocal_text: "Kokalne:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopije:"
2018-10-11 10:21:26 +02:00
};
case "da": //danish
return {
modal_header_text: "Statistikker af emojis",
modal_titlesicon_text: "Icon",
modal_titlesname_text: "Servernavn",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Lokal:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Copies:"
2018-10-11 10:21:26 +02:00
};
case "de": //german
return {
modal_header_text: "Statistiken über Emojis",
modal_titlesicon_text: "Icon",
modal_titlesname_text: "Servername",
modal_titlestotal_text: "Gesamt:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Lokal:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopien:"
2018-10-11 10:21:26 +02:00
};
case "es": //spanish
return {
modal_header_text: "Estadísticas de emojis",
modal_titlesicon_text: "Icono",
modal_titlesname_text: "Nombre del servidor",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Local:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Copias:"
2018-10-11 10:21:26 +02:00
};
case "fr": //french
return {
modal_header_text: "Statistiques des emojis",
modal_titlesicon_text: "Icône",
modal_titlesname_text: "Nom du serveur",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Local:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Copies:"
2018-10-11 10:21:26 +02:00
};
case "it": //italian
return {
modal_header_text: "Statistiche di emojis",
modal_titlesicon_text: "Icona",
modal_titlesname_text: "Nome del server",
modal_titlestotal_text: "Totale:",
modal_titlesglobal_text: "Globale:",
modal_titleslocal_text: "Locale:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Copie:"
2018-10-11 10:21:26 +02:00
};
case "nl": //dutch
return {
modal_header_text: "Statistieken van emojis",
modal_titlesicon_text: "Icoon",
modal_titlesname_text: "Servernaam",
modal_titlestotal_text: "Totaal:",
modal_titlesglobal_text: "Globaal:",
modal_titleslocal_text: "Lokaal:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopieën:"
2018-10-11 10:21:26 +02:00
};
case "no": //norwegian
return {
modal_header_text: "Statistikk av emojis",
modal_titlesicon_text: "Ikon",
modal_titlesname_text: "Servernavn",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Lokal:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopier:"
2018-10-11 10:21:26 +02:00
};
case "pl": //polish
return {
modal_header_text: "Statystyki emoji",
modal_titlesicon_text: "Ikona",
modal_titlesname_text: "Nazwa",
modal_titlestotal_text: "Całkowity:",
modal_titlesglobal_text: "Światowy:",
modal_titleslocal_text: "Lokalny:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopie:"
2018-10-11 10:21:26 +02:00
};
case "pt-BR": //portuguese (brazil)
return {
modal_header_text: "Estatísticas de emojis",
modal_titlesicon_text: "Ícone",
modal_titlesname_text: "Nome do servidor",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Local:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Cópias:"
2018-10-11 10:21:26 +02:00
};
case "fi": //finnish
return {
modal_header_text: "Tilastot emojista",
modal_titlesicon_text: "Ikoni",
modal_titlesname_text: "Palvelimen nimi",
modal_titlestotal_text: "Koko:",
modal_titlesglobal_text: "Globaali:",
modal_titleslocal_text: "Paikallinen:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopiot:"
2018-10-11 10:21:26 +02:00
};
case "sv": //swedish
return {
modal_header_text: "Statistik för emojis",
modal_titlesicon_text: "Ikon",
modal_titlesname_text: "Servernamn",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Lokal:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopior:"
2018-10-11 10:21:26 +02:00
};
case "tr": //turkish
return {
modal_header_text: "Emojis istatistikleri",
modal_titlesicon_text: "Icon",
modal_titlesname_text: "Sunucuadı",
modal_titlestotal_text: "Toplam:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Yerel:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopya:"
2018-10-11 10:21:26 +02:00
};
case "cs": //czech
return {
modal_header_text: "Statistiky emojis",
modal_titlesicon_text: "Ikona",
modal_titlesname_text: "Název serveru",
modal_titlestotal_text: "Celkový:",
modal_titlesglobal_text: "Globální:",
modal_titleslocal_text: "Místní:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Kopie:"
2018-10-11 10:21:26 +02:00
};
case "bg": //bulgarian
return {
modal_header_text: "Статистика на емотис",
modal_titlesicon_text: "Икона",
modal_titlesname_text: "Име на сървъра",
modal_titlestotal_text: "Oбщо:",
modal_titlesglobal_text: "Cветовен:",
modal_titleslocal_text: "Mестен:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Копия:"
2018-10-11 10:21:26 +02:00
};
case "ru": //russian
return {
modal_header_text: "Статистика emojis",
modal_titlesicon_text: "Значок",
modal_titlesname_text: "Имя сервера",
modal_titlestotal_text: "Всего:",
modal_titlesglobal_text: "Mировой:",
modal_titleslocal_text: "Местный:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Копии:"
2018-10-11 10:21:26 +02:00
};
case "uk": //ukrainian
return {
modal_header_text: "Статистика емідій",
modal_titlesicon_text: "Ікона",
modal_titlesname_text: "Ім'я сервера",
modal_titlestotal_text: "Всього:",
modal_titlesglobal_text: "Cвітовий:",
modal_titleslocal_text: "Місцевий:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Копії:"
2018-10-11 10:21:26 +02:00
};
case "ja": //japanese
return {
modal_header_text: "エモジスの統計",
modal_titlesicon_text: "アイコン",
modal_titlesname_text: "サーバーの名前",
modal_titlestotal_text: "合計:",
modal_titlesglobal_text: "グローバル:",
modal_titleslocal_text: "地元:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "コピー:"
2018-10-11 10:21:26 +02:00
};
case "zh-TW": //chinese (traditional)
return {
modal_header_text: "表情統計",
modal_titlesicon_text: "圖標",
modal_titlesname_text: "服務器名稱",
modal_titlestotal_text: "總:",
modal_titlesglobal_text: "全球:",
modal_titleslocal_text: "本地:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "副本:"
2018-10-11 10:21:26 +02:00
};
case "ko": //korean
return {
modal_header_text: "그림 이모티콘의 통계",
modal_titlesicon_text: "상",
modal_titlesname_text: "서버 이름",
modal_titlestotal_text: "합계:",
modal_titlesglobal_text: "글로벌:",
modal_titleslocal_text: "지방의:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "사본:"
2018-10-11 10:21:26 +02:00
};
default: //default: english
return {
modal_header_text: "Statistics of emojis",
modal_titlesicon_text: "Icon",
modal_titlesname_text: "Servername",
modal_titlestotal_text: "Total:",
modal_titlesglobal_text: "Global:",
modal_titleslocal_text: "Local:",
2019-09-11 12:14:43 +02:00
modal_titlescopies_text: "Copies:"
2018-10-11 10:21:26 +02:00
};
}
}
}