BetterDiscordAddons/Plugins/BDFDB.max.js

6328 lines
373 KiB
JavaScript
Raw Normal View History

2019-09-09 08:23:13 +02:00
if (window.BDFDB && typeof BDFDB.removeEventListener == 'function') BDFDB.removeEventListener(BDFDB);
if (window.BDFDB && BDFDB.WebModules && typeof BDFDB.WebModules.unpatchall == 'function') BDFDB.WebModules.unpatchall(BDFDB);
if (window.BDFDB && typeof BDFDB.killObservers == 'function') BDFDB.killObservers(BDFDB);
2019-07-23 21:09:07 +02:00
var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api: BDFDB && BDFDB.BDv2Api ? BDFDB.BDv2Api : undefined, creationTime: performance.now(), cachedData: {}, pressedKeys: [], mousePosition: {pageX: 0, pageY: 0}, name: '$BDFDB'};
(() => {
var id = Math.round(Math.random() * 10000000000000000);
BDFDB.id = id;
console.log(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', 'loading library.');
BDFDB.isLibraryOutdated = function () {
return performance.now() - BDFDB.creationTime > 600000;
};
BDFDB.loadMessage = function (plugin) {
BDFDB.clearStarttimout(plugin);
plugin.name = plugin.name || (typeof plugin.getName == "function" ? plugin.getName() : null);
plugin.version = plugin.version || (typeof plugin.getVersion == "function" ? plugin.getVersion() : null);
plugin.author = plugin.author || (typeof plugin.getAuthor == "function" ? plugin.getAuthor() : null);
plugin.description = plugin.description || (typeof plugin.getDescription == "function" ? plugin.getDescription() : null);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var loadmessage = BDFDB.getLibraryStrings().toast_plugin_started.replace('{{oldversion}}', 'v' + plugin.version);
console.log(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', loadmessage);
if (!(window.settingsCookie['fork-ps-2'] && window.settingsCookie['fork-ps-2'] === true)) BDFDB.showToast(plugin.name + ' ' + loadmessage, {nopointer: true, selector: 'plugin-started-toast'});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var url = typeof plugin.getRawUrl == 'function' && typeof plugin.getRawUrl() == 'string' ? plugin.getRawUrl() : `https://mwittrien.github.io/BetterDiscordAddons/Plugins/${plugin.name}/${plugin.name}.plugin.js`;
BDFDB.checkUpdate(plugin.name, url);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
if (typeof plugin.initConstructor === 'function') {
try {plugin.initConstructor();}
catch (err) {console.error(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not initiate constructor! ' + err);}
}
if (typeof plugin.css === 'string') BDFDB.appendLocalStyle(plugin.name, plugin.css);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.WebModules.patchModules(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.addOnSwitchListener(plugin);
BDFDB.addSettingsButtonListener(plugin);
BDFDB.addContextListener(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.translatePlugin(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.checkChangeLog(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
if (!window.PluginUpdates || typeof window.PluginUpdates !== 'object') window.PluginUpdates = {plugins: {} };
window.PluginUpdates.plugins[url] = {name: plugin.name, raw: url, version: plugin.version};
if (typeof window.PluginUpdates.interval === 'undefined') window.PluginUpdates.interval = setInterval(() => {BDFDB.checkAllUpdates();}, 1000*60*60*2);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
plugin.started = true;
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
for (let name in BDFDB.myPlugins) if (!BDFDB.myPlugins[name].started && typeof BDFDB.myPlugins[name].initialize == "function") BDFDB.myPlugins[name].initialize();
};
BDFDB.unloadMessage = function (plugin) {
BDFDB.clearStarttimout(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
delete BDFDB.myPlugins[plugin.name];
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var unloadmessage = BDFDB.getLibraryStrings().toast_plugin_stopped.replace('{{oldversion}}', 'v' + plugin.version);
console.log(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', unloadmessage);
if (!(window.settingsCookie['fork-ps-2'] && window.settingsCookie['fork-ps-2'] === true)) BDFDB.showToast(plugin.name + ' ' + unloadmessage, {nopointer: true, selector: 'plugin-stopped-toast'});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var url = typeof plugin.getRawUrl == 'function' && typeof plugin.getRawUrl() == 'string' ? plugin.getRawUrl() : `https://mwittrien.github.io/BetterDiscordAddons/Plugins/${plugin.name}/${plugin.name}.plugin.js`;
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
if (typeof plugin.css === 'string') BDFDB.removeLocalStyle(plugin.name);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.WebModules.unpatchall(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.removeOnSwitchListener(plugin);
BDFDB.removeSettingsButtonListener(plugin);
BDFDB.removeEventListener(plugin);
BDFDB.removeEles(`.${plugin.name}-modal, .${plugin.name.toLowerCase()}-modal, .${plugin.name}-settingsmodal, .${plugin.name.toLowerCase()}-settingsmodal`);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.killObservers(plugin);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
delete window.PluginUpdates.plugins[url];
if (BDFDB.isObjectEmpty(window.PluginUpdates.plugins)) BDFDB.removeEles('#bd-settingspane-container .bd-updatebtn' + BDFDB.dotCN._repofolderbutton);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
delete plugin.started;
};
BDFDB.translatePlugin = function (plugin) {
if (typeof plugin.setLabelsByLanguage === 'function' || typeof plugin.changeLanguageStrings === 'function') {
if (document.querySelector('html').lang) translate();
else {
var translateinterval = setInterval(() => {
if (document.querySelector('html').lang) {
clearInterval(translateinterval);
translate();
}
}, 100);
}
function translate() {
var language = BDFDB.getDiscordLanguage();
if (typeof plugin.setLabelsByLanguage === 'function') plugin.labels = plugin.setLabelsByLanguage(language.id);
if (typeof plugin.changeLanguageStrings === 'function') plugin.changeLanguageStrings();
var translatemessage = BDFDB.getLibraryStrings().toast_plugin_translated.replace('{{ownlang}}', language.ownlang);
console.log(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', translatemessage);
}
}
};
BDFDB.clearStarttimout = function (plugin) {
if (plugin.startTimeout) {
clearTimeout(plugin.startTimeout);
delete plugin.startTimeout;
}
if (plugin.libLoadTimeout) {
clearTimeout(plugin.libLoadTimeout);
delete plugin.libLoadTimeout;
}
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.checkChangeLog = function (plugin) {
if (!BDFDB.isObject(plugin) || !plugin.changelog) return;
var changelog = BDFDB.loadAllData(plugin, 'changelog');
if (!changelog.currentversion || BDFDB.checkVersions(plugin.version, changelog.currentversion)) {
changelog.currentversion = plugin.version;
BDFDB.saveAllData(changelog, plugin, 'changelog');
2019-09-04 12:00:32 +02:00
BDFDB.openChangeLogModal(plugin);
2019-07-23 21:09:07 +02:00
}
};
2019-09-04 12:34:02 +02:00
2019-09-04 12:00:32 +02:00
BDFDB.openChangeLogModal = function (plugin) {
if (!BDFDB.isObject(plugin) || !plugin.changelog) return;
var changeLogHTML = '';
var headers = {added: 'New Features', fixed: 'Bug Fixes', improved: 'Improvements', progress: 'Progress'};
for (let type in plugin.changelog) {
type = type.toLowerCase();
var classname = BDFDB.disCN['changelog' + type];
if (classname) {
changeLogHTML += `<h1 class="${classname + ' ' + BDFDB.disCN.margintop20}"${changeLogHTML.indexOf('<h1') == -1 ? 'style="margin-top: 0px !important;"' : ''}>${headers[type]}</h1><ul>`;
for (let log of plugin.changelog[type]) changeLogHTML += `<li><strong>${log[0]}</strong>${log[1] ? (': ' + log[1] + '.') : ''}</li>`;
changeLogHTML += `</ul>`
}
}
if (changeLogHTML) BDFDB.removeEles(BDFDB.openConfirmModal(plugin, changeLogHTML, BDFDB.LanguageStrings.CHANGE_LOG).querySelectorAll(".btn-cancel"));
};
2019-07-23 21:09:07 +02:00
BDFDB.addObserver = function (plugin, eleOrSelec, observer, config = {childList: true}) {
if (!BDFDB.isObject(plugin) || !eleOrSelec || !observer) return;
if (BDFDB.isObjectEmpty(plugin.observers)) plugin.observers = {};
if (!Array.isArray(plugin.observers[observer.name])) plugin.observers[observer.name] = [];
if (!observer.multi) for (let subinstance of plugin.observers[observer.name]) subinstance.disconnect();
if (observer.instance) plugin.observers[observer.name].push(observer.instance);
var instance = plugin.observers[observer.name][plugin.observers[observer.name].length - 1];
if (instance) {
var node = Node.prototype.isPrototypeOf(eleOrSelec) ? eleOrSelec : typeof eleOrSelec === 'string' ? document.querySelector(eleOrSelec) : null;
if (node) instance.observe(node, config);
}
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.killObservers = function (plugin) {
if (!BDFDB.isObjectEmpty(plugin.observers)) {
2019-09-04 12:34:02 +02:00
for (let observer in plugin.observers) for (let instance of plugin.observers[observer]) instance.disconnect();
2019-07-23 21:09:07 +02:00
delete plugin.observers;
}
};
BDFDB.addChildEventListener = function (node, actions, selector, callback) {
if (!Node.prototype.isPrototypeOf(node) || !actions || !selector || !selector.trim() || typeof callback != 'function') return;
for (var action of actions.trim().split(' ')) if (action) {
var eventcallback = callback;
if (action == 'mouseenter' || action == 'mouseleave') eventcallback = e => {if (e.target.matches(selector)) callback(e);};
node.querySelectorAll(selector.trim()).forEach(child => {child.addEventListener(action, eventcallback, true);});
}
};
BDFDB.addEventListener = function (plugin, ele, actions, selectorOrCallback, callbackOrNothing) {
if (!BDFDB.isObject(plugin) || (!Node.prototype.isPrototypeOf(ele) && ele !== window) || !actions) return;
var callbackIs4th = typeof selectorOrCallback == 'function';
var selector = callbackIs4th ? undefined : selectorOrCallback;
var callback = callbackIs4th ? selectorOrCallback : callbackOrNothing;
if (typeof callback != 'function') return;
BDFDB.removeEventListener(plugin, ele, actions, selector);
for (var action of actions.split(' ')) {
action = action.split('.');
var eventname = action.shift().toLowerCase();
if (!eventname) return;
var origeventname = eventname;
eventname = eventname == 'mouseenter' || eventname == 'mouseleave' ? 'mouseover' : eventname;
var namespace = (action.join('.') || '') + plugin.name;
if (!Array.isArray(plugin.listeners)) plugin.listeners = [];
var eventcallback = null;
if (selector) {
if (origeventname == 'mouseenter' || origeventname == 'mouseleave') {
eventcallback = e => {
for (let child of e.path) if (typeof child.matches == 'function' && child.matches(selector) && !child[namespace + 'BDFDB' + origeventname]) {
child[namespace + 'BDFDB' + origeventname] = true;
if (origeventname == 'mouseenter') callback(BDFDB.copyEvent(e, child));
let mouseout = e2 => {
if (e2.target.contains(child) || e2.target == child || !child.contains(e2.target)) {
if (origeventname == 'mouseleave') callback(BDFDB.copyEvent(e, child));
delete child[namespace + 'BDFDB' + origeventname];
document.removeEventListener('mouseout', mouseout);
}
};
document.addEventListener('mouseout', mouseout);
break;
}
};
}
else {
eventcallback = e => {
for (let child of e.path) if (typeof child.matches == 'function' && child.matches(selector)) {
callback(BDFDB.copyEvent(e, child));
break;
}
};
}
}
else eventcallback = e => {callback(BDFDB.copyEvent(e, ele));};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
plugin.listeners.push({ele, eventname, origeventname, namespace, selector, eventcallback});
ele.addEventListener(eventname, eventcallback, true);
}
};
BDFDB.copyEvent = function (e, ele) {
if (!e || !e.constructor || !e.type) return e;
var ecopy = new e.constructor(e.type, e);
Object.defineProperty(ecopy, 'originalEvent', {value: e});
Object.defineProperty(ecopy, 'which', {value: e.which});
Object.defineProperty(ecopy, 'keyCode', {value: e.keyCode});
Object.defineProperty(ecopy, 'path', {value: e.path});
Object.defineProperty(ecopy, 'relatedTarget', {value: e.relatedTarget});
Object.defineProperty(ecopy, 'srcElement', {value: e.srcElement});
Object.defineProperty(ecopy, 'target', {value: e.target});
Object.defineProperty(ecopy, 'toElement', {value: e.toElement});
if (ele) Object.defineProperty(ecopy, 'currentTarget', {value: ele});
return ecopy;
};
BDFDB.stopEvent = function (e) {
if (BDFDB.isObject(e)) {
if (typeof e.preventDefault == "function") e.preventDefault();
if (typeof e.stopPropagation == "function") e.stopPropagation();
if (typeof e.stopImmediatePropagation == "function") e.stopImmediatePropagation();
if (BDFDB.isObject(e.originalEvent)) {
if (typeof e.originalEvent.preventDefault == "function") e.originalEvent.preventDefault();
if (typeof e.originalEvent.stopPropagation == "function") e.originalEvent.stopPropagation();
if (typeof e.originalEvent.stopImmediatePropagation == "function") e.originalEvent.stopImmediatePropagation();
}
}
};
BDFDB.removeEventListener = function (plugin, ele, actions = '', selector) {
if (!BDFDB.isObject(plugin) || !Array.isArray(plugin.listeners)) return;
if (Node.prototype.isPrototypeOf(ele) || ele === window) {
for (var action of actions.split(' ')) {
action = action.split('.');
var eventname = action.shift().toLowerCase();
var namespace = (action.join('.') || '') + plugin.name;
for (let listener of plugin.listeners) {
let removedlisteners = [];
if (listener.ele == ele && (!eventname || listener.origeventname == eventname) && listener.namespace == namespace && (selector === undefined || listener.selector == selector)) {
ele.removeEventListener(listener.eventname, listener.eventcallback, true);
removedlisteners.push(listener);
}
if (removedlisteners.length) plugin.listeners = plugin.listeners.filter(listener => {return removedlisteners.indexOf(listener) < 0;});
}
}
}
else if (!ele) {
for (let listener of plugin.listeners) listener.ele.removeEventListener(listener.eventname, listener.eventcallback, true);
plugin.listeners = [];
}
};
BDFDB.checkUpdate = function (plugname, url) {
if (BDFDB.isBDv2()) return;
2019-09-06 12:21:54 +02:00
LibraryRequires.request(url, (error, response, result) => {
2019-07-23 21:09:07 +02:00
if (error) return;
var newversion = result.match(/['"][0-9]+\.[0-9]+\.[0-9]+['"]/i);
if (!newversion) return;
if (BDFDB.checkVersionDifference(newversion[0], window.PluginUpdates.plugins[url].version) > 0.2) {
BDFDB.showToast(`${plugname} will be force updated, because your version is heavily outdated.`, {type:"warn", nopointer:true, selector:'plugin-forceupdate-toast'});
BDFDB.downloadPlugin(plugname, url);
}
else if (BDFDB.checkVersions(newversion[0], window.PluginUpdates.plugins[url].version)) BDFDB.showUpdateNotice(plugname, url);
else BDFDB.removeUpdateNotice(plugname);
});
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.checkVersions = function (newv, oldv) {
if (!newv || !oldv) return true;
newv = newv.toString().replace(/["'`]/g, '').split(/,|\./g).map(n => parseInt(n)).filter(n => (n || n == 0) && !isNaN(n));
oldv = oldv.toString().replace(/["'`]/g, '').split(/,|\./g).map(n => parseInt(n)).filter(n => (n || n == 0) && !isNaN(n));
var length = Math.max(newv.length, oldv.length);
if (!length) return true;
if (newv.length > oldv.length) {
var temparray = new Array(newv.length - oldv.length);
for (let i = 0; i < temparray.length; i++) temparray[i] = 0;
oldv = temparray.concat(oldv);
}
else if (newv.length < oldv.length) {
var temparray = new Array(oldv.length - newv.length);
for (let i = 0; i < temparray.length; i++) temparray[i] = 0;
newv = temparray.concat(newv);
}
for (let i = 0; i < length; i++) for (let ioutdated = false, j = 0; j <= i; j++) {
if (j == i && newv[j] < oldv[j]) return false;
if (j < i) ioutdated = newv[j] == oldv[j];
if ((j == 0 || ioutdated) && j == i && newv[j] > oldv[j]) return true;
}
return false;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.checkVersionDifference = function (newv, oldv) {
if (!newv || !oldv) return false;
newv = newv.toString().replace(/["'`]/g, '').split(/,|\./g).map(n => parseInt(n)).filter(n => (n || n == 0) && !isNaN(n));
oldv = oldv.toString().replace(/["'`]/g, '').split(/,|\./g).map(n => parseInt(n)).filter(n => (n || n == 0) && !isNaN(n));
var length = Math.max(newv.length, oldv.length);
if (!length) return false;
if (newv.length > oldv.length) {
var temparray = new Array(newv.length - oldv.length);
for (let i = 0; i < temparray.length; i++) temparray[i] = 0;
oldv = temparray.concat(oldv);
}
else if (newv.length < oldv.length) {
var temparray = new Array(oldv.length - newv.length);
for (let i = 0; i < temparray.length; i++) temparray[i] = 0;
newv = temparray.concat(newv);
}
var oldvvalue = 0, newvvalue = 0;
for (let i in oldv.reverse()) oldvvalue += (oldv[i] * (10 ** i));
for (let i in newv.reverse()) newvvalue += (newv[i] * (10 ** i));
return (newvvalue - oldvvalue) / (10 ** (length-1));
};
BDFDB.showUpdateNotice = function (plugname, url) {
var updatenotice = document.querySelector('#pluginNotice');
if (!updatenotice) {
updatenotice = BDFDB.createNotificationsBar('The following plugins need to be updated:&nbsp;&nbsp;<strong id="outdatedPlugins"></strong>', {html:true, id:'pluginNotice', type:'info', btn:!BDFDB.isRestartNoMoreEnabled() ? 'Reload' : '', customicon:`<svg height="100%" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linecap:round;stroke-linejoin:round;" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg" xml:space="preserve" width="100%" version="1.1" viewBox="0 0 2000 2000"><metadata /><defs><filter id="shadow1"><feDropShadow dx="20" dy="0" stdDeviation="20" flood-color="rgba(0,0,0,0.35)"/></filter><filter id="shadow2"><feDropShadow dx="15" dy="0" stdDeviation="20" flood-color="rgba(255,255,255,0.15)"/></filter><filter id="shadow3"><feDropShadow dx="10" dy="0" stdDeviation="20" flood-color="rgba(0,0,0,0.35)"/></filter></defs><g><path style="filter: url(#shadow3)" d="M1195.44+135.442L1195.44+135.442L997.6+136.442C1024.2+149.742+1170.34+163.542+1193.64+179.742C1264.34+228.842+1319.74+291.242+1358.24+365.042C1398.14+441.642+1419.74+530.642+1422.54+629.642L1422.54+630.842L1422.54+632.042C1422.54+773.142+1422.54+1228.14+1422.54+1369.14L1422.54+1370.34L1422.54+1371.54C1419.84+1470.54+1398.24+1559.54+1358.24+1636.14C1319.74+1709.94+1264.44+1772.34+1193.64+1821.44C1171.04+1837.14+1025.7+1850.54+1000+1863.54L1193.54+1864.54C1539.74+1866.44+1864.54+1693.34+1864.54+1296.64L1864.54+716.942C1866.44+312.442+1541.64+135.442+1195.44+135.442Z" fill="#171717" opacity="1"/><path style="filter: url(#shadow2)" d="M1695.54+631.442C1685.84+278.042+1409.34+135.442+1052.94+135.442L361.74+136.442L803.74+490.442L1060.74+490.442C1335.24+490.442+1335.24+835.342+1060.74+835.342L1060.74+1164.84C1150.22+1164.84+1210.53+1201.48+1241.68+1250.87C1306.07+1353+1245.76+1509.64+1060.74+1509.64L361.74+1863.54L1052.94+1864.54C1409.24+1864.54+1685.74+1721.94+1695.54+1368.54C1695.54+1205.94+1651.04+1084.44+1572.64+999.942C1651.04+915.542+1695.54+794.042+1695.54+631.442Z" fill="#3E82E5" opacity="1"/><path style="filter: url(#shadow1)" d="M1469.25+631.442C1459.55+278.042+1183.05+135.442+826.65+135.442L135.45+135.442L135.45+1004C135.45+1004+135.427+1255.21+355.626+1255.21C575.825+1255.21+575.848+1004+575.848+1004L577.45+490.442L834.45+490.442C1108.95+490.442+1108.95+835.342+834.45+835.342L664.65+835.342L664.65+1164.84L834.45+1164.84C923.932+1164.84+984.244+1201.48+1015.39+1250.87C1079.78+1353+1019.47+1509.64+834.45+1509.64L135.45+1509.64L135.45+1864.54L826.65+1864.54C1182.95+1864.54+1459.45+1721.94+1469.25+1368.54C1469.25+1205.94+1424.75+1084.44+1346.35+999.942C1424.75+915.542+1469.25+794.042+1469.25+631.442Z" fill="#FFFFFF" opacity="1"/></g></svg>`});
updatenotice.style.setProperty('display', 'block', 'important');
updatenotice.style.setProperty('visibility', 'visible', 'important');
updatenotice.style.setProperty('opacity', '1', 'important');
updatenotice.querySelector(BDFDB.dotCN.noticedismiss).addEventListener('click', () => {
BDFDB.removeEles('.update-clickme-tooltip');
});
var reloadbutton = updatenotice.querySelector(BDFDB.dotCN.noticebutton);
if (reloadbutton) {
BDFDB.toggleEles(reloadbutton, true);
reloadbutton.addEventListener('click', () => {
window.location.reload(false);
});
reloadbutton.addEventListener('mouseenter', () => {
if (window.PluginUpdates.downloaded) BDFDB.createTooltip(window.PluginUpdates.downloaded.join(', '), reloadbutton, {type:'bottom', selector:'update-notice-tooltip', style: 'max-width: 420px'});
});
}
}
if (updatenotice) {
var updatenoticelist = updatenotice.querySelector('#outdatedPlugins');
if (updatenoticelist && !updatenoticelist.querySelector(`#${plugname}-notice`)) {
if (updatenoticelist.querySelector('span')) updatenoticelist.appendChild(BDFDB.htmlToElement(`<span class="separator">, </span>`));
var updateentry = BDFDB.htmlToElement(`<span id="${plugname}-notice">${plugname}</span>`);
updateentry.addEventListener('click', () => {BDFDB.downloadPlugin(plugname, url);});
updatenoticelist.appendChild(updateentry);
if (!document.querySelector('.update-clickme-tooltip')) BDFDB.createTooltip('Click us!', updatenoticelist, {type:'bottom', selector:'update-clickme-tooltip', delay:500});
}
}
};
BDFDB.downloadPlugin = function (plugname, url) {
2019-09-06 12:21:54 +02:00
LibraryRequires.request(url, (error, response, result) => {
2019-07-23 21:09:07 +02:00
if (error) return console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', 'Unable to get update for ' + plugname);
BDFDB.creationTime = 0;
var newversion = result.match(/['"][0-9]+\.[0-9]+\.[0-9]+['"]/i);
newversion = newversion.toString().replace(/['"]/g, '');
2019-09-06 12:21:54 +02:00
LibraryRequires.fs.writeFileSync(LibraryRequires.path.join(BDFDB.getPluginsFolder(), (bdplugins[plugname] ? bdplugins[plugname].filename : url.split("/").slice(-1)[0])), result);
2019-07-23 21:09:07 +02:00
BDFDB.showToast(`${plugname} v${window.PluginUpdates.plugins[url].version} has been replaced by ${plugname} v${newversion}.`, {nopointer:true, selector:'plugin-updated-toast'});
var updatenotice = document.querySelector('#pluginNotice');
if (updatenotice) {
if (updatenotice.querySelector(BDFDB.dotCN.noticebutton)) {
window.PluginUpdates.plugins[url].version = newversion;
if (!window.PluginUpdates.downloaded) window.PluginUpdates.downloaded = [];
if (!window.PluginUpdates.downloaded.includes(plugname)) window.PluginUpdates.downloaded.push(plugname);
}
BDFDB.removeUpdateNotice(plugname, updatenotice);
}
});
};
BDFDB.removeUpdateNotice = function (plugname, updatenotice = document.querySelector('#pluginNotice')) {
if (!updatenotice) return;
var updatenoticelist = updatenotice.querySelector('#outdatedPlugins');
if (updatenoticelist) {
var noticeentry = updatenoticelist.querySelector(`#${plugname}-notice`);
if (noticeentry) {
var nextsibling = noticeentry.nextSibling;
var prevsibling = noticeentry.prevSibling;
if (nextsibling && BDFDB.containsClass(nextsibling, 'separator')) nextsibling.remove();
else if (prevsibling && BDFDB.containsClass(prevsibling, 'separator')) prevsibling.remove();
noticeentry.remove();
}
if (!updatenoticelist.querySelector('span')) {
var reloadbutton = updatenotice.querySelector(BDFDB.dotCN.noticebutton);
if (reloadbutton) {
updatenotice.querySelector('.notice-message').innerText = 'To finish updating you need to reload.';
BDFDB.toggleEles(reloadbutton, false);
}
else updatenotice.querySelector(BDFDB.dotCN.noticedismiss).click();
}
}
};
BDFDB.showToast = function (text, options = {}) {
var toasts = document.querySelector('.toasts, .bd-toasts');
if (!toasts) {
var channels = document.querySelector(BDFDB.dotCN.channels + ' + div');
var channelrects = channels ? BDFDB.getRects(channels) : null;
var members = channels ? channels.querySelector(BDFDB.dotCN.memberswrap) : null;
var left = channelrects ? channelrects.left : 310;
var width = channelrects ? (members ? channelrects.width - BDFDB.getRects(members).width : channelrects.width) : window.outerWidth - 0;
var form = channels ? channels.querySelector('form') : null;
var bottom = form ? BDFDB.getRects(form).height : 80;
toasts = BDFDB.htmlToElement(`<div class="toasts bd-toasts" style="width:${width}px; left:${left}px; bottom:${bottom}px;"></div>`);
document.querySelector(BDFDB.dotCN.app).appendChild(toasts);
}
2019-08-22 11:08:08 +02:00
const {type = '', icon = true, timeout = 3000, html = false, selector = '', nopointer = false, color = ''} = options;
2019-07-23 21:09:07 +02:00
var toast = BDFDB.htmlToElement(`<div class="toast bd-toast">${html === true ? text : BDFDB.encodeToHTML(text)}</div>`);
if (type) {
BDFDB.addClass(toast, 'toast-' + type);
if (icon) BDFDB.addClass(toast, 'icon');
}
2019-08-22 11:08:08 +02:00
else if (color) {
2019-08-22 13:42:28 +02:00
var rgbcolor = BDFDB.colorCONVERT(color, 'RGB');
if (rgbcolor) toast.style.setProperty('background-color', rgbcolor, 'important');
2019-08-22 11:08:08 +02:00
}
2019-07-23 21:09:07 +02:00
BDFDB.addClass(toast, selector);
toasts.appendChild(toast);
toast.close = () => {
if (document.contains(toast)) {
BDFDB.addClass(toast, 'closing');
2019-09-16 22:18:03 +02:00
toast.style.setProperty("pointer-events", "none", "important");
2019-07-23 21:09:07 +02:00
setTimeout(() => {
toast.remove();
if (!toasts.querySelectorAll('.toast, .bd-toast').length) toasts.remove();
}, 3000);
}
};
if (nopointer) toast.style.setProperty("pointer-events", "none", "important");
else toast.addEventListener("click", toast.close);
setTimeout(() => {toast.close();}, timeout > 0 ? timeout : 600000);
return toast;
};
2019-08-28 14:02:30 +02:00
var DesktopNotificationQueue = {queue:[], running:false};
2019-07-23 21:09:07 +02:00
BDFDB.showDesktopNotification = function (parsedcontent, parsedoptions = {}) {
var queue = () => {
2019-08-28 14:02:30 +02:00
DesktopNotificationQueue.queue.push({parsedcontent, parsedoptions});
2019-07-23 21:09:07 +02:00
runqueue();
};
var runqueue = () => {
2019-08-28 14:02:30 +02:00
if (!DesktopNotificationQueue.running) {
var notification = DesktopNotificationQueue.queue.shift();
2019-07-23 21:09:07 +02:00
if (notification) notify(notification.parsedcontent, notification.parsedoptions);
}
};
var notify = (content, options) => {
2019-08-28 14:02:30 +02:00
DesktopNotificationQueue.running = true;
2019-07-23 21:09:07 +02:00
var muted = options.silent;
options.silent = options.silent || options.sound ? true : false;
var notification = new Notification(content, options);
var audio = new Audio();
var timeout = setTimeout(() => {close();}, options.timeout ? options.timeout : 3000);
if (typeof options.click == 'function') notification.onclick = () => {
clearTimeout(timeout);
close();
options.click();
};
if (!muted && options.sound) {
audio.src = options.sound;
audio.play();
}
var close = () => {
audio.pause();
notification.close();
2019-08-28 14:02:30 +02:00
DesktopNotificationQueue.running = false;
2019-07-23 21:09:07 +02:00
setTimeout(() => {runqueue();}, 1000);
};
};
if (!('Notification' in window)) {}
else if (Notification.permission === 'granted') queue();
else if (Notification.permission !== 'denied') Notification.requestPermission(function (response) {if (response === 'granted') queue();});
};
BDFDB.createTooltip = function (text, anker, options = {}) {
if (!text || !anker || !Node.prototype.isPrototypeOf(anker) || !document.contains(anker)) return null;
2019-09-05 16:17:25 +02:00
var tooltip = BDFDB.htmlToElement(`<div class="${BDFDB.disCN.tooltip}"></div>`);
2019-07-23 21:09:07 +02:00
if (options.id) tooltip.id = options.id.split(' ').join('');
if (options.selector) BDFDB.addClass(tooltip, options.selector);
2019-09-05 16:17:25 +02:00
if (options.style) tooltip.style = options.style;
if (options.html === true) tooltip.innerHTML = text;
else tooltip.innerText = text;
2019-07-23 21:09:07 +02:00
if (options.type && BDFDB.disCN['tooltip' + options.type.toLowerCase()]) {
2019-09-05 16:17:25 +02:00
BDFDB.addClass(tooltip, BDFDB.disCN['tooltip' + options.type.toLowerCase()]);
tooltip.appendChild(BDFDB.htmlToElement(`<div class="${BDFDB.disCN.tooltippointer}"></div>`));
2019-07-23 21:09:07 +02:00
}
2019-09-05 16:17:25 +02:00
if (tooltip.style.getPropertyValue("border-color") && (tooltip.style.getPropertyValue("background-color") || tooltip.style.getPropertyValue("background-image"))) BDFDB.addClass(tooltip, 'tooltip-customcolor');
else if (options.color && BDFDB.disCN['tooltip' + options.color.toLowerCase()]) BDFDB.addClass(tooltip, BDFDB.disCN['tooltip' + options.color.toLowerCase()]);
else BDFDB.addClass(tooltip, BDFDB.disCN.tooltipblack);
2019-07-23 21:09:07 +02:00
if (!options.position || options.type) options.position = options.type;
if (!options.position || !['top','bottom','left','right'].includes(options.position.toLowerCase())) options.position = 'right';
tooltip.position = options.position.toLowerCase();
2019-09-05 16:17:25 +02:00
tooltip.anker = anker;
BDFDB.appendItemLayer(tooltip, anker, {css:options.css, ankerlistener:{'mouseleave':() => {tooltip.parentElement.remove();}}});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.updateTooltipPosition(tooltip);
2019-09-05 16:17:25 +02:00
if (options.delay) {
BDFDB.toggleEles(tooltip);
setTimeout(() => {BDFDB.toggleEles(tooltip);}, options.delay);
}
return tooltip;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.updateTooltipPosition = function (tooltip) {
2019-09-05 16:17:25 +02:00
if (!Node.prototype.isPrototypeOf(tooltip)) return;
let itemlayer = BDFDB.getParentEle(BDFDB.dotCN.itemlayer, tooltip);
if (!Node.prototype.isPrototypeOf(itemlayer)) return;
tooltip = itemlayer.querySelector(BDFDB.dotCN.tooltip);
2019-07-23 21:09:07 +02:00
if (!Node.prototype.isPrototypeOf(tooltip) || !Node.prototype.isPrototypeOf(tooltip.anker) || !tooltip.position) return;
2019-09-10 10:30:14 +02:00
var left, top, trects = BDFDB.getRects(tooltip.anker), irects = BDFDB.getRects(itemlayer), arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount)), positionoffsets = {height: 0, width: 0};
2019-07-23 21:09:07 +02:00
var pointer = tooltip.querySelector(BDFDB.dotCN.tooltippointer);
if (pointer) positionoffsets = BDFDB.getRects(pointer);
switch (tooltip.position) {
case 'top':
2019-09-10 10:30:14 +02:00
top = trects.top - irects.height - positionoffsets.height + 2;
left = trects.left + (trects.width - irects.width) / 2;
2019-07-23 21:09:07 +02:00
break;
case 'bottom':
2019-09-10 10:30:14 +02:00
top = trects.top + trects.height + positionoffsets.height - 2;
left = trects.left + (trects.width - irects.width) / 2;
2019-07-23 21:09:07 +02:00
break;
case 'left':
2019-09-10 10:30:14 +02:00
top = trects.top + (trects.height - irects.height) / 2;
left = trects.left - irects.width - positionoffsets.width + 2;
2019-07-23 21:09:07 +02:00
break;
case 'right':
2019-09-10 10:30:14 +02:00
top = trects.top + (trects.height - irects.height) / 2;
left = trects.left + trects.width + positionoffsets.width - 2;
2019-07-23 21:09:07 +02:00
break;
}
2019-09-05 16:17:25 +02:00
itemlayer.style.setProperty('top', top + 'px');
itemlayer.style.setProperty('left', left + 'px');
2019-07-23 21:09:07 +02:00
if (tooltip.position == "top" || tooltip.position == "bottom") {
2019-09-11 14:31:41 +02:00
if (left < 0) {
2019-09-05 16:17:25 +02:00
itemlayer.style.setProperty('left', '5px');
2019-09-11 14:31:41 +02:00
pointer.style.setProperty('margin-left', `${left - 10}px`);
2019-07-23 21:09:07 +02:00
}
else {
2019-09-11 14:31:41 +02:00
var rightmargin = arects.width - (left + irects.width);
2019-07-23 21:09:07 +02:00
if (rightmargin < 0) {
2019-09-10 10:30:14 +02:00
itemlayer.style.setProperty('left', arects.width - irects.width - 5 + 'px');
2019-09-11 14:31:41 +02:00
pointer.style.setProperty('margin-left', `${-1*rightmargin}px`);
2019-07-23 21:09:07 +02:00
}
}
}
else if (tooltip.position == "left" || tooltip.position == "right") {
2019-09-11 14:31:41 +02:00
if (top < 0) {
2019-09-05 16:17:25 +02:00
itemlayer.style.setProperty('top', '5px');
2019-09-11 14:31:41 +02:00
pointer.style.setProperty('margin-top', `${top - 10}px`);
2019-07-23 21:09:07 +02:00
}
else {
2019-09-11 14:31:41 +02:00
var bottommargin = arects.height - (top + irects.height);
2019-07-23 21:09:07 +02:00
if (bottommargin < 0) {
2019-09-10 10:30:14 +02:00
itemlayer.style.setProperty('top', arects.height - irects.height - 5 + 'px');
2019-09-11 14:31:41 +02:00
pointer.style.setProperty('margin-top', `${-1*bottommargin}px`);
2019-07-23 21:09:07 +02:00
}
}
}
};
2019-09-10 10:04:12 +02:00
BDFDB.appendItemLayer = function (node, anker, options = {}) {
var itemlayerconainernative = document.querySelector(BDFDB.dotCN.itemlayerconainer);
if (!itemlayerconainernative || !Node.prototype.isPrototypeOf(node) || !anker || !Node.prototype.isPrototypeOf(anker) || !document.contains(anker)) return null;
var itemlayerconainer = document.querySelector(".BDFDB-itemlayerconainer");
if (!itemlayerconainer) {
itemlayerconainer = itemlayerconainernative.cloneNode();
BDFDB.addClass(itemlayerconainer, "BDFDB-itemlayerconainer");
itemlayerconainernative.parentElement.insertBefore(itemlayerconainer, itemlayerconainernative.nextSibling);
}
var id = Math.round(Math.random() * 10000000000000000);
var itemlayer = BDFDB.htmlToElement(`<div class="${BDFDB.disCN.itemlayer} BDFDB-itemlayer itemlayer-${id}"></div>`);
itemlayer.appendChild(node);
itemlayerconainer.appendChild(itemlayer);
if (options.css) BDFDB.appendLocalStyle('BDFDBcustomItemLayer' + id, options.css, itemlayerconainer);
if (BDFDB.isObject(options.ankerlistener)) for (let type in options.ankerlistener) {
if (typeof options.ankerlistener[type] == "function") anker.addEventListener(type, options.ankerlistener[type]);
else delete options.ankerlistener[type];
}
var observer = new MutationObserver(changes => {
changes.forEach(change => {
var nodes = Array.from(change.removedNodes);
var ownmatch = nodes.indexOf(itemlayer) > -1;
var ankermatch = nodes.indexOf(anker) > -1;
var parentmatch = nodes.some(n => n.contains(anker));
if (ownmatch || ankermatch || parentmatch) {
observer.disconnect();
itemlayer.remove();
BDFDB.removeLocalStyle('BDFDBcustomItemLayer' + id, itemlayerconainer);
if (!itemlayerconainer.firstElementChild) BDFDB.removeEles(itemlayerconainer);
if (BDFDB.isObject(options.ankerlistener)) for (let type in options.ankerlistener) anker.removeEventListener(type, options.ankerlistener[type]);
}
});
});
observer.observe(document.body, {subtree:true, childList:true});
};
2019-07-23 21:09:07 +02:00
BDFDB.createNotificationsBar = function (text, options = {}) {
if (!text) return;
var layers = document.querySelector(BDFDB.dotCN.layers);
if (!layers) return;
var id = Math.round(Math.random() * 10000000000000000);
2019-09-06 09:20:32 +02:00
var notice = BDFDB.htmlToElement(`<div class="${BDFDB.disCN.notice} BDFDB-notice notice-${id}"><div class="${BDFDB.disCN.noticedismiss}" style="height:36px !important; position: absolute !important; top: 0 !important; right: 0 !important; left: unset !important;"></div><span class="notice-message"></span></div>`);
2019-07-23 21:09:07 +02:00
layers.parentElement.insertBefore(notice, layers);
var noticemessage = notice.querySelector('.notice-message');
if (options.platform) for (let platform of options.platform.split(' ')) if (DiscordClasses["noticeicon" + platform]) {
let icon = BDFDB.htmlToElement(`<i class="${BDFDB.disCN["noticeicon" + platform]}"></i>`);
BDFDB.addClass(icon, BDFDB.disCN.noticeplatformicon);
BDFDB.removeClass(icon, BDFDB.disCN.noticeicon);
notice.insertBefore(icon, noticemessage);
}
if (options.customicon) {
let iconinner = BDFDB.htmlToElement(options.customicon)
let icon = BDFDB.htmlToElement(`<i></i>`);
if (iconinner.tagName == "span" && !iconinner.firstElementChild) icon.style.setProperty('background', `url(${options.customicon}) center/cover no-repeat`);
else icon.appendChild(iconinner);
BDFDB.addClass(icon, BDFDB.disCN.noticeplatformicon);
BDFDB.removeClass(icon, BDFDB.disCN.noticeicon);
notice.insertBefore(icon, noticemessage);
}
if (options.btn) notice.appendChild(BDFDB.htmlToElement(`<button class="${BDFDB.disCNS.noticebutton + BDFDB.disCNS.size14 + BDFDB.disCN.weightmedium}">${options.btn}</button>`));
if (options.id) notice.id = options.id.split(' ').join('');
if (options.selector) BDFDB.addClass(notice, options.selector);
if (options.css) BDFDB.appendLocalStyle('BDFDBcustomnotibar' + id, options.css);
if (options.style) notice.style = options.style;
if (options.html === true) noticemessage.innerHTML = text;
else {
var link = document.createElement('a');
var newtext = [];
for (let word of text.split(' ')) {
var encodedword = BDFDB.encodeToHTML(word);
link.href = word;
newtext.push(link.host && link.host !== window.location.host ? `<label class="${BDFDB.disCN.textlink}">${encodedword}</label>` : encodedword);
}
noticemessage.innerHTML = newtext.join(' ');
}
var type = null;
if (options.type && !document.querySelector(BDFDB.dotCNS.chatbase + BDFDB.dotCN.noticestreamer)) {
if (type = BDFDB.disCN["notice" + options.type]) BDFDB.addClass(notice, type);
if (options.type == 'premium') {
var noticebutton = notice.querySelector(BDFDB.dotCN.noticebutton);
if (noticebutton) BDFDB.addClass(noticebutton, BDFDB.disCN.noticepremiumaction);
BDFDB.addClass(noticemessage, BDFDB.disCN.noticepremiumtext);
notice.insertBefore(BDFDB.htmlToElement(`<i class="${BDFDB.disCN.noticepremiumlogo}"></i>`), noticemessage);
}
}
if (!type) {
var comp = BDFDB.colorCONVERT(options.color, 'RGBCOMP');
if (comp) {
var fontcolor = comp[0] > 180 && comp[1] > 180 && comp[2] > 180 ? '#000' : '#FFF';
var backgroundcolor = BDFDB.colorCONVERT(comp, 'HEX');
var filter = comp[0] > 180 && comp[1] > 180 && comp[2] > 180 ? 'brightness(0%)' : 'brightness(100%)';
BDFDB.appendLocalStyle('BDFDBcustomnotibarColorCorrection' + id, `.BDFDB-notice.notice-${id}{background-color:${backgroundcolor} !important;}.BDFDB-notice.notice-${id} .notice-message {color:${fontcolor} !important;}.BDFDB-notice.notice-${id} ${BDFDB.dotCN.noticebutton} {color:${fontcolor} !important;border-color:${BDFDB.colorSETALPHA(fontcolor,0.25,'RGBA')} !important;}.BDFDB-notice.notice-${id} ${BDFDB.dotCN.noticebutton}:hover {color:${backgroundcolor} !important;background-color:${fontcolor} !important;}.BDFDB-notice.notice-${id} ${BDFDB.dotCN.noticedismiss} {filter:${filter} !important;}`);
}
else BDFDB.addClass(notice, BDFDB.disCN.noticedefault);
}
notice.style.setProperty('height', '36px', 'important');
notice.style.setProperty('min-width', '70vw', 'important');
notice.style.setProperty('left', 'unset', 'important');
notice.style.setProperty('right', 'unset', 'important');
let sidemargin = ((BDFDB.getTotalWidth(document.body.firstElementChild) - BDFDB.getTotalWidth(notice))/2);
notice.style.setProperty('left', sidemargin + 'px', 'important');
notice.style.setProperty('right', sidemargin + 'px', 'important');
notice.style.setProperty('min-width', 'unset', 'important');
notice.style.setProperty('width', 'unset', 'important');
notice.style.setProperty('max-width', 'calc(100vw - ' + (sidemargin*2) + 'px)', 'important');
notice.querySelector(BDFDB.dotCN.noticedismiss).addEventListener('click', () => {
notice.style.setProperty('overflow', 'hidden', 'important');
notice.style.setProperty('height', '0px', 'important');
setTimeout(() => {
BDFDB.removeLocalStyle('BDFDBcustomnotibar' + id);
BDFDB.removeLocalStyle('BDFDBcustomnotibarColorCorrection' + id);
notice.remove();
}, 500);
});
return notice;
};
BDFDB.getDiscordFolder = function () {
var built = BDFDB.getDiscordBuilt();
built = 'discord' + (built == 'stable' ? '' : built);
2019-09-06 12:21:54 +02:00
return LibraryRequires.path.resolve(LibraryRequires.electron.remote.app.getPath('appData'), built, BDFDB.getDiscordVersion());
2019-07-23 21:09:07 +02:00
};
BDFDB.getPluginsFolder = function () {
2019-09-06 12:21:54 +02:00
if (LibraryRequires.process.env.injDir) return LibraryRequires.path.resolve(LibraryRequires.process.env.injDir, 'plugins/');
switch (LibraryRequires.process.platform) {
2019-07-23 21:09:07 +02:00
case 'win32':
2019-09-06 12:21:54 +02:00
return LibraryRequires.path.resolve(LibraryRequires.process.env.appdata, 'BetterDiscord/plugins/');
2019-07-23 21:09:07 +02:00
case 'darwin':
2019-09-06 12:21:54 +02:00
return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, 'Library/Preferences/BetterDiscord/plugins/');
2019-07-23 21:09:07 +02:00
default:
2019-09-06 12:21:54 +02:00
if (LibraryRequires.process.env.XDG_CONFIG_HOME) return LibraryRequires.path.resolve(LibraryRequires.process.env.XDG_CONFIG_HOME, 'BetterDiscord/plugins/');
else return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, '.config/BetterDiscord/plugins/');
2019-07-23 21:09:07 +02:00
}
};
BDFDB.getThemesFolder = function () {
2019-09-06 12:21:54 +02:00
if (LibraryRequires.process.env.injDir) return LibraryRequires.path.resolve(LibraryRequires.process.env.injDir, 'plugins/');
switch (LibraryRequires.process.platform) {
2019-07-23 21:09:07 +02:00
case 'win32':
2019-09-06 12:21:54 +02:00
return LibraryRequires.path.resolve(LibraryRequires.process.env.appdata, 'BetterDiscord/themes/');
2019-07-23 21:09:07 +02:00
case 'darwin':
2019-09-06 12:21:54 +02:00
return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, 'Library/Preferences/BetterDiscord/themes/');
2019-07-23 21:09:07 +02:00
default:
2019-09-06 12:21:54 +02:00
if (LibraryRequires.process.env.XDG_CONFIG_HOME) return LibraryRequires.path.resolve(LibraryRequires.process.env.XDG_CONFIG_HOME, 'BetterDiscord/themes/');
else return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, '.config/BetterDiscord/themes/');
2019-07-23 21:09:07 +02:00
}
};
BDFDB.checkWhichRepoPage = function (usersettings = document.querySelector(BDFDB.dotCN.layer + '[layer-id="user-settings"]')) {
if (!usersettings) return;
var folderbutton = usersettings.querySelector(BDFDB.dotCN._repofolderbutton);
if (!folderbutton) return;
var header = folderbutton.parentElement.querySelector('h2');
if (header && header.innerText) {
let headertext = header.innerText.toLowerCase();
if (headertext === 'plugins' || headertext === 'themes') return headertext;
}
};
BDFDB.checkAllUpdates = function () {
for (let url in window.PluginUpdates.plugins) {
var plugin = window.PluginUpdates.plugins[url];
BDFDB.checkUpdate(plugin.name, plugin.raw);
}
};
BDFDB.getLineOfString = function (stringbody, string) {
if (typeof stringbody != "string" || typeof stringbody != "string") return -1;
let index = stringbody.indexOf(string);
if (index < 0) return -1;
return stringbody.substring(0, index).split('\n').length;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.sortObject = function (obj, sort, except) {
var newobj = {};
if (sort === undefined || !sort) for (let key of Object.keys(obj).sort()) newobj[key] = obj[key];
else {
let values = [];
for (let key in obj) values.push(obj[key]);
values = BDFDB.sortArrayByKey(values, sort, except);
for (let value of values) for (let key in obj) if (BDFDB.equals(value, obj[key])) {
newobj[key] = value;
break;
}
}
return newobj;
};
BDFDB.reverseObject = function (obj, sort) {
var newobj = {};
for (let key of (sort === undefined || !sort) ? Object.keys(obj).reverse() : Object.keys(obj).sort().reverse()) newobj[key] = obj[key];
return newobj;
};
BDFDB.filterObject = function (obj, filter) {
return Object.keys(obj).filter(key => filter(obj[key])).reduce((newobj, key) => (newobj[key] = obj[key], newobj), {});
};
BDFDB.isObject = function (obj) {
return obj && Object.prototype.isPrototypeOf(obj) && !Array.prototype.isPrototypeOf(obj);
};
BDFDB.isObjectEmpty = function (obj) {
return typeof obj !== 'object' || Object.getOwnPropertyNames(obj).length == 0;
};
BDFDB.pushToObject = function (obj, value) {
if (BDFDB.isObject(obj)) obj[Object.keys(obj).length] = value;
};
2019-08-21 15:41:55 +02:00
BDFDB.mapObject = function (obj, keyname) {
2019-08-21 17:14:23 +02:00
var newobj = {};
if (BDFDB.isObject(obj) && typeof keyname == "string") for (let key in obj) if (BDFDB.isObject(obj[key])) newobj[key] = obj[key][keyname];
return newobj;
2019-08-21 15:41:55 +02:00
};
2019-07-23 21:09:07 +02:00
BDFDB.deepAssign = function (obj, ...objs) {
if (!objs.length) return obj;
var nextobj = objs.shift();
if (BDFDB.isObject(obj) && BDFDB.isObject(nextobj)) {
for (var key in nextobj) {
if (BDFDB.isObject(nextobj[key])) {
if (!obj[key]) Object.assign(obj, {[key]:{}});
BDFDB.deepAssign(obj[key], nextobj[key]);
}
else Object.assign(obj, {[key]:nextobj[key]});
}
}
return BDFDB.deepAssign(obj, ...objs);
};
BDFDB.sortArrayByKey = function (array, key, except) {
if (except === undefined) except = null;
return array.sort(function (x, y) {
var xvalue = x[key], yvalue = y[key];
if (xvalue !== except) return xvalue < yvalue ? -1 : xvalue > yvalue ? 1 : 0;
});
};
BDFDB.numSortArray = function (array, key, except) {
return array.sort(function (x, y) {return x < y ? -1 : x > y ? 1 : 0;});
};
BDFDB.removeFromArray = function (array, value, all = false) {
if (!array || !value || !Array.isArray(array) || !array.includes(value)) return array;
if (!all) array.splice(array.indexOf(value), 1);
else while (array.indexOf(value) > -1) array.splice(array.indexOf(value), 1);
return array;
};
BDFDB.getAllIndexes = function (array, value) {
var indexes = [], index = -1;
while ((index = array.indexOf(value, index + 1)) !== -1) indexes.push(index);
return indexes;
};
BDFDB.removeCopiesFromArray = function (array) {
return [...new Set(array)];
};
BDFDB.highlightText = function (text, searchstring) {
if (!searchstring || searchstring.length < 1) return text;
var offset = 0, original = text, prefix = `<span class="${BDFDB.disCN.highlight}">`, suffix = `</span>`;
BDFDB.getAllIndexes(text.toUpperCase(), searchstring.toUpperCase()).forEach(index => {
var d1 = offset * (prefix.length + suffix.length);
index = index + d1;
var d2 = index + searchstring.length;
var d3 = [-1].concat(BDFDB.getAllIndexes(text.substring(0, index), '<'));
var d4 = [-1].concat(BDFDB.getAllIndexes(text.substring(0, index), '>'));
if (d3[d3.length - 1] > d4[d4.length - 1]) return;
text = text.substring(0, index) + prefix + text.substring(index, d2) + suffix + text.substring(d2);
offset++;
});
return text ? text : original;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.languages = {
'$discord': {name:'Discord (English (US))', id:'en-US', ownlang:'English (US)', integrated:false, dic:false, deepl:false},
'af': {name:'Afrikaans', id:'af', ownlang:'Afrikaans', integrated:false, dic:true, deepl:false},
'sq': {name:'Albanian', id:'sq', ownlang:'Shqiptar', integrated:false, dic:false, deepl:false},
'am': {name:'Amharic', id:'am', ownlang:'አማርኛ', integrated:false, dic:false, deepl:false},
'ar': {name:'Arabic', id:'ar', ownlang:'اللغة العربية', integrated:false, dic:false, deepl:false},
'hy': {name:'Armenian', id:'hy', ownlang:'Հայերեն', integrated:false, dic:false, deepl:false},
'az': {name:'Azerbaijani', id:'az', ownlang:'آذربایجان دیلی', integrated:false, dic:false, deepl:false},
'eu': {name:'Basque', id:'eu', ownlang:'Euskara', integrated:false, dic:false, deepl:false},
'be': {name:'Belarusian', id:'be', ownlang:'Беларуская', integrated:false, dic:false, deepl:false},
'bn': {name:'Bengali', id:'bn', ownlang:'বাংলা', integrated:false, dic:false, deepl:false},
'bs': {name:'Bosnian', id:'bs', ownlang:'Босански', integrated:false, dic:false, deepl:false},
'bg': {name:'Bulgarian', id:'bg', ownlang:'български', integrated:true, dic:false, deepl:false},
'my': {name:'Burmese', id:'my', ownlang:'မြန်မာစာ', integrated:false, dic:false, deepl:false},
'ca': {name:'Catalan', id:'ca', ownlang:'Català', integrated:false, dic:false, deepl:false},
'ceb': {name:'Cebuano', id:'ceb', ownlang:'Bisaya', integrated:false, dic:false, deepl:false},
'ny': {name:'Chewa', id:'ny', ownlang:'Nyanja', integrated:false, dic:false, deepl:false},
'zh-HK': {name:'Chinese (Hong Kong)', id:'zh-HK', ownlang:'香港中文', integrated:false, dic:false, deepl:false},
'zh-CN': {name:'Chinese (Simplified)', id:'zh-CN', ownlang:'简体中文', integrated:false, dic:false, deepl:false},
'zh-TW': {name:'Chinese (Traditional)', id:'zh-TW', ownlang:'繁體中文', integrated:true, dic:false, deepl:false},
'co': {name:'Corsican', id:'co', ownlang:'Corsu', integrated:false, dic:false, deepl:false},
'hr': {name:'Croatian', id:'hr', ownlang:'Hrvatski', integrated:true, dic:false, deepl:false},
'cs': {name:'Czech', id:'cs', ownlang:'Čeština', integrated:true, dic:false, deepl:false},
'da': {name:'Danish', id:'da', ownlang:'Dansk', integrated:true, dic:true, deepl:false},
'nl': {name:'Dutch', id:'nl', ownlang:'Nederlands', integrated:true, dic:true, deepl:true},
'en': {name:'English', id:'en', ownlang:'English', integrated:false, dic:true, deepl:true},
'en-GB': {name:'English (UK)', id:'en-GB', ownlang:'English (UK)', integrated:true, dic:true, deepl:false},
'en-US': {name:'English (US)', id:'en-US', ownlang:'English (US)', integrated:true, dic:true, deepl:false},
'eo': {name:'Esperanto', id:'eo', ownlang:'Esperanto', integrated:false, dic:false, deepl:false},
'et': {name:'Estonian', id:'et', ownlang:'Eesti', integrated:false, dic:false, deepl:false},
'fil': {name:'Filipino', id:'fil', ownlang:'Wikang Filipino', integrated:false, dic:false, deepl:false},
'fi': {name:'Finnish', id:'fi', ownlang:'Suomi', integrated:true, dic:false, deepl:false},
'fr': {name:'French', id:'fr', ownlang:'Français', integrated:true, dic:true, deepl:true},
'fr-CA': {name:'French (Canadian)', id:'fr-CA', ownlang:'Français Canadien', integrated:false, dic:false, deepl:false},
'fy': {name:'Frisian', id:'fy', ownlang:'Frysk', integrated:false, dic:false, deepl:false},
'gl': {name:'Galician', id:'gl', ownlang:'Galego', integrated:false, dic:false, deepl:false},
'ka': {name:'Georgian', id:'ka', ownlang:'ქართული', integrated:false, dic:false, deepl:false},
'de': {name:'German', id:'de', ownlang:'Deutsch', integrated:true, dic:true, deepl:true},
'de-AT': {name:'German (Austria)', id:'de-AT', ownlang:'Österreichisch Deutsch', integrated:false, dic:false, deepl:false},
'de-CH': {name:'German (Switzerland)', id:'de-CH', ownlang:'Schweizerdeutsch', integrated:false, dic:false, deepl:false},
'el': {name:'Greek', id:'el', ownlang:'Ελληνικά', integrated:false, dic:false, deepl:false},
'gu': {name:'Gujarati', id:'gu', ownlang:'ગુજરાતી', integrated:false, dic:false, deepl:false},
'ht': {name:'Haitian Creole', id:'ht', ownlang:'Kreyòl Ayisyen', integrated:false, dic:false, deepl:false},
'ha': {name:'Hausa', id:'ha', ownlang:'حَوْسَ', integrated:false, dic:false, deepl:false},
'haw': {name:'Hawaiian', id:'haw', ownlang:'ʻŌlelo Hawaiʻi', integrated:false, dic:false, deepl:false},
'iw': {name:'Hebrew', id:'iw', ownlang:'עברית', integrated:false, dic:false, deepl:false},
'hi': {name:'Hindi', id:'hi', ownlang:'हिन्दी', integrated:false, dic:false, deepl:false},
'hmn': {name:'Hmong', id:'hmn', ownlang:'lol Hmongb', integrated:false, dic:false, deepl:false},
'hu': {name:'Hungarain', id:'hu', ownlang:'Magyar', integrated:false, dic:false, deepl:false},
'is': {name:'Icelandic', id:'is', ownlang:'Íslenska', integrated:false, dic:false, deepl:false},
'ig': {name:'Igbo', id:'ig', ownlang:'Asụsụ Igbo', integrated:false, dic:false, deepl:false},
'id': {name:'Indonesian', id:'id', ownlang:'Bahasa Indonesia', integrated:false, dic:false, deepl:false},
'ga': {name:'Irish', id:'ga', ownlang:'Gaeilge', integrated:false, dic:false, deepl:false},
'it': {name:'Italian', id:'it', ownlang:'Italiano', integrated:true, dic:true, deepl:true},
'ja': {name:'Japanese', id:'ja', ownlang:'日本語', integrated:true, dic:false, deepl:false},
'jv': {name:'Javanese', id:'jv', ownlang:'ꦧꦱꦗꦮ', integrated:false, dic:false, deepl:false},
'kn': {name:'Kannada', id:'kn', ownlang:'ಕನ್ನಡ', integrated:false, dic:false, deepl:false},
'kk': {name:'Kazakh', id:'kk', ownlang:'Қазақ Tілі', integrated:false, dic:false, deepl:false},
'km': {name:'Khmer', id:'km', ownlang:'ភាសាខ្មែរ', integrated:false, dic:false, deepl:false},
'ko': {name:'Korean', id:'ko', ownlang:'한국어', integrated:true, dic:false, deepl:false},
'ku': {name:'Kurdish', id:'ku', ownlang:'کوردی', integrated:false, dic:false, deepl:false},
'ky': {name:'Kyrgyz', id:'ky', ownlang:'кыргызча', integrated:false, dic:false, deepl:false},
'lo': {name:'Lao', id:'lo', ownlang:'ພາສາລາວ', integrated:false, dic:false, deepl:false},
'la': {name:'Latin', id:'la', ownlang:'Latina', integrated:false, dic:false, deepl:false},
'lv': {name:'Latvian', id:'lv', ownlang:'Latviešu', integrated:false, dic:false, deepl:false},
'lt': {name:'Lithuanian', id:'lt', ownlang:'Lietuvių', integrated:false, dic:false, deepl:false},
'lb': {name:'Luxembourgish', id:'lb', ownlang:'Lëtzebuergesch', integrated:false, dic:false, deepl:false},
'mk': {name:'Macedonian', id:'mk', ownlang:'Mакедонски', integrated:false, dic:false, deepl:false},
'mg': {name:'Malagasy', id:'mg', ownlang:'Malagasy', integrated:false, dic:false, deepl:false},
'ms': {name:'Malay', id:'ms', ownlang:'بهاس ملايو', integrated:false, dic:false, deepl:false},
'ml': {name:'Malayalam', id:'ml', ownlang:'മലയാളം', integrated:false, dic:false, deepl:false},
'mt': {name:'Maltese', id:'mt', ownlang:'Malti', integrated:false, dic:false, deepl:false},
'mi': {name:'Maori', id:'mi', ownlang:'te Reo Māori', integrated:false, dic:false, deepl:false},
'mr': {name:'Marathi', id:'mr', ownlang:'मराठी', integrated:false, dic:false, deepl:false},
'mn': {name:'Mongolian', id:'mn', ownlang:'Монгол Хэл', integrated:false, dic:false, deepl:false},
'ne': {name:'Nepali', id:'ne', ownlang:'नेपाली', integrated:false, dic:false, deepl:false},
'no': {name:'Norwegian', id:'no', ownlang:'Norsk', integrated:true, dic:false, deepl:false},
'ps': {name:'Pashto', id:'ps', ownlang:'پښتو', integrated:false, dic:false, deepl:false},
'fa': {name:'Persian', id:'fa', ownlang:'فارسی', integrated:false, dic:false, deepl:false},
'pl': {name:'Polish', id:'pl', ownlang:'Polski', integrated:true, dic:false, deepl:true},
'pt': {name:'Portuguese', id:'pt', ownlang:'Português', integrated:false, dic:true, deepl:true},
'pt-BR': {name:'Portuguese (Brazil)', id:'pt-BR', ownlang:'Português do Brasil', integrated:true, dic:true, deepl:false},
'pt-PT': {name:'Portuguese (Portugal)', id:'pt-PT', ownlang:'Português do Portugal', integrated:false, dic:false, deepl:false},
'pa': {name:'Punjabi', id:'pa', ownlang:'पंजाबी', integrated:false, dic:false, deepl:false},
'ro': {name:'Romanian', id:'ro', ownlang:'Română', integrated:false, dic:false, deepl:false},
'ru': {name:'Russian', id:'ru', ownlang:'Pусский', integrated:true, dic:true, deepl:true},
'sm': {name:'Samoan', id:'sm', ownlang:'Gagana Sāmoa', integrated:false, dic:false, deepl:false},
'gd': {name:'Scottish Gaelic', id:'gd', ownlang:'Gàidhlig', integrated:false, dic:false, deepl:false},
'sr': {name:'Serbian', id:'sr', ownlang:'Српски', integrated:false, dic:false, deepl:false},
'st': {name:'Sotho', id:'st', ownlang:'Sesotho', integrated:false, dic:false, deepl:false},
'sn': {name:'Shona', id:'sn', ownlang:'Shona', integrated:false, dic:false, deepl:false},
'sd': {name:'Sindhi', id:'sd', ownlang:'سنڌي', integrated:false, dic:false, deepl:false},
'si': {name:'Sinhala', id:'si', ownlang:'සිංහල', integrated:false, dic:false, deepl:false},
'sk': {name:'Slovak', id:'sk', ownlang:'Slovenčina', integrated:false, dic:false, deepl:false},
'sl': {name:'Slovenian', id:'sl', ownlang:'Slovenščina', integrated:false, dic:false, deepl:false},
'es': {name:'Spanish', id:'es', ownlang:'Español', integrated:true, dic:true, deepl:true},
'es-419': {name:'Spanish (Latin America)', id:'es-419', ownlang:'Español latinoamericano', integrated:false, dic:false, deepl:false},
'sw': {name:'Swahili', id:'sw', ownlang:'Kiswahili', integrated:false, dic:false, deepl:false},
'sv': {name:'Swedish', id:'sv', ownlang:'Svenska', integrated:true, dic:true, deepl:false},
'tg': {name:'Tajik', id:'tg', ownlang:'тоҷикӣ', integrated:false, dic:false, deepl:false},
'ta': {name:'Tamil', id:'ta', ownlang:'தமிழ்', integrated:false, dic:false, deepl:false},
'te': {name:'Telugu', id:'te', ownlang:'తెలుగు', integrated:false, dic:false, deepl:false},
'th': {name:'Thai', id:'th', ownlang:'ภาษาไทย', integrated:false, dic:false, deepl:false},
'tr': {name:'Turkish', id:'tr', ownlang:'Türkçe', integrated:true, dic:false, deepl:false},
'uk': {name:'Ukrainian', id:'uk', ownlang:'Yкраїнський', integrated:true, dic:false, deepl:false},
'ur': {name:'Urdu', id:'ur', ownlang:'اُردُو', integrated:false, dic:false, deepl:false},
'uz': {name:'Uzbek', id:'uz', ownlang:'اوزبیک', integrated:false, dic:false, deepl:false},
'vi': {name:'Vietnamese', id:'vi', ownlang:'Tiếng Việt Nam', integrated:false, dic:false, deepl:false},
'cy': {name:'Welsh', id:'cy', ownlang:'Cymraeg', integrated:false, dic:false, deepl:false},
'xh': {name:'Xhosa', id:'xh', ownlang:'Xhosa', integrated:false, dic:false, deepl:false},
'yi': {name:'Yiddish', id:'yi', ownlang:'ייִדיש ייִדיש‬', integrated:false, dic:false, deepl:false},
'yo': {name:'Yoruba', id:'yo', ownlang:'Èdè Yorùbá', integrated:false, dic:false, deepl:false},
'zu': {name:'Zulu', id:'zu', ownlang:'Zulu', integrated:false, dic:false, deepl:false}
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var languageinterval = setInterval(() => {
if (document.querySelector('html').lang) {
clearInterval(languageinterval);
var language = BDFDB.getDiscordLanguage();
BDFDB.languages.$discord.name = `Discord (${language.name})`;
BDFDB.languages.$discord.id = language.id;
BDFDB.languages.$discord.ownlang = language.ownlang;
}
}, 100);
BDFDB.getDiscordBuilt = function () {
if (BDFDB.getDiscordBuilt.built) return BDFDB.getDiscordBuilt.built;
else {
var built = null;
2019-09-06 12:21:54 +02:00
try {built = require(LibraryRequires.electron.remote.app.getAppPath() + '/build_info.json').releaseChannel.toLowerCase();}
2019-07-23 21:09:07 +02:00
catch (err) {
2019-09-06 12:21:54 +02:00
try {built = require(LibraryRequires.electron.remote.app.getAppPath().replace('\app.asar', '') + '/build_info.json').releaseChannel.toLowerCase();}
2019-07-23 21:09:07 +02:00
catch (err) {
var version = BDFDB.getDiscordVersion();
if (version) {
version = version.split('.');
if (version.length == 3 && !isNaN(version = parseInt(version[2]))) built = version > 300 ? 'stable' : da > 200 ? 'canary' : 'ptb';
else built = 'stable';
}
else built = 'stable';
}
}
BDFDB.getDiscordBuilt.built = built;
return built;
}
};
BDFDB.getDiscordVersion = function () {
if (BDFDB.getDiscordBuilt.version) return BDFDB.getDiscordBuilt.version;
else {
var version = null;
2019-09-06 12:21:54 +02:00
try {version = LibraryRequires.electron.remote.app.getVersion();}
2019-07-23 21:09:07 +02:00
catch (version) {version = '';}
BDFDB.getDiscordBuilt.version = version;
return version;
}
};
BDFDB.getDiscordLanguage = function () {
var lang = document.querySelector('html').lang || 'en-US';
var langids = lang.split('-');
var langid = langids[0];
var langid2 = langids[1] || '';
lang = langid2 && langid.toUpperCase() !== langid2.toUpperCase() ? langid + '-' + langid2 : langid;
return BDFDB.languages[lang] || BDFDB.languages[langid] || BDFDB.languages['en-US'];
};
BDFDB.getDiscordTheme = function () {
return document.querySelectorAll(BDFDB.dotCN.themelight).length >= document.querySelectorAll(BDFDB.dotCN.themedark).length ? BDFDB.disCN.themelight : BDFDB.disCN.themedark;
};
BDFDB.getDiscordMode = function () {
return document.querySelectorAll(BDFDB.dotCN.messagegroupcompact).length >= document.querySelectorAll(BDFDB.dotCN.messagegroupcozy).length ? 'compact' : 'cozy';
};
BDFDB.getDiscordZoomFactor = function () {
2019-09-10 10:30:14 +02:00
var arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount));
var widthzoom = Math.round(100 * window.outerWidth / arects.width);
var heightzoom = Math.round(100 * window.outerHeight / arects.height);
2019-07-23 21:09:07 +02:00
return widthzoom < heightzoom ? widthzoom : heightzoom;
};
BDFDB.getDiscordFontScale = function () {
return parseInt(document.firstElementChild.style.fontSize.replace('%', ''));
};
BDFDB.isColorBlindModeEnabled = function () {
2019-07-29 18:32:50 +02:00
return true;
2019-07-23 21:09:07 +02:00
};
BDFDB.getReactInstance = function (node) {
if (!BDFDB.isObject(node)) return null;
return node[Object.keys(node).find(key => key.startsWith('__reactInternalInstance'))];
};
BDFDB.getReactValue = function (nodeOrInstance, valuepath) {
if (!nodeOrInstance || !valuepath) return null;
let instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.getReactInstance(nodeOrInstance) : nodeOrInstance;
if (!BDFDB.isObject(instance)) return null;
let found = instance;
for (let key of valuepath.split('.').filter(n => n)) {
found = found[key];
if (found == undefined) return null;
}
return found;
};
BDFDB.getOwnerInstance = function (config) {
if (config === undefined) return null;
if (!config.node && !config.instance || !config.name && (!config.props || !Array.isArray(config.props))) return null;
var instance = config.instance || BDFDB.getReactInstance(config.node);
if (!instance) return null;
config.name = config.name && !Array.isArray(config.name) ? Array.of(config.name) : config.name;
var depth = -1;
var maxdepth = config.depth === undefined ? 15 : config.depth;
var up = config.up === undefined ? false : config.up;
var start = performance.now();
var maxtime = config.time === undefined ? 150 : config.time;
var whitelist = up ? {return:true, sibling:true, _reactInternalFiber:true} : {child:true, sibling:true, _reactInternalFiber:true};
var foundinstances = {};
var singleinstance = getInstance(instance);
if (config.all) {
for (let type in foundinstances) {
if (config.group) for (let instance in foundinstances[type]) delete foundinstances[type][instance].BDFDBreactSearch;
else delete foundinstances[type].BDFDBreactSearch;
}
return foundinstances;
}
else return singleinstance;
2019-09-04 12:34:02 +02:00
2019-09-09 09:05:55 +02:00
function getInstance (instance) {
2019-07-23 21:09:07 +02:00
depth++;
2019-09-09 09:05:55 +02:00
if (!instance || Node.prototype.isPrototypeOf(instance) || BDFDB.getReactInstance(instance) || depth > maxdepth || performance.now() - start > maxtime) return null;
2019-07-23 21:09:07 +02:00
else {
var keys = Object.getOwnPropertyNames(instance);
var result = null;
for (let i = 0; result == null && i < keys.length; i++) {
var key = keys[i];
var value = instance[key];
var statenode = instance.stateNode ? instance.stateNode : (instance.return ? instance.return.stateNode : null);
2019-09-06 10:10:43 +02:00
if (statenode && !Node.prototype.isPrototypeOf(statenode) && (instance.type && config.name && config.name.some(name => instance.type.displayName === name.split(' _ _ ')[0] || instance.type.name === name.split(' _ _ ')[0]) || config.props && config.props.every(prop => statenode[prop] !== undefined) || config.defaultProps && config.defaultProps.every(prop => statenode[prop] !== undefined))) {
2019-07-23 21:09:07 +02:00
if (config.all === undefined || !config.all) result = statenode;
else if (config.all) {
if (config.noCopies === undefined || !config.noCopies || config.noCopies && !statenode.BDFDBreactSearch) {
statenode.BDFDBreactSearch = true;
if (config.group) {
if (config.name && instance.type && (instance.type.displayName || instance.type.name)) {
var group = 'Default';
2019-09-06 10:10:43 +02:00
for (let name of config.name) if (instance.type.displayName === name.split(' _ _ ')[0] || instance.type.name === name.split(' _ _ ')[0]) {
2019-07-23 21:09:07 +02:00
group = name;
break;
}
if (typeof foundinstances[group] == 'undefined') foundinstances[group] = {};
BDFDB.pushToObject(foundinstances[group], statenode);
}
}
else BDFDB.pushToObject(foundinstances, statenode);
}
}
}
if (result == null && (typeof value === 'object' || typeof value === 'function') && whitelist[key]) result = getInstance(value);
}
}
depth--;
return result;
}
};
BDFDB.getKeyInformation = function (config) {
if (config === undefined) return null;
if (!config.node && !config.instance || !config.key) return null;
var instance = config.instance || BDFDB.getReactInstance(config.node);
if (!instance) return null;
var depth = -1;
var maxdepth = config.depth === undefined ? 15 : config.depth;
var start = performance.now();
var maxtime = config.time === undefined ? 150 : config.time;
var whitelist = {
props: true,
state: true,
stateNode: true,
refs: true,
updater: true,
prototype: true,
type: true,
children: config.up ? false : true,
type: true,
memoizedProps: true,
memoizedState: true,
child: config.up ? false : true,
return: config.up ? true : false,
sibling: config.up ? false : true,
firstEffect: true
};
var blacklist = {
contextSection: true
};
if (typeof config.whitelist === 'object') Object.assign(whitelist, config.whiteList);
if (typeof config.blacklist === 'object') Object.assign(blacklist, config.blacklist);
var foundkeys = [];
var singlekey = getKey(instance);
if (config.all) return foundkeys;
else return singlekey;
function getKey(instance) {
depth++;
if (!instance || Node.prototype.isPrototypeOf(instance) || BDFDB.getReactInstance(instance) || depth > maxdepth || performance.now() - start > maxtime) result = null;
else {
var keys = Object.getOwnPropertyNames(instance);
var result = null;
for (let i = 0; result == null && i < keys.length; i++) {
var key = keys[i];
if (key && !blacklist[key]) {
var value = instance[key];
if (config.key === key && (config.value === undefined || config.value === value)) {
if (config.all === undefined || !config.all) result = value;
else if (config.all) {
if (config.noCopies === undefined || !config.noCopies) foundkeys.push(value);
else if (config.noCopies) {
var copy = false;
for (let foundkey of foundkeys) if (BDFDB.equals(value, foundkey)) {
copy = true;
break;
}
if (!copy) foundkeys.push(value);
}
}
}
else if ((typeof value === 'object' || typeof value === 'function') && (whitelist[key] || key[0] == '.' || !isNaN(key[0]))) result = getKey(value);
}
}
}
depth--;
return result;
}
};
2019-09-09 09:42:14 +02:00
var getWebModuleReq = function () {
2019-08-21 14:18:37 +02:00
if (!getWebModuleReq.req) {
2019-07-23 21:09:07 +02:00
const id = "BDFDB-WebModules";
const req = typeof(window.webpackJsonp) == "function" ? window.webpackJsonp([], {[id]: (module, exports, req) => exports.default = req}, [id]).default : window.webpackJsonp.push([[], {[id]: (module, exports, req) => module.exports = req}, [[id]]]);
delete req.m[id];
delete req.c[id];
2019-08-21 14:18:37 +02:00
getWebModuleReq.req = req;
2019-07-23 21:09:07 +02:00
}
2019-08-21 14:18:37 +02:00
return getWebModuleReq.req;
};
BDFDB.WebModules = {};
BDFDB.WebModules.find = function (filter) {
var req = getWebModuleReq();
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
var m = req.c[i].exports;
2019-09-09 09:42:14 +02:00
if (m && (typeof m == "object" || typeof m == "function") && filter(m)) return m;
2019-09-09 09:46:02 +02:00
if (m && m.__esModule) for (let j in m) if (m[j] && (typeof m[j] == "object" || typeof m[j] == "function") && filter(m[j])) return m[j];
2019-07-23 21:09:07 +02:00
}
};
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.cachedData = {prop:{},name:{},string:{},proto:{}};
2019-07-23 21:09:07 +02:00
BDFDB.WebModules.findByProperties = function (properties) {
properties = Array.isArray(properties) ? properties : Array.from(arguments);
var cachestring = JSON.stringify(properties);
if (BDFDB.WebModules.cachedData.prop[cachestring]) return BDFDB.WebModules.cachedData.prop[cachestring];
else {
2019-08-21 14:18:37 +02:00
var m = BDFDB.WebModules.find(m => properties.every(prop => m[prop] !== undefined));
if (m) {
BDFDB.WebModules.cachedData.prop[cachestring] = m;
return m;
2019-07-23 21:09:07 +02:00
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [properties] not found in WebModules');
}
};
BDFDB.WebModules.findByName = function (name) {
var cachestring = JSON.stringify(name);
if (BDFDB.WebModules.cachedData.name[cachestring]) return BDFDB.WebModules.cachedData.name[cachestring];
else {
2019-08-21 14:18:37 +02:00
var m = BDFDB.WebModules.find(m => m.displayName === name);
if (m) {
BDFDB.WebModules.cachedData.name[cachestring] = m;
return m;
2019-07-23 21:09:07 +02:00
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [name] not found in WebModules');
}
};
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.findByString = function (string) {
var cachestring = JSON.stringify(string);
if (BDFDB.WebModules.cachedData.string[cachestring]) return BDFDB.WebModules.cachedData.string[cachestring];
else {
var m = BDFDB.WebModules.find(m => typeof m == "function" && m.toString().indexOf(string) > -1);
if (m) {
2019-09-09 09:42:14 +02:00
BDFDB.WebModules.cachedData.string[cachestring] = m;
2019-09-08 22:34:29 +02:00
return m;
}
2019-09-09 09:42:14 +02:00
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [string] not found in WebModules');
2019-09-08 22:34:29 +02:00
}
};
2019-07-23 21:09:07 +02:00
BDFDB.WebModules.findByPrototypes = function (protoprops) {
protoprops = Array.isArray(protoprops) ? protoprops : Array.from(arguments);
var cachestring = JSON.stringify(protoprops);
if (BDFDB.WebModules.cachedData.proto[cachestring]) return BDFDB.WebModules.cachedData.proto[cachestring];
else {
2019-08-21 14:18:37 +02:00
var m = BDFDB.WebModules.find(m => m.prototype && protoprops.every(prop => m.prototype[prop] !== undefined));
if (m) {
BDFDB.WebModules.cachedData.proto[cachestring] = m;
return m;
2019-07-23 21:09:07 +02:00
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [prototypes] not found in WebModules');
}
};
2019-09-04 12:34:02 +02:00
2019-09-05 12:33:55 +02:00
BDFDB.DiscordConstants = BDFDB.WebModules.findByProperties('Permissions', 'ActivityTypes');
2019-09-06 12:21:54 +02:00
var LibraryRequires = {};
for (let name of ['child_process', 'electron', 'fs', 'path', 'process', 'request']) {
try {LibraryRequires[name] = require(name);} catch (err) {}
}
BDFDB.LibraryRequires = Object.assign({}, LibraryRequires);
2019-08-07 14:02:45 +02:00
var LibraryModules = {};
2019-08-20 11:33:09 +02:00
LibraryModules.AckUtils = BDFDB.WebModules.findByProperties('localAck', 'bulkAck');
2019-09-05 12:33:55 +02:00
LibraryModules.APIUtils = BDFDB.WebModules.findByProperties('getAPIBaseURL');
LibraryModules.AnimationUtils = BDFDB.WebModules.findByProperties('spring', 'decay');
2019-08-07 14:02:45 +02:00
LibraryModules.BadgeUtils = BDFDB.WebModules.findByProperties('getBadgeCountString', 'getBadgeWidthForValue');
LibraryModules.ChannelStore = BDFDB.WebModules.findByProperties('getChannel', 'getChannels');
2019-08-07 14:06:38 +02:00
LibraryModules.ContextMenuUtils = BDFDB.WebModules.findByProperties('closeContextMenu', 'openContextMenu');
LibraryModules.CurrentUserStore = BDFDB.WebModules.findByProperties('getCurrentUser');
2019-08-07 14:02:45 +02:00
LibraryModules.DirectMessageUtils = BDFDB.WebModules.findByProperties('addRecipient', 'openPrivateChannel');
2019-09-05 12:33:55 +02:00
LibraryModules.FriendUtils = BDFDB.WebModules.findByProperties('getFriendIDs', 'getRelationships');
LibraryModules.GuildBoostUtils = BDFDB.WebModules.findByProperties('getTierName', 'getUserLevel');
2019-08-07 14:02:45 +02:00
LibraryModules.GuildStore = BDFDB.WebModules.findByProperties('getGuild', 'getGuilds');
LibraryModules.GuildChannelStore = BDFDB.WebModules.findByProperties('getChannels', 'getDefaultChannel');
2019-09-05 12:33:55 +02:00
LibraryModules.GuildEmojiStore = BDFDB.WebModules.findByProperties('getGuildEmoji', 'getDisambiguatedEmojiContext');
2019-08-07 14:02:45 +02:00
LibraryModules.GuildUtils = BDFDB.WebModules.findByProperties('transitionToGuildSync');
2019-09-05 12:33:55 +02:00
LibraryModules.HistoryUtils = BDFDB.WebModules.findByProperties('transitionTo', 'replaceWith', 'getHistory');;
2019-08-07 14:02:45 +02:00
LibraryModules.IconUtils = BDFDB.WebModules.findByProperties('getGuildIconURL', 'getGuildBannerURL');
LibraryModules.InviteUtils = BDFDB.WebModules.findByProperties('acceptInvite', 'createInvite');
LibraryModules.LanguageStore = BDFDB.WebModules.findByProperties('getLanguages', 'Messages');
LibraryModules.LastChannelStore = BDFDB.WebModules.findByProperties('getLastSelectedChannelId');
LibraryModules.LastGuildStore = BDFDB.WebModules.findByProperties('getLastSelectedGuildId');
2019-09-05 12:33:55 +02:00
LibraryModules.LoginUtils = BDFDB.WebModules.findByProperties('login', 'logout');
2019-08-07 14:02:45 +02:00
LibraryModules.MemberStore = BDFDB.WebModules.findByProperties('getMember', 'getMembers');
LibraryModules.MentionUtils = BDFDB.WebModules.findByProperties('getMentionCount', 'getMentionCounts');
LibraryModules.MessageStore = BDFDB.WebModules.findByProperties('getMessage', 'getMessages');
2019-09-05 12:33:55 +02:00
LibraryModules.MessageCreationUtils = BDFDB.WebModules.findByProperties('parse', 'isMentioned');
LibraryModules.MessagePinUtils = BDFDB.WebModules.findByProperties('pinMessage', 'unpinMessage');
LibraryModules.MessageUtils = BDFDB.WebModules.findByProperties('receiveMessage', 'editMessage');
2019-08-07 14:02:45 +02:00
LibraryModules.MutedUtils = BDFDB.WebModules.findByProperties('isGuildOrCategoryOrChannelMuted');
2019-09-05 12:33:55 +02:00
LibraryModules.NotificationSettingsUtils = BDFDB.WebModules.findByProperties('setDesktopType', 'setTTSType');
LibraryModules.NotificationSettingsStore = BDFDB.WebModules.findByProperties('getDesktopType', 'getTTSType');
2019-08-07 14:02:45 +02:00
LibraryModules.PermissionUtils = BDFDB.WebModules.findByProperties('getChannelPermissions', 'canUser');
2019-09-11 12:44:02 +02:00
LibraryModules.PermissionRoleUtils = BDFDB.WebModules.findByProperties('getHighestRole', 'can');
2019-09-05 12:33:55 +02:00
LibraryModules.ReactionUtils = BDFDB.WebModules.findByProperties('addReaction', 'removeReaction');
LibraryModules.SearchPageUtils = BDFDB.WebModules.findByProperties('searchNextPage', 'searchPreviousPage');
2019-08-07 14:02:45 +02:00
LibraryModules.SelectChannelUtils = BDFDB.WebModules.findByProperties('selectChannel', 'selectPrivateChannel');
2019-09-05 12:33:55 +02:00
LibraryModules.SettingsUtils = BDFDB.WebModules.findByProperties('updateRemoteSettings', 'updateLocalSettings');
LibraryModules.SoundUtils = BDFDB.WebModules.findByProperties('playSound', 'createSound');
LibraryModules.StatusMetaUtils = BDFDB.WebModules.findByProperties('getApplicationActivity', 'getStatus');
2019-08-07 14:02:45 +02:00
LibraryModules.StreamingUtils = BDFDB.WebModules.findByProperties('isStreaming');
2019-09-05 12:33:55 +02:00
LibraryModules.UnreadGuildUtils = BDFDB.WebModules.findByProperties('hasUnread', 'getUnreadGuilds');
2019-09-07 21:03:21 +02:00
LibraryModules.UnreadChannelUtils = BDFDB.WebModules.findByProperties('getUnreadCount', 'getOldestUnreadMessageId');
LibraryModules.UploadUtils = BDFDB.WebModules.findByProperties('upload', 'instantBatchUpload');
2019-08-07 14:02:45 +02:00
LibraryModules.UserStore = BDFDB.WebModules.findByProperties('getUser', 'getUsers');
2019-09-05 12:33:55 +02:00
LibraryModules.VoiceUtils = BDFDB.WebModules.findByProperties('getAllVoiceStates', 'getVoiceStatesForChannel');
2019-09-10 00:15:27 +02:00
LibraryModules.ZoomUtils = BDFDB.WebModules.findByProperties('setZoom', 'setFontSize');
2019-08-07 14:02:45 +02:00
BDFDB.LibraryModules = Object.assign({}, LibraryModules);
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
LibraryModules.React = BDFDB.WebModules.findByProperties('createElement', 'cloneElement');
LibraryModules.ReactDOM = BDFDB.WebModules.findByProperties('render', 'findDOMNode');
if (LibraryModules.React && LibraryModules.ReactDOM) {
BDFDB.React = Object.assign({}, LibraryModules.React, LibraryModules.ReactDOM);
BDFDB.React.findDOMNodeSafe = function (instance) {
2019-08-07 16:18:55 +02:00
if (Node.prototype.isPrototypeOf(instance)) return instance;
2019-08-07 14:02:45 +02:00
if (!instance || !instance.updater || typeof instance.updater.isMounted !== 'function' || !instance.updater.isMounted(instance)) return null;
var node = LibraryModules.ReactDOM.findDOMNode(instance) || BDFDB.getReactValue(instance, 'child.stateNode');
return Node.prototype.isPrototypeOf(node) ? node : null;
};
};
2019-09-04 12:34:02 +02:00
2019-09-09 09:42:14 +02:00
var myDataUser = LibraryModules.CurrentUserStore && typeof LibraryModules.CurrentUserStore.getCurrentUser == 'function' ? LibraryModules.CurrentUserStore.getCurrentUser() : null;
2019-08-07 14:02:45 +02:00
BDFDB.myData = new Proxy(myDataUser || {}, {
get: function (list, item) {
if (!myDataUser) myDataUser = LibraryModules.CurrentUserStore.getCurrentUser();
return myDataUser ? myDataUser[item] : null;
}
});
2019-07-23 21:09:07 +02:00
2019-08-07 16:18:55 +02:00
var webModulesPatchtypes = ['before', 'instead', 'after'];
var webModulesPatchmap = {
2019-07-23 21:09:07 +02:00
Account: 'FluxContainer(Account)',
BannedCard: 'BannedUser',
InvitationCard: 'InviteRow',
InviteCard: 'InviteRow',
PopoutContainer: 'Popout',
MemberCard: 'Member',
Note: 'FluxContainer(Note)',
WebhookCard: 'Webhook'
};
2019-08-07 16:18:55 +02:00
var webModulesNotFindableModules = {
2019-07-23 21:09:07 +02:00
AuthWrapper: 'loginscreen',
BannedCard: 'guildsettingsbannedcard',
ChannelMember: 'member',
EmojiPicker: 'emojipicker',
FriendRow: 'friendsrow',
2019-09-11 12:14:43 +02:00
Guild: 'guildouter',
2019-07-23 21:09:07 +02:00
InstantInviteModal: 'invitemodalwrapper',
InvitationCard: 'invitemodalinviterow',
InviteCard: 'guildsettingsinvitecard',
PopoutContainer: 'popout',
PrivateChannelCall: 'callcurrentcontainer',
MemberCard: 'guildsettingsmembercard',
NameTag: 'nametag',
SearchResults: 'searchresultswrap',
TypingUsers: 'typing',
UserPopout: 'userpopout',
V2C_List: '_repolist',
V2C_PluginCard: '_repoheader',
V2C_ThemeCard: '_repoheader'
};
BDFDB.WebModules.patch = function (module, modulefunctions, plugin, patchfunctions) {
2019-08-07 16:18:55 +02:00
if (!module || !modulefunctions || !plugin || !Object.keys(patchfunctions).some(type => webModulesPatchtypes.includes(type))) return null;
2019-07-23 21:09:07 +02:00
const plugname = (typeof plugin === 'string' ? plugin : plugin.name).toLowerCase();
const surpressErrors = (callback, errorstring) => (...args) => {
try {return callback(...args);}
catch (err) {console.error('Error occurred in ' + errorstring, err);}
};
if (!module.BDFDBpatch) module.BDFDBpatch = {};
modulefunctions = Array.isArray(modulefunctions) ? modulefunctions : Array.of(modulefunctions);
for (let modulefunction of modulefunctions) {
if (!module[modulefunction]) module[modulefunction] = () => {};
const originalfunction = module[modulefunction];
if (!module.BDFDBpatch[modulefunction]) {
module.BDFDBpatch[modulefunction] = {};
2019-08-07 16:18:55 +02:00
for (let type of webModulesPatchtypes) module.BDFDBpatch[modulefunction][type] = {};
2019-07-23 21:09:07 +02:00
module.BDFDBpatch[modulefunction].originalMethod = originalfunction;
module[modulefunction] = function () {
const data = {
thisObject: this,
methodArguments: arguments,
originalMethod: originalfunction,
originalMethodName: modulefunction,
callOriginalMethod: () => data.returnValue = data.originalMethod.apply(data.thisObject, data.methodArguments)
};
2019-09-09 08:23:13 +02:00
if (window.BDFDB && typeof BDFDB === 'object' && BDFDB.loaded && module.BDFDBpatch[modulefunction]) {
2019-07-23 21:09:07 +02:00
if (!BDFDB.isObjectEmpty(module.BDFDBpatch[modulefunction].before)) for (let id in BDFDB.sortObject(module.BDFDBpatch[modulefunction].before)) {
surpressErrors(module.BDFDBpatch[modulefunction].before[id], '`before` callback of ' + module[modulefunction].displayName)(data);
}
if (BDFDB.isObjectEmpty(module.BDFDBpatch[modulefunction].instead)) data.callOriginalMethod();
else for (let id in BDFDB.sortObject(module.BDFDBpatch[modulefunction].instead)) {
const tempreturn = surpressErrors(module.BDFDBpatch[modulefunction].instead[id], '`instead` callback of ' + module[modulefunction].displayName)(data);
if (tempreturn !== undefined) data.returnValue = tempreturn;
}
if (!BDFDB.isObjectEmpty(module.BDFDBpatch[modulefunction].after)) for (let id in BDFDB.sortObject(module.BDFDBpatch[modulefunction].after)) {
2019-09-08 22:34:29 +02:00
const tempreturn = surpressErrors(module.BDFDBpatch[modulefunction].after[id], '`after` callback of ' + module[modulefunction].displayName)(data);
if (tempreturn !== undefined) data.returnValue = tempreturn;
2019-07-23 21:09:07 +02:00
}
}
else data.callOriginalMethod();
return data.returnValue;
};
}
2019-08-07 16:18:55 +02:00
for (let type of webModulesPatchtypes) if (typeof patchfunctions[type] == 'function') module.BDFDBpatch[modulefunction][type][plugname] = patchfunctions[type];
2019-07-23 21:09:07 +02:00
}
const cancel = () => {BDFDB.WebModules.unpatch(module, modulefunctions, plugin);};
if (plugin && typeof plugin == 'object') {
if (!Array.isArray(plugin.patchCancels)) plugin.patchCancels = [];
plugin.patchCancels.push(cancel);
}
return cancel;
};
BDFDB.WebModules.unpatch = function (module, modulefunctions, plugin) {
if (!module || !module.BDFDBpatch) return;
const plugname = !plugin ? null : (typeof plugin === 'string' ? plugin : plugin.name).toLowerCase();
modulefunctions = Array.isArray(modulefunctions) ? modulefunctions : Array.of(modulefunctions);
for (let modulefunction of modulefunctions) {
if (module[modulefunction] && module.BDFDBpatch[modulefunction]) {
2019-08-07 16:18:55 +02:00
for (let type of webModulesPatchtypes) {
2019-07-23 21:09:07 +02:00
if (plugname) delete module.BDFDBpatch[modulefunction][type][plugname];
else delete module.BDFDBpatch[modulefunction][type];
}
var empty = true;
2019-08-07 16:18:55 +02:00
for (let type of webModulesPatchtypes) if (!BDFDB.isObjectEmpty(module.BDFDBpatch[modulefunction][type])) empty = false;
2019-07-23 21:09:07 +02:00
if (empty) {
module[modulefunction] = module.BDFDBpatch[modulefunction].originalMethod;
delete module.BDFDBpatch[modulefunction];
if (BDFDB.isObjectEmpty(module.BDFDBpatch)) delete module.BDFDBpatch;
}
}
}
};
BDFDB.WebModules.unpatchall = function (plugin) {
if (BDFDB.isObject(plugin) && Array.isArray(plugin.patchCancels)) for (let cancel of plugin.patchCancels) cancel();
};
BDFDB.WebModules.forceAllUpdates = function (plugin, selectedtype) {
2019-09-06 10:03:20 +02:00
selectedtype = selectedtype && webModulesPatchmap[selectedtype] ? webModulesPatchmap[selectedtype] + ' _ _ ' + selectedtype : selectedtype;
2019-07-23 21:09:07 +02:00
if (BDFDB.isObject(plugin) && BDFDB.isObject(plugin.patchModules) && (!selectedtype || plugin.patchModules[selectedtype])) {
const app = document.querySelector(BDFDB.dotCN.app);
const bdsettings = document.querySelector('#bd-settingspane-container ' + BDFDB.dotCN.scrollerwrap);
if (app) {
var filteredmodules = [];
for (let type in plugin.patchModules) {
var methodnames = Array.isArray(plugin.patchModules[type]) ? plugin.patchModules[type] : Array.of(plugin.patchModules[type]);
if (methodnames.includes('componentDidUpdate') || methodnames.includes('componentDidMount') || methodnames.includes('render')) filteredmodules.push(type);
}
filteredmodules = selectedtype ? filteredmodules.filter(type => type == selectedtype) : filteredmodules;
if (filteredmodules.length > 0) {
2019-09-08 22:34:29 +02:00
try {
const appins = BDFDB.getOwnerInstance({node:app, name:filteredmodules, all:true, noCopies:true, group:true, depth:99999999, time:99999999});
2019-09-10 23:17:06 +02:00
for (let type in appins) for (let i in appins[type]) BDFDB.WebModules.initiateProcess(plugin, appins[type][i], null, type, ['componentDidMount', 'componentDidUpdate', 'render']);
2019-09-08 22:34:29 +02:00
if (bdsettings) {
const bdsettingsins = BDFDB.getOwnerInstance({node:bdsettings, name:filteredmodules, all:true, noCopies:true, group:true, depth:99999999, time:99999999});
2019-09-10 23:17:06 +02:00
for (let type in bdsettingsins) for (let i in bdsettingsins[type]) BDFDB.WebModules.initiateProcess(plugin, bdsettingsins[type][i], null, type, ['componentDidMount', 'componentDidUpdate', 'render']);
2019-09-08 22:34:29 +02:00
}
2019-07-23 21:09:07 +02:00
}
2019-09-08 22:34:29 +02:00
catch (err) {console.error(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not force update components! ' + err);}
2019-07-23 21:09:07 +02:00
}
}
}
};
BDFDB.WebModules.patchModules = function (plugin) {
if (BDFDB.isObject(plugin) && BDFDB.isObject(plugin.patchModules)) {
for (let type in plugin.patchModules) {
2019-08-07 16:18:55 +02:00
var mapped = webModulesPatchmap[type];
2019-09-09 09:48:37 +02:00
var classname = webModulesNotFindableModules[type.split(' _ _ ')[1] || type];
2019-09-06 10:10:43 +02:00
var patchtype = mapped ? mapped + ' _ _ ' + type : type;
2019-07-23 21:09:07 +02:00
if (mapped) {
2019-09-05 10:59:01 +02:00
plugin.patchModules[patchtype] = plugin.patchModules[type];
2019-07-23 21:09:07 +02:00
delete plugin.patchModules[type];
}
2019-09-09 09:48:37 +02:00
if (!classname) patchInstance(BDFDB.WebModules.findByName(patchtype.split(' _ _ ')[0]), patchtype);
else if (DiscordClasses[classname]) checkForInstance(classname, patchtype);
2019-07-23 21:09:07 +02:00
}
function patchInstance(instance, type) {
if (instance) {
2019-09-06 10:10:43 +02:00
var name = type.split(' _ _ ')[0];
2019-09-05 10:59:01 +02:00
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
2019-09-06 10:03:20 +02:00
instance = instance.displayName == name ? instance : BDFDB.getOwnerInstance({instance, name, up:true});
2019-07-23 21:09:07 +02:00
if (instance) {
2019-09-05 10:59:01 +02:00
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.patch(instance.prototype, plugin.patchModules[type], plugin, {after: e => {
2019-09-09 08:23:13 +02:00
if (window.BDFDB && typeof BDFDB === 'object' && BDFDB.loaded) BDFDB.WebModules.initiateProcess(plugin, e.thisObject, e.returnValue, type, [e.originalMethodName]);
2019-09-08 22:34:29 +02:00
}});
2019-07-23 21:09:07 +02:00
}
}
}
2019-09-09 09:48:37 +02:00
function checkForInstance(classname, type) {
2019-09-05 10:59:01 +02:00
const app = document.querySelector(BDFDB.dotCN.app), bdsettings = document.querySelector('#bd-settingspane-container ' + BDFDB.dotCN.scrollerwrap);
2019-07-23 21:09:07 +02:00
var instancefound = false;
if (app) {
var appins = BDFDB.getOwnerInstance({node:app, name:type, depth:99999999, time:99999999});
if (appins) {
instancefound = true;
patchInstance(appins, type);
}
}
if (!instancefound && bdsettings) {
var bdsettingsins = BDFDB.getOwnerInstance({node:bdsettings, name:type, depth:99999999, time:99999999});
if (bdsettingsins) {
instancefound = true;
patchInstance(bdsettingsins, type);
}
}
if (!instancefound) {
2019-09-09 09:48:37 +02:00
var found = false, instanceobserver = new MutationObserver(cs => {cs.forEach(c => {c.addedNodes.forEach(n => {
2019-09-05 10:59:01 +02:00
if (found || !n || !n.tagName) return;
2019-09-09 09:48:37 +02:00
var ele = null;
2019-09-09 11:04:57 +02:00
if ((ele = BDFDB.containsClass(n, BDFDB.disCN[classname]) ? n : n.querySelector(BDFDB.dotCN[classname])) != null) {
2019-09-09 09:48:37 +02:00
var ins = BDFDB.getReactInstance(ele);
if (isCorrectInstance(ins, type)) {
found = true;
instanceobserver.disconnect();
patchInstance(ins, type);
BDFDB.WebModules.forceAllUpdates(plugin, type);
2019-07-23 21:09:07 +02:00
}
}
});});});
BDFDB.addObserver(plugin, BDFDB.dotCN.appmount, {name:'checkForInstanceObserver', instance:instanceobserver, multi:true
}, {childList:true, subtree:true});
}
}
function isCorrectInstance(instance, type) {
if (!instance) return false;
2019-09-05 10:59:01 +02:00
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
2019-07-23 21:09:07 +02:00
instance = instance.displayName == type ? instance : BDFDB.getOwnerInstance({instance:instance, name:type, up:true});
return instance && (type != 'V2C_PluginCard' && type != 'V2C_ThemeCard' || type == 'V2C_PluginCard' && BDFDB.checkWhichRepoPage() == 'plugins' || type == 'V2C_ThemeCard' && BDFDB.checkWhichRepoPage() == 'themes');
}
}
};
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.initiateProcess = function (plugin, instance, returnvalue, type, methodnames) {
2019-07-23 21:09:07 +02:00
if (BDFDB.isObject(plugin) && instance) {
2019-09-06 01:02:04 +02:00
type = (type.split(' _ _ ')[1] || type).replace(/[^A-z0-9]|_/g, '');
2019-07-23 21:09:07 +02:00
type = type[0].toUpperCase() + type.slice(1);
if (typeof plugin['process' + type] == 'function') {
var wrapper = BDFDB.React.findDOMNodeSafe(instance);
2019-09-08 22:34:29 +02:00
if (wrapper) plugin['process' + type](instance, wrapper, returnvalue, methodnames);
2019-07-23 21:09:07 +02:00
else setImmediate(() => {
wrapper = BDFDB.React.findDOMNodeSafe(instance);
2019-09-08 22:34:29 +02:00
if (wrapper) plugin['process' + type](instance, wrapper, returnvalue, methodnames);
2019-07-23 21:09:07 +02:00
});
}
}
};
BDFDB.addOnSwitchListener = function (plugin) {
if (typeof plugin.onSwitch === 'function') {
BDFDB.removeOnSwitchListener(plugin);
2019-09-09 08:31:13 +02:00
var spacer = document.querySelector(`${BDFDB.dotCN.guildswrapper} ~ * > ${BDFDB.dotCN.chatspacer}`);
2019-07-23 21:09:07 +02:00
if (spacer) {
var nochannelobserver = new MutationObserver(changes => {changes.forEach(change => {
if (change.target && BDFDB.containsClass(change.target, BDFDB.disCN.nochannel)) plugin.onSwitch();
});});
var nochannel = spacer.querySelector(BDFDB.dotCNC.chat + BDFDB.dotCN.nochannel);
if (nochannel) nochannelobserver.observe(nochannel, {attributes:true});
plugin.onSwitchFix = new MutationObserver(changes => {changes.forEach(change => {if (change.addedNodes) {change.addedNodes.forEach(node => {
if (BDFDB.containsClass(node, BDFDB.disCN.chat, BDFDB.disCN.nochannel, false)) nochannelobserver.observe(node, {attributes:true});
});}});});
plugin.onSwitchFix.observe(spacer, {childList:true});
}
}
};
BDFDB.removeOnSwitchListener = function (plugin) {
if (typeof plugin.onSwitch === 'function' && BDFDB.isObject(plugin.onSwitchFix)) {
plugin.onSwitchFix.disconnect();
delete plugin.onSwitchFix;
}
};
2019-09-10 14:55:02 +02:00
var NoFluxContextMenus = ['ChannelContextMenu', 'DeveloperContextMenu', 'GuildContextMenu', 'GuildRoleContextMenu', 'LfgContextMenu', 'MessageContextMenu', 'NativeContextMenu', 'ScreenshareContextMenu', 'UserContextMenu', 'UserSettingsCogContextMenu'];
var NoFluxPopouts = ['MessageOptionPopout'];
var FluxContextMenus = ['ApplicationContextMenu', 'GroupDMContextMenu'];
var PatchMenuQueries = {};
for (let type of FluxContextMenus) PatchMenuQueries[type] = {query:[], module:null};
2019-07-23 21:09:07 +02:00
BDFDB.addContextListener = function (plugin) {
2019-09-08 22:34:29 +02:00
if (!BDFDB.isObject(plugin)) return;
2019-09-10 14:55:02 +02:00
for (let type of NoFluxContextMenus) if (typeof plugin[`on${type}`] === 'function') BDFDBpatchContextMenuModulePlugin(plugin, type, BDFDB.WebModules.findByName(type));
for (let type of NoFluxPopouts) if (typeof plugin[`on${type}`] === 'function') BDFDBpatchPopoutModulePlugin(plugin, type, BDFDB.WebModules.findByName(type));
for (let type of FluxContextMenus) if (typeof plugin[`on${type}`] === 'function') {
if (PatchMenuQueries[type].module) BDFDBpatchContextMenuModulePlugin(plugin, type, PatchMenuQueries[type].module);
else PatchMenuQueries[type].query.push(plugin);
2019-09-09 11:31:33 +02:00
}
};
2019-09-10 14:55:02 +02:00
var BDFDBpatchContextMenuModulePlugin = function (plugin, type, module) {
if (module && module.prototype) BDFDB.WebModules.patch(module.prototype, 'render', plugin, {after: e => {
let instance = e.thisObject, menu = BDFDB.React.findDOMNodeSafe(e.thisObject), returnvalue = e.returnValue;
if (instance && menu && returnvalue && typeof plugin[`on${type}`] === 'function') {
plugin[`on${type}`](instance, menu, returnvalue);
}
}});
};
var BDFDBpatchPopoutModulePlugin = function (plugin, type, module) {
if (module && module.prototype) BDFDB.WebModules.patch(module.prototype, 'render', plugin, {after: e => {
let instance = e.thisObject, popout = BDFDB.React.findDOMNodeSafe(e.thisObject), returnvalue = e.returnValue;
if (instance && popout && returnvalue && typeof plugin[`on${type}`] === 'function') {
plugin[`on${type}`](instance, popout, returnvalue);
if (!instance.BDFDBforceUpdateTimeout && typeof instance.forceUpdate == 'function') instance.forceUpdate();
}
}});
};
var BDFDBpatchContextMenuModuleLib = function (module, repatch) {
2019-09-09 11:31:33 +02:00
if (module && module.prototype) {
BDFDB.WebModules.patch(module.prototype, 'componentDidMount', BDFDB, {after: e => {
2019-09-10 10:04:12 +02:00
if (!e.thisObject.BDFDBforceRenderTimeout && typeof e.thisObject.render == 'function') e.thisObject.render();
2019-09-09 11:31:33 +02:00
}});
BDFDB.WebModules.patch(module.prototype, 'componentDidUpdate', BDFDB, {after: e => {
2019-09-10 10:30:14 +02:00
var menu = BDFDB.React.findDOMNodeSafe(e.thisObject);
if (menu) {
BDFDB.initElements(menu);
const updater = BDFDB.getReactValue(e, 'thisObject._reactInternalFiber.stateNode.props.onHeightUpdate');
const mrects = BDFDB.getRects(menu), arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount));
if (updater && (mrects.top + mrects.height > arects.height)) updater();
}
2019-09-09 11:31:33 +02:00
}});
BDFDB.WebModules.patch(module.prototype, 'render', BDFDB, {after: e => {
2019-09-10 17:05:17 +02:00
if (e.thisObject.props.BDFDBcontextMenu && e.thisObject.props.children && e.returnValue && e.returnValue.props) {
e.returnValue.props.children = e.thisObject.props.children;
2019-09-11 08:25:45 +02:00
delete e.thisObject.props.value;
2019-09-10 17:05:17 +02:00
delete e.thisObject.props.children;
delete e.thisObject.props.BDFDBcontextMenu;
}
2019-09-09 11:31:33 +02:00
if (BDFDB.React.findDOMNodeSafe(e.thisObject)) {
e.thisObject.BDFDBforceRenderTimeout = true;
setTimeout(() => {delete e.thisObject.BDFDBforceRenderTimeout;}, 1000);
2019-09-09 09:55:55 +02:00
}
2019-09-10 14:55:02 +02:00
if (repatch) {
let newmodule = BDFDB.getReactValue(e, 'thisObject._reactInternalFiber.child.type');
if (newmodule && newmodule.displayName && PatchMenuQueries[newmodule.displayName] && !PatchMenuQueries[newmodule.displayName].module) {
PatchMenuQueries[newmodule.displayName].module = newmodule;
BDFDBpatchContextMenuModuleLib(newmodule, false);
while (PatchMenuQueries[newmodule.displayName].query.length) {
BDFDBpatchContextMenuModulePlugin(PatchMenuQueries[newmodule.displayName].query.pop(), newmodule.displayName, newmodule);
}
}
}
2019-09-09 09:55:55 +02:00
}});
2019-07-23 21:09:07 +02:00
}
};
2019-09-10 14:55:02 +02:00
var BDFDBpatchPopoutModuleLib = function (module, repatch) {
2019-09-09 11:31:33 +02:00
if (module && module.prototype) {
BDFDB.WebModules.patch(module.prototype, 'componentDidMount', BDFDB, {after: e => {
2019-09-09 15:16:08 +02:00
if (!e.thisObject.BDFDBforceRenderTimeout && !e.thisObject.BDFDBforceUpdateTimeout && typeof e.thisObject.render == 'function') e.thisObject.render();
2019-09-09 11:31:33 +02:00
}});
2019-09-09 12:39:15 +02:00
BDFDB.WebModules.patch(module.prototype, 'componentDidUpdate', BDFDB, {after: e => {
const updater = BDFDB.getReactValue(e, 'thisObject._reactInternalFiber.return.return.return.stateNode.updateOffsets');
if (updater) updater();
2019-09-09 15:16:08 +02:00
e.thisObject.BDFDBforceUpdateTimeout = true;
setTimeout(() => {delete e.thisObject.BDFDBforceUpdateTimeout;}, 1000);
2019-09-09 12:39:15 +02:00
}});
2019-09-09 11:31:33 +02:00
BDFDB.WebModules.patch(module.prototype, 'render', BDFDB, {after: e => {
if (BDFDB.React.findDOMNodeSafe(e.thisObject)) {
e.thisObject.BDFDBforceRenderTimeout = true;
setTimeout(() => {delete e.thisObject.BDFDBforceRenderTimeout;}, 1000);
}
2019-09-09 11:53:19 +02:00
if (e.thisObject.props.message && !e.thisObject.props.target) {
const messageswrap = document.querySelector(BDFDB.dotCN.messages);
if (messageswrap) {
var messages = BDFDB.getOwnerInstance({node:messageswrap, name:"Message", all:true, noCopies:true, depth:99999999, time:99999999});
for (let i in messages) if (e.thisObject.props.message.id == messages[i].props.message.id) {
target = BDFDB.React.findDOMNodeSafe(messages[i]);
if (target) e.thisObject.props.target = target
break;
}
}
}
2019-09-09 11:31:33 +02:00
}});
}
2019-09-08 23:46:48 +02:00
};
2019-09-10 14:55:02 +02:00
for (let type of NoFluxContextMenus) BDFDBpatchContextMenuModuleLib(BDFDB.WebModules.findByName(type), false);
for (let type of NoFluxPopouts) BDFDBpatchPopoutModuleLib(BDFDB.WebModules.findByName(type), false);
for (let type of FluxContextMenus) BDFDBpatchContextMenuModuleLib(BDFDB.WebModules.findByName('FluxContainer(' + type + ')'), true);
2019-07-23 21:09:07 +02:00
BDFDB.addSettingsButtonListener = function (plugin) {
if (BDFDB.isBDv2() && typeof plugin.getSettingsPanel === 'function') {
BDFDB.removeSettingsButtonListener(plugin);
BDFDB.appendSettingsButton(plugin);
var BDv2settings = document.querySelector('.bd-content-region > .bd-content');
if (BDv2settings) {
plugin.settingsButtonObserver = new MutationObserver(changes => {changes.forEach(change => {if (change.addedNodes) {change.addedNodes.forEach(node => {
if (node.tagName && BDFDB.containsClass(node, 'active')) BDFDB.appendSettingsButton(plugin);
});}});});
plugin.settingsButtonObserver.observe(BDv2settings, {childList:true});
}
}
};
BDFDB.appendSettingsButton = function (plugin) {
var plugincard = document.querySelector(`${BDFDB.dotCN._bdv2card}[data-plugin-id=${plugin.id}]`);
if (plugincard) {
var settingsbutton = BDFDB.htmlToElement(`<div class="BDFDB-settingsbutton ${BDFDB.disCNS._bdv2button + BDFDB.disCN._bdv2hastooltip}"><span class="${BDFDB.disCN._bdv2materialdesignicon}"><svg width="18" height="18" viewBox="0 0 24 24"><path d="M12,15.5C10.07,15.5 8.5,13.93 8.5,12C8.5,10.07 10.07,8.5 12,8.5C13.93,8.5 15.5,10.07 15.5,12C15.5,13.93 13.93,15.5 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.03 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.67 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.03 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z"></path></svg></span></div>`);
plugincard.insertBefore(settingsbutton, plugincard.querySelector(BDFDB.d._bdv2button));
settingsbutton.addEventListener('mouseenter', () => {
BDFDB.createTooltip('Settings', settingsbutton, {type:'top'});
BDFDB.addClass(settingsbutton, BDFDB.disCN._bdv2tooltipopen);
});
settingsbutton.addEventListener('mouseleave', () => {
BDFDB.removeClass(settingsbutton, BDFDB.disCN._bdv2tooltipopen);
});
settingsbutton.addEventListener('click', () => {
2019-09-18 10:19:56 +02:00
var settingsmodal = BDFDB.htmlToElement(`<span class="BDFDB-modal BDFDB-settingsmodal ${plugin.id}-settingsmodal"><div class="${BDFDB.disCN.backdrop}"></div><div class="${BDFDB.disCN.modal}"><div class="${BDFDB.disCN.modalinner}"><div class="${BDFDB.disCNS.modalsub + BDFDB.disCN.modalsizemedium}" style="width:600px !important;"><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;"><div class="${BDFDB.disCN.flexchild}" style="flex:1 1 auto;"><h4 class="${BDFDB.disCNS.h4 + BDFDB.disCNS.defaultcolor + BDFDB.disCN.h4defaultmargin}">${plugin.name} Settings</h4></div><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 class="" xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 12 12"><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></div><div class="${BDFDB.disCNS.scrollerwrap + BDFDB.disCNS.modalcontent + BDFDB.disCNS.scrollerthemed + BDFDB.disCN.themeghosthairline}"><div class="${BDFDB.disCNS.scroller + BDFDB.disCN.modalsubinner}"></div></div></div></div></div></span>`);
2019-07-23 21:09:07 +02:00
var settingshtml = plugin.getSettingsPanel();
settingsmodal.querySelector(BDFDB.dotCN.modalsubinner).appendChild(typeof settingshtml == 'string' ? BDFDB.htmlToElement(settingshtml) : settingshtml);
if (typeof plugin.onSettingsClosed === 'function') BDFDB.addChildEventListener(settingsmodal, 'click', BDFDB.dotCNC.modalclose + BDFDB.dotCN.backdrop, () => {
plugin.onSettingsClosed();
});
BDFDB.appendModal(settingsmodal);
});
}
};
BDFDB.removeSettingsButtonListener = function (plugin) {
if (BDFDB.isBDv2() && typeof plugin.settingsButtonObserver === 'object') {
BDFDB.removeEles(`.bd-card[data-plugin-id=${plugin.id}] .BDFDB-settingsbutton`);
plugin.settingsButtonObserver.disconnect();
delete plugin.settingsButtonObserver;
}
};
2019-09-04 12:34:02 +02:00
2019-09-09 09:42:14 +02:00
var LanguageStringsVars = {}, LanguageStrings = LibraryModules.LanguageStore && LibraryModules.LanguageStore._proxyContext ? Object.assign({}, LibraryModules.LanguageStore._proxyContext.defaultMessages) : {};
2019-07-23 21:09:07 +02:00
BDFDB.LanguageStrings = new Proxy(LanguageStrings, {
get: function (list, item) {
2019-08-07 14:02:45 +02:00
var stringobj = LibraryModules.LanguageStore.Messages[item];
2019-07-23 21:09:07 +02:00
if (!stringobj) console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' not found in BDFDB.LanguageStrings');
else {
var string = typeof stringobj == 'object' ? stringobj.format(Object.assign({}, LanguageStringsVars)) : stringobj;
if (typeof string == "string") return string;
else if (Array.isArray(string)) {
var newstring = "";
for (let ele of string) {
if (typeof ele == "string") newstring += BDFDB.encodeToHTML(ele);
else if (BDFDB.isObject(ele) && ele.props) newstring += `<${ele.type}>${BDFDB.encodeToHTML(ele.props.children[0].toString())}</${ele.type}>`
}
return newstring;
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' could not be parsed from BDFDB.LanguageStrings');
}
return "";
}
});
BDFDB.LanguageStringsCheck = new Proxy(LanguageStrings, {
get: function (list, item) {
2019-08-07 14:02:45 +02:00
return LibraryModules.LanguageStore.Messages[item];
2019-07-23 21:09:07 +02:00
}
});
BDFDB.LanguageStringsFormat = function (item, value) {
if (item && value) {
2019-08-07 14:02:45 +02:00
var stringobj = LibraryModules.LanguageStore.Messages[item];
2019-07-23 21:09:07 +02:00
if (stringobj && typeof stringobj == "object" && typeof stringobj.format == "function") {
try {
var valueobject = {};
for (let key in LanguageStringsVars) valueobject[key] = value;
var string = stringobj.format(valueobject);
if (typeof string == "string") return string;
else if (Array.isArray(string)) {
var newstring = "";
for (let ele of string) {
if (typeof ele == "string") newstring += BDFDB.encodeToHTML(ele);
else if (BDFDB.isObject(ele) && ele.props) newstring += `<${ele.type}>${BDFDB.encodeToHTML(ele.props.children[0].toString())}</${ele.type}>`
}
return newstring;
}
}
catch (err) {console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' failed to format string in BDFDB.LanguageStrings');}
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' is not a formatable string in BDFDB.LanguageStrings');
}
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' enter a valid key and value to format the string');
return "";
};
2019-08-07 14:02:45 +02:00
if (LibraryModules.LanguageStore) for (let string in LanguageStrings) {
2019-07-23 21:09:07 +02:00
try {BDFDB.LanguageStrings[string];}
catch (err) {
let strvar = err.toString().split('for: ')[1];
if (strvar && typeof strvar == 'string' && !LanguageStringsVars[strvar]) LanguageStringsVars[strvar] = `{{${strvar.toLowerCase()}}}`;
}
};
BDFDB.equals = function (mainA, mainB, sorted) {
var i = -1;
if (sorted === undefined || typeof sorted !== 'boolean') sorted = false;
return equal(mainA, mainB);
function equal(a, b) {
i++;
var result = true;
if (i > 1000) result = null;
else {
if (typeof a !== typeof b) result = false;
else if (typeof a === 'undefined') result = true;
else if (typeof a === 'symbol') result = true;
else if (typeof a === 'boolean') result = a == b;
else if (typeof a === 'string') result = a == b;
else if (typeof a === 'number') {
if (isNaN(a) || isNaN(b)) result = isNaN(a) == isNaN(b);
else result = a == b;
}
else if (!a && !b) result = true;
else if (!a || !b) result = false;
else if (typeof a === 'function' || typeof a === 'object') {
var keysA = Object.getOwnPropertyNames(a);
var keysB = Object.getOwnPropertyNames(b);
if (keysA.length !== keysB.length) result = false;
else for (let j = 0; result === true && j < keysA.length; j++) {
if (sorted) result = equal(a[keysA[j]], b[keysB[j]]);
else result = equal(a[keysA[j]], b[keysA[j]]);
}
}
}
i--;
return result;
}
};
BDFDB.getGuildIcon = function (id) {
2019-08-07 14:02:45 +02:00
var guild = LibraryModules.GuildStore.getGuild(typeof id == 'number' ? id.toFixed() : id);
2019-07-23 21:09:07 +02:00
if (!guild || !guild.icon) return null;
2019-08-07 14:02:45 +02:00
return LibraryModules.IconUtils.getGuildIconURL(guild).split('?')[0];
2019-07-23 21:09:07 +02:00
};
BDFDB.getGuildBanner = function (id) {
2019-08-07 14:02:45 +02:00
var guild = LibraryModules.GuildStore.getGuild(typeof id == 'number' ? id.toFixed() : id);
2019-07-23 21:09:07 +02:00
if (!guild || !guild.banner) return null;
2019-08-07 14:02:45 +02:00
return LibraryModules.IconUtils.getGuildBannerURL(guild).split('?')[0];
2019-07-23 21:09:07 +02:00
};
BDFDB.getUserStatus = function (id = BDFDB.myData.id) {
id = typeof id == 'number' ? id.toFixed() : id;
2019-09-05 12:33:55 +02:00
return LibraryModules.StreamingUtils.isStreaming(LibraryModules.StatusMetaUtils.getApplicationActivity(id)) ? 'streaming' : LibraryModules.StatusMetaUtils.getStatus(id);
2019-07-23 21:09:07 +02:00
};
BDFDB.getUserStatusColor = function (status) {
status = typeof status == "string" ? status.toLowerCase() : null;
switch (status) {
case 'online': return '#43b581';
2019-08-22 11:08:08 +02:00
case 'mobile': return '#43b581';
2019-07-23 21:09:07 +02:00
case 'idle': return '#faa61a';
case 'dnd': return '#f04747';
case 'streaming': return '#593695';
default: return '#747f8d';
}
};
BDFDB.getUserAvatar = function (id = BDFDB.myData.id) {
2019-08-07 14:02:45 +02:00
var user = LibraryModules.UserStore.getUser(typeof id == 'number' ? id.toFixed() : id);
2019-07-23 21:09:07 +02:00
if (!user) return 'https://discordapp.com/assets/322c936a8c8be1b803cd94861bdfa868.png';
2019-08-07 14:02:45 +02:00
else return ((user.avatar ? '' : 'https://discordapp.com') + LibraryModules.IconUtils.getUserAvatarURL(user)).split('?')[0];
2019-07-23 21:09:07 +02:00
};
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
BDFDB.isUserAllowedTo = function (permission, id = BDFDB.myData.id, channelid = LibraryModules.LastChannelStore.getChannelId()) {
2019-09-05 12:33:55 +02:00
if (!BDFDB.DiscordConstants.Permissions[permission]) console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', permission + ' not found in Permissions');
2019-07-23 21:09:07 +02:00
else {
2019-08-07 14:02:45 +02:00
var channel = LibraryModules.ChannelStore.getChannel(channelid);
2019-09-05 12:33:55 +02:00
if (channel) return LibraryModules.PermissionUtils.canUser(id, BDFDB.DiscordConstants.Permissions[permission], channel);
2019-07-23 21:09:07 +02:00
}
return false;
};
BDFDB.getChannelIcon = function (id) {
2019-08-07 14:02:45 +02:00
var channel = LibraryModules.ChannelStore.getChannel(id = typeof id == 'number' ? id.toFixed() : id);
2019-07-23 21:09:07 +02:00
if (!channel) return null;
if (!channel.icon) return channel.type == 1 ? BDFDB.getUserAvatar(channel.recipients[0]) : (channel.type == 3 ? 'https://discordapp.com/assets/f046e2247d730629309457e902d5c5b3.svg' : null);
2019-08-07 14:02:45 +02:00
return LibraryModules.IconUtils.getChannelIconURL(channel).split('?')[0];
2019-07-23 21:09:07 +02:00
};
2019-08-07 14:02:45 +02:00
BDFDB.getParsedLength = function (string, channelid = LibraryModules.LastChannelStore.getChannelId()) {
2019-07-23 21:09:07 +02:00
if (!string) return 0;
2019-08-07 14:02:45 +02:00
var channel = LibraryModules.ChannelStore.getChannel(channelid);
2019-09-05 12:33:55 +02:00
var length = (string.indexOf('/') == 0 || string.indexOf('s/') == 0 || string.indexOf('+:') == 0) ? string.length : LibraryModules.MessageCreationUtils.parse(channel, string).content.length;
2019-07-23 21:09:07 +02:00
return length > string.length ? length : string.length;
};
BDFDB.readServerList = function () {
2019-07-25 11:01:11 +02:00
var found = [], ins = BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.guilds), name:['Guild','GuildIcon'], all:true, noCopies:true, depth:99999999, time:99999999});
2019-08-07 11:19:17 +02:00
for (let info in ins) if (ins[info].props && ins[info].props.guild) found.push(Object.assign(new ins[info].props.guild.constructor(ins[info].props.guild), {div:ins[info].handleContextMenu ? BDFDB.React.findDOMNodeSafe(ins[info]) : BDFDB.createServerDivCopy(ins[info].props.guild), instance:ins[info]}));
2019-07-23 21:09:07 +02:00
return found;
};
BDFDB.readUnreadServerList = function (servers) {
2019-08-07 14:02:45 +02:00
var found = [];
2019-07-28 08:17:38 +02:00
for (let eleOrInfoOrId of servers === undefined || !Array.isArray(servers) ? BDFDB.readServerList() : servers) {
if (!eleOrInfoOrId) return null;
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getServerID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
id = typeof id == 'number' ? id.toFixed() : id;
2019-09-05 12:33:55 +02:00
if (id && (LibraryModules.UnreadGuildUtils.hasUnread(id) || LibraryModules.MentionUtils.getMentionCount(id) > 0)) found.push(eleOrInfoOrId);
2019-07-23 21:09:07 +02:00
}
return found;
};
BDFDB.readMutedServerList = function (servers) {
2019-08-07 14:02:45 +02:00
var found = [];
2019-07-28 08:17:38 +02:00
for (let eleOrInfoOrId of servers === undefined || !Array.isArray(servers) ? BDFDB.readServerList() : servers) {
if (!eleOrInfoOrId) return null;
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getServerID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
id = typeof id == 'number' ? id.toFixed() : id;
2019-08-07 14:02:45 +02:00
if (id && LibraryModules.MutedUtils.isGuildOrCategoryOrChannelMuted(id)) found.push(eleOrInfoOrId);
2019-07-23 21:09:07 +02:00
}
return found;
};
BDFDB.getSelectedServer = function () {
2019-08-07 14:02:45 +02:00
var info = LibraryModules.GuildStore.getGuild(LibraryModules.LastGuildStore.getGuildId());
2019-07-23 21:09:07 +02:00
if (info) return BDFDB.getServerData(info.id) || Object.assign(new info.constructor(info), {div:null, instance:null});
else return null;
};
BDFDB.getServerID = function (div) {
if (!Node.prototype.isPrototypeOf(div) || !BDFDB.getReactInstance(div)) return;
let guilddiv = BDFDB.getParentEle(BDFDB.dotCN.guildouter, div);
if (!guilddiv) return;
var iconwrap = guilddiv.querySelector(BDFDB.dotCN.guildiconwrapper);
var id = iconwrap && iconwrap.href ? iconwrap.href.split('/').slice(-2)[0] : null;
return id && !isNaN(parseInt(id)) ? id.toString() : null;
};
BDFDB.getServerDiv = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
if (Node.prototype.isPrototypeOf(eleOrInfoOrId)) return BDFDB.getParentEle(BDFDB.dotCN.guildouter, eleOrInfoOrId);
else {
let id = typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
2019-08-07 14:46:10 +02:00
if (id) return BDFDB.getParentEle(BDFDB.dotCN.guildouter, document.querySelector(`${BDFDB.dotCNS.guilds + BDFDB.dotCN.guildiconwrapper}[href*="/channels/${id}"]`)) || BDFDB.createServerDivCopy(id, {pill: true, hover: true, click: true, menu: true});
2019-07-23 21:09:07 +02:00
}
return null;
};
BDFDB.getServerData = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getServerID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
id = typeof id == 'number' ? id.toFixed() : id;
for (let info of BDFDB.readServerList()) if (info && info.id == id) return info;
return null;
};
2019-09-04 12:34:02 +02:00
2019-08-07 14:46:10 +02:00
BDFDB.createServerDivCopy = function (infoOrId, functionality = {pill: false, hover: false, click:false, menu:false, size:null}) {
2019-08-07 11:19:17 +02:00
let id = typeof infoOrId == 'object' ? infoOrId.id : infoOrId;
2019-08-07 14:02:45 +02:00
let guild = id ? LibraryModules.GuildStore.getGuild(id) : null;
if (guild) {
let randomid = Math.round(Math.random() * 10000000000000000);
2019-09-11 22:44:30 +02:00
let div = BDFDB.htmlToElement(`<div class="${BDFDB.disCNS.guildouter + BDFDB.disCN._bdguild}"><div class="${BDFDB.disCNS.guildpill + BDFDB.disCN.guildpillwrapper}"><span class="${BDFDB.disCN.guildpillitem}" style="opacity: 0; height: 8px; transform: translate3d(0px, 0px, 0px);"></span></div><div class="${BDFDB.disCN.guildcontainer}" draggable="false" style="border-radius: 50%; overflow: hidden;"><div class="${BDFDB.disCN.guildinner}"><svg width="48" height="48" viewBox="0 0 48 48" class="${BDFDB.disCN.guildsvg}"><mask id="" fill="black" x="0" y="0" width="48" height="48"><path d="M48 24C48 37.2548 37.2548 48 24 48C10.7452 48 0 37.2548 0 24C0 10.7452 10.7452 0 24 0C37.2548 0 48 10.7452 48 24Z" fill="white"></path><rect x="28" y="-4" width="24" height="24" rx="12" ry="12" transform="translate(20 -20)" fill="black"></rect><rect x="28" y="28" width="24" height="24" rx="12" ry="12" transform="translate(20 20)" fill="black"></rect></mask><foreignObject mask="" x="0" y="0" width="48" height="48"><a class="${BDFDB.disCN.guildiconwrapper}" aria-label="${guild.name}"${functionality.click ? ' href="channels/"' + guild.id + '/' + LibraryModules.LastChannelStore.getChannelId(guild.id) + '"' : ''} draggable="false">${guild.icon ? `<img class="${BDFDB.disCN.guildicon}" src="${BDFDB.getGuildIcon(guild.id)}?size=128" alt="" width="48" height="48" draggable="false" aria-hidden="true"></img>` : `<div class="${BDFDB.disCNS.guildiconchildwrapper +BDFDB.disCN.guildiconacronym}" aria-hidden="true" style="font-size: ${guild.acronym.length > 5 ? 10 : (guild.acronym.length > 4 ? 12 : (guild.acronym.length > 3 ? 14 : (guild.acronym.length > 1 ? 16 : 18)))}px;">${guild.acronym}</div>`}</a></foreignObject></svg><div class="${BDFDB.disCN.guildbadgewrapper}"></div></div></div><div class="${BDFDB.disCN.guildedgewrapper}" aria-hidden="true"><span class="${BDFDB.disCN.guildedge}"></span><span class="${BDFDB.disCN.guildedgemiddle}"></span><span class="${BDFDB.disCN.guildedge}"></span></div></div>`);
2019-08-07 14:46:10 +02:00
let divinner = div.querySelector(BDFDB.dotCN.guildcontainer);
2019-08-07 14:02:45 +02:00
BDFDB.toggleEles(div.querySelector(BDFDB.dotCN.guildpillwrapper), functionality.pill);
if (functionality.hover) {
let diviconwrapper = div.querySelector(BDFDB.dotCN.guildiconwrapper);
let divpillitem = div.querySelector(BDFDB.dotCN.guildpillitem);
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
let pillvisible = divpillitem.style.getPropertyValue("opacity") != 0;
2019-09-04 12:34:02 +02:00
2019-09-05 12:33:55 +02:00
let borderRadius = new LibraryModules.AnimationUtils.Value(0);
2019-08-07 14:02:45 +02:00
borderRadius
.interpolate({inputRange: [0, 1], outputRange: [50, 30]})
2019-08-07 14:46:10 +02:00
.addListener((value) => {divinner.style.setProperty("border-radius", `${value.value}%`);});
2019-08-07 14:02:45 +02:00
2019-09-05 12:33:55 +02:00
let pillHeight = new LibraryModules.AnimationUtils.Value(0);
2019-08-07 14:02:45 +02:00
pillHeight
.interpolate({inputRange: [0, 1], outputRange: [8, 20]})
.addListener((value) => {divpillitem.style.setProperty("height", `${value.value}px`);});
2019-09-05 12:33:55 +02:00
let pillOpacity = new LibraryModules.AnimationUtils.Value(0);
2019-08-07 14:02:45 +02:00
pillOpacity
.interpolate({inputRange: [0, 1], outputRange: [0, 0.7]})
.addListener((value) => {divpillitem.style.setProperty("opacity", `${value.value}`);});
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
let animate = (v) => {
2019-09-05 12:33:55 +02:00
LibraryModules.AnimationUtils.parallel([
LibraryModules.AnimationUtils.timing(borderRadius, {toValue: v, duration: 200}),
LibraryModules.AnimationUtils.spring(pillHeight, {toValue: v, friction: 5})
2019-08-07 14:02:45 +02:00
]).start();
};
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
let animate2 = (v) => {
2019-09-05 12:33:55 +02:00
LibraryModules.AnimationUtils.parallel([
LibraryModules.AnimationUtils.timing(pillOpacity, {toValue: v, duration: 200}),
2019-08-07 14:02:45 +02:00
]).start();
};
2019-09-04 12:34:02 +02:00
2019-08-07 14:02:45 +02:00
divinner.addEventListener("mouseenter", () => {
pillvisible = divpillitem.style.getPropertyValue("opacity") != 0;
if (LibraryModules.LastGuildStore.getGuildId() != guild.id) {
animate(1);
if (!pillvisible) animate2(1);
}
})
divinner.addEventListener("mouseleave", () => {
if (LibraryModules.LastGuildStore.getGuildId() != guild.id) {
animate(0);
if (!pillvisible) animate2(0);
}
});
}
2019-08-07 14:46:10 +02:00
if (functionality.click) divinner.addEventListener("click", e => {
BDFDB.stopEvent(e);
LibraryModules.GuildUtils.transitionToGuildSync(guild.id);
if (typeof functionality.click == "function") functionality.click();
});
if (functionality.menu) divinner.addEventListener("contextmenu", e => {
BDFDB.openGuildContextMenu(guild.id, e);
if (typeof functionality.menu == "function") functionality.menu();
});
if (functionality.size) {
div.style.setProperty("margin", "0", "important");
div.style.setProperty("width", functionality.size + "px", "important");
div.style.setProperty("height", functionality.size + "px", "important");
}
2019-08-07 14:02:45 +02:00
return div;
}
else return null;
2019-08-07 11:19:17 +02:00
};
2019-09-04 12:34:02 +02:00
2019-08-07 14:46:10 +02:00
BDFDB.openGuildContextMenu = function (eleOrInfoOrId, e = BDFDB.mousePosition) {
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getServerID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
let guild = LibraryModules.GuildStore.getGuild(id);
if (guild) LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) {
return BDFDB.React.createElement(BDFDB.WebModules.findByName("GuildContextMenu"), Object.assign({}, e, {
2019-09-05 12:33:55 +02:00
type: BDFDB.DiscordConstants.ContextMenuTypes.GUILD_ICON_BAR,
2019-08-07 14:46:10 +02:00
guild: guild,
badge: LibraryModules.MentionUtils.getMentionCount(guild.id),
2019-09-05 12:33:55 +02:00
link: BDFDB.DiscordConstants.Routes.CHANNEL(guild.id, LibraryModules.LastChannelStore.getChannelId(guild.id)),
2019-08-07 14:46:10 +02:00
selected: guild.id == LibraryModules.LastGuildStore.getGuildId()
}));
});
};
2019-07-23 21:09:07 +02:00
BDFDB.readChannelList = function () {
var found = [], ins = BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.channels), name:['ChannelCategoryItem', 'ChannelItem', 'PrivateChannel'], all:true, noCopies:true, depth:99999999, time:99999999});
for (let info in ins) if (ins[info].props && !ins[info].props.ispin && ins[info].props.channel && ins[info]._reactInternalFiber.return) {
var div = BDFDB.React.findDOMNodeSafe(ins[info]);
div = div && BDFDB.containsClass(div.parentElement, BDFDB.disCN.categorycontainerdefault, BDFDB.disCN.channelcontainerdefault, false) ? div.parentElement : div;
found.push(Object.assign(new ins[info].props.channel.constructor(ins[info].props.channel), {div, instance:ins[info]}));
}
return found;
};
BDFDB.getSelectedChannel = function () {
2019-08-07 14:02:45 +02:00
var info = LibraryModules.ChannelStore.getChannel(LibraryModules.LastChannelStore.getChannelId());
2019-07-23 21:09:07 +02:00
if (info) return BDFDB.getChannelData(info.id) || Object.assign(new info.constructor(info), {div:null, instance:null});
else return null;
};
BDFDB.getChannelID = function (div) {
if (!Node.prototype.isPrototypeOf(div) || !BDFDB.getReactInstance(div)) return;
div = BDFDB.getParentEle(BDFDB.dotCNC.categorycontainerdefault + BDFDB.dotCNC.channelcontainerdefault + BDFDB.dotCN.dmchannel, div);
if (!div) return;
var info = BDFDB.getKeyInformation({node:div, key:'channel'});
return info ? info.id.toString() : null;
};
BDFDB.getChannelDiv = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
let info = BDFDB.getChannelData(eleOrInfoOrId);
return info ? info.div : null;
};
BDFDB.getChannelData = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getChannelID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
id = typeof id == 'number' ? id.toFixed() : id;
for (let info of BDFDB.readChannelList()) if (info && info.id == id) return info;
return null;
};
2019-09-11 08:56:24 +02:00
BDFDB.openChannelContextMenu = function (eleOrInfoOrId, e = BDFDB.mousePosition) {
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getChannelID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
let channel = LibraryModules.ChannelStore.getChannel(id);
if (channel) {
let type = null;
for (let t in BDFDB.DiscordConstants.ChannelTypes) if (BDFDB.DiscordConstants.ChannelTypes[t] == channel.type) {
2019-09-11 10:56:54 +02:00
type = BDFDB.DiscordConstants.ContextMenuTypes[(t == "GUILD_CATEGORY" ? "CHANNEL_" : "CHANNEL_LIST_") + t.replace("GUILD_", "")];
2019-09-11 08:56:24 +02:00
break;
}
if (type) LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) {
return BDFDB.React.createElement(BDFDB.WebModules.findByName("ChannelContextMenu"), Object.assign({}, e, {
type,
channel,
2019-09-11 21:28:36 +02:00
guild: LibraryModules.GuildStore.getGuild(channel.guild_id),
2019-09-11 08:56:24 +02:00
selected: channel.id == LibraryModules.LastChannelStore.getChannelId()
}));
});
}
};
2019-07-23 21:09:07 +02:00
BDFDB.readDmList = function () {
var found = [], ins = BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.guilds), name:'DirectMessage', all:true, noCopies:true, depth:99999999, time:99999999});
for (let info in ins) if (ins[info].props && ins[info].props.channel && ins[info]._reactInternalFiber.child) found.push(Object.assign(new ins[info].props.channel.constructor(ins[info].props.channel), {div:BDFDB.React.findDOMNodeSafe(ins[info]), instance:ins[info]}));
return found;
};
BDFDB.getDmID = function (div) {
if (!Node.prototype.isPrototypeOf(div) || !BDFDB.getReactInstance(div)) return;
let dmdiv = BDFDB.getParentEle(BDFDB.dotCN.guildouter, div);
if (!dmdiv) return;
var iconwrap = dmdiv.querySelector(BDFDB.dotCN.guildiconwrapper);
var id = iconwrap && iconwrap.href ? iconwrap.href.split('/').slice(-1)[0] : null;
return id && !isNaN(parseInt(id)) ? id.toString() : null;
};
BDFDB.getDmDiv = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
if (Node.prototype.isPrototypeOf(eleOrInfoOrId)) {
var div = BDFDB.getParentEle(BDFDB.dotCN.guildouter, eleOrInfoOrId);
return div ? div.parentElement : div;
}
else {
let id = typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
if (id) {
var div = BDFDB.getParentEle(BDFDB.dotCN.guildouter, document.querySelector(`${BDFDB.dotCNS.guilds + BDFDB.dotCN.dmpill + " + * " + BDFDB.dotCN.guildiconwrapper}[href*="/channels/@me/${id}"]`));
return div && BDFDB? div.parentElement : div;
}
}
return null;
};
BDFDB.getDmData = function (eleOrInfoOrId) {
if (!eleOrInfoOrId) return null;
let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.getDmID(eleOrInfoOrId) : typeof eleOrInfoOrId == 'object' ? eleOrInfoOrId.id : eleOrInfoOrId;
id = typeof id == 'number' ? id.toFixed() : id;
for (let info of BDFDB.readDmList()) if (info && info.id == id) return info;
return null;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.markChannelAsRead = function (channels) {
if (!channels) return;
2019-07-29 09:42:21 +02:00
var unreadchannels = [];
for (let cha of channels = Array.isArray(channels) ? channels : (typeof channels == "string" || typeof channels == "number" ? Array.of(channels) : Array.from(channels))) {
let id = Node.prototype.isPrototypeOf(cha) ? (BDFDB.getChannelID(cha) || BDFDB.getDmID(cha)) : cha && typeof cha == 'object' ? cha.id : cha;
if (id) unreadchannels.push(id);
2019-07-23 21:09:07 +02:00
}
2019-08-07 14:02:45 +02:00
if (unreadchannels.length > 0) LibraryModules.AckUtils.bulkAck(unreadchannels);
2019-07-23 21:09:07 +02:00
};
BDFDB.markGuildAsRead = function (servers) {
if (!servers) return;
2019-07-29 09:42:21 +02:00
var unreadchannels = [];
for (let server of Array.isArray(servers) ? servers : (typeof servers == "string" || typeof servers == "number" ? Array.of(servers) : Array.from(servers))) {
let id = Node.prototype.isPrototypeOf(server) ? BDFDB.getServerID(server) : server && typeof server == 'object' ? server.id : server;
2019-08-07 14:02:45 +02:00
let channels = id ? LibraryModules.GuildChannelStore.getChannels(id) : null;
2019-07-29 09:42:21 +02:00
if (channels) for (let type in channels) if (Array.isArray(channels[type])) for (let channelobj of channels[type]) unreadchannels.push(channelobj.channel.id);
}
2019-08-07 14:02:45 +02:00
if (unreadchannels.length > 0) LibraryModules.AckUtils.bulkAck(unreadchannels);
2019-07-23 21:09:07 +02:00
};
BDFDB.saveAllData = function (data, plugin, key) {
2019-09-06 12:21:54 +02:00
var configpath, plugname;
2019-07-23 21:09:07 +02:00
if (!BDFDB.isBDv2()) {
plugname = typeof plugin === 'string' ? plugin : plugin.name;
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
2019-07-23 21:09:07 +02:00
}
else {
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
if (!contentpath) return;
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
2019-07-23 21:09:07 +02:00
}
2019-09-06 12:21:54 +02:00
var exists = LibraryRequires.fs.existsSync(configpath);
2019-07-23 21:09:07 +02:00
var config = !exists ? {} : typeof BDFDB.cachedData[plugname] !== 'undefined' ? BDFDB.cachedData[plugname] : BDFDB.readConfig(configpath);
config[key] = data;
if (BDFDB.isObjectEmpty(config[key])) delete config[key];
if (BDFDB.isObjectEmpty(config)) {
delete BDFDB.cachedData[plugname];
2019-09-06 12:21:54 +02:00
if (exists) LibraryRequires.fs.unlinkSync(configpath);
2019-07-23 21:09:07 +02:00
}
else {
BDFDB.cachedData[plugname] = config;
2019-09-06 12:21:54 +02:00
LibraryRequires.fs.writeFileSync(configpath, JSON.stringify(config, null, ' '));
2019-07-23 21:09:07 +02:00
}
};
BDFDB.loadAllData = function (plugin, key) {
2019-09-06 12:21:54 +02:00
var configpath, plugname;
2019-07-23 21:09:07 +02:00
if (!BDFDB.isBDv2()) {
plugname = typeof plugin === 'string' ? plugin : plugin.name;
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
2019-07-23 21:09:07 +02:00
}
else {
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
if (!contentpath) return {};
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
2019-07-23 21:09:07 +02:00
}
2019-09-06 12:21:54 +02:00
if (!LibraryRequires.fs.existsSync(configpath)) {
2019-07-23 21:09:07 +02:00
delete BDFDB.cachedData[plugname];
return {};
}
var config = typeof BDFDB.cachedData[plugname] !== 'undefined' ? BDFDB.cachedData[plugname] : BDFDB.readConfig(configpath);
BDFDB.cachedData[plugname] = config;
return config && typeof config[key] !== 'undefined' ? config[key] : {};
};
BDFDB.removeAllData = function (plugin, key) {
2019-09-06 12:21:54 +02:00
var configpath, plugname;
2019-07-23 21:09:07 +02:00
if (!BDFDB.isBDv2()) {
plugname = typeof plugin === 'string' ? plugin : plugin.name;
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
2019-07-23 21:09:07 +02:00
}
else {
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
if (!contentpath) return;
2019-09-06 12:21:54 +02:00
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
2019-07-23 21:09:07 +02:00
}
2019-09-06 12:21:54 +02:00
var exists = LibraryRequires.fs.existsSync(configpath);
2019-07-23 21:09:07 +02:00
var config = !exists ? {} : typeof BDFDB.cachedData[plugname] !== 'undefined' ? BDFDB.cachedData[plugname] : BDFDB.readConfig(configpath);
delete config[key];
if (BDFDB.isObjectEmpty(config)) {
delete BDFDB.cachedData[plugname];
2019-09-06 12:21:54 +02:00
if (exists) LibraryRequires.fs.unlinkSync(configpath);
2019-07-23 21:09:07 +02:00
}
else {
BDFDB.cachedData[plugname] = config;
2019-09-06 12:21:54 +02:00
LibraryRequires.fs.writeFileSync(configpath, JSON.stringify(config, null, ' '));
2019-07-23 21:09:07 +02:00
}
};
BDFDB.getAllData = function (plugin, key) {
2019-09-14 16:57:33 +02:00
plugin = typeof plugin == "string" && BDFDB.isObject(window.BdApi) ? window.BdApi.getPlugin(plugin) : plugin;
2019-07-23 21:09:07 +02:00
if (!BDFDB.isObject(plugin) || !plugin.defaults || !plugin.defaults[key]) return {};
var oldconfig = BDFDB.loadAllData(plugin, key), newconfig = {}, update = false;
for (let k in plugin.defaults[key]) {
if (oldconfig[k] == null) {
2019-09-14 16:57:33 +02:00
newconfig[k] = BDFDB.isObject(plugin.defaults[key][k].value) ? BDFDB.deepAssign({}, plugin.defaults[key][k].value) : plugin.defaults[key][k].value;
2019-07-23 21:09:07 +02:00
update = true;
}
else newconfig[k] = oldconfig[k];
}
if (update) BDFDB.saveAllData(newconfig, plugin, key);
return newconfig;
};
BDFDB.readConfig = function (path) {
2019-09-06 12:21:54 +02:00
try {return JSON.parse(LibraryRequires.fs.readFileSync(path));}
2019-07-23 21:09:07 +02:00
catch (err) {return {};}
};
BDFDB.saveData = function (id, data, plugin, key) {
var config = BDFDB.loadAllData(plugin, key);
config[id] = data;
BDFDB.saveAllData(config, plugin, key);
};
BDFDB.loadData = function (id, plugin, key) {
var config = BDFDB.loadAllData(plugin, key);
var data = config[id];
return data === undefined ? null : data;
};
BDFDB.removeData = function (id, plugin, key) {
var config = BDFDB.loadAllData(plugin, key);
delete config[id];
BDFDB.saveAllData(config, plugin, key);
};
BDFDB.getData = function (id, plugin, key) {
var config = BDFDB.getAllData(plugin, key);
var data = config[id];
return data === undefined ? null : data;
};
BDFDB.appendWebScript = function (path, container) {
if (!container && !document.head.querySelector('bd-head bd-scripts')) document.head.appendChild(BDFDB.htmlToElement(`<bd-head><bd-scripts></bd-scripts></bd-head>`));
container = container || document.head.querySelector('bd-head bd-scripts') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeWebScript(path, container);
container.appendChild(BDFDB.htmlToElement(`<script src="${path}"></script>`));
};
BDFDB.removeWebScript = function (path, container) {
container = container || document.head.querySelector('bd-head bd-scripts') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeEles(container.querySelectorAll(`script[src="${path}"]`));
};
BDFDB.appendWebStyle = function (path, container) {
if (!container && !document.head.querySelector('bd-head bd-styles')) document.head.appendChild(BDFDB.htmlToElement(`<bd-head><bd-styles></bd-styles></bd-head>`));
container = container || document.head.querySelector('bd-head bd-styles') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeWebStyle(path, container);
container.appendChild(BDFDB.htmlToElement(`<link type="text/css" rel="Stylesheet" href="${path}"></link>`));
};
BDFDB.removeWebStyle = function (path, container) {
container = container || document.head.querySelector('bd-head bd-styles') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeEles(container.querySelectorAll(`link[href="${path}"]`));
};
BDFDB.appendLocalStyle = function (id, css, container) {
if (!container && !document.head.querySelector('bd-head bd-styles')) document.head.appendChild(BDFDB.htmlToElement(`<bd-head><bd-styles></bd-styles></bd-head>`));
container = container || document.head.querySelector('bd-head bd-styles') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeLocalStyle(id, container);
container.appendChild(BDFDB.htmlToElement(`<style id="${id}CSS">${css.replace(/\t|\r|\n/g,"")}</style>`));
};
BDFDB.removeLocalStyle = function (id, container) {
container = container || document.head.querySelector('bd-head bd-styles') || document.head;
container = Node.prototype.isPrototypeOf(container) ? container : document.head;
BDFDB.removeEles(container.querySelectorAll(`style[id="${id}CSS"]`));
};
BDFDB.formatBytes = function (bytes, sigdigits) {
bytes = parseInt(bytes);
if (isNaN(bytes) || bytes < 0) return '0 Bytes';
if (bytes == 1) return '1 Byte';
var size = Math.floor(Math.log(bytes) / Math.log(1024));
return parseFloat((bytes / Math.pow(1024, size)).toFixed(sigdigits < 1 ? 0 : sigdigits > 20 ? 20 : sigdigits || 2)) + ' ' + ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'][size];
};
BDFDB.colorCONVERT = function (color, conv, type) {
if (!color) return null;
conv = conv === undefined || !conv ? conv = 'RGBCOMP' : conv.toUpperCase();
type = type === undefined || !type || !['RGB', 'RGBA', 'RGBCOMP', 'HSL', 'HSLA', 'HSLCOMP'].includes(type.toUpperCase()) ? BDFDB.colorTYPE(color) : type.toUpperCase();
if (conv == 'RGBCOMP') {
switch (type) {
case 'RGBCOMP':
if (color.length == 3) return processRGB(color);
else if (color.length == 4) {
var a = processA(color.pop());
return processRGB(color).concat(a);
}
case 'RGB':
return processRGB(color.replace(/\s/g, '').slice(4, -1).split(','));
case 'RGBA':
var comp = color.replace(/\s/g, '').slice(5, -1).split(',');
var a = processA(comp.pop());
return processRGB(comp).concat(a);
case 'HSLCOMP':
if (color.length == 3) return BDFDB.colorCONVERT(`hsl(${color.join(',')})`, 'RGBCOMP');
else if (color.length == 4) {
var a = processA(jg.pop());
return BDFDB.colorCONVERT(`hsl(${jg.join(',')})`, 'RGBCOMP').concat(a);
}
case 'HSL':
var hslcomp = processHSL(color.replace(/\s/g, '').slice(4, -1).split(','));
var r, g, b, m, c, x, p, q;
var h = hslcomp[0] / 360, l = parseInt(hslcomp[1]) / 100, s = parseInt(hslcomp[2]) / 100; m = Math.floor(h * 6); c = h * 6 - m; x = s * (1 - l); p = s * (1 - c * l); q = s * (1 - (1 - c) * l);
switch (m % 6) {
case 0: r = s, g = q, b = x; break;
case 1: r = p, g = s, b = x; break;
case 2: r = x, g = s, b = q; break;
case 3: r = x, g = p, b = s; break;
case 4: r = q, g = x, b = s; break;
case 5: r = s, g = x, b = p; break;
}
return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)];
case 'HSLA':
var hslcomp = color.replace(/\s/g, '').slice(5, -1).split(',');
var a = processA(hslcomp.pop());
return BDFDB.colorCONVERT(`hsl(${hslcomp.join(',')})`, 'RGBCOMP').concat(a);
case 'HEX':
var hex = /^#([a-f\d]{1})([a-f\d]{1})([a-f\d]{1})$|^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(color);
return [parseInt(hex[1] + hex[1] || hex[4], 16).toString(), parseInt(hex[2] + hex[2] || hex[0x5], 16).toString(), parseInt(hex[3] + hex[3] || hex[6], 16).toString()];
default:
return null;
}
}
else {
var rgbcomp = type == 'RGBCOMP' ? color : BDFDB.colorCONVERT(color, 'RGBCOMP', type);
if (rgbcomp) switch (conv) {
case 'RGB':
return `rgb(${processRGB(rgbcomp.slice(0, 3)).join(',')})`;
case 'RGBA':
rgbcomp = rgbcomp.slice(0, 4);
var a = rgbcomp.length == 4 ? processA(rgbcomp.pop()) : 1;
return `rgba(${processRGB(rgbcomp).concat(a).join(',')})`;
case 'HSLCOMP':
var a = rgbcomp.length == 4 ? processA(rgbcomp.pop()) : null;
var hslcomp = processHSL(BDFDB.colorCONVERT(rgbcomp, 'HSL').replace(/\s/g, '').split(','));
return a ? hslcomp.concat(a) : hslcomp;
case 'HSL':
var r = processC(rgbcomp[0]), g = processC(rgbcomp[1]), b = processC(rgbcomp[2]);
var max = Math.max(r, g, b), min = Math.min(r, g, b), dif = max - min, h, l = max === 0 ? 0 : dif / max, s = max / 255;
switch (max) {
case min: h = 0; break;
case r: h = g - b + dif * (g < b ? 6 : 0); h /= 6 * dif; break;
case g: h = b - r + dif * 2; h /= 6 * dif; break;
case b: h = r - g + dif * 4; h /= 6 * dif; break;
}
return `hsl(${processHSL([Math.round(h * 360), l * 100, s * 100]).join(',')})`;
case 'HSLA':
var j0 = rgbcomp.length == 4 ? processA(rgbcomp.pop()) : 1;
return `hsla(${BDFDB.colorCONVERT(rgbcomp, 'HSL').slice(4, -1).split(',').concat(j0).join(',')})`;
case 'HEX':
return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1)).toUpperCase();
default:
return null;
}
}
function processC(c) {c = parseInt(c.toString().replace(/[^0-9\-]/g, ''));return isNaN(c) || c > 255 ? 255 : c < 0 ? 0 : c;};
function processRGB(comp) {return comp.map(c => {return processC(c);});};
function processA(a) {a = a.toString();a = (a.indexOf('%') > -1 ? 0.01 : 1) * parseFloat(a.replace(/[^0-9\.\-]/g, ''));return isNaN(a) || a > 1 ? 1 : a < 0 ? 0 : a;};
function processSL(sl) {sl = parseFloat(sl.toString().replace(/[^0-9\.\-]/g, ''));return (isNaN(sl) || sl > 100 ? 100 : sl < 0 ? 0 : sl) + '%';};
function processHSL(comp) {let h = parseFloat(comp.shift().toString().replace(/[^0-9\.\-]/g, ''));h = isNaN(h) || h > 360 ? 360 : h < 0 ? 0 : h;return [h].concat(comp.map(sl => {return processSL(sl);}));};
};
2019-08-17 13:18:49 +02:00
var setAlpha = (color, a, conv) => {
var comp = BDFDB.colorCONVERT(color, 'RGBCOMP');
if (comp) {
2019-07-23 21:09:07 +02:00
a = a.toString();
a = (a.indexOf('%') > -1 ? 0.01 : 1) * parseFloat(a.replace(/[^0-9\.\-]/g, ''));
a = isNaN(a) || a > 1 ? 1 : a < 0 ? 0 : a;
2019-08-17 13:18:49 +02:00
comp[3] = a;
2019-07-23 21:09:07 +02:00
conv = (conv || BDFDB.colorTYPE(color)).toUpperCase();
conv = conv == 'HSL' || conv == 'RGB' ? conv + 'A' : conv;
2019-08-17 13:18:49 +02:00
return BDFDB.colorCONVERT(comp, conv);
2019-07-23 21:09:07 +02:00
}
return null;
};
2019-08-17 13:18:49 +02:00
BDFDB.colorSETALPHA = function (color, a, conv) {
if (BDFDB.isObject(color)) {
var newcolor = {};
for (let pos in color) newcolor[pos] = setAlpha(color[pos], a, conv);
return newcolor;
}
else return setAlpha(color, a, conv);
};
2019-07-23 21:09:07 +02:00
2019-08-17 10:00:38 +02:00
var colorChange = (color, value, conv) => {
var comp = BDFDB.colorCONVERT(color, 'RGBCOMP');
if (comp) {
if (parseInt(value) !== value) {
value = value.toString();
value = (value.indexOf('%') > -1 ? 0.01 : 1) * parseFloat(value.replace(/[^0-9\.\-]/g, ''));
value = isNaN(value) ? 0 : value;
return BDFDB.colorCONVERT([Math.round(comp[0] * (1 + value)), Math.round(comp[1] * (1 + value)), Math.round(comp[2] * (1 + value))], conv || BDFDB.colorTYPE(color));
}
else return BDFDB.colorCONVERT([Math.round(comp[0] + value), Math.round(comp[1] + value), Math.round(comp[2] + value)], conv || BDFDB.colorTYPE(color));
}
return null;
};
2019-07-23 21:09:07 +02:00
BDFDB.colorCHANGE = function (color, value, conv) {
value = parseFloat(value);
if (color && typeof value == 'number' && !isNaN(value)) {
2019-08-17 10:00:38 +02:00
if (BDFDB.isObject(color)) {
var newcolor = {};
for (let pos in color) newcolor[pos] = colorChange(color[pos], value, conv);
return newcolor;
2019-07-23 21:09:07 +02:00
}
2019-08-17 10:00:38 +02:00
else return colorChange(color, value, conv);
2019-07-23 21:09:07 +02:00
}
return null;
};
BDFDB.colorINV = function (color, conv) {
if (color) {
var comp = BDFDB.colorCONVERT(color, 'RGBCOMP');
if (comp) return BDFDB.colorCONVERT([255 - comp[0], 255 - comp[1], 255 - comp[2]], conv || BDFDB.colorTYPE(color));
}
return null;
};
BDFDB.colorCOMPARE = function (color1, color2) {
if (color1 && color2) {
color1 = BDFDB.colorCONVERT(color1, 'RGBCOMP');
color2 = BDFDB.colorCONVERT(color2, 'RGBCOMP');
if (color1 && color2) return BDFDB.equals(color1, color2);
}
return null;
};
BDFDB.colorISBRIGHT = function (color, compare = 160) {
color = BDFDB.colorCONVERT(color, 'RGBCOMP');
if (!color) return false;
return parseInt(compare) < Math.sqrt(0.299 * color[0]**2 + 0.587 * color[1]**2 + 0.144 * color[2]**2);
};
BDFDB.colorTYPE = function (color) {
if (color) {
if (typeof color === 'object' && (color.length == 3 || color.length == 4)) {
if (isRGB(color)) return 'RGBCOMP';
else if (isHSL(color)) return 'HSLCOMP';
}
else if (typeof color === 'string') {
if (/^#[0-9a-f]{3}$|^#[0-9a-f]{6}$/i.test(color)) return 'HEX';
else {
color = color.toUpperCase();
var comp = color.replace(/[^0-9\.\-\,\%]/g, '').split(',');
if (color.indexOf('RGB(') == 0 && comp.length == 3 && isRGB(comp)) return 'RGB';
else if (color.indexOf('RGBA(') == 0 && comp.length == 4 && isRGB(comp)) return 'RGBA';
else if (color.indexOf('HSL(') == 0 && comp.length == 3 && isHSL(comp)) return 'HSL';
else if (color.indexOf('HSLA(') == 0 && comp.length == 4 && isHSL(comp)) return 'HSLA';
}
}
}
return null;
function isRGB(comp) {return comp.slice(0, 3).every(rgb => rgb.toString().indexOf('%') == -1 && parseFloat(rgb) == parseInt(rgb));};
function isHSL(comp) {return comp.slice(1, 3).every(hsl => hsl.toString().indexOf('%') == hsl.length - 1);};
};
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
BDFDB.colorGRADIENT = function (colorobj, direction = 'to right') {
var sortedgradient = {};
var gradientstring = 'linear-gradient(' + direction;
2019-08-17 13:18:49 +02:00
for (let pos of Object.keys(colorobj).sort()) gradientstring += `, ${colorobj[pos]} ${pos*100}%`
2019-08-17 10:00:38 +02:00
return gradientstring += ")";
};
2019-07-23 21:09:07 +02:00
2019-08-17 12:16:31 +02:00
BDFDB.setInnerText = function (node, stringOrNode) {
2019-07-23 21:09:07 +02:00
if (!node || !Node.prototype.isPrototypeOf(node)) return;
2019-08-17 12:16:31 +02:00
var textnode = node.nodeType == Node.TEXT_NODE ? node : null;
if (!textnode) for (let child of node.childNodes) if (child.nodeType == Node.TEXT_NODE || BDFDB.containsClass(child, "BDFDB-textnode")) {
2019-07-23 21:09:07 +02:00
textnode = child;
break;
}
2019-08-17 12:16:31 +02:00
if (textnode) {
if (Node.prototype.isPrototypeOf(stringOrNode) && stringOrNode.nodeType != Node.TEXT_NODE) {
BDFDB.addClass(stringOrNode, "BDFDB-textnode");
node.replaceChild(stringOrNode, textnode);
}
else if (Node.prototype.isPrototypeOf(textnode) && textnode.nodeType != Node.TEXT_NODE) node.replaceChild(document.createTextNode(stringOrNode), textnode);
else textnode.textContent = stringOrNode;
2019-07-23 21:09:07 +02:00
}
2019-08-17 12:16:31 +02:00
else node.appendChild(Node.prototype.isPrototypeOf(stringOrNode) ? stringOrNode : document.createTextNode(stringOrNode));
2019-07-23 21:09:07 +02:00
};
BDFDB.getInnerText = function (node) {
if (!node || !Node.prototype.isPrototypeOf(node)) return;
for (let child of node.childNodes) if (child.nodeType == Node.TEXT_NODE) return child.textContent;
};
BDFDB.getParentEle = function (listOrSelector, node) {
var parent = null;
if (Node.prototype.isPrototypeOf(node) && listOrSelector) {
var list = NodeList.prototype.isPrototypeOf(listOrSelector) ? listOrSelector : typeof listOrSelector == 'string' ? document.querySelectorAll(listOrSelector) : null;
if (list) for (let listnode of list) if (listnode.contains(node)) {
parent = listnode;
break;
}
}
return parent;
};
BDFDB.getRects = function (node) {
var rects = {};
if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) {
2019-08-22 13:42:28 +02:00
var hidenode = node;
while (hidenode) {
var hidden = BDFDB.isEleHidden(hidenode);
if (hidden) {
BDFDB.toggleEles(hidenode, true);
hidenode.BDFDBgetRectsHidden = true;
}
hidenode = hidenode.parentElement;
}
2019-07-23 21:09:07 +02:00
rects = node.getBoundingClientRect();
2019-08-22 13:42:28 +02:00
hidenode = node;
while (hidenode) {
if (hidenode.BDFDBgetRectsHidden) {
BDFDB.toggleEles(hidenode, false);
delete hidenode.BDFDBgetRectsHidden;
}
hidenode = hidenode.parentElement;
}
2019-07-23 21:09:07 +02:00
}
return rects;
};
BDFDB.getTotalHeight = function (node) {
if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) {
var rects = BDFDB.getRects(node);
var style = getComputedStyle(node);
return rects.height + parseInt(style.marginTop) + parseInt(style.marginBottom);
}
return 0;
};
BDFDB.getTotalWidth = function (node) {
if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) {
var rects = BDFDB.getRects(node);
var style = getComputedStyle(node);
return rects.width + parseInt(style.marginLeft) + parseInt(style.marginRight);
}
return 0;
};
BDFDB.isEleHidden = function (node) {
if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) return getComputedStyle(node, null).getPropertyValue('display') == 'none';
};
BDFDB.toggleEles = function (...eles) {
if (!eles) return;
var force = eles.pop();
if (typeof force != 'boolean') {
eles.push(force);
force = undefined;
}
if (!eles.length) return;
for (let ele of eles) for (let e of Array.isArray(ele) ? ele : Array.of(ele)) {
if (!e) {}
else if (Node.prototype.isPrototypeOf(e)) toggle(e);
else if (NodeList.prototype.isPrototypeOf(e)) for (let n of e) toggle(n);
else if (typeof e == 'string') for (let c of e.split(',')) if (c && (c = c.trim())) for (let n of document.querySelectorAll(c)) toggle(n);
}
function toggle(node) {
if (!node || !Node.prototype.isPrototypeOf(node)) return;
var hidden = force === undefined ? !BDFDB.isEleHidden(node) : !force;
if (hidden) node.style.setProperty('display', 'none', 'important');
else node.style.removeProperty('display');
}
};
BDFDB.removeEles = function (...eles) {
for (let ele of eles) for (let e of Array.isArray(ele) ? ele : Array.of(ele)) {
if (!e) {}
else if (Node.prototype.isPrototypeOf(e)) e.remove();
else if (NodeList.prototype.isPrototypeOf(e)) {
e = Array.from(e);
while (e.length) e.shift().remove();
}
else if (typeof e == 'string') for (let c of e.split(',')) if (c && (c = c.trim())) {
let n = Array.from(document.querySelectorAll(c));
while (n.length) n.shift().remove();
}
}
};
BDFDB.addClass = function (eles, ...classes) {
if (!eles || !classes) return;
for (let ele of Array.isArray(eles) ? eles : Array.of(eles)) {
if (!ele) {}
else if (Node.prototype.isPrototypeOf(ele)) add(ele);
else if (NodeList.prototype.isPrototypeOf(ele)) for (let e of ele) add(e);
else if (typeof ele == 'string') for (let e of ele.split(',')) if (e && (e = e.trim())) for (let n of document.querySelectorAll(e)) add(n);
}
function add(node) {
if (node && node.classList) for (let cla of classes) for (let cl of Array.isArray(cla) ? cla : Array.of(cla)) if (typeof cl == 'string') for (let c of cl.split(' ')) if (c) node.classList.add(c);
}
};
BDFDB.removeClass = function (eles, ...classes) {
if (!eles || !classes) return;
for (let ele of Array.isArray(eles) ? eles : Array.of(eles)) {
if (!ele) {}
else if (Node.prototype.isPrototypeOf(ele)) remove(ele);
else if (NodeList.prototype.isPrototypeOf(ele)) for (let e of ele) remove(e);
else if (typeof ele == 'string') for (let e of ele.split(',')) if (e && (e = e.trim())) for (let n of document.querySelectorAll(e)) remove(n);
}
function remove(node) {
if (node && node.classList) for (let cla of classes) for (let cl of Array.isArray(cla) ? cla : Array.of(cla)) if (typeof cl == 'string') for (let c of cl.split(' ')) if (c) node.classList.remove(c);
}
};
BDFDB.toggleClass = function (eles, ...classes) {
if (!eles || !classes) return;
var force = classes.pop();
if (typeof force != 'boolean') {
classes.push(force);
force = undefined;
}
if (!classes.length) return;
for (let ele of Array.isArray(eles) ? eles : Array.of(eles)) {
if (!ele) {}
else if (Node.prototype.isPrototypeOf(ele)) toggle(ele);
else if (NodeList.prototype.isPrototypeOf(ele)) for (let e of ele) toggle(e);
else if (typeof ele == 'string') for (let e of ele.split(',')) if (e && (e = e.trim())) for (let n of document.querySelectorAll(e)) toggle(n);
}
function toggle(node) {
if (node && node.classList) for (let cla of classes) for (let cl of Array.isArray(cla) ? cla : Array.of(cla)) if (typeof cl == 'string') for (let c of cl.split(' ')) if (c) node.classList.toggle(c, force);
}
};
BDFDB.containsClass = function (eles, ...classes) {
if (!eles || !classes) return;
var all = classes.pop();
if (typeof all != 'boolean') {
classes.push(all);
all = true;
}
if (!classes.length) return;
var contained = undefined;
for (let ele of Array.isArray(eles) ? eles : Array.of(eles)) {
if (!ele) {}
else if (Node.prototype.isPrototypeOf(ele)) contains(ele);
else if (NodeList.prototype.isPrototypeOf(ele)) for (let e of ele) contains(e);
else if (typeof ele == 'string') for (let c of ele.split(',')) if (c && (c = c.trim())) for (let n of document.querySelectorAll(c)) contains(n);
}
return contained;
function contains(node) {
if (node && node.classList) for (let cla of classes) if (typeof cla == 'string') for (let c of cla.split(' ')) if (c) {
if (contained === undefined) contained = all;
if (all && !node.classList.contains(c)) contained = false;
if (!all && node.classList.contains(c)) contained = true;
}
}
};
BDFDB.replaceClass = function (eles, oldclass, newclass) {
if (!eles || typeof oldclass != "string" || typeof newclass != "string") return;
for (let ele of Array.isArray(eles) ? eles : Array.of(eles)) {
if (!ele) {}
else if (Node.prototype.isPrototypeOf(ele)) replace(ele);
else if (NodeList.prototype.isPrototypeOf(ele)) for (let e of ele) replace(e);
else if (typeof ele == 'string') for (let e of ele.split(',')) if (e && (e = e.trim())) for (let n of document.querySelectorAll(e)) replace(n);
}
function replace(node) {
if (node && node.tagName && node.className) node.className = node.className.replace(new RegExp(oldclass, "g"), newclass).trim();
}
};
BDFDB.removeClasses = function (...classes) {
for (let cla of classes) for (let c of Array.isArray(cla) ? cla : Array.of(cla)) {
if (!c) {}
else if (typeof c == 'string') for (let a of c.split(',')) if (a && (a = a.replace(/\.|\s/g, ''))) BDFDB.removeClass(document.querySelectorAll('.' + a), a);
}
};
BDFDB.htmlToElement = function (html) {
if (!html || !html.trim()) return null;
let template = document.createElement('template');
2019-08-31 08:13:30 +02:00
try {template.innerHTML = html.replace(/(?<!pre)>[\t\r\n]+<(?!pre)/g, "><");}
catch (err) {template.innerHTML = html.replace(/>[\t\r\n]+<(?!pre)/g, "><");}
2019-07-23 21:09:07 +02:00
if (template.content.childElementCount == 1) return template.content.firstElementChild;
else {
var wrapper = document.createElement("span");
var nodes = Array.from(template.content.childNodes);
while (nodes.length) wrapper.appendChild(nodes.shift());
return wrapper;
}
};
BDFDB.encodeToHTML = function (string) {
var ele = document.createElement('div');
ele.innerText = string;
return ele.innerHTML;
};
BDFDB.regEscape = function (string) {
return string.replace(/([\-\/\\\^\$\*\+\?\.\(\)\|\[\]\{\}])/g, '\\$1');
};
BDFDB.insertNRST = function (string) {
return string.replace(/\\r/g, '\r').replace(/\\n/g, '\n').replace(/\\t/g, '\t').replace(/\\s/g, ' ');
};
BDFDB.triggerSend = function (textarea) {
if (!textarea) return;
setImmediate(() => {
var e = new KeyboardEvent('keypress', {key:'Enter', code:'Enter', which:13, keyCode:13, bubbles:true });
Object.defineProperty(e, 'keyCode', {value:13});
Object.defineProperty(e, 'which', {value:13});
textarea.dispatchEvent(e);
});
};
BDFDB.initElements = function (container, plugin) {
if (!Node.prototype.isPrototypeOf(container)) return;
var islighttheme = BDFDB.getDiscordTheme() == BDFDB.disCN.themelight;
var languagestrings = BDFDB.getLibraryStrings();
2019-08-22 11:58:19 +02:00
container.querySelectorAll(".BDFDB-containertext").forEach(ele => {
if (BDFDB.containsClass(ele.nextElementSibling, "BDFDB-collapsecontainer")) {
if (BDFDB.containsClass(ele.firstElementChild, "closed")) BDFDB.toggleEles(ele.nextElementSibling, false);
2019-08-22 13:44:49 +02:00
ele.BDFDBupdateElement = () => {
2019-08-22 11:58:19 +02:00
BDFDB.toggleEles(ele.nextElementSibling, BDFDB.containsClass(ele.firstElementChild, "closed"));
BDFDB.toggleClass(ele.firstElementChild, "closed");
2019-08-22 13:42:28 +02:00
};
2019-08-22 13:44:49 +02:00
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
2019-08-22 11:38:34 +02:00
}
});
2019-07-23 21:09:07 +02:00
container.querySelectorAll(BDFDB.dotCN.switchinner).forEach(ele => {
setSwitch(ele, false);
2019-08-22 13:44:49 +02:00
ele.BDFDBupdateElement = () => {
2019-07-23 21:09:07 +02:00
setSwitch(ele, true);
2019-08-22 13:42:28 +02:00
};
2019-08-22 13:44:49 +02:00
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
2019-07-23 21:09:07 +02:00
});
container.querySelectorAll(BDFDB.dotCNS.checkboxwrapper + BDFDB.dotCN.checkboxinput).forEach(ele => {
2019-08-22 13:42:28 +02:00
setCheckbox(ele);
2019-08-22 13:44:49 +02:00
ele.BDFDBupdateElement = () => {
2019-08-22 13:42:28 +02:00
setCheckbox(ele);
};
2019-08-22 13:44:49 +02:00
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
2019-07-23 21:09:07 +02:00
});
container.querySelectorAll(BDFDB.dotCN.giffavoritebutton).forEach(ele => {
setGifFavButton(ele);
2019-08-22 13:44:49 +02:00
ele.BDFDBupdateElement = () => {
2019-07-23 21:09:07 +02:00
BDFDB.toggleClass(ele, BDFDB.disCN.giffavoriteselected);
setGifFavButton(ele);
2019-08-22 13:42:28 +02:00
};
2019-08-22 13:44:49 +02:00
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
2019-07-23 21:09:07 +02:00
});
container.querySelectorAll('.file-navigator').forEach(ele => {
2019-08-22 13:44:49 +02:00
ele.BDFDBupdateElement = () => {
2019-07-23 21:09:07 +02:00
var input = ele.querySelector('input[type="file"]');
if (input) input.click();
2019-08-22 13:42:28 +02:00
};
2019-08-22 13:44:49 +02:00
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
2019-07-23 21:09:07 +02:00
});
container.querySelectorAll('input[type="file"]').forEach(ele => {
addInitEventListener(ele, 'change', e => {
var input = ele.parentElement.parentElement.querySelector('input[type="text"]');
var file = ele.files[0];
if (input && file)
input.value = file.path;
});
});
container.querySelectorAll(BDFDB.dotCN.input).forEach(ele => {
addInitEventListener(ele, 'keydown', e => {
e.stopPropagation();
});
});
container.querySelectorAll(BDFDB.dotCNS.searchbar + BDFDB.dotCN.searchbarinput).forEach(ele => {
ele.setAttribute('placeholder', languagestrings.search_placeholder);
addInitEventListener(ele, 'keyup', e => {
let icons = ele.parentElement.querySelectorAll(BDFDB.dotCN.searchbaricon);
BDFDB.toggleClass(icons[0], BDFDB.disCN.searchbarvisible, ele.value.length == 0);
BDFDB.toggleClass(icons[1], BDFDB.disCN.searchbarvisible, ele.value.length > 0);
});
});
container.querySelectorAll(BDFDB.dotCNS.searchbar + BDFDB.dotCN.searchbarclear).forEach(ele => {
addInitEventListener(ele, 'click', e => {
if (BDFDB.containsClass(ele, BDFDB.disCN.searchbarvisible)) {
var input = BDFDB.getParentEle(BDFDB.dotCN.searchbar, ele).querySelector(BDFDB.dotCN.searchbarinput);
input.value = '';
input.dispatchEvent(new Event('change'));
input.dispatchEvent(new Event('input'));
input.dispatchEvent(new Event('keydown'));
input.dispatchEvent(new Event('keyup'));
input.dispatchEvent(new Event('keypressed'));
BDFDB.addClass(ele.parentElement.querySelectorAll(BDFDB.dotCN.searchbaricon)[0], BDFDB.disCN.searchbarvisible);
BDFDB.removeClass(ele, BDFDB.disCN.searchbarvisible);
}
});
});
container.querySelectorAll('.numberinput-button-up').forEach(ele => {
addInitEventListener(ele, 'click', e => {
var input = ele.parentElement.parentElement.querySelector('input');
var min = parseInt(input.getAttribute('min'));
var max = parseInt(input.getAttribute('max'));
var newv = parseInt(input.value) + 1;
if (isNaN(max) || !isNaN(max) && newv <= max) {
BDFDB.addClass(ele.parentElement, 'pressed');
clearTimeout(ele.parentElement.pressedTimeout);
input.value = isNaN(min) || !isNaN(min) && newv >= min ? newv : min;
input.dispatchEvent(new Event('change'));
input.dispatchEvent(new Event('input'));
input.dispatchEvent(new Event('keydown'));
input.dispatchEvent(new Event('keyup'));
input.dispatchEvent(new Event('keypressed'));
ele.parentElement.pressedTimeout = setTimeout(() => {BDFDB.removeClass(ele.parentElement, 'pressed');}, 3000);
}
});
});
container.querySelectorAll('.numberinput-button-down').forEach(ele => {
addInitEventListener(ele, 'click', e => {
var input = ele.parentElement.parentElement.querySelector('input');
var min = parseInt(input.getAttribute('min'));
var max = parseInt(input.getAttribute('max'));
var newv = parseInt(input.value) - 1;
if (isNaN(min) || !isNaN(min) && newv >= min) {
BDFDB.addClass(ele.parentElement, 'pressed');
clearTimeout(ele.parentElement.pressedTimeout);
input.value = isNaN(max) || !isNaN(max) && newv <= max ? newv : max;
input.dispatchEvent(new Event('change'));
input.dispatchEvent(new Event('input'));
input.dispatchEvent(new Event('keydown'));
input.dispatchEvent(new Event('keyup'));
input.dispatchEvent(new Event('keypressed'));
ele.parentElement.pressedTimeout = setTimeout(() => {BDFDB.removeClass(ele.parentElement, 'pressed');}, 3000);
}
});
});
container.querySelectorAll('.amount-input').forEach(ele => {
addInitEventListener(ele, 'input', e => {
if (BDFDB.isObject(plugin)) {
var option = ele.getAttribute("option");
var newv = parseInt(ele.value);
var min = parseInt(ele.getAttribute('min'));
var max = parseInt(ele.getAttribute('max'));
if (option && !isNaN(newv) && (isNaN(min) || !isNaN(min) && newv >= min) && (isNaN(max) || !isNaN(max) && newv <= max)) {
BDFDB.saveData(option, newv, plugin, "amounts");
plugin.SettingsUpdated = true;
}
}
});
});
container.querySelectorAll(BDFDB.dotCNC.tabbaritem + BDFDB.dotCN.tabbarheaderitem).forEach(ele => {
setTabitem(ele, ele.parentElement.querySelector(BDFDB.dotCNC.tabbaritem + BDFDB.dotCN.tabbarheaderitem) == ele ? 2 : 0);
addInitEventListener(ele, 'click', e => {
BDFDB.removeClass(container.querySelectorAll('.tab-content.open'), 'open');
ele.parentElement.querySelectorAll(BDFDB.dotCNC.tabbaritem + BDFDB.dotCN.tabbarheaderitem).forEach(ele => {setTabitem(ele, 0);});
var tab = container.querySelector(`.tab-content[tab="${ele.getAttribute('tab')}"]`);
if (tab) BDFDB.addClass(tab, 'open');
setTabitem(ele, 2);
});
addInitEventListener(ele, 'mouseenter', e => {
if (!BDFDB.containsClass(ele, BDFDB.disCN.settingsitemselected)) setTabitem(ele, 1);
});
addInitEventListener(ele, 'mouseleave', e => {
if (!BDFDB.containsClass(ele, BDFDB.disCN.settingsitemselected)) setTabitem(ele, 0);
});
});
2019-09-08 23:46:48 +02:00
container.querySelectorAll('.BDFDB-contextMenuItem ' + BDFDB.dotCN.contextmenulabel).forEach(ele => {
BDFDB.addClass(ele, 'BDFDB-textscrollwrapper');
ele.setAttribute('speed', 3);
ele.innerHTML = `<div class="BDFDB-textscroll">${BDFDB.encodeToHTML(ele.innerText)}</div>`;
});
container.querySelectorAll('.BDFDB-contextMenuItem ' + BDFDB.dotCN.contextmenuhint).forEach(ele => {
2019-09-09 13:42:17 +02:00
if (ele.innerText) {
ele.innerHTML = `<div class="BDFDB-textscrollwrapper" speed=3><div class="BDFDB-textscroll">${BDFDB.encodeToHTML(ele.innerText)}</div></div>`;
ele.style.setProperty('top', getComputedStyle(ele.parentElement).paddingTop, 'important');
ele.style.setProperty('right', getComputedStyle(ele.parentElement).paddingRight, 'important');
ele.style.setProperty('width', '42px', 'important');
ele.style.setProperty('max-width', '42px', 'important');
2019-09-11 00:35:53 +02:00
ele.style.setProperty('margin-left', '8px', 'important');
2019-09-09 13:42:17 +02:00
}
2019-09-08 23:46:48 +02:00
});
2019-07-23 21:09:07 +02:00
container.querySelectorAll('.BDFDB-textscrollwrapper').forEach(ele => {
var inner = ele.querySelector('.BDFDB-textscroll');
if (inner) {
if (BDFDB.containsClass(ele.parentElement, BDFDB.disCN.contextmenuitemsubmenu)) ele.style.setProperty('margin-right', '10px');
if (BDFDB.getRects(ele).width > 100) ele.style.setProperty('text-overflow', 'ellipsis', 'important');
ele.style.setProperty('position', 'relative', 'important');
ele.style.setProperty('display', 'block', 'important');
ele.style.setProperty('overflow', 'hidden', 'important');
inner.style.setProperty('left', '0px', 'important');
inner.style.setProperty('position', 'relative', 'important');
inner.style.setProperty('white-space', 'nowrap', 'important');
inner.style.setProperty('display', 'inline', 'important');
var animate, Animation;
addInitEventListener(ele, 'mouseenter', e => {
if (BDFDB.getRects(ele).width < BDFDB.getRects(inner).width) {
BDFDB.addClass(ele, 'scrolling');
if (!Animation || !animate) initAnimation();
animate(1);
inner.style.setProperty('display', 'block', 'important');
}
});
addInitEventListener(ele, 'mouseleave', e => {
if (BDFDB.containsClass(ele, 'scrolling')) {
BDFDB.removeClass(ele, 'scrolling');
inner.style.setProperty('display', 'inline', 'important');
if (!Animation || !animate) initAnimation();
animate(0);
}
});
function initAnimation() {
2019-09-05 12:33:55 +02:00
Animation = new LibraryModules.AnimationUtils.Value(0);
2019-07-23 21:09:07 +02:00
Animation
.interpolate({inputRange:[0, 1], outputRange:[0, (BDFDB.getRects(inner).width - BDFDB.getRects(ele).width) * -1]})
.addListener(v => {inner.style.setProperty('left', v.value + 'px', 'important');});
animate = p => {
var w = p + parseFloat(inner.style.getPropertyValue('left')) / (BDFDB.getRects(inner).width - BDFDB.getRects(ele).width);
w = isNaN(w) || !isFinite(w) ? p : w;
w *= BDFDB.getRects(inner).width / (BDFDB.getRects(ele).width * 2);
2019-09-05 12:33:55 +02:00
LibraryModules.AnimationUtils.parallel([LibraryModules.AnimationUtils.timing(Animation, {toValue:p, duration:Math.sqrt(w**2) * 4000 / (ele.getAttribute('speed') || 1)})]).start();
2019-07-23 21:09:07 +02:00
};
}
}
});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.removeClass(container.querySelectorAll('.tab-content'), 'open');
BDFDB.addClass(container.querySelector('.tab-content'), 'open');
2019-09-04 12:34:02 +02:00
2019-09-09 15:53:29 +02:00
container.querySelectorAll('.btn-save ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.SAVE;});
container.querySelectorAll('.btn-cancel ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.CANCEL;});
container.querySelectorAll('.btn-add ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.ADD;});
container.querySelectorAll('.btn-ok ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.OKAY;});
2019-07-23 21:09:07 +02:00
container.querySelectorAll('.btn-all ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = languagestrings.btn_all_text;});
container.querySelectorAll('.file-navigator ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = languagestrings.file_navigator_text;});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
if (islighttheme) {
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectcontroldark), BDFDB.disCN.selectcontroldark, BDFDB.disCN.selectcontrollight);
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectsingledark), BDFDB.disCN.selectsingledark, BDFDB.disCN.selectsinglelight);
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectarrowcontainerdark), BDFDB.disCN.selectarrowcontainerdark, BDFDB.disCN.selectarrowcontainerlight);
}
else {
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectcontrollight), BDFDB.disCN.selectcontrollight, BDFDB.disCN.selectcontroldark);
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectsinglelight), BDFDB.disCN.selectsinglelight, BDFDB.disCN.selectsingledark);
BDFDB.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectarrowcontainerlight), BDFDB.disCN.selectarrowcontainerlight, BDFDB.disCN.selectarrowcontainerdark);
}
2019-09-04 12:34:02 +02:00
2019-08-21 16:55:38 +02:00
var executeDelayedIfNotAppened = () => {
container.querySelectorAll('.BDFDB-tableheader').forEach(ele => {
var panel = BDFDB.getParentEle('.BDFDB-modal, .BDFDB-settings', ele);
2019-08-22 09:50:53 +02:00
var tableid = ele.getAttribute('table-id');
2019-08-21 16:55:38 +02:00
var text = ele.querySelector('.BDFDB-tableheadertext');
2019-08-22 14:14:46 +02:00
var columns = ele.querySelectorAll('.BDFDB-tableheadercolumns .BDFDB-tableheadercolumn');
2019-08-22 09:50:53 +02:00
if (panel && tableid && text && columns.length) {
2019-09-14 16:57:33 +02:00
let maxwidth = BDFDB.isObject(panel['BDFDB-tableheader-maxwidth']) ? panel['BDFDB-tableheader-maxwidth'][tableid] : 0;
2019-09-13 12:05:32 +02:00
if (!maxwidth) {
for (let column of columns) {
let width = BDFDB.getRects(column).width;
maxwidth = width > maxwidth ? width : maxwidth;
}
maxwidth += 4;
2019-08-21 16:55:38 +02:00
}
for (let column of columns) {
column.style.setProperty('flex', `0 0 ${maxwidth}px`, 'important');
column.style.setProperty('text-align', 'center', 'important');
}
2019-08-21 17:04:51 +02:00
text.style.setProperty('flex', `0 0 ${556 - (columns.length * maxwidth)}px`, 'important');
2019-08-21 16:55:38 +02:00
columns[0].parentElement.style.setProperty('flex', `0 0 ${columns.length * maxwidth}px`, 'important');
2019-08-22 09:50:53 +02:00
if (!BDFDB.isObject(panel['BDFDB-tableheader-maxwidth'])) panel['BDFDB-tableheader-maxwidth'] = {}
panel['BDFDB-tableheader-maxwidth'][tableid] = maxwidth;
2019-08-21 16:55:38 +02:00
}
});
container.querySelectorAll('.BDFDB-tablecheckbox').forEach(ele => {
var panel = BDFDB.getParentEle('.BDFDB-modal, .BDFDB-settings', ele);
2019-08-22 09:50:53 +02:00
var tableid = ele.getAttribute('table-id');
if (panel && tableid && BDFDB.isObject(panel['BDFDB-tableheader-maxwidth']) && panel['BDFDB-tableheader-maxwidth'][tableid]) {
2019-08-21 16:55:38 +02:00
var style = getComputedStyle(ele);
2019-09-07 22:17:22 +02:00
ele.style.setProperty('flex', `0 0 ${panel['BDFDB-tableheader-maxwidth'][tableid] - parseInt(style.marginLeft) - parseInt(style.marginRight)}px`, 'important');
2019-08-21 16:55:38 +02:00
}
});
};
2019-09-04 12:34:02 +02:00
2019-08-21 16:55:38 +02:00
if (document.contains(container)) executeDelayedIfNotAppened();
else setImmediate(() => {executeDelayedIfNotAppened();});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
function setSwitch(switchitem, triggered) {
var checked = switchitem.checked;
BDFDB.toggleClass(switchitem.parentElement, BDFDB.disCN.switchvaluechecked, checked);
BDFDB.toggleClass(switchitem.parentElement, BDFDB.disCN.switchvalueunchecked, !checked);
if (triggered && BDFDB.isObject(plugin) && BDFDB.containsClass(switchitem, 'settings-switch')) {
let keys = switchitem.getAttribute('value').trim().split(' ').filter(n => n);
let option = keys.shift();
if (option) {
var data = BDFDB.loadAllData(plugin, option);
var newdata = '';
for (let key of keys) newdata += `{"${key}":`;
newdata += checked + '}'.repeat(keys.length);
newdata = JSON.parse(newdata);
if (BDFDB.isObject(newdata)) BDFDB.deepAssign(data, newdata);
else data = newdata;
BDFDB.saveAllData(data, plugin, option);
plugin.SettingsUpdated = true;
}
}
};
function setCheckbox(checkbox) {
var checkboxstyle = checkbox.parentElement.querySelector(BDFDB.dotCN.checkbox);
var checkboxstyleinner = checkboxstyle.querySelector('polyline');
if (checkbox.checked) {
BDFDB.addClass(checkboxstyle, BDFDB.disCN.checkboxchecked);
checkboxstyle.style.setProperty('background-color', 'rgb(67, 181, 129)');
checkboxstyle.style.setProperty('border-color', 'rgb(67, 181, 129)');
checkboxstyleinner.setAttribute('stroke', '#ffffff');
}
else {
BDFDB.removeClass(checkboxstyle, BDFDB.disCN.checkboxchecked);
checkboxstyle.style.removeProperty('background-color');
checkboxstyle.style.removeProperty('border-color');
checkboxstyleinner.setAttribute('stroke', 'transparent');
}
};
function setGifFavButton(button) {
var selected = BDFDB.containsClass(button, BDFDB.disCN.giffavoriteselected);
var icon = button.querySelector(BDFDB.dotCN.giffavoriteicon);
icon.setAttribute('name', selected ? 'FavoriteFilled' : 'Favorite');
icon.innerHTML = selected ? '<path d="M0,0H24V24H0Z" fill="none"></path><path fill="currentColor" d="M12.5,17.6l3.6,2.2a1,1,0,0,0,1.5-1.1l-1-4.1a1,1,0,0,1,.3-1l3.2-2.8A1,1,0,0,0,19.5,9l-4.2-.4a.87.87,0,0,1-.8-.6L12.9,4.1a1.05,1.05,0,0,0-1.9,0l-1.6,4a1,1,0,0,1-.8.6L4.4,9a1.06,1.06,0,0,0-.6,1.8L7,13.6a.91.91,0,0,1,.3,1l-1,4.1a1,1,0,0,0,1.5,1.1l3.6-2.2A1.08,1.08,0,0,1,12.5,17.6Z"></path>' : '<path fill="currentColor" d="M19.6,9l-4.2-0.4c-0.4,0-0.7-0.3-0.8-0.6l-1.6-3.9c-0.3-0.8-1.5-0.8-1.8,0L9.4,8.1C9.3,8.4,9,8.6,8.6,8.7L4.4,9c-0.9,0.1-1.2,1.2-0.6,1.8L7,13.6c0.3,0.2,0.4,0.6,0.3,1l-1,4.1c-0.2,0.9,0.7,1.5,1.5,1.1l3.6-2.2c0.3-0.2,0.7-0.2,1,0l3.6,2.2c0.8,0.5,1.7-0.2,1.5-1.1l-1-4.1c-0.1-0.4,0-0.7,0.3-1l3.2-2.8C20.9,10.2,20.5,9.1,19.6,9zM12,15.4l-3.8,2.3l1-4.3l-3.3-2.9l4.4-0.4l1.7-4l1.7,4l4.4,0.4l-3.3,2.9l1,4.3L12,15.4z"></path>';
if (selected) {
BDFDB.addClass(button, BDFDB.disCN.giffavoriteshowpulse);
setTimeout(() => {BDFDB.removeClass(button, BDFDB.disCN.giffavoriteshowpulse);}, 500);
}
};
function setTabitem(item, state) {
switch (state) {
case 0:
BDFDB.removeClass(item, BDFDB.disCN.settingsitemselected);
item.style.setProperty('border-color', 'transparent');
item.style.setProperty('color', islighttheme ? 'rgba(79, 84, 92, 0.4)' : 'rgba(255, 255, 255, 0.4)');
break;
case 1:
BDFDB.removeClass(item, BDFDB.disCN.settingsitemselected);
item.style.setProperty('border-color', islighttheme ? 'rgba(79, 84, 92, 0.6)' : 'rgba(255, 255, 255, 0.6)');
item.style.setProperty('color', islighttheme ? 'rgba(79, 84, 92, 0.6)' : 'rgba(255, 255, 255, 0.6)');
break;
case 2:
BDFDB.addClass(item, BDFDB.disCN.settingsitemselected);
item.style.setProperty('border-color', islighttheme ? 'rgb(79, 84, 92)' : 'rgb(255, 255, 255)');
item.style.setProperty('color', islighttheme ? 'rgb(79, 84, 92)' : 'rgb(255, 255, 255)');
break;
}
};
function addInitEventListener(ele, action, callback) {
2019-08-22 13:44:49 +02:00
if (!ele.BDFDBupdateElementsListeners) ele.BDFDBupdateElementsListeners = {};
if (ele.BDFDBupdateElementsListeners[action]) ele.removeEventListener(action, ele.BDFDBupdateElementsListeners[action]);
ele.BDFDBupdateElementsListeners[action] = callback;
2019-07-23 21:09:07 +02:00
ele.addEventListener(action, callback, true);
};
};
BDFDB.appendModal = function (modalwrapper) {
if (!Node.prototype.isPrototypeOf(modalwrapper)) return;
2019-09-09 13:44:23 +02:00
if (!BDFDB.appendModal.modals || !document.contains(BDFDB.appendModal.modals)) BDFDB.appendModal.modals = BDFDB.React.findDOMNodeSafe(BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.app), name:"Modals", depth:99999999, time:99999999}));
2019-07-23 21:09:07 +02:00
if (!BDFDB.appendModal.modals) return;
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var modal = BDFDB.containsClass(modalwrapper, BDFDB.disCN.modal) ? modalwrapper : modalwrapper.querySelector(BDFDB.dotCN.modal);
2019-08-29 10:12:51 +02:00
var backdrop = modal ? modal.previousElementSibling : null;
2019-09-04 12:34:02 +02:00
2019-09-05 12:33:55 +02:00
var modalOpacity = new LibraryModules.AnimationUtils.Value(0);
2019-07-23 21:09:07 +02:00
modalOpacity
.interpolate({inputRange: [0, 1], outputRange: [0, 1]})
.addListener((value) => {if (modal) modal.style.setProperty("opacity", `${value.value}`);});
2019-09-05 12:33:55 +02:00
var modalTransform = new LibraryModules.AnimationUtils.Value(0);
2019-07-23 21:09:07 +02:00
modalTransform
.interpolate({inputRange: [0, 1], outputRange: [0.7, 1]})
.addListener((value) => {if (modal) modal.style.setProperty("transform", `scale(${value.value}) translateZ(0px)`);});
2019-09-05 12:33:55 +02:00
var backdropOpacity = new LibraryModules.AnimationUtils.Value(0);
2019-07-23 21:09:07 +02:00
backdropOpacity
.interpolate({inputRange: [0, 1], outputRange: [0, 0.85]})
.addListener((value) => {if (backdrop) {
backdrop.style.setProperty("opacity", `${value.value}`);
backdrop.style.setProperty("background-color", "rgb(0, 0, 0)");
backdrop.style.setProperty("z-index", "1000");
backdrop.style.setProperty("transform", "translateZ(0px)");
}});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var animate = (v) => {
2019-09-05 12:33:55 +02:00
LibraryModules.AnimationUtils.parallel([
LibraryModules.AnimationUtils.timing(modalOpacity, {toValue: v, duration: 250, easing: LibraryModules.AnimationUtils.Easing.inOut(LibraryModules.AnimationUtils.Easing.ease)}),
LibraryModules.AnimationUtils.timing(modalTransform, {toValue: v, duration: 250, easing: LibraryModules.AnimationUtils.Easing.inOut(LibraryModules.AnimationUtils.Easing.ease)}),
LibraryModules.AnimationUtils.timing(backdropOpacity, {toValue: v, duration: 200, delay:50}),
2019-07-23 21:09:07 +02:00
]).start();
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var keydown = e => {
if (!document.contains(modalwrapper)) document.removeEventListener('keydown', keydown);
else if (e.which == 27 && backdrop) backdrop.click();
};
document.addEventListener('keydown', keydown);
BDFDB.addChildEventListener(modalwrapper, 'click', BDFDB.dotCNC.backdrop + BDFDB.dotCNC.modalclose + '.btn-close, .btn-save, .btn-send, .btn-cancel, .btn-ok', () => {
document.removeEventListener('keydown', keydown);
animate(0);
setTimeout(() => {modalwrapper.remove();}, 300);
});
BDFDB.appendModal.modals.appendChild(modalwrapper);
BDFDB.initElements(modalwrapper);
animate(1);
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.createSearchBar = function (size = "small") {
if (typeof size != "string" || !["small","medium","large"].includes(size.toLowerCase())) size = "small";
var sizeclass = DiscordClassModules.SearchBar[size] ? (" " + BDFDB.disCN["searchbar" + size]) : "";
2019-09-18 10:19:56 +02:00
var searchBar = BDFDB.htmlToElement(`<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.searchbar + sizeclass}" style="flex: 1 1 auto;"><div class="${BDFDB.disCN.searchbarinner}"><input class="${BDFDB.disCN.searchbarinput}" type="text" spellcheck="false" placeholder="" value=""><div tabindex="0" class="${BDFDB.disCN.searchbariconlayout + sizeclass}" role="button"><div class="${BDFDB.disCN.searchbariconwrap}"><svg name="Search" class="${BDFDB.disCNS.searchbaricon + BDFDB.disCN.searchbarvisible}" width="18" height="18" viewBox="0 0 18 18"><g fill="none" fill-rule="evenodd"><path fill="currentColor" d="M3.60091481,7.20297313 C3.60091481,5.20983419 5.20983419,3.60091481 7.20297313,3.60091481 C9.19611206,3.60091481 10.8050314,5.20983419 10.8050314,7.20297313 C10.8050314,9.19611206 9.19611206,10.8050314 7.20297313,10.8050314 C5.20983419,10.8050314 3.60091481,9.19611206 3.60091481,7.20297313 Z M12.0057176,10.8050314 L11.3733562,10.8050314 L11.1492281,10.5889079 C11.9336764,9.67638651 12.4059463,8.49170955 12.4059463,7.20297313 C12.4059463,4.32933105 10.0766152,2 7.20297313,2 C4.32933105,2 2,4.32933105 2,7.20297313 C2,10.0766152 4.32933105,12.4059463 7.20297313,12.4059463 C8.49170955,12.4059463 9.67638651,11.9336764 10.5889079,11.1492281 L10.8050314,11.3733562 L10.8050314,12.0057176 L14.8073185,16 L16,14.8073185 L12.2102538,11.0099776 L12.0057176,10.8050314 Z"></path></g></svg><svg name="Clear" class="${BDFDB.disCNS.searchbaricon + BDFDB.disCN.searchbarclear}" width="12" height="12" viewBox="0 0 12 12"><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></div></div></div>`);
2019-07-23 21:09:07 +02:00
BDFDB.initElements(searchBar);
return searchBar;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.createSelectMenu = function (inner, value, type = "", dark = BDFDB.getDiscordTheme() == BDFDB.disCN.themedark) {
if (typeof inner != "string" || (typeof value != "string" && typeof value != "number")) return BDFDB.htmlToElement(`<div></div>`);
var suffix = dark ? "dark" : "light";
2019-09-18 10:19:56 +02:00
return `<div class="${BDFDB.disCN.selectwrap} BDFDB-select" style="flex: 1 1 auto;"><div class="${BDFDB.disCN.select}" type="${type}" value="${value}"><div class="${BDFDB.disCNS.selectcontrol + BDFDB.disCN["selectcontrol" + suffix]}"><div class="${BDFDB.disCN.selectvalue}"><div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignbaseline + BDFDB.disCNS.nowrap + BDFDB.disCNS.selectsingle + BDFDB.disCN["selectsingle" + suffix]}">${inner}</div><input readonly="" tabindex="0" class="${BDFDB.disCN.selectdummyinput}" value=""></div><div class="${BDFDB.disCN.selectarrowzone}"><div aria-hidden="true" class="${BDFDB.disCNS.selectarrowcontainer + BDFDB.disCN["selectarrowcontainer" + suffix]}"><svg height="20" width="20" viewBox="0 0 20 20" aria-hidden="true" focusable="false" class="${BDFDB.disCN.selectarrow}"><path d="M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z"></path></svg></div></div></div></div></div>`;
2019-07-23 21:09:07 +02:00
};
BDFDB.openDropdownMenu = function (e, callback, createinner, values, selector = "", dark = BDFDB.getDiscordTheme() == BDFDB.disCN.themedark) {
if (typeof callback != "function" || typeof createinner != "function" || !values || typeof values != "object") return;
let selectControl = e.currentTarget;
let selectWrap = selectControl.parentElement;
if (BDFDB.containsClass(selectWrap, BDFDB.disCN.selectisopen)) return;
BDFDB.addClass(selectWrap, BDFDB.disCN.selectisopen);
var type = selectWrap.getAttribute("type");
var oldchoice = selectWrap.getAttribute("value");
var suffix = dark ? "dark" : "light";
var menuhtml = `<div class="${BDFDB.disCNS.selectmenuouter + BDFDB.disCN["selectmenuouter" + suffix]}"><div class="${BDFDB.disCN.selectmenu}">`;
for (var key in values) menuhtml += `<div value="${key}" class="${BDFDB.disCNS.selectoption + (key == oldchoice ? BDFDB.disCN["selectoptionselect" + suffix] : BDFDB.disCN["selectoption" + suffix])}" style="flex: 1 1 auto; display: flex;">${createinner(key)}</div>`;
menuhtml += `</div></div>`;
var selectMenu = BDFDB.htmlToElement(menuhtml);
if (selector) BDFDB.addClass(selectMenu, selector);
selectWrap.appendChild(selectMenu);
BDFDB.addChildEventListener(selectMenu, "mouseenter", BDFDB.dotCN.selectoption + BDFDB.notCN.selectoptionselectlight + BDFDB.notCN.selectoptionselectdark, e2 => {
if (dark) {
BDFDB.removeClass(e2.currentTarget, BDFDB.disCN.selectoptiondark);
BDFDB.addClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverdark);
}
else {
BDFDB.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionlight);
BDFDB.addClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverlight);
}
});
BDFDB.addChildEventListener(selectMenu, "mouseleave", BDFDB.dotCN.selectoption + BDFDB.notCN.selectoptionselectlight + BDFDB.notCN.selectoptionselectdark, e2 => {
if (dark) {
BDFDB.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverdark);
BDFDB.addClass(e2.currentTarget, BDFDB.disCN.selectoptiondark);
}
else {
BDFDB.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverlight);
BDFDB.addClass(e2.currentTarget, BDFDB.disCN.selectoptionlight);
}
});
BDFDB.addChildEventListener(selectMenu, "mousedown", BDFDB.dotCN.selectoption, e2 => {
var newchoice = e2.currentTarget.getAttribute("value");
selectWrap.setAttribute("value", newchoice);
callback(selectWrap, type, newchoice);
});
var removeMenu = e2 => {
if (e2.target.parentElement != selectMenu) {
document.removeEventListener("mousedown", removeMenu);
selectMenu.remove();
setTimeout(() => {BDFDB.removeClass(selectWrap, BDFDB.disCN.selectisopen);},100);
}
};
document.addEventListener("mousedown", removeMenu);
};
BDFDB.openConfirmModal = function () {
if (arguments.length < 2) return;
var plugin = arguments[0];
var text = arguments[1];
if (!BDFDB.isObject(plugin) || !text) return;
var callback = typeof arguments[2] == "function" ? arguments[2] : (typeof arguments[3] == "function" ? arguments[3] : null);
var header = typeof arguments[2] == "string" ? arguments[2] : "Are you sure?";
2019-09-18 10:19:56 +02:00
let confirmModal = BDFDB.htmlToElement(`<span class="${plugin.name || plugin.getName()}-modal BDFDB-confirmation-modal BDFDB-modal"><div class="${BDFDB.disCN.backdrop}"></div><div class="${BDFDB.disCN.modal}"><div class="${BDFDB.disCN.modalinner}"><div class="${BDFDB.disCNS.modalsub + BDFDB.disCNS.modalmini + BDFDB.disCN.modalminisize}"><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;"><div class="${BDFDB.disCN.flexchild}" style="flex:1 1 auto;"><h4 class="${BDFDB.disCNS.h4 + BDFDB.disCNS.defaultcolor + BDFDB.disCN.h4defaultmargin}">${header}</h4><div class="${BDFDB.disCNS.modalguildname + BDFDB.disCNS.small + BDFDB.disCNS.size12 + BDFDB.disCNS.height16 + BDFDB.disCN.primary}">${plugin.name || plugin.getName()}</div></div><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 class="" xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 12 12"><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></div><div class="${BDFDB.disCNS.scrollerwrap + BDFDB.disCNS.modalcontent + BDFDB.disCNS.scrollerthemed + BDFDB.disCN.themeghosthairline}"><div class="${BDFDB.disCNS.scroller + BDFDB.disCNS.modalsubinner + BDFDB.disCN.modalminicontent}"><div class="${BDFDB.disCNS.modalminitext + BDFDB.disCNS.medium + BDFDB.disCNS.primary + BDFDB.disCN.selectable}">${text}</div></div> </div><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}"><button type="button" class="btn-ok ${BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCNS.buttonsizemedium + BDFDB.disCN.buttongrow}"><div class="${BDFDB.disCN.buttoncontents}"></div></button><button type="button" class="btn-cancel ${BDFDB.disCNS.button + BDFDB.disCNS.buttonlooklink + BDFDB.disCNS.buttoncolorwhite + BDFDB.disCNS.buttonsizemedium + BDFDB.disCN.buttongrow}"><div class="${BDFDB.disCN.buttoncontents}"></div></button></div></div></div></div></span>`);
2019-07-23 21:09:07 +02:00
BDFDB.appendModal(confirmModal);
if (typeof callback == 'function') confirmModal.querySelector('.btn-ok').addEventListener('click', () => {
setTimeout(() => {callback();}, 300);
});
return confirmModal;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.updateContextPosition = function (menu, e = BDFDB.mousePosition) {
if (!Node.prototype.isPrototypeOf(menu)) return;
2019-09-05 16:17:25 +02:00
var itemlayer = BDFDB.getParentEle(BDFDB.dotCN.itemlayer, menu) || menu;
2019-07-23 21:09:07 +02:00
var arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount));
2019-09-05 16:17:25 +02:00
var irects = BDFDB.getRects(itemlayer);
2019-07-23 21:09:07 +02:00
var newpos = {
2019-09-05 16:17:25 +02:00
pageX: e.pageX - irects.width,
pageY: e.pageY - irects.height
2019-07-23 21:09:07 +02:00
};
2019-09-05 16:17:25 +02:00
itemlayer.style.setProperty('left', (e.pageX + irects.width > arects.width ? (newpos.pageX < 0 ? 11 : newpos.pageX) : e.pageX) + 'px');
itemlayer.style.setProperty('top', (e.pageY + irects.height > arects.height ? (newpos.pageY < 0 ? 11 : newpos.pageY) : e.pageY) + 'px');
2019-07-23 21:09:07 +02:00
BDFDB.initElements(menu);
};
2019-09-09 09:05:55 +02:00
BDFDB.getContextMenuGroupAndIndex = function (startchildren, names) {
names = Array.isArray(names) ? names : (typeof names == "string" ? [names] : Array.from(names));
2019-09-09 12:17:46 +02:00
var startIsArray = Array.isArray(startchildren);
2019-09-10 00:44:25 +02:00
var parent = startchildren;
2019-09-09 09:05:55 +02:00
return search(startchildren);
function search (children) {
2019-09-10 00:44:25 +02:00
while (children && !Array.isArray(children) && children.props && children.props.children) {
parent = children;
children = children.props.children;
}
if (children && !Array.isArray(children)) {
2019-09-11 14:31:41 +02:00
if (parent && parent.props) {
2019-09-10 00:44:25 +02:00
var child = children;
parent.props.children = [];
parent.props.children.push(child);
2019-09-11 14:31:41 +02:00
return [parent.props.children, check(child) ? 0 : -1];
2019-09-10 00:44:25 +02:00
}
else return [startchildren, -1];
}
2019-09-09 09:05:55 +02:00
else {
2019-09-09 12:17:46 +02:00
if (!startIsArray) {
startchildren = children;
startIsArray = true;
}
2019-09-09 09:05:55 +02:00
var result = [startchildren, -1];
2019-09-09 12:08:55 +02:00
for (let i in children) if (children[i]) {
2019-09-10 00:44:25 +02:00
if (check(children[i])) result = [children, i];
else if (children[i].props) {
parent = children[i];
result = search(children[i].props.children);
}
2019-09-09 09:05:55 +02:00
if (result[1] > -1) break;
}
return result;
}
}
2019-09-10 00:44:25 +02:00
function check (child) {
var displayname = child.type ? child.type.displayName || child.type.name || "" : "";
var label = child.props ? child.props.label || "" : "";
return names.some(name => displayname == name || label == name);
}
2019-09-09 09:05:55 +02:00
};
2019-09-10 17:05:17 +02:00
BDFDB.openContextMenu = function (plugin, e, children) {
LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) {
return BDFDB.React.createElement(LibraryComponents.ContextMenu, Object.assign({}, e, {
BDFDBcontextMenu: true,
2019-09-10 17:06:44 +02:00
type: BDFDB.DiscordConstants.ContextMenuTypes.NATIVE_TEXT,
2019-09-10 17:05:17 +02:00
value: "",
className: `${BDFDB.disCN.contextmenu} BDFDB-contextMenu ${plugin.name}-contextMenuItem`,
children
}));
});
};
2019-07-23 21:09:07 +02:00
BDFDB.closeContextMenu = function (nodeOrInstance) {
if (!BDFDB.isObject(nodeOrInstance)) return;
var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.getOwnerInstance({node:nodeOrInstance, name:"ContextMenu", up:true}) : BDFDB.getOwnerInstance({instance:nodeOrInstance, name:"ContextMenu", up:true});
if (BDFDB.isObject(instance) && instance.props && typeof instance.props.closeContextMenu == "function") instance.props.closeContextMenu();
};
BDFDB.createMessageOptionPopout = function (button) {
if (!button) return;
var popouts = document.querySelector(BDFDB.dotCN.popouts);
if (!popouts) return;
button = BDFDB.containsClass(button, BDFDB.disCN.optionpopoutbutton) ? button : button.querySelector(BDFDB.dotCN.optionpopoutbutton);
var containerins = BDFDB.getReactInstance(BDFDB.getParentEle(BDFDB.dotCN.messagebuttoncontainer, button));
containerins = containerins && containerins.child ? containerins.child : null;
containerins = containerins && containerins.stateNode && typeof containerins.stateNode.renderReactionPopout == 'function' ? containerins.sibling : containerins;
if (containerins && containerins.stateNode && typeof containerins.stateNode.renderOptionPopout == 'function') {
BDFDB.addClass(button, 'popout-open');
var popout = BDFDB.htmlToElement(`<div role="dialog" class="${BDFDB.disCNS.popoutnoarrow + BDFDB.disCNS.popout + BDFDB.disCNS.popoutbottom + BDFDB.disCN.popoutarrowalignmenttop}" style="z-index:1001; visibility:visible; transform:translateX(-50%) translateY(0%) translateZ(0px);"></div>`);
popouts.appendChild(popout);
var popoutinstance = containerins.stateNode.renderOptionPopout(containerins.stateNode.props);
popoutinstance.props.target = button;
popoutinstance.props.onClose = () => {
BDFDB.removeClass(button, 'popout-open');
popout.remove();
};
BDFDB.React.render(popoutinstance, popout);
var buttonrects = BDFDB.getRects(button);
popout.style.setProperty('left', buttonrects.left + buttonrects.width / 2 + 'px');
popout.style.setProperty('top', buttonrects.top + buttonrects.height / 2 + 'px');
var mousedown = e => {
document.removeEventListener('mousedown', mousedown);
if (!popout.contains(e.target)) popoutinstance.props.onClose();
};
document.addEventListener('mousedown', mousedown);
}
};
BDFDB.createSortPopout = function (anker, markup, callback) {
if (!anker || !markup || typeof callback != 'function' || BDFDB.containsClass(anker, 'popout-open')) return;
var popouts = document.querySelector(BDFDB.dotCN.popouts);
var valueinput = anker.querySelector(BDFDB.dotCNC.quickselectvalue + BDFDB.dotCN.recentmentionsmentionfiltervalue);
if (!popouts || !valueinput) return;
BDFDB.addClass(anker, 'popout-open');
var popout = BDFDB.htmlToElement(markup);
var ankerrects = BDFDB.getRects(anker);
popout.style.setProperty('left', ankerrects.left + ankerrects.width + 'px');
popout.style.setProperty('top', ankerrects.top + BDFDB.getRects(valueinput).height + 'px');
BDFDB.addClass(popout.querySelector(BDFDB.dotCN.contextmenu), BDFDB.getDiscordTheme());
BDFDB.addChildEventListener(popout, 'click', BDFDB.dotCN.contextmenuitem, e => {
valueinput.innerText = e.currentTarget.innerText;
valueinput.setAttribute('option', e.currentTarget.getAttribute('option'));
document.removeEventListener('mousedown', mousedown);
popout.remove();
setTimeout(() => {BDFDB.removeClass(anker, 'popout-open');}, 300);
callback();
});
popouts.appendChild(popout);
2019-09-05 16:17:25 +02:00
BDFDB.initElements(popout);
2019-07-23 21:09:07 +02:00
var mousedown = e => {
if (!document.contains(popout)) document.removeEventListener('mousedown', mousedown);
else if (!popout.contains(e.target)) {
document.removeEventListener('mousedown', mousedown);
popout.remove();
setTimeout(() => {BDFDB.removeClass(anker, 'popout-open');}, 300);
}
};
document.addEventListener('mousedown', mousedown);
};
2019-08-15 15:24:34 +02:00
var setSwatch = (swatch, color, selected) => {
if (!swatch) return;
else if (selected) {
BDFDB.addClass(swatch, 'selected');
var iscustom = BDFDB.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom);
2019-08-17 10:00:38 +02:00
var isgradient = color && BDFDB.isObject(color);
var selectedcolor = !isgradient ? BDFDB.colorCONVERT(color, 'RGB') : BDFDB.colorGRADIENT(color);
var bright = selectedcolor && !isgradient ? BDFDB.colorISBRIGHT(selectedcolor) : false;
if (!swatch.querySelector(".swatch-checkmark")) swatch.appendChild(BDFDB.htmlToElement(`<svg class="swatch-checkmark" name="Checkmark" aria-hidden="false" width="${iscustom ? 32 : 16}" height="${iscustom ? 24 : 16}" viewBox="0 0 18 18" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><polyline stroke="${bright ? '#000000' : '#ffffff'}" stroke-width="2" points="3.5 9.5 7 13 15 5"></polyline></g></svg>`));
2019-08-15 15:24:34 +02:00
if (iscustom) {
BDFDB.removeClass(swatch, BDFDB.disCN.colorpickerswatchnocolor);
swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute('fill', bright ? '#000000' : '#ffffff');
2019-08-17 10:00:38 +02:00
if (selectedcolor) {
if (isgradient) swatch.gradient = color;
swatch.style.setProperty(isgradient ? 'background-image' : 'background-color', selectedcolor, 'important');
}
2019-08-15 15:24:34 +02:00
}
}
else {
2019-08-17 10:00:38 +02:00
delete swatch.gradient;
2019-08-15 15:24:34 +02:00
BDFDB.removeClass(swatch, 'selected');
BDFDB.removeEles(swatch.querySelectorAll(".swatch-checkmark"));
if (BDFDB.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom)) {
BDFDB.addClass(swatch, BDFDB.disCN.colorpickerswatchnocolor);
swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute('fill', '#ffffff');
2019-08-17 10:00:38 +02:00
swatch.style.removeProperty('background-color');
swatch.style.removeProperty('background-image');
2019-08-15 15:24:34 +02:00
}
}
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.setColorSwatches = function (container, currentcolor) {
if (!Node.prototype.isPrototypeOf(container)) return;
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var swatches = container.querySelector('.swatches:not([swatchnr])');
if (!swatches) return;
swatches.setAttribute('swatchnr', parseInt(container.querySelectorAll('.swatches[swatchnr]').length + 1));
2019-09-04 12:34:02 +02:00
2019-08-15 15:24:34 +02:00
var colorlist = [null, 'rgb(82,233,30)', 'rgb(46,204,113)', 'rgb(26,188,156)', 'rgb(52,152,219)', 'rgb(52,84,219)', 'rgb(134,30,233)', 'rgb(155,89,182)', 'rgb(233,30,99)', 'rgb(233,65,30)', 'rgb(231,76,60)', 'rgb(230,126,34)', 'rgb(241,196,15)', 'rgb(199,204,205)', 'rgb(112,128,136)', 'rgb(99,99,99)', 'rgb(255,255,255)', 'rgb(59,173,20)', 'rgb(31,139,76)', 'rgb(17,128,106)', 'rgb(32,102,148)', 'rgb(32,57,148)', 'rgb(109,20,173)', 'rgb(113,54,138)', 'rgb(173,20,87)', 'rgb(173,32,20)', 'rgb(153,45,34)', 'rgb(168,67,0)', 'rgb(194,124,14)', 'rgb(151,156,159)', 'rgb(93,104,109)', 'rgb(44,44,44)'];
var colorrows = [colorlist.slice(0, parseInt(colorlist.length/2)), colorlist.slice(parseInt(colorlist.length/2))];
colorlist.shift();
2019-09-04 12:34:02 +02:00
2019-09-18 10:19:56 +02:00
swatches.appendChild(BDFDB.htmlToElement(`<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.margintop8}" style="flex: 1 1 auto;"><div class="${BDFDB.disCN.marginreset}" style="flex: 0 0 auto;"><div aria-label="" class=""><button type="button" class="${BDFDB.disCNS.colorpickerswatch + BDFDB.disCNS.colorpickerswatchcustom + BDFDB.disCN.colorpickerswatchnocolor}" style="margin-left: 0;"><svg class="${BDFDB.disCN.colorpickerswatchdropper}" width="14" height="14" viewBox="0 0 16 16"><g fill="none"><path d="M-4-4h24v24H-4z"/><path class="${BDFDB.disCN.colorpickerswatchdropperfg}" fill="#ffffff" d="M14.994 1.006C13.858-.257 11.904-.3 10.72.89L8.637 2.975l-.696-.697-1.387 1.388 5.557 5.557 1.387-1.388-.697-.697 1.964-1.964c1.13-1.13 1.3-2.985.23-4.168zm-13.25 10.25c-.225.224-.408.48-.55.764L.02 14.37l1.39 1.39 2.35-1.174c.283-.14.54-.33.765-.55l4.808-4.808-2.776-2.776-4.813 4.803z"/></g></svg></button></div></div><div class="${BDFDB.disCNS.flex + BDFDB.disCNS.vertical + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.flexmarginreset}" style="flex: 1 1 auto;">${colorrows.map(row => '<div class="' + BDFDB.disCNS.flex + BDFDB.disCNS.horizontal + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.wrap + BDFDB.disCN.colorpickerrow + '">' + row.map(c => '<button type="button" class="' + BDFDB.disCN.colorpickerswatch + (c ? "" : (" " + BDFDB.disCN.colorpickerswatchnocolor)) + '" style="background-color: ' + c + ';"></button>').join('') + '</div>').join('')}</div></div>`));
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
if (currentcolor && !BDFDB.colorCOMPARE(currentcolor, [0, 0, 0, 0])) {
var selection = colorlist.indexOf(BDFDB.colorCONVERT(currentcolor, 'RGB'));
2019-08-15 15:24:34 +02:00
setSwatch(selection > -1 ? swatches.querySelectorAll(BDFDB.dotCNS.colorpickerrow + BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor)[selection] : swatches.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom), currentcolor, true);
2019-07-23 21:09:07 +02:00
}
2019-08-15 15:24:34 +02:00
else setSwatch(swatches.querySelector(BDFDB.dotCNS.colorpickerrow + BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchnocolor), null, true);
BDFDB.addChildEventListener(swatches, 'click', BDFDB.dotCN.colorpickerswatch, e => {
2019-08-15 15:30:20 +02:00
if (BDFDB.containsClass(swatches, 'disabled') || BDFDB.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchdisabled)) return;
2019-08-15 15:24:34 +02:00
else if (BDFDB.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchcustom)) {
2019-08-17 10:00:38 +02:00
BDFDB.openColorPicker(swatches, e.currentTarget, e.currentTarget.gradient || e.currentTarget.style.getPropertyValue("background-color"));
2019-07-23 21:09:07 +02:00
}
else {
2019-08-15 15:24:34 +02:00
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + ".selected"), null, false);
2019-07-23 21:09:07 +02:00
setSwatch(e.currentTarget, e.currentTarget.style.getPropertyValue('background-color'), true);
}
});
2019-08-15 15:43:13 +02:00
BDFDB.addChildEventListener(swatches, 'mouseenter', BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom, e => {
BDFDB.createTooltip(BDFDB.LanguageStrings.CUSTOM_COLOR, e.currentTarget, {type: 'bottom'});
});
BDFDB.addChildEventListener(swatches, 'mouseenter', BDFDB.dotCNS.colorpickerrow + BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchnocolor, e => {
BDFDB.createTooltip(BDFDB.LanguageStrings.DEFAULT, e.currentTarget, {type: 'bottom'});
});
2019-07-23 21:09:07 +02:00
};
BDFDB.getSwatchColor = function (container, nr) {
if (!Node.prototype.isPrototypeOf(container)) return;
2019-09-04 12:34:02 +02:00
2019-08-15 15:24:34 +02:00
var swatch = container.querySelector(`.swatches[swatchnr="${nr}"] ${BDFDB.dotCN.colorpickerswatch}.selected`);
2019-08-17 10:00:38 +02:00
return swatch ? swatch.gradient || BDFDB.colorCONVERT(swatch.style.getPropertyValue('background-color'), 'RGBCOMP') : null;
2019-07-23 21:09:07 +02:00
};
2019-08-15 15:24:34 +02:00
BDFDB.openColorPicker = function (swatches, target, color) {
if (!swatches || !target) return;
2019-08-17 10:00:38 +02:00
var isgradient = color && BDFDB.isObject(color);
var selectedcolor = BDFDB.colorCONVERT(isgradient ? color[Object.keys(color)[0]] : color, 'HEX') || '#000000';
var [h, s, l] = BDFDB.colorCONVERT(selectedcolor, 'HSLCOMP');
2019-08-15 15:24:34 +02:00
var targetrects = BDFDB.getRects(target);
2019-09-18 10:19:56 +02:00
var colorPicker = BDFDB.htmlToElement(`<div role="dialog" class="BDFDB-colorpicker ${BDFDB.disCNS.popoutnoarrow + BDFDB.disCNS.popoutnoshadow + BDFDB.disCNS.popout + BDFDB.disCNS.popoutbottom + BDFDB.disCNS.popoutarrowalignmenttop + BDFDB.disCN.themeundefined}" style="z-index: 2001; visibility: visible; left: ${targetrects.left + targetrects.width/2}px; top: ${targetrects.top + targetrects.height}px; transform: translateX(-50%) translateY(0%) translateZ(0px);"><div class="${BDFDB.disCNS.flex + BDFDB.disCNS.vertical + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.colorpicker}" style="flex: 1 1 auto;"><div class="${BDFDB.disCN.colorpickerinner}"><div class="${BDFDB.disCN.colorpickersaturation}"><div class="saturation-color" style="position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px; background: ${BDFDB.colorCONVERT([h, '100%', '100%'], 'RGB')} !important;"><style>.saturation-white {background: -webkit-linear-gradient(to right, #fff, rgba(255,255,255,0));background: linear-gradient(to right, #fff, rgba(255,255,255,0));}.saturation-black {background: -webkit-linear-gradient(to top, #000, rgba(0,0,0,0));background: linear-gradient(to top, #000, rgba(0,0,0,0));}</style><div class="saturation-white" style="position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px;"><div class="saturation-black" style="position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px;"></div><div class="saturation-cursor" style="position: absolute; top: 55.2941%; left: 44.7368%; cursor: default;"><div style="width: 4px; height: 4px; box-shadow: rgb(255, 255, 255) 0px 0px 0px 1.5px, rgba(0, 0, 0, 0.3) 0px 0px 1px 1px inset, rgba(0, 0, 0, 0.4) 0px 0px 1px 2px; border-radius: 50%; transform: translate(-2px, -2px);"></div></div></div></div></div><div class="${BDFDB.disCN.colorpickerhue}"><div style="position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px;"><div class="hue-horizontal" style="padding: 0px 2px; position: relative; height: 100%;"><style>.hue-horizontal {background: linear-gradient(to right, #f00 0%, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);background: -webkit-linear-gradient(to right, #f00 0%, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);}.hue-vertical {background: linear-gradient(to top, #f00 0%, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);background: -webkit-linear-gradient(to top, #f00 0%, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);}</style><div class="hue-cursor" style="position: absolute; left: 0%;"><div style="margin-top: 1px; width: 4px; border-radius: 1px; height: 8px; box-shadow: rgba(0, 0, 0, 0.6) 0px 0px 2px; background: rgb(255, 255, 255); transform: translateX(-2px);"></div></div></div></div></div><div class="gradient-bar" style="position: relative; height: 8px; margin: 27px 2px 2px 2px;${!isgradient ? ' display: none;' : ''}"><div style="position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px;"><div class="gradient-horizontal" style="padding: 0px 2px; position: relative; height: 100%; background-color: ${selectedcolor};"><div class="gradient-cursor edge selected" style="position: absolute; left: 0%;"><div style="background-color: ${selectedcolor} !important;"></div></div><div class="gradient-cursor edge" style="position: absolute; left: 100%;"><div style="background-color: ${isgradient ? BDFDB.colorCONVERT(color[1], 'HEX') : selectedcolor} !important;"></div></div></div></div></div></div><div class="${BDFDB.disCNS.horizontal + BDFDB.disCNS.colorpickerhexinput + BDFDB.disCN.margintop8}"><input class="${BDFDB.disCN.inputdefault}" maxlength="7" name="" type="text" placeholder="" value="${selectedcolor}"></input><div class="gradient-button${isgradient ? ' selected' : ''}" style="transform: rotate(-90deg); margin: 2px 0 0 5px; cursor: pointer; border-radius: 5px; height: 36px;"><svg width="36" height="36" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" fill="#f6f6f7"><path d="M469.333333 384h85.333334v85.333333h-85.333334z m-85.333333 85.333333h85.333
2019-08-15 15:24:34 +02:00
document.querySelector(BDFDB.dotCN.popouts).appendChild(colorPicker);
var removePopout = e => {
if (!colorPicker.contains(e.target)) {
document.removeEventListener("mousedown", removePopout);
colorPicker.remove();
2019-07-23 21:09:07 +02:00
}
2019-08-15 15:24:34 +02:00
};
document.addEventListener("mousedown", removePopout);
2019-09-04 12:34:02 +02:00
2019-08-15 15:24:34 +02:00
var hexinput = colorPicker.querySelector(BDFDB.dotCNS.colorpickerhexinput + BDFDB.dotCN.input);
2019-08-17 10:00:38 +02:00
var gradientbutton = colorPicker.querySelector('.gradient-button');
var gradientbar = colorPicker.querySelector('.gradient-bar');
var gradientpane = colorPicker.querySelector('.gradient-horizontal');
2019-08-15 15:24:34 +02:00
var satpane = colorPicker.querySelector('.saturation-color');
var huepane = colorPicker.querySelector('.hue-horizontal');
var satcursor = colorPicker.querySelector('.saturation-cursor');
var huecursor = colorPicker.querySelector('.hue-cursor');
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
var gMinX, gMaxX, sMinX, sMaxX, sMinY, sMaxY, hMinX, hMaxX;
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
updateRects();
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
if (isgradient) for (let pos in color) if (pos > 0 && pos < 1) gradientpane.appendChild(BDFDB.htmlToElement(`<div class="gradient-cursor" style="position: absolute; left: ${pos * 100}%;"><div style="background-color: ${color[pos]} !important;"></div></div>`));
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
updateColors(false);
2019-09-04 12:34:02 +02:00
2019-08-17 10:00:38 +02:00
BDFDB.addChildEventListener(colorPicker, "mousedown", ".move-corner", e => {
var rects = BDFDB.getRects(colorPicker);
var transform = getComputedStyle(colorPicker, null).getPropertyValue("transform").replace(/[^0-9,-]/g,"").split(",");
var left = rects.left - (transform.length > 4 ? parseFloat(transform[4]) : 0);
var top = rects.top - (transform.length > 4 ? parseFloat(transform[5]) : 0);
var oldX = e.pageX;
var oldY = e.pageY;
var mouseup = () => {
BDFDB.removeLocalStyle("disableTextSelection");
document.removeEventListener("mouseup", mouseup);
document.removeEventListener("mousemove", mousemove);
};
var mousemove = e2 => {
left = left - (oldX - e2.pageX);
top = top - (oldY - e2.pageY);
oldX = e2.pageX;
oldY = e2.pageY;
colorPicker.style.setProperty("left", left + "px", "important");
colorPicker.style.setProperty("top", top + "px", "important");
updateRects();
};
document.addEventListener("mouseup", mouseup);
document.addEventListener("mousemove", mousemove);
});
gradientpane.addEventListener('mousedown', e => {
setImmediate(() => {
if (BDFDB.containsClass(e.target.parentElement, "gradient-cursor")) {
if (e.which == 1) {
if (!BDFDB.containsClass(e.target.parentElement, "selected")) {
BDFDB.removeClass(gradientpane.querySelectorAll(".gradient-cursor.selected"), "selected");
BDFDB.addClass(e.target.parentElement, "selected");
[h, s, l] = BDFDB.colorCONVERT(e.target.style.getPropertyValue("background-color"), 'HSLCOMP');
updateColors(true);
}
if (!BDFDB.containsClass(e.target.parentElement, "edge")) {
var mouseup = () => {
document.removeEventListener('mouseup', mouseup);
document.removeEventListener('mousemove', mousemove);
};
var mousemove = e2 => {
e.target.parentElement.style.setProperty("left", BDFDB.mapRange([gMinX, gMaxX], [1, 99], e2.clientX) + '%');
updateGradient();
};
document.addEventListener('mouseup', mouseup);
document.addEventListener('mousemove', mousemove);
}
}
else if (e.which == 3 && !BDFDB.containsClass(e.target.parentElement, "edge")) {
BDFDB.removeEles(e.target.parentElement);
if (BDFDB.containsClass(e.target.parentElement, "selected")) {
var firstcursor = gradientpane.querySelector(".gradient-cursor");
BDFDB.addClass(firstcursor, "selected");
[h, s, l] = BDFDB.colorCONVERT(firstcursor.firstElementChild.style.getPropertyValue("background-color"), 'HSLCOMP');
}
updateColors(true);
}
}
else if (gradientpane == e.target && e.which == 1) {
BDFDB.removeClass(gradientpane.querySelectorAll(".gradient-cursor.selected"), "selected");
var newcursor = BDFDB.htmlToElement(`<div class="gradient-cursor selected" style="position: absolute; left: ${BDFDB.mapRange([gMinX, gMaxX], [1, 99], e.clientX)}%;"><div style="background-color: #000000 !important;"></div></div>`);
gradientpane.appendChild(newcursor);
[h, s, l] = [0, "0%", "0%"];
updateColors(true);
var mouseup = () => {
document.removeEventListener('mouseup', mouseup);
document.removeEventListener('mousemove', mousemove);
};
var mousemove = e2 => {
newcursor.style.setProperty("left", BDFDB.mapRange([gMinX, gMaxX], [1, 99], e2.clientX) + '%');
updateGradient();
};
document.addEventListener('mouseup', mouseup);
document.addEventListener('mousemove', mousemove);
}
});
});
2019-08-15 15:24:34 +02:00
satpane.addEventListener('mousedown', e => {
s = BDFDB.mapRange([sMinX, sMaxX], [0, 100], e.clientX) + '%';
l = BDFDB.mapRange([sMinY, sMaxY], [100, 0], e.clientY) + '%';
2019-08-17 10:00:38 +02:00
updateColors(true);
2019-08-15 15:24:34 +02:00
var mouseup = () => {
document.removeEventListener('mouseup', mouseup);
document.removeEventListener('mousemove', mousemove);
};
var mousemove = e2 => {
s = BDFDB.mapRange([sMinX, sMaxX], [0, 100], e2.clientX) + '%';
l = BDFDB.mapRange([sMinY, sMaxY], [100, 0], e2.clientY) + '%';
2019-08-17 10:00:38 +02:00
updateColors(true);
2019-08-15 15:24:34 +02:00
};
document.addEventListener('mouseup', mouseup);
document.addEventListener('mousemove', mousemove);
});
huepane.addEventListener('mousedown', e => {
h = BDFDB.mapRange([hMinX, hMaxX], [0, 360], e.clientX);
2019-08-17 10:00:38 +02:00
updateColors(true);
2019-08-15 15:24:34 +02:00
var mouseup = () => {
document.removeEventListener('mouseup', mouseup);
document.removeEventListener('mousemove', mousemove);
};
var mousemove = e2 => {
h = BDFDB.mapRange([hMinX, hMaxX], [0, 360], e2.clientX);
2019-08-17 10:00:38 +02:00
updateColors(true);
2019-08-15 15:24:34 +02:00
};
document.addEventListener('mouseup', mouseup);
document.addEventListener('mousemove', mousemove);
});
hexinput.addEventListener('input', e => {
if (/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.test(hexinput.value)) {
[h, s, l] = BDFDB.colorCONVERT(hexinput.value, 'HSLCOMP');
2019-08-17 10:00:38 +02:00
updateColors(false);
2019-07-23 21:09:07 +02:00
}
});
2019-08-17 10:00:38 +02:00
gradientbutton.addEventListener('click', e => {
isgradient = !isgradient;
BDFDB.toggleEles(gradientbar, isgradient);
BDFDB.toggleClass(gradientbutton, "selected", isgradient);
updateColors(true);
});
2019-08-19 12:24:32 +02:00
gradientbutton.addEventListener('mouseenter', e => {
2019-08-19 13:17:41 +02:00
BDFDB.createTooltip("Color Gradient", gradientbutton, {type: "bottom"});
2019-08-19 12:24:32 +02:00
});
2019-08-17 10:00:38 +02:00
function updateRects () {
var hidden = BDFDB.isEleHidden(gradientbar);
if (hidden) BDFDB.toggleEles(gradientbar);
var gradientpanerects = BDFDB.getRects(gradientpane);
if (hidden) BDFDB.toggleEles(gradientbar);
gMinX = gradientpanerects.left;
gMaxX = gMinX + gradientpanerects.width;
var satpanerects = BDFDB.getRects(satpane);
sMinX = satpanerects.left;
sMaxX = sMinX + satpanerects.width;
sMinY = satpanerects.top;
sMaxY = sMinY + satpanerects.height;
var huepanerects = BDFDB.getRects(huepane);
hMinX = huepanerects.left;
hMaxX = hMinX + huepanerects.width;
}
function updateColors (setinput) {
2019-08-15 15:24:34 +02:00
satpane.style.setProperty('background', BDFDB.colorCONVERT([h, '100%', '100%'], 'RGB'), 'important');
satcursor.style.setProperty('left', s, 'important');
satcursor.style.setProperty('top', BDFDB.mapRange([0, 100], [100, 0], parseFloat(l)) + '%', 'important');
huecursor.style.setProperty('left', BDFDB.mapRange([0, 360], [0, 100], h) + '%', 'important');
2019-08-17 10:00:38 +02:00
var hex = BDFDB.colorCONVERT([h, s, l], 'HEX');
2019-08-15 15:24:34 +02:00
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + ".selected"), null, false);
2019-08-17 10:00:38 +02:00
if (isgradient) {
gradientpane.querySelector(".gradient-cursor.selected").firstElementChild.style.setProperty("background-color", hex);
updateGradient();
}
else {
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), [h, s, l], true);
}
if (setinput) hexinput.value = hex;
}
function updateGradient () {
gradientpane.style.removeProperty("background-color");
var gradient = {};
for (let cursor of gradientpane.querySelectorAll(".gradient-cursor")) gradient[parseFloat(cursor.style.getPropertyValue("left"))/100] = cursor.firstElementChild.style.getPropertyValue("background-color");
gradientpane.style.setProperty("background-image", BDFDB.colorGRADIENT(gradient));
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), gradient, true);
2019-08-15 15:24:34 +02:00
}
2019-07-23 21:09:07 +02:00
};
BDFDB.mapRange = function (from, to, value) {
2019-08-15 15:24:34 +02:00
if (parseFloat(value) < parseFloat(from[0])) return parseFloat(to[0]);
else if (parseFloat(value) > parseFloat(from[1])) return parseFloat(to[1]);
else return parseFloat(to[0]) + (parseFloat(value) - parseFloat(from[0])) * (parseFloat(to[1]) - parseFloat(to[0])) / (parseFloat(from[1]) - parseFloat(from[0]));
2019-07-23 21:09:07 +02:00
};
BDFDB.shake = function () {
BDFDB.getReactInstance(document.querySelector(BDFDB.dotCN.appold)).return.stateNode.shake();
};
BDFDB.isBDv2 = function () {
return typeof BDFDB.BDv2Api !== 'undefined';
};
BDFDB.isPluginEnabled = function (plugname) {
if (!BDFDB.isBDv2()) return window.bdplugins[plugname] && window.pluginCookie[plugname];
else return BDFDB.Plugins[plugname.toLowerCase()] ? BDFDB.Plugins[plugname.toLowerCase()].enabled : null;
};
BDFDB.isRestartNoMoreEnabled = function () {
return window.settingsCookie['fork-ps-5'] && window.settingsCookie['fork-ps-5'] === true || BDFDB.isPluginEnabled('Restart-No-More') || BDFDB.isPluginEnabled('Restart No More');
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.isThemeEnabled = function (themename) {
if (!BDFDB.isBDv2()) return window.bdthemes[themename] && window.themeCookie[themename];
else return BDFDB.Themes[themename.toLowerCase()] ? BDFDB.Themes[themename.toLowerCase()].enabled : null;
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
(BDFDB.setPluginCache = function () {
if (!BDFDB.isBDv2()) return;
BDFDB.Plugins = {};
for (let plugin of BDFDB.BDv2Api.Plugins.listPlugins()) BDFDB.BDv2Api.Plugins.getPlugin(plugin).then(plugindata => {BDFDB.Plugins[plugin] = plugindata;});
})();
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
(BDFDB.setThemeCache = function () {
if (!BDFDB.isBDv2()) return;
BDFDB.Themes = {};
for (let theme of BDFDB.BDv2Api.Themes.listThemes()) BDFDB.BDv2Api.Themes.getTheme(theme).then(themedata => {BDFDB.Themes[theme] = themedata;});
})();
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var DiscordClassModules = {};
DiscordClassModules.BDFDB = {
BDFDBundefined: 'BDFDB_undefined',
cardInner: 'card-inner',
2019-09-05 09:53:30 +02:00
overflowEllipsis: 'overflowellipsis'
2019-07-23 21:09:07 +02:00
};
DiscordClassModules.BDrepo = {
bdGuild: 'bd-guild',
bdGuildAnimatable: 'bd-animatable',
bdGuildAudio: 'bd-audio',
bdGuildSelected: 'bd-selected',
bdGuildSeparator: 'bd-guild-separator',
bdGuildUnread: 'bd-unread',
bdGuildVideo: 'bd-video',
bdPillSelected: 'bd-selected',
bdPillUnread: 'bd-unread',
bdaAuthor: 'bda-author',
bdaControls: 'bda-controls',
bdaDescription: 'bda-description',
bdaDescriptionWrap: 'bda-description-wrap',
bdaFooter: 'bda-footer',
bdaHeader: 'bda-header',
bdaHeaderTitle: 'bda-header-title',
bdaLink: 'bda-link',
bdaLinks: 'bda-links',
bdaName: 'bda-name',
bdaSettingsButton: 'bda-settings-button',
bdaSlist: 'bda-slist',
bdaVersion: 'bda-version',
bdPfbtn: 'bd-pfbtn',
settingsOpen: 'settings-open',
settingsClosed: 'settings-closed',
switch: 'ui-switch',
switchCheckbox: 'ui-switch-checkbox',
switchChecked: 'checked',
switchItem: 'ui-switch-item',
switchWrapper: 'ui-switch-wrapper'
};
DiscordClassModules.BDv2repo = {
bdButton: 'bd-button',
bdCard: 'bd-card',
bdHasTooltip: 'bd-hasTooltip',
bdMaterialDesignIcon: 'bd-materialDesignIcon',
bdTooltip: 'bd-tooltip',
vTooltipOpen: 'v-tooltip-open'
};
DiscordClassModules.NotFound = {
_: '',
applicationStore: 'applicationStore-1pNvnv',
avatarStopAnimation: 'stop-animation',
badgeWrapper: 'wrapper-232cHJ',
2019-09-11 10:56:54 +02:00
nameContainerNameContainer: 'container-2ax-kl',
2019-07-23 21:09:07 +02:00
gameLibrary: 'gameLibrary-TTDw4Y',
guildChannels: 'container-PNkimc',
highlight: 'highlight',
2019-09-13 12:05:32 +02:00
hoverCardButton: 'button-2CgfFz',
2019-07-23 21:09:07 +02:00
loginScreen: 'wrapper-3Q5DdO',
lfg: 'lfg-3xoFkI',
mention: 'mention',
select: 'css-1kj8ui-container',
selectArrow: 'css-19bqh2r',
selectArrowContainer: 'css-bdfdb-indicatorContainer',
selectArrowContainerDark: 'css-12qlrak-indicatorContainer',
selectArrowContainerLight: 'css-11dkexk-indicatorContainer',
selectArrowZone: 'css-1wy0on6',
selectControl: 'css-bdfdb-control',
selectControlDark: 'css-15ejc46-control',
selectControlLight: 'css-oc2jo8-control',
selectDummyInput: 'css-gj7qu5-dummyInput',
selectHasValue: 'css-bdfdb-hasValue',
selectIsOpen: 'css-bdfdb-isOpen',
selectMenu: 'css-1ye7vu0',
selectMenuOuter: 'css-bdfdb-menuOuter',
selectMenuOuterDark: 'css-ua3v5p-menu',
selectMenuOuterLight: 'css-1ea7eys-menu',
selectOption: 'css-bdfdb-option',
selectOptionDark: 'css-1aymab5-option',
selectOptionLight: 'css-ddw2o3-option',
selectOptionHoverDark: 'css-1gnr91b-option',
selectOptionHoverLight: 'css-qgio2y-option',
selectOptionSelectDark: 'css-12o7ek3-option',
selectOptionSelectLight: 'css-1kft5vg-option',
selectSingle: 'css-bdfdb-singleValue',
selectSingleDark: 'css-1k00wn6-singleValue',
selectSingleLight: 'css-6nrxdk-singleValue',
selectValue: 'css-1hwfws3',
splashBackground: 'splashBackground-1FRCko',
themeDark: 'theme-dark',
2019-08-15 15:24:34 +02:00
themeLight: 'theme-light',
themeUndefined: 'theme-undefined'
2019-07-23 21:09:07 +02:00
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
DiscordClassModules.AccountDetails = BDFDB.WebModules.findByProperties('usernameContainer', 'container');
DiscordClassModules.ActivityFeed = BDFDB.WebModules.findByProperties('activityFeed');
DiscordClassModules.Anchor = BDFDB.WebModules.findByProperties('anchor', 'anchorUnderlineOnHover');
2019-09-09 08:07:41 +02:00
DiscordClassModules.AppBase = BDFDB.WebModules.findByProperties('container', 'base');
2019-07-23 21:09:07 +02:00
DiscordClassModules.AppMount = BDFDB.WebModules.findByProperties('appMount');
DiscordClassModules.AppInner = BDFDB.WebModules.findByProperties('app');
DiscordClassModules.AppOuter = BDFDB.WebModules.find(module => typeof module.app == 'string' && module != DiscordClassModules.AppInner);
DiscordClassModules.AuditLog = BDFDB.WebModules.findByProperties('auditLog');
DiscordClassModules.AuthBox = BDFDB.WebModules.findByProperties('authBox');
DiscordClassModules.Autocomplete = BDFDB.WebModules.findByProperties('autocomplete', 'autocompleteRow');
DiscordClassModules.Avatar = BDFDB.WebModules.findByProperties('avatar', 'mask', 'wrapper');
DiscordClassModules.AvatarIcon = BDFDB.WebModules.findByProperties('iconActiveLarge', 'iconActiveMedium');
DiscordClassModules.Backdrop = BDFDB.WebModules.findByProperties('backdrop');
DiscordClassModules.Badge = BDFDB.WebModules.findByProperties('numberBadge', 'textBadge', 'iconBadge');
DiscordClassModules.BotTag = BDFDB.WebModules.findByProperties('botTag', 'botTagInvert');
DiscordClassModules.Button = BDFDB.WebModules.findByProperties('colorBlack', 'button');
2019-09-06 00:32:27 +02:00
DiscordClassModules.Call = BDFDB.WebModules.findByProperties('callAvatarWrapper', 'video');
2019-07-23 21:09:07 +02:00
DiscordClassModules.CallCurrent = BDFDB.WebModules.findByProperties('wrapper', 'fullScreen');
DiscordClassModules.CallDetails = BDFDB.WebModules.findByProperties('container', 'hotspot');
DiscordClassModules.CallIncoming = BDFDB.WebModules.findByProperties('incomingCall', 'container');
DiscordClassModules.CallIncomingInner = BDFDB.WebModules.findByProperties('incomingCallInner', 'members');
DiscordClassModules.Card = BDFDB.WebModules.findByProperties('card', 'cardBrand');
DiscordClassModules.CardStatus = BDFDB.WebModules.findByProperties('reset', 'error', 'card');
DiscordClassModules.CardStore = BDFDB.WebModules.findByProperties('card', 'interactive', 'url');
DiscordClassModules.Category = BDFDB.WebModules.findByProperties('wrapper', 'children', 'muted');
DiscordClassModules.CategoryContainer = BDFDB.WebModules.findByProperties('addButtonIcon', 'containerDefault');
DiscordClassModules.ChangeLog = BDFDB.WebModules.findByProperties('added', 'fixed', 'improved', 'progress');
DiscordClassModules.Channel = BDFDB.WebModules.findByProperties('wrapper', 'content', 'modeSelected');;
DiscordClassModules.ChannelContainer = BDFDB.WebModules.findByProperties('actionIcon', 'containerDefault');
DiscordClassModules.ChannelTextArea = BDFDB.WebModules.findByProperties('textArea', 'attachButtonDivider');
DiscordClassModules.ChannelTextAreaButton = BDFDB.WebModules.findByProperties('buttonWrapper', 'active');
DiscordClassModules.ChannelWindow = BDFDB.WebModules.findByProperties('chat', 'channelTextArea');
DiscordClassModules.Checkbox = BDFDB.WebModules.findByProperties('checkboxWrapper', 'round');
2019-08-15 15:24:34 +02:00
DiscordClassModules.ColorPicker = BDFDB.WebModules.findByProperties('colorPickerCustom', 'customColorPickerInput');
DiscordClassModules.ColorPickerInner = BDFDB.WebModules.findByProperties('saturation', 'hue', 'wrapper');
2019-07-23 21:09:07 +02:00
DiscordClassModules.ContextMenu = BDFDB.WebModules.findByProperties('contextMenu', 'itemGroup');
DiscordClassModules.ContextMenuCheckbox = BDFDB.WebModules.findByProperties('checkboxInner', 'checkboxElement');
2019-09-06 09:20:32 +02:00
DiscordClassModules.CtaVerification = BDFDB.WebModules.findByProperties('attendeeCTA', 'verificationNotice');
2019-07-23 21:09:07 +02:00
DiscordClassModules.Cursor = BDFDB.WebModules.findByProperties('cursorDefault', 'userSelectNone');
2019-09-12 22:57:39 +02:00
DiscordClassModules.DmAddPopout = BDFDB.WebModules.findByProperties('popout', 'searchBarComponent');
DiscordClassModules.DmAddPopoutItems = BDFDB.WebModules.findByProperties('friendSelected', 'friendWrapper');
2019-07-23 21:09:07 +02:00
DiscordClassModules.DownloadLink = BDFDB.WebModules.findByProperties('downloadLink', 'size12');
DiscordClassModules.Embed = BDFDB.WebModules.findByProperties('embed', 'embedAuthorIcon');
DiscordClassModules.EmbedActions = BDFDB.WebModules.findByProperties('iconPlay', 'iconWrapperActive');
DiscordClassModules.EmojiPicker = BDFDB.WebModules.findByProperties('emojiPicker', 'categories');
DiscordClassModules.File = BDFDB.WebModules.findByProperties('downloadButton', 'fileNameLink');
DiscordClassModules.Flex = BDFDB.WebModules.findByProperties('alignBaseline', 'alignCenter');
DiscordClassModules.FlexChild = BDFDB.WebModules.findByProperties('flexChild', 'flex');
DiscordClassModules.FormText = BDFDB.WebModules.findByProperties('description', 'modeDefault');
DiscordClassModules.Friends = BDFDB.WebModules.findByProperties('friendsColumn', 'friendsRow');
DiscordClassModules.Game = BDFDB.WebModules.findByProperties('game', 'gameName');
DiscordClassModules.GifFavoriteButton = BDFDB.WebModules.findByProperties('gifFavoriteButton', 'showPulse');
DiscordClassModules.GiftInventory = BDFDB.WebModules.find(module => typeof module['root'] == 'string' && typeof module['body'] == 'string' && (Object.keys(module).length == 2 || Object.keys(module).length == 3));
DiscordClassModules.Guild = BDFDB.WebModules.findByProperties('wrapper', 'badgeWrapper', 'svg');
DiscordClassModules.GuildChannels = BDFDB.WebModules.findByProperties('positionedContainer', 'unreadBar');
DiscordClassModules.GuildDm = BDFDB.WebModules.find(module => typeof module['pill'] == 'string' && Object.keys(module).length == 1);
DiscordClassModules.GuildEdges = BDFDB.WebModules.findByProperties('wrapper', 'edge', 'autoPointerEvents')
2019-08-07 11:00:40 +02:00
DiscordClassModules.GuildFolder = BDFDB.WebModules.findByProperties('folder', 'expandedGuilds')
2019-09-08 08:09:34 +02:00
DiscordClassModules.GuildHeader = BDFDB.WebModules.findByProperties('header', 'name', 'bannerImage');
2019-07-23 21:09:07 +02:00
DiscordClassModules.GuildIcon = BDFDB.WebModules.findByProperties('acronym', 'selected', 'wrapper');
DiscordClassModules.GuildSettingsBanned = BDFDB.WebModules.findByProperties('bannedUser', 'bannedUserAvatar');
DiscordClassModules.GuildSettingsInvite = BDFDB.WebModules.findByProperties('countdownColumn', 'inviteSettingsInviteRow');
DiscordClassModules.GuildSettingsMember = BDFDB.WebModules.findByProperties('member', 'membersFilterPopout');
DiscordClassModules.GuildServer = BDFDB.WebModules.findByProperties('blobContainer', 'pill');
2019-09-05 08:28:37 +02:00
DiscordClassModules.GuildsItems = BDFDB.WebModules.findByProperties('guildSeparator', 'guildsError');
2019-07-23 21:09:07 +02:00
DiscordClassModules.GuildsWrapper = BDFDB.WebModules.findByProperties('scrollerWrap', 'unreadMentionsBar', 'wrapper');
DiscordClassModules.HeaderBar = BDFDB.WebModules.findByProperties('container', 'children', 'toolbar');
DiscordClassModules.HeaderBarExtras = BDFDB.WebModules.findByProperties('headerBarLoggedOut', 'search');
DiscordClassModules.HeaderBarTopic = BDFDB.WebModules.findByProperties('topic', 'expandable', 'content');
2019-09-05 09:53:30 +02:00
DiscordClassModules.HomeIcon = BDFDB.WebModules.findByProperties('homeIcon');
2019-07-23 21:09:07 +02:00
DiscordClassModules.HotKeyRecorder = BDFDB.WebModules.findByProperties('editIcon', 'recording');
DiscordClassModules.HoverCard = BDFDB.WebModules.findByProperties('card', 'active');
DiscordClassModules.IconDirection = BDFDB.WebModules.findByProperties('directionDown', 'directionUp');
DiscordClassModules.ImageWrapper = BDFDB.WebModules.findByProperties('clickable', 'imageWrapperBackground');
DiscordClassModules.InviteModal = BDFDB.WebModules.findByProperties('inviteRow', 'modal');
DiscordClassModules.Item = BDFDB.WebModules.findByProperties('item', 'side', 'header');
2019-09-05 16:17:25 +02:00
DiscordClassModules.ItemLayerContainer = BDFDB.WebModules.findByProperties('layer', 'layerContainer');
2019-09-05 10:01:13 +02:00
DiscordClassModules.Input = BDFDB.WebModules.findByProperties('inputMini', 'inputDefault');
2019-07-23 21:09:07 +02:00
DiscordClassModules.Layers = BDFDB.WebModules.findByProperties('layer', 'layers');
DiscordClassModules.Margins = BDFDB.WebModules.findByProperties('marginBottom4', 'marginCenterHorz');
2019-09-05 09:22:43 +02:00
DiscordClassModules.Member = BDFDB.WebModules.findByProperties('member', 'ownerIcon');
2019-07-23 21:09:07 +02:00
DiscordClassModules.MembersWrap = BDFDB.WebModules.findByProperties('membersWrap', 'membersGroup');
DiscordClassModules.Mention = BDFDB.WebModules.findByProperties('wrapperHover', 'wrapperNoHover');
2019-09-05 08:28:37 +02:00
DiscordClassModules.Message = BDFDB.WebModules.findByProperties('containerCozy', 'content');
2019-07-23 21:09:07 +02:00
DiscordClassModules.MessageAccessory = BDFDB.WebModules.findByProperties('embedWrapper', 'gifFavoriteButton');
DiscordClassModules.MessageBody = BDFDB.WebModules.findByProperties('buttonContainer', 'isMentioned');
DiscordClassModules.MessageFile = BDFDB.WebModules.findByProperties('cancelButton', 'filenameLinkWrapper');
DiscordClassModules.MessageMarkup = BDFDB.WebModules.findByProperties('markup');
DiscordClassModules.MessageSystem = BDFDB.WebModules.findByProperties('container', 'actionAnchor');
DiscordClassModules.MessagesPopout = BDFDB.WebModules.findByProperties('messageGroupWrapperOffsetCorrection', 'messagesPopout');
DiscordClassModules.MessagesWrap = BDFDB.WebModules.findByProperties('messagesWrapper', 'messageGroupBlocked');
DiscordClassModules.Modal = BDFDB.WebModules.findByProperties('modal', 'sizeLarge');
DiscordClassModules.ModalDivider = BDFDB.WebModules.find(module => typeof module['divider'] == 'string' && Object.keys(module).length == 1);
DiscordClassModules.ModalItems = BDFDB.WebModules.findByProperties('guildName', 'checkboxContainer');
DiscordClassModules.ModalMiniContent = BDFDB.WebModules.find(module => typeof module['modal'] == 'string' && typeof module['content'] == 'string' && typeof module['size'] == 'string' && Object.keys(module).length == 3);
DiscordClassModules.ModalWrap = BDFDB.WebModules.find(module => typeof module['modal'] == 'string' && typeof module['inner'] == 'string' && Object.keys(module).length == 2);
2019-09-06 09:20:32 +02:00
DiscordClassModules.NameContainer = DiscordClassModules.ContextMenu.subMenuContext ? BDFDB.WebModules.findByProperties('nameAndDecorators', 'name') : {};
2019-07-23 21:09:07 +02:00
DiscordClassModules.NameTag = BDFDB.WebModules.findByProperties('bot', 'nameTag');
DiscordClassModules.Note = BDFDB.WebModules.find(module => typeof module['note'] == 'string' && Object.keys(module).length == 1);
DiscordClassModules.Notice = BDFDB.WebModules.findByProperties('notice', 'noticeFacebook');
DiscordClassModules.OptionPopout = BDFDB.WebModules.findByProperties('container', 'button', 'item');
DiscordClassModules.PictureInPicture = BDFDB.WebModules.findByProperties('pictureInPicture', 'pictureInPictureWindow');
DiscordClassModules.PillWrapper = BDFDB.WebModules.find(module => typeof module['item'] == 'string' && typeof module['wrapper'] == 'string' && Object.keys(module).length == 2);
2019-09-11 14:31:41 +02:00
DiscordClassModules.PrivateChannel = BDFDB.WebModules.findByProperties('channel', 'closeButton');
DiscordClassModules.PrivateChannelActivity = BDFDB.WebModules.findByProperties('activity', 'text');
2019-07-23 21:09:07 +02:00
DiscordClassModules.PrivateChannelList = BDFDB.WebModules.findByProperties('privateChannels', 'searchBar');
DiscordClassModules.Popout = BDFDB.WebModules.findByProperties('popout', 'arrowAlignmentTop');
DiscordClassModules.PopoutActivity = BDFDB.WebModules.findByProperties('ellipsis', 'activityActivityFeed');
DiscordClassModules.QuickSelect = BDFDB.WebModules.findByProperties('quickSelectArrow', 'selected');
DiscordClassModules.QuickSwitch = BDFDB.WebModules.findByProperties('resultFocused', 'guildIconContainer');
DiscordClassModules.QuickSwitchWrap = BDFDB.WebModules.findByProperties('container', 'miscContainer');
DiscordClassModules.Reactions = BDFDB.WebModules.findByProperties('reactionBtn', 'reaction');
DiscordClassModules.RecentMentions = BDFDB.WebModules.findByProperties('recentMentionsFilterPopout', 'mentionFilter');
DiscordClassModules.Role = BDFDB.WebModules.findByProperties('roleCircle', 'roleName');
DiscordClassModules.Scroller = BDFDB.WebModules.findByProperties('firefoxFixScrollFlex', 'scroller');
DiscordClassModules.SearchBar = BDFDB.WebModules.findByProperties('container', 'clear');
DiscordClassModules.SearchPopout = BDFDB.WebModules.findByProperties('datePicker', 'searchResultChannelIconBackground');
DiscordClassModules.SearchPopoutWrap = BDFDB.WebModules.findByProperties('container', 'queryContainer');
DiscordClassModules.SearchResults = BDFDB.WebModules.findByProperties('resultsWrapper', 'searchResults');
DiscordClassModules.Select = BDFDB.WebModules.findByProperties('select', 'error', 'errorMessage');
DiscordClassModules.SettingsCloseButton = BDFDB.WebModules.findByProperties('closeButton', 'keybind');
DiscordClassModules.SettingsItems = BDFDB.WebModules.findByProperties('dividerMini', 'note');
DiscordClassModules.SettingsTable = BDFDB.WebModules.findByProperties('headerOption', 'headerSize');
DiscordClassModules.SettingsWindow = BDFDB.WebModules.findByProperties('contentRegion', 'standardSidebarView');
DiscordClassModules.Slider = BDFDB.WebModules.findByProperties('slider', 'grabber');
DiscordClassModules.Spoiler = BDFDB.WebModules.findByProperties('spoilerContainer', 'hidden');
DiscordClassModules.Switch = BDFDB.WebModules.findByProperties('switchDisabled', 'valueChecked');
DiscordClassModules.Table = BDFDB.WebModules.findByProperties('stickyHeader', 'emptyStateText');
DiscordClassModules.Text = BDFDB.WebModules.findByProperties('defaultColor', 'defaultMarginh1');
2019-09-06 00:32:27 +02:00
DiscordClassModules.TextSize = BDFDB.WebModules.findByProperties('size10', 'size14', 'size20');
DiscordClassModules.TextStyle = BDFDB.WebModules.findByProperties('large', 'primary', 'selectable');
2019-07-23 21:09:07 +02:00
DiscordClassModules.TextWeight = BDFDB.WebModules.findByProperties('weightBold', 'weightSemiBold');
2019-09-06 00:32:27 +02:00
DiscordClassModules.Title = BDFDB.WebModules.findByProperties('title', 'size18');
2019-07-23 21:09:07 +02:00
DiscordClassModules.TitleBar = BDFDB.WebModules.findByProperties('titleBar', 'wordmark');
DiscordClassModules.Tooltip = BDFDB.WebModules.findByProperties('tooltip', 'tooltipTop');
DiscordClassModules.Typing = BDFDB.WebModules.findByProperties('cooldownWrapper', 'typing');
DiscordClassModules.UserPopout = BDFDB.WebModules.findByProperties('userPopout', 'headerPlaying');
DiscordClassModules.UserProfile = BDFDB.WebModules.findByProperties('topSectionNormal', 'tabBarContainer');
DiscordClassModules.Video = BDFDB.WebModules.findByProperties('video', 'fullScreen');
DiscordClassModules.Voice = BDFDB.WebModules.findByProperties('avatarSpeaking', 'voiceUser');
BDFDB.DiscordClassModules = Object.assign({}, DiscordClassModules);
var DiscordClasses = {
_bdguild: ['BDrepo', 'bdGuild'],
_bdguildanimatable: ['BDrepo', 'bdGuildAnimatable'],
_bdguildaudio: ['BDrepo', 'bdGuildAudio'],
_bdguildselected: ['BDrepo', 'bdGuildSelected'],
_bdguildseparator: ['BDrepo', 'bdGuildSeparator'],
_bdguildunread: ['BDrepo', 'bdGuildUnread'],
_bdguildvideo: ['BDrepo', 'bdGuildVideo'],
_bdpillselected: ['BDrepo', 'bdPillSelected'],
_bdpillunread: ['BDrepo', 'bdPillUnread'],
_bdv2button: ['BDv2repo', 'bdButton'],
_bdv2card: ['BDv2repo', 'bdCard'],
_bdv2hastooltip: ['BDv2repo', 'bdHasTooltip'],
_bdv2materialdesignicon: ['BDv2repo', 'bdMaterialDesignIcon'],
_bdv2tooltipopen: ['BDv2repo', 'vTooltipOpen'],
_repoauthor: ['BDrepo', 'bdaAuthor'],
_repocheckbox: ['BDrepo', 'switchCheckbox'],
_repocheckboxchecked: ['BDrepo', 'switchChecked'],
_repocheckboxinner: ['BDrepo', 'switch'],
_repocheckboxitem: ['BDrepo', 'switchItem'],
_repocheckboxwrap: ['BDrepo', 'switchWrapper'],
_repocontrols: ['BDrepo', 'bdaControls'],
_repodescription: ['BDrepo', 'bdaDescription'],
_repodescriptionwrap: ['BDrepo', 'bdaDescriptionWrap'],
_repofolderbutton: ['BDrepo', 'bdPfbtn'],
_repofooter: ['BDrepo', 'bdaFooter'],
_repoheader: ['BDrepo', 'bdaHeader'],
_repoheadertitle: ['BDrepo', 'bdaHeaderTitle'],
_repolist: ['BDrepo', 'bdaSlist'],
_repolink: ['BDrepo', 'bdaLink'],
_repolinks: ['BDrepo', 'bdaLinks'],
_reponame: ['BDrepo', 'bdaName'],
_reposettingsbutton: ['BDrepo', 'bdaSettingsButton'],
_reposettingsopen: ['BDrepo', 'settingsOpen'],
_reposettingsclosed: ['BDrepo', 'settingsClosed'],
_repoversion: ['BDrepo', 'bdaVersion'],
accountinfo: ['AccountDetails', 'container'],
accountinfodetails: ['AccountDetails', 'usernameContainer'],
accountinfousername: ['AccountDetails', 'username'],
activityfeed: ['ActivityFeed', 'activityFeed'],
alignbaseline: ['Flex', 'alignBaseline'],
aligncenter: ['Flex', 'alignCenter'],
alignend: ['Flex', 'alignEnd'],
alignstart: ['Flex', 'alignStart'],
alignstretch: ['Flex', 'alignStretch'],
anchor: ['Anchor', 'anchor'],
anchorunderlineonhover: ['Anchor', 'anchorUnderlineOnHover'],
app: ['AppOuter', 'app'],
appcontainer: ['AppBase', 'container'],
appmount: ['AppMount', 'appMount'],
applicationstore: ['NotFound', 'applicationStore'],
appold: ['AppInner', 'app'],
auditlog: ['AuditLog', 'auditLog'],
auditloguserhook: ['AuditLog', 'userHook'],
authbox: ['AuthBox', 'authBox'],
autocomplete: ['Autocomplete', 'autocomplete'],
autocomplete2: ['ChannelTextArea', 'autocomplete'],
autocompleteavatarstatus: ['Autocomplete', 'avatarStatus'],
autocompletecontent: ['Autocomplete', 'content'],
autocompletecontenttitle: ['Autocomplete', 'contentTitle'],
autocompletedescription: ['Autocomplete', 'description'],
autocompletedescriptiondiscriminator: ['Autocomplete', 'descriptionDiscriminator'],
autocompletedescriptionusername: ['Autocomplete', 'descriptionUsername'],
autocompleteicon: ['Autocomplete', 'icon'],
autocompleteiconforeground: ['Autocomplete', 'iconForeground'],
autocompleteinner: ['Autocomplete', 'autocompleteInner'],
autocompleterow: ['Autocomplete', 'autocompleteRow'],
autocompleterowhorizontal: ['Autocomplete', 'autocompleteRowHorizontal'],
autocompleterowvertical: ['Autocomplete', 'autocompleteRowVertical'],
autocompleteselectable: ['Autocomplete', 'selectable'],
autocompleteselected: ['Autocomplete', 'selectorSelected'],
autocompleteselector: ['Autocomplete', 'selector'],
avatar: [DiscordClassModules.Avatar.avatar ? 'Avatar' : 'Message', 'avatar'],
avatarcursordefault: ['Avatar', 'cursorDefault'],
avataricon: ['AvatarIcon', 'icon'],
avatariconactivelarge: ['AvatarIcon', 'iconActiveLarge'],
avatariconactivemedium: ['AvatarIcon', 'iconActiveMedium'],
avatariconactivemini: ['AvatarIcon', 'iconActiveMini'],
avatariconactivesmall: ['AvatarIcon', 'iconActiveSmall'],
avatariconactivexlarge: ['AvatarIcon', 'iconActiveXLarge'],
avatariconinactive: ['AvatarIcon', 'iconInactive'],
avatariconsizelarge: ['AvatarIcon', 'iconSizeLarge'],
avatariconsizemedium: ['AvatarIcon', 'iconSizeMedium'],
avatariconsizemini: ['AvatarIcon', 'iconSizeMini'],
avatariconsizesmall: ['AvatarIcon', 'iconSizeSmall'],
avatariconsizexlarge: ['AvatarIcon', 'iconSizeXLarge'],
avatarmask: ['Avatar', 'mask'],
avatarnoicon: ['AvatarIcon', 'noIcon'],
avatarpointer: ['Avatar', 'pointer'],
avatarpointerevents: ['Avatar', 'pointerEvents'],
avatarverifiedicon: ['AvatarIcon', 'verifiedIcon'],
avatarwrapper: ['Avatar', 'wrapper'],
backdrop: ['Backdrop', 'backdrop'],
badgewrapper: ['NotFound', 'badgeWrapper'],
bottag: ['BotTag', 'botTag'],
bottaginvert: ['BotTag', 'botTagInvert'],
bottagmessage: ['Message', 'botTag'],
bottagmessagecompact: ['Message', 'botTagCompact'],
bottagmessagecozy: ['Message', 'botTagCozy'],
bottagnametag: ['NameTag', 'bot'],
bottagregular: ['BotTag', 'botTagRegular'],
button: ['Button', 'button'],
buttoncolorblack: ['Button', 'colorBlack'],
buttoncolorbrand: ['Button', 'colorBrand'],
buttoncolorgreen: ['Button', 'colorGreen'],
buttoncolorgrey: ['Button', 'colorGrey'],
buttoncolorlink: ['Button', 'colorLink'],
buttoncolorprimary: ['Button', 'colorPrimary'],
buttoncolorred: ['Button', 'colorRed'],
buttoncolortransparent: ['Button', 'colorTransparent'],
buttoncolorwhite: ['Button', 'colorWhite'],
buttoncoloryellow: ['Button', 'colorYellow'],
buttoncontents: ['Button', 'contents'],
buttondisabledoverlay: ['Button', 'disabledButtonOverlay'],
buttondisabledwrapper: ['Button', 'disabledButtonWrapper'],
buttonfullwidth: ['Button', 'fullWidth'],
buttongrow: ['Button', 'grow'],
buttonhashover: ['Button', 'hasHover'],
buttonhoverblack: ['Button', 'hoverBlack'],
buttonhoverbrand: ['Button', 'hoverBrand'],
buttonhovergreen: ['Button', 'hoverGreen'],
buttonhovergrey: ['Button', 'hoverGrey'],
buttonhoverlink: ['Button', 'hoverLink'],
buttonhoverprimary: ['Button', 'hoverPrimary'],
buttonhoverred: ['Button', 'hoverRed'],
buttonhovertransparent: ['Button', 'hoverTransparent'],
buttonhoverwhite: ['Button', 'hoverWhite'],
buttonhoveryellow: ['Button', 'hoverYellow'],
buttonlookblank: ['Button', 'lookBlank'],
buttonlookfilled: ['Button', 'lookFilled'],
buttonlookghost: ['Button', 'lookGhost'],
buttonlookinverted: ['Button', 'lookInverted'],
buttonlooklink: ['Button', 'lookLink'],
buttonlookoutlined: ['Button', 'lookOutlined'],
buttonsizeicon: ['Button', 'sizeIcon'],
buttonsizelarge: ['Button', 'sizeLarge'],
buttonsizemax: ['Button', 'sizeMax'],
buttonsizemedium: ['Button', 'sizeMedium'],
buttonsizemin: ['Button', 'sizeMin'],
buttonsizesmall: ['Button', 'sizeSmall'],
buttonsizexlarge: ['Button', 'sizeXlarge'],
buttonspinner: ['Button', 'spinner'],
buttonspinneritem: ['Button', 'spinnerItem'],
buttonsubmitting: ['Button', 'submitting'],
2019-09-06 00:32:27 +02:00
callavatar: ['Call', DiscordClassModules.Call.callAvatar ? 'callAvatar' : 'callAvatarVideo'],
2019-07-23 21:09:07 +02:00
callavatarwrapper: ['Call', 'callAvatarWrapper'],
callcurrentcontainer: ['CallCurrent', 'wrapper'],
callcurrentdetails: ['CallDetails', 'container'],
callcurrentvideo: ['Video', 'video'],
callincoming: ['CallIncoming', 'incomingCall'],
callincomingcontainer: ['CallIncoming', 'container'],
callincominginner: ['CallIncomingInner', 'incomingCallInner'],
callmembers: ['CallIncomingInner', 'members'],
callselected: ['Call', 'selected'],
callvideo: ['Call', 'video'],
card: ['Card', 'card'],
cardbrand: ['Card', 'cardBrand'],
cardbrandoutline: ['Card', 'cardBrandOutline'],
carddanger: ['Card', 'cardDanger'],
carddangeroutline: ['Card', 'cardDangerOutline'],
cardprimary: ['Card', 'cardPrimary'],
cardprimaryeditable: ['Card', 'cardPrimaryEditable'],
cardprimaryoutline: ['Card', 'cardPrimaryOutline'],
cardprimaryoutlineeditable: ['Card', 'cardPrimaryOutlineEditable'],
cardstore: ['CardStore', 'card'],
cardstoreinteractive: ['CardStore', 'interactive'],
cardsuccess: ['Card', 'cardSuccess'],
cardsuccessoutline: ['Card', 'cardSuccessOutline'],
cardwarning: ['Card', 'cardWarning'],
cardwarningoutline: ['Card', 'cardWarningOutline'],
categorychildren: ['Category', 'children'],
categoryclickable: ['Category', 'clickable'],
categorycollapsed: ['Category', 'collapsed'],
categorycontainerdefault: ['CategoryContainer', 'containerDefault'],
categorydisabled: ['CategoryContainer', 'disabled'],
categoryicon: ['Category', 'icon'],
categoryiconvisibility: ['CategoryContainer', 'iconVisibility'],
categorymuted: ['Category', 'muted'],
categoryname: ['Category', 'name'],
categoryselected: ['CategoryContainer', 'selected'],
categorywrapper: ['Category', 'wrapper'],
changelogadded: ['ChangeLog', 'added'],
changelogfixed: ['ChangeLog', 'fixed'],
changelogimproved: ['ChangeLog', 'improved'],
changelogprogress: ['ChangeLog', 'added'],
changelogtitle: ['ChangeLog', 'title'],
channelactionicon: ['ChannelContainer', 'actionIcon'],
channelchildren: ['Channel', 'children'],
channelcontainerdefault: ['ChannelContainer', 'containerDefault'],
channelcontent: ['Channel', 'content'],
channeldisabled: ['ChannelContainer', 'disabled'],
channelheaderchannelname: ['ChannelWindow', 'channelName'],
channelheaderchildren: ['HeaderBar', 'children'],
channelheaderdivider: ['HeaderBar', 'divider'],
channelheaderheaderbar: ['HeaderBar', 'container'],
channelheaderheaderbartitle: ['HeaderBar', 'title'],
channelheadericon: ['HeaderBar', 'icon'],
channelheadericonbadge: ['HeaderBar', 'iconBadge'],
channelheadericonclickable: ['HeaderBar', 'clickable'],
channelheadericonselected: ['HeaderBar', 'selected'],
channelheadericonwrapper: ['HeaderBar', 'iconWrapper'],
channelheadertitle: ['ChannelWindow', 'title'],
channelheadertitlewrapper: ['ChannelWindow', 'titleWrapper'],
channelheadersearch: ['HeaderBarExtras', 'search'],
channelheadertoolbar: ['HeaderBar', 'toolbar'],
channelheadertoolbar2: ['HeaderBarExtras', 'toolbar'],
channelheadertopic: ['HeaderBarTopic', 'topic'],
channelicon: ['Channel', 'icon'],
channeliconvisibility: ['ChannelContainer', 'iconVisibility'],
channelmodeconnected: ['Channel', 'modeConnected'],
channelmodelocked: ['Channel', 'modeLocked'],
channelmodemuted: ['Channel', 'modeMuted'],
channelmodeselected: ['Channel', 'modeSelected'],
channelmodeunread: ['Channel', 'modeUnread'],
channelname: ['Channel', 'name'],
2019-09-10 00:15:27 +02:00
channels: ['AppBase', 'sidebar'],
2019-07-23 21:09:07 +02:00
channelselected: ['ChannelContainer', 'selected'],
channelsscroller: ['GuildChannels', 'scroller'],
channelunread: ['Channel', 'unread'],
channelwrapper: ['Channel', 'wrapper'],
chat: ['ChannelWindow', 'chat'],
chatbase: ['AppBase', 'base'],
chatcontent: ['ChannelWindow', 'content'],
2019-09-10 00:15:27 +02:00
chatspacer: ['AppBase', 'content'],
2019-07-23 21:09:07 +02:00
checkbox: ['Checkbox', 'checkbox'],
checkboxchecked: ['Checkbox', 'checked'],
checkboxcontainer: ['ModalItems', 'checkboxContainer'],
checkboxinput: ['Checkbox', 'input'],
checkboxinputdefault: ['Checkbox', 'inputDefault'],
checkboxinputdisabled: ['Checkbox', 'inputDisabled'],
checkboxround: ['Checkbox', 'round'],
checkboxwrapper: ['Checkbox', 'checkboxWrapper'],
checkboxwrapperdisabled: ['Checkbox', 'checkboxWrapperDisabled'],
clickable: ['Message', 'clickOverride'],
clickable: ['Message', 'clickOverride'],
2019-08-15 15:24:34 +02:00
colorpicker: ['ColorPicker', 'colorPickerCustom'],
colorpickerhexinput: ['ColorPicker', 'customColorPickerInput'],
colorpickerhue: ['ColorPickerInner', 'hue'],
colorpickerinner: ['ColorPickerInner', 'wrapper'],
colorpickerrow: ['ColorPicker', 'colorPickerRow'],
colorpickersaturation: ['ColorPickerInner', 'saturation'],
colorpickerswatch: ['ColorPicker', 'colorPickerSwatch'],
colorpickerswatchcustom: ['ColorPicker', 'custom'],
colorpickerswatchdefault: ['ColorPicker', 'default'],
colorpickerswatchdisabled: ['ColorPicker', 'disabled'],
colorpickerswatchdropper: ['ColorPicker', 'colorPickerDropper'],
colorpickerswatchdropperfg: ['ColorPicker', 'colorPickerDropperFg'],
colorpickerswatchnocolor: ['ColorPicker', 'noColor'],
2019-07-23 21:09:07 +02:00
contentregion: ['SettingsWindow', 'contentRegion'],
contextmenu: ['ContextMenu', 'contextMenu'],
contextmenucheckbox: ['ContextMenuCheckbox', 'checkbox'],
contextmenucheckbox2: ['ContextMenu', 'checkbox'],
contextmenucheckboxdisabled: ['ContextMenuCheckbox', 'disabled'],
contextmenucheckboxinner: ['ContextMenuCheckbox', 'checkboxInner'],
contextmenucheckboxelement: ['ContextMenuCheckbox', 'checkboxElement'],
contextmenuhint: ['ContextMenu', 'hint'],
contextmenuinvertchildx: ['ContextMenu', 'invertChildX'],
contextmenuitem: ['ContextMenu', 'item'],
contextmenuitembrand: ['ContextMenu', 'brand'],
2019-09-06 09:20:32 +02:00
contextmenuitemclickable: [DiscordClassModules.ContextMenu.subMenuContext ? 'ContextMenu' : 'NotFound', DiscordClassModules.ContextMenu.subMenuContext ? 'clickable' : '_'],
2019-07-23 21:09:07 +02:00
contextmenuitemdanger: ['ContextMenu', 'danger'],
contextmenuitemdisabled: ['ContextMenu', 'disabled'],
contextmenuitemgroup: ['ContextMenu', 'itemGroup'],
contextmenuitemtoggle: ['ContextMenu', 'itemToggle'],
2019-09-05 09:24:14 +02:00
contextmenuitemselected: ['ContextMenu', 'selected'],
2019-07-23 21:09:07 +02:00
contextmenuitemslider: ['ContextMenu', 'itemSlider'],
contextmenuitemsubmenu: ['ContextMenu', 'itemSubMenu'],
2019-09-06 09:20:32 +02:00
contextmenuitemsubmenucaret: [DiscordClassModules.ContextMenu.subMenuContext ? 'ContextMenu' : 'NotFound', DiscordClassModules.ContextMenu.subMenuContext ? 'caret' : '_'],
2019-07-23 21:09:07 +02:00
contextmenulabel: ['ContextMenu', 'label'],
contextmenuscroller: ['ContextMenu', 'scroller'],
contextmenuslider: ['ContextMenu', 'slider'],
2019-09-05 16:17:25 +02:00
contextmenusubcontext: ['ContextMenu', 'subMenuContext'],
2019-07-23 21:09:07 +02:00
cooldownwrapper: ['Typing', 'cooldownWrapper'],
cursordefault: ['Cursor', 'cursorDefault'],
cursorpointer: ['Cursor', 'cursorPointer'],
defaultcolor: ['Text', 'defaultColor'],
description: ['FormText', 'description'],
directioncolumn: ['Flex', 'directionColumn'],
directiondown: ['IconDirection', 'directionDown'],
directionleft: ['IconDirection', 'directionLeft'],
directionright: ['IconDirection', 'directionRight'],
directionrow: ['Flex', 'directionRow'],
directionrowreverse: ['Flex', 'directionRowReverse'],
directionup: ['IconDirection', 'directionUp'],
directiontransition: ['IconDirection', 'transition'],
disabled: ['SettingsItems', 'disabled'],
2019-09-17 13:29:21 +02:00
discriminator: ['NameTag', 'discriminator'],
2019-07-23 21:09:07 +02:00
dmchannel: ['PrivateChannel', 'channel'],
2019-09-11 14:31:41 +02:00
dmchannelactivity: ['PrivateChannelActivity', 'activity'],
dmchannelactivityicon: ['PrivateChannelActivity', 'icon'],
dmchannelactivitytext: ['PrivateChannelActivity', 'text'],
dmchannelclose: ['PrivateChannel', 'closeButton'],
2019-09-11 15:48:41 +02:00
dmchannelheader: ['PrivateChannelList', 'header'],
2019-07-23 21:09:07 +02:00
dmchannelnamewithactivity: ['PrivateChannel', 'nameWithActivity'],
dmchannels: ['PrivateChannelList', 'privateChannels'],
dmpill: ['GuildDm', 'pill'],
downloadlink: ['DownloadLink', 'downloadLink'],
ellipsis: ['PopoutActivity', 'ellipsis'],
embed: ['Embed', 'embed'],
embedauthor: ['Embed', 'embedAuthor'],
embedauthoricon: ['Embed', 'embedAuthorIcon'],
embedauthorname: ['Embed', 'embedAuthorName'],
embedauthornamelink: ['Embed', 'embedAuthorNameLink'],
embedcentercontent: ['Embed', 'centerContent'],
embedcontent: ['Embed', 'embedContent'],
embedcontentinner: ['Embed', 'embedContentInner'],
embeddescription: ['Embed', 'embedDescription'],
embedfield: ['Embed', 'embedField'],
embedfieldinline: ['Embed', 'embedFieldInline'],
embedfieldname: ['Embed', 'embedFieldName'],
embedfields: ['Embed', 'embedFields'],
embedfieldvalue: ['Embed', 'embedFieldValue'],
embedfooter: ['Embed', 'embedFooter'],
embedfootericon: ['Embed', 'embedFooterIcon'],
embedfooterseparator: ['Embed', 'embedFooterSeparator'],
embedfootertext: ['Embed', 'embedFooterText'],
embedgiftag: ['Embed', 'embedGIFTag'],
embedgifv: ['Embed', 'embedGIFV'],
embedhiddenspoiler: ['Embed', 'hiddenSpoiler'],
embedhighbackgroundopacity: ['Embed', 'highBackgroundOpacity'],
embediframe: ['Embed', 'embedIframe'],
embedimage: ['Embed', 'embedImage'],
embedinner: ['Embed', 'embedInner'],
embedlink: ['Embed', 'embedLink'],
embedlowbackgroundopacity: ['Embed', 'lowBackgroundOpacity'],
embedmargin: ['Embed', 'embedMargin'],
embedmarginlarge: ['Embed', 'embedMarginLarge'],
2019-08-28 10:06:31 +02:00
embedmediumbackgroundopacity: ['Embed', 'mediumBackgroundOpacity'],
2019-07-23 21:09:07 +02:00
embedpill: ['Embed', 'embedPill'],
embedprovider: ['Embed', 'embedProvider'],
embedproviderlink: ['Embed', 'embedProviderLink'],
embedspoilerattachment: ['Embed', 'spoilerAttachment'],
embedspoilerembed: ['Embed', 'spoilerEmbed'],
embedspotify: ['Embed', 'embedSpotify'],
embedthumbnail: ['Embed', 'embedThumbnail'],
embedtitle: ['Embed', 'embedTitle'],
embedtitlelink: ['Embed', 'embedTitleLink'],
embedvideo: ['Embed', 'embedVideo'],
embedvideoaction: ['Embed', 'embedVideoAction'],
embedvideoactions: ['Embed', 'embedVideoActions'],
embedvideoimagecomponent: ['Embed', 'embedVideoImageComponent'],
embedvideoimagecomponentinner: ['Embed', 'embedVideoImageComponentInner'],
embedwrapper: ['MessageAccessory', 'embedWrapper'],
emojipicker: ['EmojiPicker', 'emojiPicker'],
emojipickeractivity: ['EmojiPicker', 'activity'],
emojipickerbutton: ['Reactions', 'reactionBtn'],
emojipickercategories: ['EmojiPicker', 'categories'],
emojipickercategory: ['EmojiPicker', 'category'],
emojipickercustom: ['EmojiPicker', 'custom'],
emojipickerdimmer: ['EmojiPicker', 'dimmer'],
emojipickerdisabled: ['EmojiPicker', 'disabled'],
emojipickerdiversityselector: ['EmojiPicker', 'diversitySelector'],
emojipickeremojiitem: ['EmojiPicker', 'emojiItem'],
emojipickerflags: ['EmojiPicker', 'flags'],
emojipickerfood: ['EmojiPicker', 'food'],
emojipickerheader: ['EmojiPicker', 'header'],
emojipickeritem: ['EmojiPicker', 'item'],
emojipickernature: ['EmojiPicker', 'nature'],
emojipickerobjects: ['EmojiPicker', 'objects'],
emojipickerpeople: ['EmojiPicker', 'people'],
emojipickerpopout: ['EmojiPicker', 'popout'],
emojipickerpremiumpromo: ['EmojiPicker', 'premiumPromo'],
emojipickerpremiumpromoclose: ['EmojiPicker', 'premiumPromoClose'],
emojipickerpremiumpromodescription: ['EmojiPicker', 'premiumPromoDescription'],
emojipickerpremiumpromoimage: ['EmojiPicker', 'premiumPromoImage'],
emojipickerpremiumpromotitle: ['EmojiPicker', 'premiumPromoTitle'],
emojipickerrecent: ['EmojiPicker', 'recent'],
emojipickerrow: ['EmojiPicker', 'row'],
emojipickersearchbar: ['EmojiPicker', 'searchBar'],
emojipickerscroller: ['EmojiPicker', 'scroller'],
emojipickerscrollerwrap: ['EmojiPicker', 'scrollerWrap'],
emojipickerselected: ['EmojiPicker', 'selected'],
emojipickerspriteitem: ['EmojiPicker', 'spriteItem'],
emojipickerstickyheader: ['EmojiPicker', 'stickyHeader'],
emojipickersymbols: ['EmojiPicker', 'symbols'],
emojipickertravel: ['EmojiPicker', 'travel'],
emojipickervisible: ['EmojiPicker', 'visible'],
fileattachment: ['File', 'attachment'],
fileattachmentinner: ['File', 'attachmentInner'],
filecancelbutton: ['File', 'cancelButton'],
filedownloadbutton: ['File', 'downloadButton'],
filename: ['File', 'filename'],
filenamelink: ['File', 'fileNameLink'],
filenamelinkwrapper: ['File', 'filenameLinkWrapper'],
filenamewrapper: ['File', 'filenameWrapper'],
firefoxfixscrollflex: ['Scroller', 'firefoxFixScrollFlex'],
2019-09-18 10:19:56 +02:00
flex: ['FlexChild', 'flex'],
flex2: ['Flex', 'flex'],
2019-07-23 21:09:07 +02:00
flexcenter: ['Flex', 'flexCenter'],
flexchild: ['FlexChild', 'flexChild'],
flexmarginreset: ['FlexChild', 'flexMarginReset'],
formtext: ['FormText', 'formText'],
friends: ['Friends', 'container'],
friendscolumn: ['Friends', 'friendsColumn'],
friendscolumnnamewrap: ['Friends', 'friendsColumnName'],
friendsrow: ['Friends', 'friendsRow'],
friendstable: ['Friends', 'friendsTable'],
friendstableheader: ['Friends', 'friendsTableHeader'],
friendsusername: ['Friends', 'username'],
game: ['Game', 'game'],
gamelibrary: ['NotFound', 'gameLibrary'],
gamelibrarytable: ['Table', 'table'],
gamelibrarytableheader: ['Table', 'header'],
gamelibrarytablestickyheader: ['Table', 'stickyHeader'],
gamename: ['Game', 'gameName'],
gamenameinput: ['Game', 'gameNameInput'],
giffavoritebutton: ['MessageAccessory', 'gifFavoriteButton'],
giffavoritecolor: ['GifFavoriteButton', 'gifFavoriteButton'],
giffavoriteicon: ['GifFavoriteButton', 'icon'],
giffavoriteshowpulse: ['GifFavoriteButton', 'showPulse'],
giffavoritesize: ['GifFavoriteButton', 'size'],
giffavoriteselected: ['GifFavoriteButton', 'selected'],
giftinventory: ['GiftInventory', 'root'],
guildbadgebase: ['Badge', 'base'],
guildbadgeicon: ['Badge', 'icon'],
guildbadgeiconbadge: ['Badge', 'iconBadge'],
guildbadgeiconbadge2: ['GuildsItems', 'iconBadge'],
guildbadgenumberbadge: ['Badge', 'numberBadge'],
guildbadgetextbadge: ['Badge', 'textBadge'],
guildbadgewrapper: ['Guild', 'badgeWrapper'],
guildbuttoncontainer: ['GuildsItems', 'circleButtonMask'],
guildbuttoninner: ['GuildsItems', 'circleIconButton'],
guildbuttonicon: ['GuildsItems', 'circleIcon'],
guildbuttonpill: ['GuildsItems', 'pill'],
guildbuttonselected: ['GuildsItems', 'selected'],
guildchannels: ['NotFound', 'guildChannels'],
guildcontainer: ['GuildServer', 'blobContainer'],
guilddragfix: ['Guild', 'dragfix'],
guildedge: ['GuildEdges', 'edge'],
2019-07-29 18:56:15 +02:00
guildedgemiddle: ['GuildEdges', 'middle'],
2019-07-23 21:09:07 +02:00
guildedgewrapper: ['GuildEdges', 'wrapper'],
2019-08-07 11:00:40 +02:00
guildfolder: ['GuildFolder', 'folder'],
guildfolderexpandendbackground: ['GuildFolder', 'expandedFolderBackground'],
guildfolderexpandendbackgroundcollapsed: ['GuildFolder', 'collapsed'],
guildfolderexpandendbackgroundhover: ['GuildFolder', 'hover'],
guildfolderexpandedguilds: ['GuildFolder', 'expandedGuilds'],
guildfoldericonwrapperclosed: ['GuildFolder', 'closedFolderIconWrapper'],
guildfoldericonwrapperexpanded: ['GuildFolder', 'expandedFolderIconWrapper'],
guildfolderwrapper: ['GuildFolder', 'wrapper'],
2019-07-23 21:09:07 +02:00
guildheader: ['GuildHeader', 'container'],
guildheaderbanner: ['GuildHeader', 'banner'],
guildheaderbannerimage: ['GuildHeader', 'bannerImage'],
guildheaderhasdropdown: ['GuildHeader', 'hasDropdown'],
guildheaderheader: ['GuildHeader', 'header'],
guildheadername: ['GuildHeader', 'name'],
guildicon: ['GuildIcon', 'icon'],
guildiconacronym: ['GuildIcon', 'acronym'],
2019-09-10 00:15:27 +02:00
guildiconchildwrapper: ['GuildIcon', 'childWrapper'],
2019-07-23 21:09:07 +02:00
guildiconselected: ['GuildIcon', 'selected'],
guildiconwrapper: ['GuildIcon', 'wrapper'],
guildinner: ['Guild', 'wrapper'],
guildinnerwrapper: ['GuildsItems', 'listItemWrapper'],
guildlowerbadge: ['Guild', 'lowerBadge'],
guildouter: ['GuildsItems', 'listItem'],
guildpill: ['GuildServer', 'pill'],
guildpillitem: ['PillWrapper', 'item'],
guildpillwrapper: ['PillWrapper', 'wrapper'],
guildplaceholder: ['GuildsItems', 'dragInner'],
guildplaceholdermask: ['GuildsItems', 'placeholderMask'],
2019-09-10 00:15:27 +02:00
guilds: ['AppBase', 'guilds'],
2019-07-23 21:09:07 +02:00
guildseparator: ['GuildsItems', 'guildSeparator'],
guildserror: ['GuildsItems', 'guildsError'],
guildsettingsbannedcard: ['GuildSettingsBanned', 'bannedUser'],
guildsettingsbanneddiscrim: ['GuildSettingsBanned', 'discrim'],
guildsettingsbannedusername: ['GuildSettingsBanned', 'username'],
guildsettingsinvitecard: ['GuildSettingsInvite', 'inviteSettingsInviteRow'],
guildsettingsinvitechannelname: ['GuildSettingsInvite', 'channelName'],
guildsettingsinviteusername: ['GuildSettingsInvite', 'username'],
guildsettingsmembercard: ['GuildSettingsMember', 'member'],
guildsettingsmembername: ['GuildSettingsMember', 'name'],
guildsettingsmembernametag: ['GuildSettingsMember', 'nameTag'],
2019-09-09 08:07:41 +02:00
guildsscroller: ['GuildsWrapper', 'scroller'],
2019-07-23 21:09:07 +02:00
guildsscrollerwrap: ['GuildsWrapper', 'scrollerWrap'],
guildsvg: ['Guild', 'svg'],
guildswrapper: ['GuildsWrapper', 'wrapper'],
guildswrapperunreadmentionsindicatorbottom: ['GuildsWrapper', 'unreadMentionsIndicatorBottom'],
guildswrapperunreadmentionsindicatortop: ['GuildsWrapper', 'unreadMentionsIndicatorTop'],
guildupperbadge: ['Guild', 'upperBadge'],
h1: ['Text', 'h1'],
h1defaultmargin: ['Text', 'defaultMarginh1'],
h2: ['Text', 'h2'],
h2defaultmargin: ['Text', 'defaultMarginh2'],
h3: ['Text', 'h3'],
h3defaultmargin: ['Text', 'defaultMarginh3'],
h4: ['Text', 'h4'],
h4defaultmargin: ['Text', 'defaultMarginh4'],
h5: ['Text', 'h5'],
h5defaultmargin: ['Text', 'defaultMarginh5'],
headertitle: ['Text', 'title'],
2019-09-06 00:32:27 +02:00
height12: ['UserPopout', 'height12'],
height16: ['File', 'height16'],
height24: ['Title', 'height24'],
2019-07-23 21:09:07 +02:00
height36: ['Notice', 'height36'],
highlight: ['NotFound', 'highlight'],
homebutton: ['HomeIcon', 'button'],
homebuttonicon: ['HomeIcon', 'homeIcon'],
homebuttonpill: ['HomeIcon', 'pill'],
homebuttonselected: ['HomeIcon', 'selected'],
horizontal: ['FlexChild', 'horizontal'],
horizontal2: ['NotFound', '_'],
horizontalreverse: ['FlexChild', 'horizontalReverse'],
horizontalreverse2: ['NotFound', '_'],
hotkeybase: ['NotFound', '_'],
hotkeybutton: ['HotKeyRecorder', 'button'],
hotkeybutton2: ['NotFound', '_'],
hotkeycontainer: ['HotKeyRecorder', 'container'],
hotkeycontainer2: ['NotFound', '_'],
hotkeydisabled: ['HotKeyRecorder', 'disabled'],
hotkeydisabled2: ['NotFound', '_'],
hotkeyediticon: ['HotKeyRecorder', 'editIcon'],
hotkeyhasvalue: ['HotKeyRecorder', 'hasValue'],
hotkeyinput: ['HotKeyRecorder', 'input'],
hotkeyinput2: ['HotKeyRecorder', 'input'],
hotkeylayout: ['HotKeyRecorder', 'layout'],
hotkeylayout2: ['HotKeyRecorder', 'layout'],
hotkeyrecording: ['HotKeyRecorder', 'recording'],
hotkeyshadowpulse: ['HotKeyRecorder', 'shadowPulse'],
hotkeytext: ['HotKeyRecorder', 'text'],
hovercard: ['HoverCard', 'card'],
hovercardinner: ['BDFDB', 'cardInner'],
2019-09-13 12:05:32 +02:00
hovercardbutton: ['NotFound', 'hoverCardButton'],
2019-07-23 21:09:07 +02:00
icon: ['EmbedActions', 'icon'],
iconactionswrapper: ['EmbedActions', 'wrapper'],
iconexternal: ['EmbedActions', 'iconExternal'],
iconexternalmargins: ['EmbedActions', 'iconExternalMargins'],
iconplay: ['EmbedActions', 'iconPlay'],
iconwrapper: ['EmbedActions', 'iconWrapper'],
iconwrapperactive: ['EmbedActions', 'iconWrapperActive'],
imageaccessory: ['ImageWrapper', 'imageAccessory'],
imageclickable: ['ImageWrapper', 'clickable'],
imageerror: ['ImageWrapper', 'imageError'],
imageplaceholder: ['ImageWrapper', 'imagePlaceholder'],
imageplaceholderoverlay: ['ImageWrapper', 'imagePlaceholderOverlay'],
imagewrapper: ['ImageWrapper', 'imageWrapper'],
imagewrapperbackground: ['ImageWrapper', 'imageWrapperBackground'],
imagewrapperinner: ['ImageWrapper', 'imageWrapperInner'],
imagezoom: ['ImageWrapper', 'imageZoom'],
2019-09-05 16:17:25 +02:00
itemlayer: ['ItemLayerContainer', 'layer'],
itemlayerconainer: ['ItemLayerContainer', 'layerContainer'],
2019-07-23 21:09:07 +02:00
input: ['Input', 'input'],
inputdefault: ['Input', 'inputDefault'],
inputdisabled: ['Input', 'disabled'],
inputeditable: ['Input', 'editable'],
inputerror: ['Input', 'error'],
inputfocused: ['Input', 'focused'],
inputmini: ['Input', 'inputMini'],
inputsuccess: ['Input', 'success'],
inputwrapper: ['Input', 'inputWrapper'],
invitemodal: ['InviteModal', 'modal'],
invitemodalinviterow: ['InviteModal', 'inviteRow'],
invitemodalinviterowname: ['InviteModal', 'inviteRowName'],
invitemodalwrapper: ['InviteModal', 'wrapper'],
justifycenter: ['Flex', 'justifyCenter'],
justifyend: ['Flex', 'justifyEnd'],
justifystart: ['Flex', 'justifyStart'],
large: ['TextStyle', 'large'],
layer: ['Layers', 'layer'],
layers: ['Layers', 'layers'],
lfg: ['NotFound', 'lfg'],
loginscreen: ['NotFound', 'loginScreen'],
marginbottom4: ['Margins', 'marginBottom4'],
marginbottom8: ['Margins', 'marginBottom8'],
marginbottom20: ['Margins', 'marginBottom20'],
marginbottom40: ['Margins', 'marginBottom40'],
marginbottom60: ['Margins', 'marginBottom60'],
margincenterhorz: ['Margins', 'marginCenterHorz'],
marginleft4: ['Autocomplete', 'marginLeft4'],
marginleft8: ['Autocomplete', 'marginLeft8'],
marginreset: ['Margins', 'marginReset'],
margintop4: ['Margins', 'marginTop4'],
margintop8: ['Margins', 'marginTop8'],
margintop20: ['Margins', 'marginTop20'],
margintop40: ['Margins', 'marginTop40'],
margintop60: ['Margins', 'marginTop60'],
medium: ['TextStyle', 'medium'],
member: ['Member', 'member'],
membercontent: ['Member', 'memberContent'],
membericon: ['Member', 'icon'],
memberinner: ['Member', 'memberInner'],
memberownericon: ['Member', 'ownerIcon'],
memberpremiumicon: ['Member', 'premiumIcon'],
members: ['MembersWrap', 'members'],
membersgroup: ['MembersWrap', 'membersGroup'],
memberswrap: ['MembersWrap', 'membersWrap'],
2019-09-10 00:15:27 +02:00
memberusername: ['Member', 'roleColor'],
2019-07-23 21:09:07 +02:00
mention: ['NotFound', 'mention'],
mentionwrapper: ['Mention', 'wrapper'],
mentionwrapperhover: ['Mention', 'wrapperHover'],
mentionwrappernohover: ['Mention', 'wrapperNoHover'],
message: ['Message', 'message'],
messageaccessory: ['MessageAccessory', 'container'],
messageaccessorycompact: ['MessageAccessory', 'containerCompact'],
messageaccessorycozy: ['MessageAccessory', 'containerCozy'],
messageavatar: ['Message', 'avatar'],
messagebody: ['MessageBody', 'container'],
messagebodycompact: ['MessageBody', 'containerCompact'],
messagebodycozy: ['MessageBody', 'containerCozy'],
messagebuttoncontainer: ['Message', 'buttonContainer'],
messagebuttoncontainerouter: ['MessageBody', 'buttonContainer'],
messagecompact: ['Message', 'messageCompact'],
messagecontent: ['Message', 'content'],
messagecontentcompact: ['Message', 'contentCompact'],
messagecontentcozy: ['Message', 'contentCozy'],
messagecozy: ['Message', 'messageCozy'],
messagedivider: ['Message', 'divider'],
messagedividerenabled: ['Message', 'dividerEnabled'],
messageedited: ['MessageBody', 'edited'],
messagegroup: ['Message', 'container'],
messagegroupcozy: ['Message', 'containerCozy'],
messagegroupcompact: ['Message', 'containerCompact'],
messagegroupwrapper: ['MessagesPopout', 'messageGroupWrapper'],
messagegroupwrapperoffsetcorrection: ['MessagesPopout', 'messageGroupWrapperOffsetCorrection'],
messageheadercompact: ['Message', 'headerCompact'],
messageheadercozy: ['Message', 'headerCozy'],
messageheadercozymeta: ['Message', 'headerCozyMeta'],
messagelocalbotmessage: ['Message', 'localBotMessage'],
messagemarkup: ['MessageMarkup', 'markup'],
messagemarkupiscompact: ['MessageBody', 'isCompact'],
messages: ['MessagesWrap', 'messages'],
messagespopout: ['MessagesPopout', 'messagesPopout'],
messagespopoutaccessories: ['MessagesPopout', 'accessories'],
messagespopoutactionbuttons: ['MessagesPopout', 'actionButtons'],
messagespopoutbody: ['MessagesPopout', 'body'],
messagespopoutbottom: ['MessagesPopout', 'bottom'],
messagespopoutchannelname: ['MessagesPopout', 'channelName'],
messagespopoutchannelseparator: ['MessagesPopout', 'channelSeparator'],
messagespopoutclosebutton: ['MessagesPopout', 'closeButton'],
messagespopoutcomment: ['MessagesPopout', 'comment'],
messagespopoutcontainercompactbounded: ['Message', 'containerCompactBounded'],
messagespopoutcontainercozybounded: ['Message', 'containerCozyBounded'],
messagespopoutemptyplaceholder: ['MessagesPopout', 'emptyPlaceholder'],
messagespopoutfooter: ['MessagesPopout', 'footer'],
messagespopoutguildname: ['MessagesPopout', 'guildName'],
messagespopouthasmore: ['MessagesPopout', 'hasMore'],
messagespopouthasmorebutton: ['MessagesPopout', 'hasMoreButton'],
messagespopoutheader: ['MessagesPopout', 'header'],
messagespopouthidden: ['MessagesPopout', 'hidden'],
messagespopoutimage: ['MessagesPopout', 'image'],
messagespopoutjumpbutton: ['MessagesPopout', 'jumpButton'],
messagespopoutloading: ['MessagesPopout', 'loading'],
messagespopoutloadingmore: ['MessagesPopout', 'loadingMore'],
messagespopoutloadingplaceholder: ['MessagesPopout', 'loadingPlaceholder'],
messagespopoutmessagegroupcozy: ['MessagesPopout', 'messageGroupCozy'],
messagespopoutmessagegroupwrapper: ['MessagesPopout', 'messageGroupWrapper'],
messagespopoutmessagegroupwrapperoffsetcorrection: ['MessagesPopout', 'messageGroupWrapperOffsetCorrection'],
messagespopoutscrollingfooterwrap: ['MessagesPopout', 'scrollingFooterWrap'],
messagespopoutspinner: ['MessagesPopout', 'spinner'],
messagespopouttext: ['MessagesPopout', 'text'],
messagespopouttip: ['MessagesPopout', 'tip'],
messagespopouttitle: ['MessagesPopout', 'title'],
messagespopoutvisible: ['MessagesPopout', 'visible'],
messagespopoutwrap: ['MessagesPopout', 'messagesPopoutWrap'],
messageswrapper: ['MessagesWrap', 'messagesWrapper'],
messagesystem: ['MessageSystem', 'container'],
messagesystemcontent: ['MessageSystem', 'content'],
messagetimestampcompact: ['Message', 'timestampCompact'],
messagetimestampcompactismentioned: ['Message', 'timestampCompactIsMentioned'],
messagetimestampcozy: ['Message', 'timestampCozy'],
messageuploadcancel: ['MessageFile', 'cancelButton'],
messageusername: ['Message', 'username'],
modal: ['ModalWrap', 'modal'],
modalclose: ['Modal', 'close'],
modalcontent: ['Modal', 'content'],
modaldivider: ['ModalDivider', 'divider'],
modaldividerdefault: ['SettingsItems', 'dividerDefault'],
modaldividermini: ['SettingsItems', 'dividerMini'],
modalfooter: ['Modal', 'footer'],
modalguildname: ['ModalItems', 'guildName'],
modalheader: ['Modal', 'header'],
modalinner: ['ModalWrap', 'inner'],
modalmini: ['ModalMiniContent', 'modal'],
modalminicontent: ['ModalMiniContent', 'content'],
modalminisize: ['ModalMiniContent', 'size'],
2019-09-06 00:32:27 +02:00
modalminitext: ['HeaderBarTopic', 'content'],
2019-07-23 21:09:07 +02:00
modalseparator: ['Modal', 'separator'],
modalsizelarge: ['Modal', 'sizeLarge'],
modalsizemedium: ['Modal', 'sizeMedium'],
modalsizesmall: ['Modal', 'sizeSmall'],
modalsub: ['Modal', 'modal'],
modalsubinner: ['Modal', 'inner'],
modedefault: ['FormText', 'modeDefault'],
modedisabled: ['FormText', 'modeDisabled'],
modeselectable: ['FormText', 'modeSelectable'],
2019-09-11 11:06:09 +02:00
namecontainer: ['NameContainer', 'container'],
namecontainerclickable: ['NameContainer', 'clickable'],
2019-09-12 22:57:39 +02:00
namecontainercontent: ['NameContainer', 'content'],
2019-09-11 11:02:29 +02:00
namecontainerlayout: ['NameContainer', 'layout'],
2019-09-05 12:33:55 +02:00
namecontainername: ['NameContainer', 'name'],
2019-09-11 10:56:54 +02:00
namecontainernamecontainer: ['NotFound', 'nameContainerNameContainer'],
2019-09-05 16:17:25 +02:00
namecontainernamewrapper: ['NameContainer', 'nameAndDecorators'],
2019-09-05 12:33:55 +02:00
namecontainerselected: ['NameContainer', 'selected'],
2019-07-23 21:09:07 +02:00
nametag: ['NameTag', 'nameTag'],
nochannel: ['ChannelWindow', 'noChannel'],
notice: ['Notice', 'notice'],
noticebrand: ['Notice', 'noticeBrand'],
noticebutton: ['Notice', 'button'],
noticedanger: ['Notice', 'noticeDanger'],
noticedefault: ['Notice', 'noticeDefault'],
noticedismiss: ['Notice', 'dismiss'],
noticefacebook: ['Notice', 'noticeFacebook'],
noticeicon: ['Notice', 'icon'],
noticeiconandroid: ['Notice', 'iconAndroid'],
noticeiconapple: ['Notice', 'iconApple'],
noticeiconwindows: ['Notice', 'iconWindows'],
noticeinfo: ['Notice', 'noticeInfo'],
noticeplatformicon: ['Notice', 'platformIcon'],
noticepremium: ['Notice', 'noticePremium'],
noticepremiumaction: ['Notice', 'premiumAction'],
noticepremiumgrandfathered: ['Notice', 'noticePremiumGrandfathered'],
noticepremiumlogo: ['Notice', 'premiumLogo'],
noticepremiumtext: ['Notice', 'premiumText'],
noticespotify: ['Notice', 'noticeSpotify'],
noticestreamer: ['Notice', 'noticeStreamerMode'],
noticesuccess: ['Notice', 'noticeSuccess'],
noticesurvey: ['Notice', 'noticeSurvey'],
note: ['SettingsItems', 'note'],
nowrap: ['Flex', 'noWrap'],
optionpopout: ['OptionPopout', 'container'],
optionpopoutbutton: ['OptionPopout', 'button'],
2019-09-10 00:15:27 +02:00
optionpopoutbuttonicon: ['OptionPopout', 'icon'],
2019-07-23 21:09:07 +02:00
optionpopoutitem: ['OptionPopout', 'item'],
overflowellipsis: ['BDFDB', 'overflowEllipsis'],
pictureinpicture: ['PictureInPicture', 'pictureInPicture'],
pictureinpicturewindow: ['PictureInPicture', 'pictureInPictureWindow'],
popout: ['Popout', 'popout'],
popoutarrowalignmenttop: ['Popout', 'arrowAlignmentTop'],
popoutbody: ['Popout', 'body'],
popoutbottom: ['Popout', 'popoutBottom'],
popoutbottomleft: ['Popout', 'popoutBottomLeft'],
popoutbottomright: ['Popout', 'popoutBottomRight'],
popoutfooter: ['Popout', 'footer'],
popoutheader: ['Popout', 'header'],
popoutinvert: ['Popout', 'popoutInvert'],
popoutleft: ['Popout', 'popoutLeft'],
popoutnoarrow: ['Popout', 'noArrow'],
popoutnoshadow: ['Popout', 'noShadow'],
popouts: ['Popout', 'popouts'],
popoutsubtitle: ['Popout', 'subtitle'],
popoutthemedpopout: ['Popout', 'themedPopout'],
popouttip: ['Popout', 'tip'],
popouttitle: ['Popout', 'title'],
popouttop: ['Popout', 'popoutTop'],
popouttopleft: ['Popout', 'popoutTopLeft'],
popouttopright: ['Popout', 'popoutTopRight'],
primary: ['TextStyle', 'primary'],
quickselect: ['QuickSelect', 'quickSelect'],
quickselectarrow: ['QuickSelect', 'quickSelectArrow'],
quickselectclick: ['QuickSelect', 'quickSelectClick'],
quickselectlabel: ['QuickSelect', 'quickSelectLabel'],
quickselectpopout: ['QuickSelect', 'quickSelectPopout'],
quickselectpopoutoption: ['QuickSelect', 'quickSelectPopoutOption'],
quickselectpopoutscroll: ['QuickSelect', 'quickSelectPopoutScroll'],
quickselectscroller: ['QuickSelect', 'quickSelectScroller'],
quickselectselected: ['QuickSelect', 'selected'],
quickselectvalue: ['QuickSelect', 'quickSelectValue'],
quickswitcher: ['QuickSwitchWrap', 'quickswitcher'],
quickswitchresult: ['QuickSwitch', 'result'],
quickswitchresultfocused: ['QuickSwitch', 'resultFocused'],
quickswitchresultguildicon: ['QuickSwitch', 'guildIcon'],
quickswitchresultmatch: ['QuickSwitch', 'match'],
quickswitchresultmisccontainer: ['QuickSwitchWrap', 'miscContainer'],
quickswitchresultname: ['QuickSwitch', 'name'],
quickswitchresultnote: ['QuickSwitch', 'note'],
quickswitchresultusername: ['QuickSwitch', 'username'],
recentmentionsfilterpopout: ['RecentMentions', 'recentMentionsFilterPopout'],
recentmentionsheader: ['RecentMentions', 'header'],
recentmentionsloadingmore: ['RecentMentions', 'loadingMore'],
recentmentionsmentionfilter: ['RecentMentions', 'mentionFilter'],
recentmentionsmentionfilterlabel: ['RecentMentions', 'label'],
recentmentionsmentionfiltervalue: ['RecentMentions', 'value'],
recentmentionspopout: ['RecentMentions', 'recentMentionsPopout'],
reset: ['CardStatus', 'reset'],
scroller: ['Scroller', 'scroller'],
scrollerthemed: ['Scroller', 'scrollerThemed'],
scrollerwrap: ['Scroller', 'scrollerWrap'],
searchbar: ['SearchBar', 'container'],
searchbarclear: ['SearchBar', 'clear'],
searchbarclose: ['SearchBar', 'close'],
searchbardark: ['SearchBar', 'darkTheme'],
searchbaricon: ['SearchBar', 'icon'],
searchbariconlayout: ['SearchBar', 'iconLayout'],
searchbariconwrap: ['SearchBar', 'iconContainer'],
searchbarinner: ['SearchBar', 'inner'],
searchbarinput: ['SearchBar', 'input'],
searchbarlarge: ['SearchBar', 'large'],
searchbarlight: ['SearchBar', 'lightTheme'],
searchbarmedium: ['SearchBar', 'medium'],
searchbarsmall: ['SearchBar', 'small'],
searchbartag: ['SearchBar', 'tag'],
searchbarvisible: ['SearchBar', 'visible'],
searchpopout: ['SearchPopoutWrap', 'container'],
searchpopoutanswer: ['SearchPopout', 'answer'],
searchpopoutdatepicker: ['SearchPopout', 'datePicker'],
searchpopoutdatepickerhint: ['SearchPopout', 'datePickerHint'],
searchpopoutdmaddpopout: ['DmAddPopout', 'popout'],
2019-09-12 22:57:39 +02:00
searchpopoutddmaddfriend: ['DmAddPopoutItems', 'friend'],
searchpopoutddmaddfriendwrapper: ['DmAddPopoutItems', 'friendWrapper'],
2019-07-23 21:09:07 +02:00
searchpopoutdisplayavatar: ['SearchPopout', 'displayAvatar'],
searchpopoutdisplayusername: ['SearchPopout', 'displayUsername'],
searchpopoutdisplayednick: ['SearchPopout', 'displayedNick'],
searchpopoutfilter: ['SearchPopout', 'filter'],
searchpopoutheader: ['SearchPopout', 'header'],
searchpopouthint: ['SearchPopout', 'hint'],
searchpopouthintvalue: ['SearchPopout', 'hintValue'],
searchpopoutlinksource: ['SearchPopout', 'linkSource'],
searchpopoutnontext: ['SearchPopout', 'nonText'],
searchpopoutoption: ['SearchPopout', 'option'],
searchpopoutplusicon: ['SearchPopout', 'plusIcon'],
searchpopoutresultchannel: ['SearchPopout', 'resultChannel'],
searchpopoutresultsgroup: ['SearchPopout', 'resultsGroup'],
searchpopoutsearchclearhistory: ['SearchPopout', 'searchClearHistory'],
searchpopoutsearchlearnmore: ['SearchPopout', 'searchLearnMore'],
searchpopoutsearchoption: ['SearchPopout', 'searchOption'],
searchpopoutsearchresultchannelcategory: ['SearchPopout', 'searchResultChannelCategory'],
searchpopoutsearchresultchannelicon: ['SearchPopout', 'searchResultChannelIcon'],
searchpopoutsearchresultchanneliconbackground: ['SearchPopout', 'searchResultChannelIconBackground'],
searchpopoutselected: ['SearchPopout', 'selected'],
searchpopoutuser: ['SearchPopout', 'user'],
searchresults: ['SearchResults', 'searchResults'],
searchresultschannelname: ['SearchResults', 'channelName'],
searchresultspagination: ['SearchResults', 'pagination'],
searchresultspaginationdisabled: ['SearchResults', 'disabled'],
searchresultspaginationnext: ['SearchResults', 'paginationNext'],
searchresultspaginationprevious: ['SearchResults', 'paginationPrevious'],
searchresultssearchheader: ['SearchResults', 'searchHeader'],
searchresultswrap: ['SearchResults', 'searchResultsWrap'],
searchresultswrapper: ['SearchResults', 'resultsWrapper'],
select: ['NotFound', 'select'],
selectable: ['TextStyle', 'selectable'],
selectarrow: ['NotFound', 'selectArrow'],
selectarrowcontainer: ['NotFound', 'selectArrowContainer'],
selectarrowcontainerdark: ['NotFound', 'selectArrowContainerDark'],
selectarrowcontainerlight: ['NotFound', 'selectArrowContainerLight'],
selectarrowzone: ['NotFound', 'selectArrowZone'],
selectcontrol: ['NotFound', 'selectControl'],
selectcontroldark: ['NotFound', 'selectControlDark'],
selectcontrollight: ['NotFound', 'selectControlLight'],
selectdummyinput: ['NotFound', 'selectDummyInput'],
selecthasvalue: ['NotFound', 'selectHasValue'],
selectisopen: ['NotFound', 'selectIsOpen'],
selectmenu: ['NotFound', 'selectMenu'],
selectmenuouter: ['NotFound', 'selectMenuOuter'],
selectmenuouterdark: ['NotFound', 'selectMenuOuterDark'],
selectmenuouterlight: ['NotFound', 'selectMenuOuterLight'],
selectoption: ['NotFound', 'selectOption'],
selectoptiondark: ['NotFound', 'selectOptionDark'],
selectoptionlight: ['NotFound', 'selectOptionLight'],
selectoptionhoverdark: ['NotFound', 'selectOptionHoverDark'],
selectoptionhoverlight: ['NotFound', 'selectOptionHoverLight'],
selectoptionselectdark: ['NotFound', 'selectOptionSelectDark'],
selectoptionselectlight: ['NotFound', 'selectOptionSelectLight'],
selectselected: ['NotFound', 'selectIsSelected'],
selectsingle: ['NotFound', 'selectSingle'],
selectsingledark: ['NotFound', 'selectSingleDark'],
selectsinglelight: ['NotFound', 'selectSingleLight'],
selectvalue: ['NotFound', 'selectValue'],
selectwrap: ['Select', 'select'],
settingsclosebutton: ['SettingsCloseButton', 'closeButton'],
settingsclosebuttoncontainer: ['SettingsCloseButton', 'container'],
settingsheader: ['Item', 'header'],
settingsitem: ['Item', 'item'],
settingsitemselected: ['Item', 'selected'],
settingsitemthemed: ['Item', 'themed'],
settingsseparator: ['Item', 'separator'],
settingstabbar: ['Friends', 'tabBar'],
settingstabbarbadge: ['Friends', 'badge'],
settingstabbartoppill: ['Item', 'topPill'],
sidebarregion: ['SettingsWindow', 'sidebarRegion'],
sinkinteractions: ['Message', 'disableInteraction'],
2019-09-06 09:20:32 +02:00
size10: ['UserPopout', 'size10'],
size12: ['UserPopout', 'size12'],
size14: ['UserPopout', 'size14'],
size16: ['UserPopout', 'size16'],
2019-09-06 00:32:27 +02:00
size18: ['Title', 'size18'],
2019-09-06 09:20:32 +02:00
size20: ['CtaVerification', 'size20'],
2019-09-06 00:32:27 +02:00
size24: ['TextSize', 'size24'],
2019-09-06 09:20:32 +02:00
size36: ['CtaVerification', 'size24'],
2019-07-23 21:09:07 +02:00
slider: ['Slider', 'slider'],
sliderbar: ['Slider', 'bar'],
sliderbarfill: ['Slider', 'barFill'],
sliderbubble: ['Slider', 'bubble'],
sliderdisabled: ['Slider', 'disabled'],
slidergrabber: ['Slider', 'grabber'],
sliderinput: ['Slider', 'input'],
slidermark: ['Slider', 'mark'],
slidermarkdash: ['Slider', 'markDash'],
slidermarkdashsimple: ['Slider', 'markDashSimple'],
slidermarkvalue: ['Slider', 'markValue'],
slidermini: ['Slider', 'mini'],
slidertrack: ['Slider', 'track'],
spoilercontainer: ['Spoiler', 'spoilerContainer'],
spoilerhidden: ['Spoiler', 'hidden'],
spoilertext: ['Spoiler', 'spoilerText'],
spoilerwarning: ['Spoiler', 'spoilerWarning'],
small: ['TextStyle', 'small'],
splashbackground: ['NotFound', 'splashBackground'],
standardsidebarview: ['SettingsWindow', 'standardSidebarView'],
status: ['Avatar', 'status'],
switch: ['Switch', 'switch'],
switchdisabled: ['Switch', 'switchDisabled'],
switchenabled: ['Switch', 'switchEnabled'],
switchinner: ['Switch', 'checkbox'],
switchinnerdisabled: ['Switch', 'checkboxDisabled'],
switchinnerenabled: ['Switch', 'checkboxEnabled'],
switchsize: ['Switch', 'size'],
switchsizedefault: ['Switch', 'sizeDefault'],
switchsizemini: ['Switch', 'sizeMini'],
switchthemeclear: ['Switch', 'themeClear'],
switchthemedefault: ['Switch', 'themeDefault'],
switchvalue: ['Switch', 'value'],
switchvaluechecked: ['Switch', 'valueChecked'],
switchvalueunchecked: ['Switch', 'valueUnchecked'],
2019-07-26 10:44:57 +02:00
systempad: ['Scroller', 'systemPad'],
2019-07-23 21:09:07 +02:00
tabbar: ['UserProfile', 'tabBar'],
tabbarcontainer: ['UserProfile', 'tabBarContainer'],
tabbarheader: ['RecentMentions', 'tabBar'],
tabbarheadercontainer: ['RecentMentions', 'headerTabBarWrapper'],
tabbarheaderitem: ['RecentMentions', 'tabBarItem'],
tabbaritem: ['UserProfile', 'tabBarItem'],
tabbartop: ['Item', 'top'],
tableheader: ['SettingsTable', 'header'],
tableheadername: ['SettingsTable', 'headerName'],
tableheaderoption: ['SettingsTable', 'headerOption'],
tableheadersize: ['SettingsTable', 'headerSize'],
textarea: ['ChannelTextArea', 'textArea'],
textareaattachbutton: ['ChannelTextArea', 'attachButton'],
textareaattachbuttondivider: ['ChannelTextArea', 'attachButtonDivider'],
textareaattachbuttoninner: ['ChannelTextArea', 'attachButtonInner'],
textareaattachbuttonplus: ['ChannelTextArea', 'attachButtonPlus'],
textareabutton: ['ChannelTextAreaButton', 'button'],
textareabuttonactive: ['ChannelTextAreaButton', 'active'],
textareabuttonwrapper: ['ChannelTextAreaButton', 'buttonWrapper'],
textareaicon: ['ChannelTextAreaButton', 'icon'],
textareainner: ['ChannelTextArea', 'inner'],
textareainnerautocomplete: ['ChannelTextArea', 'innerAutocomplete'],
textareainnerdisabled: ['ChannelTextArea', 'innerDisabled'],
textareainnerenablednoattach: ['ChannelTextArea', 'innerEnabledNoAttach'],
textareainnernoautocomplete: ['ChannelTextArea', 'innerNoAutocomplete'],
textareapickerbutton: ['ChannelTextArea', 'button'],
textareapickerbuttons: ['ChannelTextArea', 'buttons'],
textareauploadinput: ['ChannelTextArea', 'uploadInput'],
textareawrapall: ['ChannelTextArea', 'channelTextArea'],
textareawrapchat: ['ChannelWindow', 'channelTextArea'],
textareawrapdisabled: ['ChannelTextArea', 'channelTextAreaDisabled'],
textareawrapenablednoattach: ['ChannelTextArea', 'channelTextAreaEnabledNoAttach'],
textlink: ['Notice', 'textLink'],
textrow: ['PopoutActivity', 'textRow'],
themedark: ['NotFound', 'themeDark'],
themeghosthairline: ['Scroller', 'themeGhostHairline'],
themelight: ['NotFound', 'themeLight'],
2019-08-15 15:24:34 +02:00
themeundefined: ['NotFound', 'themeUndefined'],
2019-07-23 21:09:07 +02:00
title: ['SettingsItems', 'title'],
titlebar: ['TitleBar', 'titleBar'],
titledefault: ['SettingsItems', 'titleDefault'],
titlemini: ['SettingsItems', 'titleMini'],
2019-09-05 16:17:25 +02:00
tooltip: ['Tooltip', 'tooltip'],
2019-07-23 21:09:07 +02:00
tooltipblack: ['Tooltip', 'tooltipBlack'],
tooltipbottom: ['Tooltip', 'tooltipBottom'],
tooltipbrand: ['Tooltip', 'tooltipBrand'],
tooltipgreen: ['Tooltip', 'tooltipGreen'],
tooltipleft: ['Tooltip', 'tooltipLeft'],
tooltippointer: ['Tooltip', 'tooltipPointer'],
tooltipred: ['Tooltip', 'tooltipRed'],
tooltipright: ['Tooltip', 'tooltipRight'],
tooltiptop: ['Tooltip', 'tooltipTop'],
tooltipyellow: ['Tooltip', 'tooltipYellow'],
typing: ['Typing', 'typing'],
userpopout: ['UserPopout', 'userPopout'],
userpopoutavatarwrapper: ['UserPopout', 'avatarWrapper'],
userpopoutcustomstatus: ['UserPopout', 'customStatus'],
userpopoutheader: ['UserPopout', 'header'],
userpopoutheaderbottagwithnickname: ['UserPopout', 'headerBotTagWithNickname'],
userpopoutheadernamewrapper: ['UserPopout', 'headerNameWrapper'],
userpopoutheadernickname: ['UserPopout', 'headerName'],
userpopoutheadernonickname: ['UserPopout', 'headerTagUsernameNoNickname'],
userpopoutheadernormal: ['UserPopout', 'headerNormal'],
userpopoutheaderplaying: ['UserPopout', 'headerPlaying'],
userpopoutheaderspotify: ['UserPopout', 'headerSpotify'],
userpopoutheaderstreaming: ['UserPopout', 'headerStreaming'],
userpopoutheadertag: ['UserPopout', 'headerTag'],
userpopoutheadertagnonickname: ['UserPopout', 'headerTagNoNickname'],
userpopoutheadertagusernamenonickname: ['UserPopout', 'headerTagUsernameNoNickname'],
userpopoutheadertagwithnickname: ['UserPopout', 'headerTagWithNickname'],
userpopoutheadertext: ['UserPopout', 'headerText'],
userpopoutnametag: ['UserPopout', 'nametag'],
userpopoutrole: ['Role', 'role'],
userpopoutrolecircle: ['Role', 'roleCircle'],
userpopoutrolelist: ['UserPopout', 'rolesList'],
userpopoutrolename: ['Role', 'roleName'],
userprofile: ['UserProfile', 'root'],
userprofilebody: ['UserProfile', 'body'],
userprofilebottag: ['UserProfile', 'botTag'],
userprofilecustomstatus: ['UserProfile', 'customStatus'],
userprofileheader: ['UserProfile', 'header'],
userprofileheaderfill: ['UserProfile', 'headerFill'],
userprofileheaderinfo: ['UserProfile', 'headerInfo'],
userprofilelistavatar: ['UserProfile', 'listAvatar'],
userprofilelistguildavatarwithouticon: ['UserProfile', 'guildAvatarWithoutIcon'],
userprofilelistname: ['UserProfile', 'listName'],
userprofilelistrow: ['UserProfile', 'listRow'],
userprofilenametag: ['UserProfile', 'nameTag'],
userprofiletopsectionnormal: ['UserProfile', 'topSectionNormal'],
userprofiletopsectionplaying: ['UserProfile', 'topSectionPlaying'],
userprofiletopsectionspotify: ['UserProfile', 'topSectionSpotify'],
userprofiletopsectionstreaming: ['UserProfile', 'topSectionStreaming'],
userprofiletopsectionxbox: ['UserProfile', 'topSectionXbox'],
userprofileusername: ['UserProfile', 'username'],
2019-09-17 13:29:21 +02:00
username: ['NameTag', 'username'],
2019-07-23 21:09:07 +02:00
usernote: ['Note', 'note'],
usernotepopout: ['UserPopout', 'note'],
usernoteprofile: ['UserProfile', 'note'],
vertical: ['Flex', 'vertical'],
voiceavatar: ['Voice', 'avatar'],
voiceavatarcontainer: ['Voice', 'avatarContainer'],
voiceavatarlarge: ['Voice', 'avatarLarge'],
voiceavatarsmall: ['Voice', 'avatarSmall'],
voiceavatarspeaking: ['Voice', 'avatarSpeaking'],
voiceclickable: ['Voice', 'clickable'],
voicecontent: ['Voice', 'content'],
voiceflipped: ['Voice', 'flipped'],
voiceicon: ['Voice', 'icon'],
voiceicons: ['Voice', 'icons'],
voiceiconspacing: ['Voice', 'iconSpacing'],
voicelist: ['Voice', 'list'],
voicelistcollapse: ['Voice', 'listCollapse'],
voicelistdefault: ['Voice', 'listDefault'],
voiceliveicon: ['Voice', 'liveIcon'],
voicename: ['Voice', 'username'],
voicenamefont: ['Voice', 'usernameFont'],
voicenamespeaking: ['Voice', 'usernameSpeaking'],
voicered: ['Voice', 'red'],
voiceselected: ['Voice', 'selected'],
voiceuser: ['Voice', 'voiceUser'],
voiceuserlarge: ['Voice', 'userLarge'],
voiceusersmall: ['Voice', 'userSmall'],
weightbold: ['TextWeight', 'weightBold'],
weightlight: ['TextWeight', 'weightLight'],
weightmedium: ['TextWeight', 'weightMedium'],
weightnormal: ['TextWeight', 'weightNormal'],
weightsemibold: ['TextWeight', 'weightSemiBold'],
wrap: ['Flex', 'wrap'],
wrapreverse: ['Flex', 'wrapReverse']
};
BDFDB.DiscordClasses = Object.assign({}, DiscordClasses);
BDFDB.disCN = new Proxy(DiscordClasses, {
get: function (list, item) {
return BDFDB.getDiscordClass(item, false).replace('#', '');
}
});
BDFDB.disCNS = new Proxy(DiscordClasses, {
get: function (list, item) {
return BDFDB.getDiscordClass(item, false).replace('#', '') + ' ';
}
});
BDFDB.disCNC = new Proxy(DiscordClasses, {
get: function (list, item) {
return BDFDB.getDiscordClass(item, false).replace('#', '') + ',';
}
});
BDFDB.dotCN = new Proxy(DiscordClasses, {
get: function (list, item) {
let classname = BDFDB.getDiscordClass(item, true);
return (classname.indexOf('#') == 0 ? '' : '.') + classname;
}
});
BDFDB.dotCNS = new Proxy(DiscordClasses, {
get: function (list, item) {
let classname = BDFDB.getDiscordClass(item, true);
return (classname.indexOf('#') == 0 ? '' : '.') + classname + ' ';
}
});
BDFDB.dotCNC = new Proxy(DiscordClasses, {
get: function (list, item) {
let classname = BDFDB.getDiscordClass(item, true);
return (classname.indexOf('#') == 0 ? '' : '.') + classname + ',';
}
});
BDFDB.notCN = new Proxy(DiscordClasses, {
get: function (list, item) {
return `:not(.${BDFDB.getDiscordClass(item, true).split('.')[0]})`;
}
});
BDFDB.notCNS = new Proxy(DiscordClasses, {
get: function (list, item) {
return `:not(.${BDFDB.getDiscordClass(item, true).split('.')[0]}) `;
}
});
BDFDB.notCNC = new Proxy(DiscordClasses, {
get: function (list, item) {
return `:not(.${BDFDB.getDiscordClass(item, true).split('.')[0]}),`;
}
});
BDFDB.getDiscordClass = function (item, selector) {
var classname = DiscordClassModules.BDFDB.BDFDBundefined;
if (DiscordClasses[item] === undefined) {
console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' not found in DiscordClasses');
return classname;
}
else if (!Array.isArray(DiscordClasses[item]) || DiscordClasses[item].length != 2) {
console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', item + ' is not an Array of Length 2 in DiscordClasses');
return classname;
}
else if (DiscordClassModules[DiscordClasses[item][0]] === undefined) {
console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', DiscordClasses[item][0] + ' not found in DiscordClassModules');
return classname;
}
else if (DiscordClassModules[DiscordClasses[item][0]][DiscordClasses[item][1]] === undefined) {
console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', DiscordClasses[item][1] + ' not found in ' + DiscordClasses[item][0] + ' in DiscordClassModules');
return classname;
}
else {
classname = DiscordClassModules[DiscordClasses[item][0]][DiscordClasses[item][1]];
if (selector) {
classname = classname.split(' ').filter(n => n.indexOf('da-') != 0).join(selector ? '.' : ' ');
classname = classname ? classname : DiscordClassModules.BDFDB.BDFDBundefined;
}
return classname;
}
};
2019-09-12 22:39:24 +02:00
var LibraryComponents = {};
LibraryComponents.Button = BDFDB.WebModules.findByProperties('Colors', 'Hovers', 'Looks');
LibraryComponents.ContextMenu = BDFDB.WebModules.findByName('NativeContextMenu');
LibraryComponents.ContextMenuItem = BDFDB.WebModules.findByString("{className:(0,l.default)(i.default.item,(t={},t[i.default.clickable]=!v");
LibraryComponents.ContextMenuItemGroup = BDFDB.WebModules.findByString('{className:i.default.itemGroup}');
LibraryComponents.ContextMenuSliderItem = BDFDB.WebModules.findByName('SliderMenuItem');
LibraryComponents.ContextMenuSubItem = BDFDB.WebModules.findByName('FluxContainer(SubMenuItem)');
LibraryComponents.ContextMenuToggleItem = LibraryModules.React && LibraryModules.React.Component ? (class OtherItem extends LibraryModules.React.Component {
handleToggle() {
this.props.active = !this.props.active;
if (this.props.action) this.props.action(this.props.active);
this.forceUpdate();
}
render() {return LibraryModules.React.createElement(BDFDB.WebModules.findByName('ToggleMenuItem'), Object.assign({}, this.props, {action: this.handleToggle.bind(this)}));}
}) : undefined;
BDFDB.LibraryComponents = Object.assign({}, LibraryComponents);
2019-07-23 21:09:07 +02:00
BDFDB.getLibraryStrings = function () {
switch (BDFDB.getDiscordLanguage().id) {
case 'hr':
return {
toast_plugin_started: '{{oldversion}} je započeo.',
toast_plugin_stopped: '{{oldversion}} zaustavljen.',
toast_plugin_translated: 'prijevod na {{ownlang}}.',
colorpicker_modal_header_text: 'Birač boja',
file_navigator_text: 'Pregledajte datoteku',
btn_all_text: 'Sve',
search_placeholder: 'Traziti ...'
};
case 'da':
return {
toast_plugin_started: '{{oldversion}} er startet.',
toast_plugin_stopped: '{{oldversion}} er stoppet.',
toast_plugin_translated: 'oversat til {{ownlang}}.',
colorpicker_modal_header_text: 'Farvevælger',
file_navigator_text: 'Gennemse fil',
btn_all_text: 'Alle',
search_placeholder: 'Søge efter ...'
};
case 'de':
return {
toast_plugin_started: '{{oldversion}} wurde gestartet.',
toast_plugin_stopped: '{{oldversion}} wurde gestoppt.',
toast_plugin_translated: 'auf {{ownlang}} übersetzt.',
colorpicker_modal_header_text: 'Farbauswahl',
file_navigator_text: 'Datei durchsuchen',
btn_all_text: 'Alle',
search_placeholder: 'Suchen nach ...'
};
case 'es':
return {
toast_plugin_started: '{{oldversion}} se guilddiv iniciado.',
toast_plugin_stopped: '{{oldversion}} se guilddiv detenido.',
toast_plugin_translated: 'traducido a {{ownlang}}.',
colorpicker_modal_header_text: 'Selector de color',
file_navigator_text: 'Buscar archivo',
btn_all_text: 'Todo',
search_placeholder: 'Buscar ...'
};
case 'fr':
return {
toast_plugin_started: '{{oldversion}} a été démarré.',
toast_plugin_stopped: '{{oldversion}} a été arrêté.',
toast_plugin_translated: 'traduit en {{ownlang}}.',
colorpicker_modal_header_text: 'Pipette à couleurs',
file_navigator_text: 'Parcourir le fichier',
btn_all_text: 'Tout',
search_placeholder: 'Rechercher ...'
};
case 'it':
return {
toast_plugin_started: '{{oldversion}} è stato avviato.',
toast_plugin_stopped: '{{oldversion}} è stato interrotto.',
toast_plugin_translated: 'tradotto in {{ownlang}}.',
colorpicker_modal_header_text: 'Raccoglitore di colore',
file_navigator_text: 'Sfoglia file',
btn_all_text: 'Tutto',
search_placeholder: 'Cercare ...'
};
case 'nl':
return {
toast_plugin_started: '{{oldversion}} is gestart.',
toast_plugin_stopped: '{{oldversion}} is gestopt.',
toast_plugin_translated: 'vertaald naar {{ownlang}}.',
colorpicker_modal_header_text: 'Kleur kiezer',
file_navigator_text: 'Bestand zoeken',
btn_all_text: 'Alle',
search_placeholder: 'Zoeken ...'
};
case 'no':
return {
toast_plugin_started: '{{oldversion}} er startet.',
toast_plugin_stopped: '{{oldversion}} er stoppet.',
toast_plugin_translated: 'oversatt til {{ownlang}}.',
colorpicker_modal_header_text: 'Fargevelger',
file_navigator_text: 'Bla gjennom fil',
btn_all_text: 'Alle',
search_placeholder: 'Søk etter ...'
};
case 'pl':
return {
toast_plugin_started: '{{oldversion}} został uruchomiony.',
toast_plugin_stopped: '{{oldversion}} został zatrzymany.',
toast_plugin_translated: 'przetłumaczono na {{ownlang}}.',
colorpicker_modal_header_text: 'Narzędzie do wybierania kolorów',
file_navigator_text: 'Przeglądać plik',
btn_all_text: 'Wszystkie',
search_placeholder: 'Szukać ...'
};
case 'pt-BR':
return {
toast_plugin_started: '{{oldversion}} foi iniciado.',
toast_plugin_stopped: '{{oldversion}} foi interrompido.',
toast_plugin_translated: 'traduzido para {{ownlang}}.',
colorpicker_modal_header_text: 'Seletor de cores',
file_navigator_text: 'Procurar arquivo',
btn_all_text: 'Todo',
search_placeholder: 'Procurar por ...'
};
case 'fi':
return {
toast_plugin_started: '{{oldversion}} on käynnistetty.',
toast_plugin_stopped: '{{oldversion}} on pysäytetty.',
toast_plugin_translated: 'käännetty osoitteeseen {{ownlang}}.',
colorpicker_modal_header_text: 'Värinvalitsija',
file_navigator_text: 'Selaa tiedostoa',
btn_all_text: 'Kaikki',
search_placeholder: 'Etsiä ...'
};
case 'sv':
return {
toast_plugin_started: '{{oldversion}} har startats.',
toast_plugin_stopped: '{{oldversion}} har blivit stoppad.',
toast_plugin_translated: 'översatt till {{ownlang}}.',
colorpicker_modal_header_text: 'Färgväljare',
file_navigator_text: 'Bläddra i fil',
btn_all_text: 'All',
search_placeholder: 'Söka efter ...'
};
case 'tr':
return {
toast_plugin_started: '{{oldversion}} başlatıldı.',
toast_plugin_stopped: '{{oldversion}} durduruldu.',
toast_plugin_translated: '{{ownlang}} olarak çevrildi.',
colorpicker_modal_header_text: 'Renk seçici',
file_navigator_text: 'Dosyaya gözat',
btn_all_text: 'Her',
search_placeholder: 'Aramak ...'
};
case 'cs':
return {
toast_plugin_started: '{{oldversion}} byl spuštěn.',
toast_plugin_stopped: '{{oldversion}} byl zastaven.',
toast_plugin_translated: 'přeložen do {{ownlang}}.',
colorpicker_modal_header_text: 'Výběr barev',
file_navigator_text: 'Procházet soubor',
btn_all_text: 'Vše',
search_placeholder: 'Hledat ...'
};
case 'bg':
return {
toast_plugin_started: '{{oldversion}} е стартиран.',
toast_plugin_stopped: '{{oldversion}} е спрян.',
toast_plugin_translated: 'преведена на {{ownlang}}.',
colorpicker_modal_header_text: 'Избор на цвят',
file_navigator_text: 'Прегледайте файла',
btn_all_text: 'Bсичко',
search_placeholder: 'Търся ...'
};
case 'ru':
return {
toast_plugin_started: '{{oldversion}} запущен.',
toast_plugin_stopped: '{{oldversion}} остановлен.',
toast_plugin_translated: 'переведен на {{ownlang}}.',
colorpicker_modal_header_text: 'Выбор цвета',
file_navigator_text: 'Просмотр файла',
btn_all_text: 'Все',
search_placeholder: 'Искать ...'
};
case 'uk':
return {
toast_plugin_started: '{{oldversion}} було запущено.',
toast_plugin_stopped: '{{oldversion}} було зупинено.',
toast_plugin_translated: 'перекладено {{ownlang}}.',
colorpicker_modal_header_text: 'Колір обкладинки',
file_navigator_text: 'Перегляньте файл',
btn_all_text: 'Все',
search_placeholder: 'Шукати ...'
};
case 'ja':
return {
toast_plugin_started: '{{oldversion}}が開始されました.',
toast_plugin_stopped: '{{oldversion}}が停止しました.',
toast_plugin_translated: 'は{{ownlang}}に翻訳されました.',
colorpicker_modal_header_text: 'カラーピッカー',
file_navigator_text: 'ファイルを参照',
btn_all_text: 'すべて',
search_placeholder: '検索する ...'
};
case 'zh-TW':
return {
toast_plugin_started: '{{oldversion}}已經啟動.',
toast_plugin_stopped: '{{oldversion}}已停止.',
toast_plugin_translated: '翻譯為{{ownlang}}.',
colorpicker_modal_header_text: '選色器',
file_navigator_text: '瀏覽文件',
btn_all_text: '所有',
search_placeholder: '搜索 ...'
};
case 'ko':
return {
toast_plugin_started: '{{oldversion}} 시작되었습니다.',
toast_plugin_stopped: '{{oldversion}} 중지되었습니다.',
toast_plugin_translated: '{{ownlang}} 로 번역되었습니다.',
colorpicker_modal_header_text: '색상 선택 도구',
file_navigator_text: '파일 찾아보기',
btn_all_text: '모든',
search_placeholder: '검색 ...'
};
default:
return {
toast_plugin_started: '{{oldversion}} has been started.',
toast_plugin_stopped: '{{oldversion}} has been stopped.',
toast_plugin_translated: 'translated to {{ownlang}}.',
colorpicker_modal_header_text: 'Color Picker',
file_navigator_text: 'Browse File',
btn_all_text: 'All',
search_placeholder: 'Search for ...'
};
}
};
BDFDB.appendLocalStyle('BDFDB', `
@import url(https://mwittrien.github.io/BetterDiscordAddons/Themes/BetterDocsBlock.css);
2019-09-09 15:20:09 +02:00
2019-09-09 15:20:32 +02:00
${BDFDB.dotCN.optionpopoutbutton} svg.BDFDB-undefined,
2019-09-09 15:20:09 +02:00
${BDFDB.dotCN.optionpopoutbutton} .BDFDB-undefined svg {
display: none;
}
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
${BDFDB.dotCN.overflowellipsis} {
overflow: hidden;
text-overflow: ellipsis;
}
2019-09-04 12:34:02 +02:00
2019-09-05 09:22:43 +02:00
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercozy} {
2019-07-28 15:24:47 +02:00
padding-top: 0;
}
2019-09-05 09:22:43 +02:00
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercompact} > span.popout-open,
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercompact} > span[class=""],
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercozymeta} > span.popout-open,
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercozymeta} > span[class=""] {
2019-07-28 15:24:47 +02:00
display: inline-flex;
2019-07-28 15:55:42 +02:00
align-items: baseline;
2019-07-28 15:24:47 +02:00
}
2019-09-05 09:22:43 +02:00
${BDFDB.dotCNS.messagegroup + BDFDB.dotCNS.messageheadercompact + BDFDB.dotCN.bottag},
${BDFDB.dotCNS.messagegroup + BDFDB.dotCNS.messageheadercompact + BDFDB.dotCN.messageusername} {
2019-07-28 15:24:47 +02:00
text-indent: 0px;
}
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
#bd-settingspane-container .ui-form-title {
display: inline-block;
}
#bd-settingspane-container ${BDFDB.dotCN._repofolderbutton} {
position: static;
margin-bottom: 0;
border-radius: 5px;
display: inline-block;
margin-left: 10px;
}
#bd-settingspane-container .bd-updatebtn ~ .bd-updatebtn {
display: none !important;
}
#bd-settingspane-container ${BDFDB.dotCN._repodescription} {
white-space: pre-line !important;
}
2019-09-04 16:52:59 +02:00
.BDFDB-versionchangelog {
display: inline-block;
background: currentColor;
-webkit-mask: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 510 510"><path fill="currentColor" d="M267.75,12.75c-89.25,0-168.3,48.45-209.1,122.4L0,76.5v165.75h165.75 l-71.4-71.4c33.15-63.75,96.9-107.1,173.4-107.1C372.3,63.75,459,150.45,459,255s-86.7,191.25-191.25,191.25 c-84.15,0-153-53.55-181.05-127.5H33.15c28.05,102,122.4,178.5,234.6,178.5C402.9,497.25,510,387.6,510,255 C510,122.4,400.35,12.75,267.75,12.75z M229.5,140.25V270.3l119.85,71.4l20.4-33.15l-102-61.2v-107.1H229.5z"></path></svg>') center/contain no-repeat;
cursor: pointer;
margin: 0 4px 0 3px;
}
2019-07-23 21:09:07 +02:00
${BDFDB.dotCNS.themedark + BDFDB.dotCN.popoutthemedpopout + BDFDB.notCN.messagespopoutwrap} {
-webkit-box-shadow: 0 2px 10px 0 rgba(0,0,0,20%);
background-color: #2f3136;
border: 1px solid rgba(28,36,43,.6);
box-shadow: 0 2px 10px 0 rgba(0,0,0,.2);
}
.BDFDB-notice {
transition: height 0.5s ease !important;
2019-09-16 22:18:03 +02:00
border-radius: 0 !important;
2019-07-23 21:09:07 +02:00
}
.BDFDB-notice ${BDFDB.dotCN.noticeplatformicon} {
margin-top: -7px;
}
.BDFDB-notice ${BDFDB.dotCN.noticeplatformicon} svg {
max-height: 28px;
}
.hidden-by-OTB .BDFDB-notice {
-webkit-app-region: drag !important;
}
#pluginNotice #outdatedPlugins span {
-webkit-app-region: no-drag;
color: #FFF;
cursor: pointer;
}
#pluginNotice #outdatedPlugins span:hover {
text-decoration: underline;
}
2019-09-05 16:17:25 +02:00
.BDFDB-itemlayerconainer, .BDFDB-itemlayer {
2019-08-06 12:40:09 +02:00
z-index: 3002;
2019-07-23 21:09:07 +02:00
}
2019-09-05 16:17:25 +02:00
${BDFDB.dotCN.tooltip}.tooltip-customcolor ${BDFDB.dotCN.tooltippointer} {
2019-07-23 21:09:07 +02:00
border-top-color: inherit !important;
}
.toasts {
position: fixed;
display: flex;
top: 0;
flex-direction: column;
align-items: center;
justify-content: flex-end;
pointer-events: none;
z-index: 4000;
}
@keyframes toast-up {
from {
transform: translateY(0);
opacity: 0;
}
}
.toast {
animation: toast-up 300ms ease;
transform: translateY(-10px);
background-color: #36393F;
padding: 10px;
border-radius: 5px;
box-shadow: 0 0 0 1px rgba(32,34,37,.6), 0 2px 10px 0 rgba(0,0,0,.2);
font-weight: 500;
color: #fff;
user-select: text;
font-size: 14px;
opacity: 1;
margin-top: 10px;
pointer-events: auto;
}
@keyframes toast-down {
to {
transform: translateY(0px);
opacity: 0;
}
}
.toast.closing {
animation: toast-down 200ms ease;
animation-fill-mode: forwards;
opacity: 1;
transform: translateY(-10px);
}
.toast .toast-inner {
display: flex;
align-items: center;
}
.toast .toast-avatar {
margin-right: 5px;
width: 25px;
height: 25px;
background-size: cover;
background-position: center;
border-radius: 50%;
}
.toast.icon {
padding-left: 30px;
background-size: 20px 20px;
background-repeat: no-repeat;
background-position: 6px 50%;
}
.toast.toast-brand {
background-color: #7289DA;
}
.toast.toast-brand.icon {
background-image: url();
}
.toast.toast-danger,
.toast.toast-error {
background-color: #F04747;
}
.toast.toast-danger.icon,
.toast.toast-error.icon {
background-image: url();
}
.toast.toast-default {
background-color: #F26522;
}
.toast.toast-default.icon {
padding-left: 10px;
}
.toast.toast-facebook {
background-color: #355089;
}
.toast.toast-facebook.icon {
background-image: url();
}
.toast.toast-info {
background-color: #4A90E2;
}
.toast.toast-info.icon {
background-image: url();
}
.toast.toast-premium {
background-color: #202225;
}
.toast.toast-premium.icon {
background-image: url();
background-size: 63px 16px;
padding-left: 73px;
}
.toast.toast-spotify {
background-color: #1DB954;
}
.toast.toast-spotify.icon {
background-image: url();
}
.toast.toast-streamermode {
background-color: #593695;
}
.toast.toast-streamermode.icon {
background-image: url();
}
.toast.toast-success {
background-color: #43B581;
}
.toast.toast-success.icon {
background-image: url();
}
.toast.toast-warning,
.toast.toast-warn {
background-color: #FFA600;
}
.toast.toast-warning.icon,
.toast.toast-warn.icon {
background-image: url();
}
2019-09-09 13:42:17 +02:00
.BDFDB-quickSelectPopout {
2019-07-23 21:09:07 +02:00
min-width: 210px !important;
position: relative !important;
width: auto !important;
}
.BDFDB-modal ${BDFDB.dotCN.modalsizelarge} {
max-height: 80vh;
}
.BDFDB-modal ${BDFDB.dotCN.title + BDFDB.notCN.cursorpointer},
.BDFDB-settings ${BDFDB.dotCN.title + BDFDB.notCN.cursorpointer} {
cursor: default !important;
}
2019-08-22 13:42:28 +02:00
.BDFDB-modal .BDFDB-settings-inner .BDFDB-containertext,
.BDFDB-settings .BDFDB-settings-inner .BDFDB-containertext {
margin-left: -18px;
}
2019-08-22 11:38:34 +02:00
.BDFDB-modal .BDFDB-containerarrow,
.BDFDB-settings .BDFDB-containerarrow {
background: url();
height: 16px;
width: 16px;
display: inline-block;
2019-08-22 11:58:19 +02:00
position: relative;
top: 2px;
2019-08-22 11:38:34 +02:00
transition: transform .3s ease;
transform: rotate(0);
}
.BDFDB-modal .BDFDB-containerarrow.closed,
.BDFDB-settings .BDFDB-containerarrow.closed {
transform: rotate(-90deg);
}
2019-07-23 21:09:07 +02:00
.BDFDB-settings .BDFDB-settings-inner {
padding-left: 15px;
padding-right: 5px;
}
.BDFDB-settings .BDFDB-settings-inner-list {
padding-left: 15px;
}
.inputNumberWrapper .numberinput-buttons-zone:hover + ${BDFDB.dotCN.input} {
border-color: black;
}
.inputNumberWrapper .numberinput-buttons-zone:hover + ${BDFDB.dotCN.input}:focus,
.inputNumberWrapper .numberinput-buttons-zone.pressed + ${BDFDB.dotCN.input} {
border-color: #7289da;
}
.inputNumberWrapper {
position: relative !important;
}
.inputNumberWrapper ${BDFDB.dotCN.input}[type=number] {
padding-right: 25px;
}
.inputNumberWrapper.inputNumberWrapperMini ${BDFDB.dotCN.input}[type=number] {
padding-left: 6px;
padding-right: 17px;
}
.inputNumberWrapper ${BDFDB.dotCN.input}[type=number]::-webkit-inner-spin-button,
.inputNumberWrapper ${BDFDB.dotCN.input}[type=number]::-webkit-outer-spin-button{
-webkit-appearance: none;
}
.inputNumberWrapper .numberinput-buttons-zone {
cursor: pointer;
position: absolute;
display: flex;
flex-direction: column;
align-items: center;
justify-content: space-around;
height: 110%;
right: 8px;
top: -5%;
}
.inputNumberWrapper.inputNumberWrapperMini .numberinput-buttons-zone {
right: 4px;
}
.inputNumberWrapper .numberinput-button-up {
border-color: transparent transparent #999 transparent;
border-style: solid;
border-width: 2.5px 5px 5px 5px;
display: inline-block;
}
.inputNumberWrapper .numberinput-button-up:hover {
border-bottom-color: #666;
}
${BDFDB.dotCN.themelight} .inputNumberWrapper .numberinput-button-up {
border-bottom-color: #dcddde;
}
${BDFDB.dotCN.themelight} .inputNumberWrapper .numberinput-button-up:hover {
border-bottom-color: #4f545c;
}
${BDFDB.dotCN.themedark} .inputNumberWrapper .numberinput-button-up {
border-bottom-color: #72767d;
}
${BDFDB.dotCN.themedark} .inputNumberWrapper .numberinput-button-up:hover {
border-bottom-color: #f6f6f7;
}
.inputNumberWrapper .numberinput-button-down {
border-color: #999 transparent transparent transparent;
border-style: solid;
border-width: 5px 5px 2.5px 5px;
display: inline-block;
}
.inputNumberWrapper .numberinput-button-down:hover {
border-top-color: #666;
}
${BDFDB.dotCN.themelight} .inputNumberWrapper .numberinput-button-down {
border-top-color: #dcddde;
}
${BDFDB.dotCN.themelight} .inputNumberWrapper .numberinput-button-down:hover {
border-top-color: #4f545c;
}
${BDFDB.dotCN.themedark} .inputNumberWrapper .numberinput-button-down {
border-top-color: #72767d;
}
${BDFDB.dotCN.themedark} .inputNumberWrapper .numberinput-button-down:hover {
border-top-color: #f6f6f7;
}
.BDFDB-select ${BDFDB.dotCN.select} {
position: relative;
box-sizing: border-box;
}
.BDFDB-select ${BDFDB.dotCN.selectcontrol} {
-webkit-box-align: center;
align-items: center;
display: flex;
flex-wrap: wrap;
-webkit-box-pack: justify;
justify-content: space-between;
min-height: 40px;
position: relative;
box-sizing: border-box;
border-radius: 3px;
border-style: solid;
border-width: 1px;
transition: border 0.15s ease 0s;
outline: 0px !important;
}
.BDFDB-select ${BDFDB.dotCN.selectcontrollight} {
background-color: rgba(79, 84, 92, 0.02);
background-color: rgba(79, 84, 92, 0.02);
}
.BDFDB-select ${BDFDB.dotCN.selectcontroldark} {
background-color: rgba(0, 0, 0, 0.1);
border-color: rgba(0, 0, 0, 0.3);
}
.BDFDB-select ${BDFDB.dotCN.selectvalue} {
-webkit-box-align: center;
align-items: center;
display: flex;
flex-wrap: wrap;
position: relative;
box-sizing: border-box;
flex: 1 1 0%;
padding: 2px 8px;
overflow: hidden;
}
.BDFDB-select ${BDFDB.dotCN.selectsingle} {
margin-left: 2px;
margin-right: 2px;
max-width: calc(100% - 8px);
width: calc(100% - 8px);
position: absolute;
text-overflow: ellipsis;
white-space: nowrap;
top: 50%;
transform: translateY(-50%);
box-sizing: border-box;
opacity: 1;
overflow: hidden;
}
.BDFDB-select ${BDFDB.dotCN.selectsinglelight} {
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectsingledark} {
color: rgb(246, 246, 247);
}
.BDFDB-select ${BDFDB.dotCN.selectdummyinput} {
font-size: inherit;
width: 1px;
color: transparent;
left: -100px;
opacity: 0;
position: relative;
transform: scale(0);
background: 0px center;
border-width: 0px;
border-style: initial;
border-color: initial;
border-image: initial;
outline: 0px;
padding: 0px;
}
.BDFDB-select ${BDFDB.dotCN.selectarrowzone} {
-webkit-box-align: center;
align-items: center;
align-self: stretch;
display: flex;
flex-shrink: 0;
box-sizing: border-box;
}
.BDFDB-select ${BDFDB.dotCN.selectarrowcontainer} {
display: flex;
box-sizing: border-box;
cursor: pointer;
opacity: 0.3;
padding: 8px 8px 8px 0px;
transition: color 150ms ease 0s;
}
.BDFDB-select ${BDFDB.dotCN.selectarrowcontainerlight} {
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectarrowcontainerdark} {
color: rgb(246, 246, 247);
}
.BDFDB-select ${BDFDB.dotCN.selectarrow} {
display: inline-block;
fill: currentcolor;
line-height: 1;
stroke: currentcolor;
stroke-width: 0;
}
.BDFDB-select ${BDFDB.dotCN.selectmenuouter} {
top: 100%;
margin-bottom: -1px;
margin-top: -1px;
position: absolute;
width: 100%;
z-index: 100;
box-sizing: border-box;
border-radius: 0px 0px 3px 3px;
border-width: 1px;
border-style: solid;
border-image: initial;
}
.BDFDB-select ${BDFDB.dotCN.selectmenuouterlight} {
background-color: rgb(255, 255, 255);
border-color: rgb(185, 187, 190);
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectmenuouterdark} {
background-color: rgb(47, 49, 54);
border-color: rgb(32, 34, 37);
color: rgb(246, 246, 247);
}
.BDFDB-select ${BDFDB.dotCN.selectmenu} {
max-height: 300px;
overflow-y: auto;
position: relative;
box-sizing: border-box;
padding: 0px;
}
.BDFDB-select ${BDFDB.dotCN.selectmenu}::-webkit-scrollbar {
width: 8px;
}
.BDFDB-select ${BDFDB.dotCN.selectmenu}::-webkit-scrollbar-thumb {
background-color: rgba(0, 0, 0, 0.4);
background-clip: padding-box;
border-color: transparent;
border-radius: 4px;
}
.BDFDB-select ${BDFDB.dotCN.selectmenu}::-webkit-scrollbar-track-piece {
background-color: transparent;
border-color: transparent;
}
.BDFDB-select ${BDFDB.dotCN.selectoption} {
cursor: pointer;
display: flex;
font-size: inherit;
width: 100%;
user-select: none;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
box-sizing: border-box;
-webkit-box-align: center;
align-items: center;
min-height: 40px;
padding: 8px 12px;
}
.BDFDB-select ${BDFDB.dotCN.selectoptionlight} {
background-color: transparent;
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectoptiondark} {
background-color: transparent;
color: rgb(246, 246, 247);
}
.BDFDB-select ${BDFDB.dotCN.selectoptionhoverlight} {
background-color: rgb(246, 246, 247);
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectoptionhoverdark} {
background-color: rgba(0, 0, 0, 0.1);
color: rgb(246, 246, 247);
}
.BDFDB-select ${BDFDB.dotCN.selectoptionselectlight} {
background-color: rgb(220, 221, 222);
color: rgb(32, 34, 37);
}
.BDFDB-select ${BDFDB.dotCN.selectoptionselectdark} {
background-color: rgba(0, 0, 0, 0.2);
color: rgb(246, 246, 247);
}
.BDFDB-settings ${BDFDB.dotCN.hovercard},
.BDFDB-settings ${BDFDB.dotCNS.hovercard + BDFDB.dotCN.hovercardinner} {
width: 550px;
min-height: 28px;
}
.BDFDB-settingsmodal .BDFDB-settings {
margin-bottom: 20px;
}
.BDFDB-settingsmodal .BDFDB-settings ${BDFDB.dotCN.hovercard},
.BDFDB-settingsmodal .BDFDB-settings ${BDFDB.dotCNS.hovercard + BDFDB.dotCN.hovercardinner} {
width: 520px;
}
.BDFDB-settings ${BDFDB.dotCN.hovercard}:before {
z-index: 50;
left: -10px;
}
.BDFDB-settings ${BDFDB.dotCNS.hovercard + BDFDB.dotCN.hovercardinner} {
overflow: hidden;
display: flex;
align-items: center;
position: relative;
z-index: 100;
}
.BDFDB-settings ${BDFDB.dotCNS.hovercard + BDFDB.dotCN.hovercardbutton} {
opacity: 0;
position: absolute;
right: -31px;
top: -12px;
z-index: 200;
}
.BDFDB-settings ${BDFDB.dotCN.hovercard}:hover ${BDFDB.dotCN.hovercardbutton} {
opacity: 1;
}
.BDFDB-modal ${BDFDB.dotCN.checkboxcontainer},
.BDFDB-settings ${BDFDB.dotCN.checkboxcontainer} {
2019-08-21 17:22:56 +02:00
display: flex;
align-items: center;
flex-direction: column;
margin-right: 5px;
margin-left: 5px;
2019-07-23 21:09:07 +02:00
}
.BDFDB-modal ${BDFDB.dotCN.checkboxcontainer}:before,
.BDFDB-settings ${BDFDB.dotCN.checkboxcontainer}:before {
display: none;
2019-08-15 15:24:34 +02:00
}
2019-07-23 21:09:07 +02:00
.BDFDB-modal .swatches.disabled {
cursor: no-drop;
filter: grayscale(70%) brightness(50%);
}
2019-08-15 15:24:34 +02:00
.BDFDB-modal .swatches.disabled ${BDFDB.dotCN.colorpickerswatch} {
2019-07-23 21:09:07 +02:00
cursor: no-drop;
}
2019-08-17 10:00:38 +02:00
.BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom}[style*="background"] {
border: none;
}
${BDFDB.dotCNS.themelight + BDFDB.dotCN.colorpickersaturation} > div > div > div > div {
box-shadow: rgb(200, 200, 200) 0px 0px 0px 1.5px, rgba(0, 0, 0, 0.6) 0px 0px 1px 1px inset, rgba(0, 0, 0, 0.6) 0px 0px 1px 2px !important;
}
${BDFDB.dotCNS.themelight + BDFDB.dotCN.colorpickerhue} > div > div > div > div {
background: rgb(200, 200, 200) !important;
box-shadow: rgba(0, 0, 0, 1) 0px 0px 2px !important;
}
.BDFDB-colorpicker .gradient-button svg {
cursor: pointer;
opacity: 0.3;
transition: all 200ms ease;
}
.BDFDB-colorpicker .gradient-button svg:hover {
opacity: 0.6;
}
.BDFDB-colorpicker .gradient-button.selected svg,
.BDFDB-colorpicker .gradient-button.selected svg:hover {
opacity: 1;
}
${BDFDB.dotCN.themelight} .BDFDB-colorpicker .gradient-button svg {
fill: #4f545c;
}
${BDFDB.dotCN.themedark} .BDFDB-colorpicker .gradient-button svg {
fill: #fff;
}
.BDFDB-colorpicker .gradient-bar .gradient-horizontal {
border-radius: 3px;
}
.BDFDB-colorpicker .gradient-bar .gradient-cursor {
position: absolute;
}
.BDFDB-colorpicker .gradient-bar .gradient-cursor > div {
height: 8px;
width: 8px;
margin-top: -15px;
border: 1px solid rgb(128, 128, 128);
border-radius: 3px;
transform: translateX(-5px);
}
.BDFDB-colorpicker .gradient-bar .gradient-cursor > div:before {
content: "";
position: absolute;
border: 3px solid transparent;
border-top-width: 5px;
border-top-color: rgb(128, 128, 128);
width: 0;
height: 0;
top: 100%;
left: -50%;
transform: translateX(5px);
}
.BDFDB-colorpicker .gradient-bar .gradient-cursor.edge > div:before {
border-right-width: 0;
border-left-width: 5px;
}
.BDFDB-colorpicker .gradient-bar .gradient-cursor.edge ~ .gradient-cursor.edge > div:before {
border-right-width: 5px;
border-left-width: 0;
}
${BDFDB.dotCN.themelight} .BDFDB-colorpicker .gradient-bar .gradient-cursor.selected > div {
border-color: rgb(55, 55, 55);
}
${BDFDB.dotCN.themelight} .BDFDB-colorpicker .gradient-bar .gradient-cursor.selected > div:before {
border-top-color: rgb(55, 55, 55);
}
${BDFDB.dotCN.themedark} .BDFDB-colorpicker .gradient-bar .gradient-cursor.selected > div {
border-color: rgb(200, 200, 200);
}
${BDFDB.dotCN.themedark} .BDFDB-colorpicker .gradient-bar .gradient-cursor.selected > div:before {
border-top-color: rgb(200, 200, 200);
}
2019-07-23 21:09:07 +02:00
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.valid {
background-color: rgba(67,181,129,.5);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.valid:hover {
border-color: rgb(27,141,89);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.valid:focus {
border-color: rgb(67,181,129);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.valid::placeholder {
color: rgba(67,181,129,.7);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.invalid {
background-color: rgba(241,71,71,.5);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.invalid:hover {
border-color: rgb(201,31,31);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.invalid:focus {
border-color: rgb(241,71,71);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}.invalid::placeholder {
color: rgba(241,71,71,.7);
}
.BDFDB-modal ${BDFDB.dotCN.inputdefault}:disabled {
color: #555555;
cursor: no-drop;
background-color: rgba(0,0,0,.5);
}
.BDFDB-modal ${BDFDB.dotCN.tabbarcontainer} {
border: none !important;
background: rgba(0,0,0,.1);
box-shadow: 0 2px 3px 0 rgba(0,0,0,.05);
}
${BDFDB.dotCN.themedark} .BDFDB-modal ${BDFDB.dotCN.tabbarcontainer} {
background: rgba(0,0,0,.2);
box-shadow: 0 2px 3px 0 rgba(0,0,0,.1);
}
.BDFDB-modal .tab-content:not(.open) {
display: none;
}
.colorpicker-modal .colorpicker-container {
padding: 10px 10px 10px 30px;
overflow: hidden;
display: initial;
margin: auto;
}
.colorpicker-modal .colorpicker-color,
.colorpicker-modal .colorpicker-slider,
.colorpicker-modal .colorpicker-controls {
float: left;
margin-right: 20px;
}
.colorpicker-modal .colorpicker-inputs {
text-align: center;
width: 150px;
padding: 3px 3px 3px 10px;
margin-top: 87px;
}
.colorpicker-modal .colorpicker-pickerpane,
.colorpicker-modal .colorpicker-black,
.colorpicker-modal .colorpicker-white,
.colorpicker-modal .colorpicker-color {
position: relative;
top: 0px;
left: 0px;
height: 308px;
width: 308px;
}
.colorpicker-modal .colorpicker-pickercursor {
position: absolute;
height: 14px;
width: 14px;
}
.colorpicker-modal .colorpicker-pickercursor svg {
position: relative;
height: 14px;
width: 14px;
}
.colorpicker-modal .colorpicker-sliderpane,
.colorpicker-modal .colorpicker-slider {
position: relative;
top: 0px;
left: 0px;
height: 308px;
width: 20px;
}
.colorpicker-modal .colorpicker-slidercursor {
position: absolute;
left: -6px;
height: 12px;
width: 32px;
}
.colorpicker-modal .colorpicker-slidercursor svg {
position: relative;
height: 12px;
width: 32px;
}
.colorpicker-modal [class^="colorpicker-preview-"] {
background-color: #808080;
border: 3px solid transparent;
height: 65px;
width: 80px;
float: left;
}
.colorpicker-modal .colorpicker-preview-0 {
border-radius: 5px 0 0 5px;
border-right: none;
}
.colorpicker-modal .colorpicker-preview-2 {
border-radius: 0 5px 5px 0;
border-left: none;
}`);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.addEventListener(BDFDB, document, 'click.BDFDBPluginClick', '.bd-settingswrap .bd-refresh-button, .bd-settingswrap .bd-switch-checkbox', () => {
BDFDB.setPluginCache();
BDFDB.setThemeCache();
});
var keydowntimeouts = {};
BDFDB.addEventListener(BDFDB, document, 'keydown.BDFDBPressedKeys', e => {
if (!BDFDB.pressedKeys.includes(e.which)) {
clearTimeout(keydowntimeouts[e.which]);
BDFDB.pressedKeys.push(e.which);
keydowntimeouts[e.which] = setTimeout(() => {BDFDB.removeFromArray(BDFDB.pressedKeys, e.which, true);},60000);
}
});
BDFDB.addEventListener(BDFDB, document, 'keyup.BDFDBPressedKeys', e => {
BDFDB.removeFromArray(BDFDB.pressedKeys, e.which, true);
});
BDFDB.addEventListener(BDFDB, document, 'mousedown.BDFDBMousePosition', e => {
BDFDB.mousePosition = e;
});
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.patchModules = {
V2C_List: 'componentDidMount',
V2C_PluginCard: ['componentDidMount','componentDidUpdate'],
V2C_ThemeCard: ['componentDidMount','componentDidUpdate'],
UserPopout: ['componentDidMount'],
UserProfile: ['componentDidMount'],
2019-09-09 11:53:19 +02:00
Message: ['componentDidMount','componentDidUpdate','render']
2019-07-23 21:09:07 +02:00
};
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.patch(LibraryModules.GuildStore, 'getGuild', BDFDB, {after: e => {
2019-07-23 21:09:07 +02:00
if (e.returnValue && e.methodArguments[0] == '410787888507256842' && !e.returnValue.banner) {
e.returnValue.banner = '
}
}});
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.WebModules.patch(LibraryModules.IconUtils, 'getGuildBannerURL', BDFDB, {instead: e => {
2019-07-23 21:09:07 +02:00
return e.methodArguments[0].id == '410787888507256842' ? e.methodArguments[0].banner : e.callOriginalMethod();
}});
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.processV2CList = function (instance, wrapper, returnvalue) {
2019-07-23 21:09:07 +02:00
if (window.PluginUpdates && window.PluginUpdates.plugins && instance._reactInternalFiber.key && instance._reactInternalFiber.key.split('-')[0] == 'plugin') {
var folderbutton = document.querySelector(BDFDB.dotCN._repofolderbutton);
if (folderbutton) {
var updatebutton = BDFDB.htmlToElement(`<button class="bd-updatebtn ${BDFDB.disCN._repofolderbutton}">Check for Updates</button>`);
updatebutton.addEventListener('click', () => {BDFDB.checkAllUpdates();});
updatebutton.addEventListener('mouseenter', () => {
BDFDB.createTooltip('Only checks for updates of plugins, which support the updatecheck. Rightclick for a list of supported plugins.', updatebutton, {type: 'top', selector: 'update-button-tooltip', style: 'max-width: 420px'});
});
updatebutton.addEventListener('contextmenu', () => {
if (window.PluginUpdates && window.PluginUpdates.plugins && !document.querySelector('.update-list-tooltip')) {
var plugnames = [];
for (let url in window.PluginUpdates.plugins) plugnames.push(window.PluginUpdates.plugins[url].name);
BDFDB.createTooltip(plugnames.sort().join(', '), updatebutton, {type: 'bottom', selector: 'update-list-tooltip', style: 'max-width: 420px'});
}
});
BDFDB.removeEles('#bd-settingspane-container .bd-updatebtn' + BDFDB.dotCN._repofolderbutton);
folderbutton.parentElement.insertBefore(updatebutton, folderbutton.nextSibling);
new MutationObserver(changes => {changes.forEach(change => {change.addedNodes.forEach(node => {
if (folderbutton.parentElement.querySelectorAll('.bd-updatebtn').length > 1 && BDFDB.containsClass(node, 'bd-updatebtn')) BDFDB.removeEles(node);
});});}).observe(folderbutton.parentElement, {subtree:true, childList:true});
}
}
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var innerProcessCard = (instance, wrapper, data) => {
var author, description = null;
if (BDFDB.containsClass(wrapper, BDFDB.disCN._reposettingsclosed) && (author = wrapper.querySelector(BDFDB.dotCN._repoauthor)) != null && (description = wrapper.querySelector(BDFDB.dotCN._repodescription)) != null && (!BDFDB.isObject(data) || typeof data.getRawUrl != "function")) {
if (!author.firstElementChild && !description.firstElementChild && (author.innerText == "DevilBro" || author.innerText.indexOf("DevilBro,") == 0)) {
description.style.setProperty("display", "block", "important");
author.innerHTML = `<a class="${BDFDB.disCNS.anchor + BDFDB.disCN.anchorunderlineonhover}">DevilBro</a>${author.innerText.split("DevilBro").slice(1).join("DevilBro")}`;
2019-09-04 12:00:32 +02:00
author.addEventListener('click', () => {
if (BDFDB.myData.id == '278543574059057154') return;
let DMid = LibraryModules.ChannelStore.getDMFromUserId('278543574059057154')
2019-08-07 14:02:45 +02:00
if (DMid) LibraryModules.SelectChannelUtils.selectPrivateChannel(DMid);
2019-09-04 12:00:32 +02:00
else LibraryModules.DirectMessageUtils.openPrivateChannel(BDFDB.myData.id, '278543574059057154');
2019-07-23 21:09:07 +02:00
let close = document.querySelector(BDFDB.dotCNS.settingsclosebuttoncontainer + BDFDB.dotCN.settingsclosebutton);
if (close) close.click();
});
2019-09-04 12:00:32 +02:00
let version = wrapper.querySelector(BDFDB.dotCN._repoversion);
if (version && data.changelog) {
BDFDB.removeEles(version.querySelectorAll('.BDFDB-versionchangelog'));
2019-09-04 16:59:33 +02:00
let changelogicon = BDFDB.htmlToElement(`<span class="BDFDB-versionchangelog" style="white-space: pre !important;"> </span>`);
2019-09-04 12:00:32 +02:00
version.appendChild(changelogicon);
changelogicon.addEventListener('click', () => {BDFDB.openChangeLogModal(data);});
changelogicon.addEventListener('mouseenter', () => {
BDFDB.createTooltip(BDFDB.LanguageStrings.CHANGE_LOG, changelogicon, {type:'top', selector:'changelogicon-tooltip'});
});
}
2019-07-23 21:09:07 +02:00
let links = wrapper.querySelector(BDFDB.dotCN._repolinks);
if (links) {
2019-09-04 12:00:32 +02:00
if (links.firstElementChild) links.appendChild(document.createTextNode(' | '));
2019-07-23 21:09:07 +02:00
let supportlink = BDFDB.htmlToElement(`<a class="${BDFDB.disCNS._repolink + BDFDB.disCN._repolink}-support" target="_blank">Support Server</a>`);
2019-09-04 12:00:32 +02:00
supportlink.addEventListener('click', e => {
2019-07-23 21:09:07 +02:00
BDFDB.stopEvent(e);
let switchguild = () => {
2019-09-04 12:00:32 +02:00
LibraryModules.GuildUtils.transitionToGuildSync('410787888507256842');
2019-07-23 21:09:07 +02:00
let close = document.querySelector(BDFDB.dotCNS.settingsclosebuttoncontainer + BDFDB.dotCN.settingsclosebutton);
if (close) close.click();
};
2019-09-04 12:00:32 +02:00
if (LibraryModules.GuildStore.getGuild('410787888507256842')) switchguild();
else LibraryModules.InviteUtils.acceptInvite('Jx3TjNS').then(() => {switchguild();});
2019-07-23 21:09:07 +02:00
});
links.appendChild(supportlink);
2019-09-04 12:00:32 +02:00
if (BDFDB.myData.id != '98003542823944192' && BDFDB.myData.id != '116242787980017679' && BDFDB.myData.id != '81388395867156480') {
links.appendChild(document.createTextNode(' | '));
2019-07-23 21:09:07 +02:00
links.appendChild(BDFDB.htmlToElement(`<a class="${BDFDB.disCNS._repolink + BDFDB.disCN._repolink}-donations" href="https://www.paypal.me/MircoWittrien" target="_blank">Donations</a>`));
}
}
}
}
};
2019-09-08 22:34:29 +02:00
BDFDB.processV2CPluginCard = function (instance, wrapper, returnvalue) {innerProcessCard(instance, wrapper, instance.props.plugin);};
BDFDB.processV2CThemeCard = function (instance, wrapper, returnvalue) {innerProcessCard(instance, wrapper, instance.props.theme);};
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.processUserPopout = function (instance, wrapper, returnvalue) {
2019-07-23 21:09:07 +02:00
innerProcessAvatar(instance.props.user, wrapper.querySelector(BDFDB.dotCN.userpopoutavatarwrapper));
};
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.processUserProfile = function (instance, wrapper, returnvalue) {
2019-07-23 21:09:07 +02:00
innerProcessAvatar(instance.props.user, wrapper.querySelector(BDFDB.dotCN.avatarwrapper));
};
2019-09-04 12:34:02 +02:00
2019-09-08 22:34:29 +02:00
BDFDB.processMessage = function (instance, wrapper, returnvalue) {
2019-07-23 21:09:07 +02:00
innerProcessAvatar(instance.props.message.author, wrapper.querySelector(BDFDB.dotCN.avatarwrapper));
};
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
var innerProcessAvatar = function (user, avatar) {
if (avatar && user) {
avatar.setAttribute("user_by_BDFDB", user.id);
var status = avatar.querySelector(BDFDB.dotCN.avatarpointerevents);
if (status) {
status.addEventListener("mouseenter", () => {BDFDB.addClass(avatar, "statusHovered")});
status.addEventListener("mouseleave", () => {BDFDB.removeClass(avatar, "statusHovered")});
}
}
};
BDFDB.WebModules.patchModules(BDFDB);
2019-09-04 12:34:02 +02:00
2019-07-23 21:09:07 +02:00
BDFDB.WebModules.forceAllUpdates(BDFDB);
2019-09-08 22:34:29 +02:00
BDFDB.addContextListener(BDFDB);
2019-07-23 21:09:07 +02:00
BDFDB.loaded = true;
var reloadLib = function () {
var libraryScript = document.querySelector('head script#BDFDBLibraryScript');
if (libraryScript) libraryScript.remove();
libraryScript = document.createElement("script");
libraryScript.setAttribute("id", "BDFDBLibraryScript");
libraryScript.setAttribute("type", "text/javascript");
libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js");
libraryScript.setAttribute("date", performance.now());
document.head.appendChild(libraryScript);
};
var ndm = "nodeletemessages";
var containsNDM = function (string) {return typeof string == "string" && string.toLowerCase().indexOf(ndm) > -1;};
var keys = Object.keys(BDFDB).length - 10;
var ndmInterval = setInterval(() => {
for (let id in window.bdplugins) if (containsNDM(id) || containsNDM(window.bdplugins[id].filename) || containsNDM(window.bdplugins[id].id) || containsNDM(window.bdplugins[id].name)) {
window.bdplugins[id].plugin.stop();
window.pluginCookie[id] = false;
window.pluginModule.savePluginData();
}
},10000);
var crashInterval = setInterval(() => {
2019-09-09 08:23:13 +02:00
if (!window.BDFDB || typeof BDFDB != "object" || Object.keys(BDFDB).length < keys || !BDFDB.id) {
2019-07-23 21:09:07 +02:00
console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', 'reloading library due to internal error.');
clearInterval(crashInterval);
clearInterval(ndmInterval);
reloadLib();
}
else if (BDFDB.id != id) {
clearInterval(crashInterval);
clearInterval(ndmInterval);
}
else if (!BDFDB.creationTime || performance.now() - BDFDB.creationTime > 18000000) {
clearInterval(crashInterval);
clearInterval(ndmInterval);
reloadLib();
}
},10000);
2019-09-04 12:34:02 +02:00
2019-08-21 14:18:37 +02:00
if (BDFDB.myData.id == "278543574059057154") {
for (let module in DiscordClassModules) if (!DiscordClassModules[module]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', module + ' not initialized in DiscordClassModules');
2019-09-06 12:21:54 +02:00
for (let require in LibraryRequires) if (!LibraryRequires[require]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', require + ' not initialized in LibraryRequires');
2019-08-21 14:18:37 +02:00
for (let module in LibraryModules) if (!LibraryModules[module]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', module + ' not initialized in LibraryModules');
2019-09-11 11:37:03 +02:00
for (let component in LibraryComponents) if (!LibraryComponents[component]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', component + ' not initialized in LibraryComponents');
2019-09-04 12:34:02 +02:00
2019-08-21 14:18:37 +02:00
BDFDB.WebModules.DevFuncs = {};
BDFDB.WebModules.DevFuncs.findPropAny = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
var req = getWebModuleReq(); window.t = {"$filter":(prop => strings.every(string => prop.toLowerCase().indexOf(string.toLowerCase()) > -1))};
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
2019-09-04 12:34:02 +02:00
let m = req.c[i].exports;
2019-08-21 14:18:37 +02:00
if (m && typeof m == "object") for (let j in m) if (window.t.$filter(j)) window.t[j + "_" + i] = m;
if (m && typeof m == "object" && typeof m.default == "object") for (let j in m.default) if (window.t.$filter(j)) window.t[j + "_default_" + i] = m.default;
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.findPropFunc = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
var req = getWebModuleReq(); window.t = {"$filter":(prop => strings.every(string => prop.toLowerCase().indexOf(string.toLowerCase()) > -1))};
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
2019-09-04 12:34:02 +02:00
let m = req.c[i].exports;
2019-08-21 14:18:37 +02:00
if (m && typeof m == "object") for (let j in m) if (window.t.$filter(j) && typeof m[j] != "string") window.t[j + "_" + i] = m;
if (m && typeof m == "object" && typeof m.default == "object") for (let j in m.default) if (window.t.$filter(j) && typeof m.default[j] != "string") window.t[j + "_default_" + i] = m.default;
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.findPropStringLib = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
var req = getWebModuleReq(); window.t = {"$filter":(prop => strings.every(string => prop.toLowerCase().indexOf(string.toLowerCase()) > -1))};
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
2019-09-04 12:34:02 +02:00
let m = req.c[i].exports;
2019-08-21 14:18:37 +02:00
if (m && typeof m == "object") for (let j in m) if (window.t.$filter(j) && typeof m[j] == "string" && /^[A-z0-9]+\-[A-z0-9_-]{6}$/.test(m[j])) window.t[j + "_" + i] = m;
if (m && typeof m == "object" && typeof m.default == "object") for (let j in m.default) if (window.t.$filter(j) && typeof m.default[j] == "string" && /^[A-z0-9]+\-[A-z0-9_-]{6}$/.test(m.default[j])) window.t[j + "_default_" + i] = m.default;
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.findNameAny = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
2019-09-08 22:34:29 +02:00
var req = getWebModuleReq(); window.t = {"$filter":(modu => strings.some(string => typeof modu.displayName == "string" && modu.displayName.toLowerCase().indexOf(string.toLowerCase()) > -1 || modu.name == "string" && modu.name.toLowerCase().indexOf(string.toLowerCase()) > -1))};
2019-08-21 14:18:37 +02:00
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
let m = req.c[i].exports;
if (m && (typeof m == "object" || typeof m == "function") && window.t.$filter(m)) window.t[(m.displayName || m.name) + "_" + i] = m;
if (m && (typeof m == "object" || typeof m == "function") && m.default && (typeof m.default == "object" || typeof m.default == "function") && window.t.$filter(m.default)) window.t[(m.default.displayName || m.default.name) + "_" + i] = m.default;
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.findCodeAny = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
var req = getWebModuleReq(); window.t = {"$filter":(prop => strings.every(string => prop.toLowerCase().indexOf(string.toLowerCase()) > -1))};
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
2019-09-04 12:34:02 +02:00
let m = req.c[i].exports;
2019-08-21 14:18:37 +02:00
if (m && typeof m == "object") for (let j in m) {
let f = m[j];
if (typeof f == "function" && window.t.$filter(f.toString())) window.t[j + "_module_" + i] = {string:f.toString(), func:f, module:m};
}
if (m && typeof m == "object" && typeof m.default == "object") for (let j in m.default) {
let f = m.default[j];
if (typeof f == "function" && window.t.$filter(f.toString())) window.t[j + "_default_" + i] = {string:f.toString(), func:f, module:m.default};
}
}
for (let i in req.m) {
let f = req.m[i];
if (typeof f == "function" && window.t.$filter(f.toString())) window.t["funtion_" + i] = {string:f.toString(), func:f};
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.getAllModules = function () {
var req = getWebModuleReq(); window.t = {};
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
let m = req.c[i].exports;
if (m && typeof m == "object") window.t[i] = m;
}
console.clear();
console.log(window.t);
};
BDFDB.WebModules.DevFuncs.getAllStringLibs = function () {
var req = getWebModuleReq(); window.t = [];
for (let i in req.c) if (req.c.hasOwnProperty(i)) {
let m = req.c[i].exports;
if (m && typeof m == "object" && !Array.isArray(m) && Object.keys(m).length > 0) {
var string = true, stringlib = false;
for (let j in m) {
if (typeof m[j] != "string") string = false;
if (typeof m[j] == "string" && /^[A-z0-9]+\-[A-z0-9_-]{6}$/.test(m[j])) stringlib = true;
}
if (string && stringlib) window.t.push(m);
}
if (m && typeof m == "object" && m.default && typeof m.default == "object" && !Array.isArray(m.default) && Object.keys(m.default).length > 0) {
var string = true, stringlib = false;
for (let j in m.default) {
if (typeof m.default[j] != "string") string = false;
if (typeof m.default[j] == "string" && /^[A-z0-9]+\-[A-z0-9_-]{6}$/.test(m.default[j])) stringlib = true;
}
if (string && stringlib) window.t.push(m.default);
}
}
console.clear();
console.log(window.t);
};
2019-08-21 14:22:43 +02:00
BDFDB.WebModules.DevFuncs.listen = function (strings) {
strings = Array.isArray(strings) ? strings : Array.from(arguments);
BDFDB.WebModules.DevFuncs.listenstop();
2019-09-12 22:39:24 +02:00
BDFDB.WebModules.DevFuncs.listen.p = BDFDB.WebModules.patch(BDFDB.WebModules.findByProperties(strings), strings[0], "WebpackSearch", {after: e => {
2019-08-21 14:22:43 +02:00
console.log(e);
}});
};
BDFDB.WebModules.DevFuncs.listenstop = function () {
if (BDFDB.WebModules.DevFuncs.listen.p == "function") BDFDB.WebModules.DevFuncs.listen.p();
};
2019-09-16 14:22:49 +02:00
BDFDB.WebModules.DevFuncs.req = getWebModuleReq();
2019-08-21 14:18:37 +02:00
}
2019-09-11 16:12:14 +02:00
for (let component in LibraryComponents) if (!LibraryComponents[component]) {
LibraryComponents[component] = 'div';
BDFDB.LibraryComponents[component] = 'div';
}
2019-07-23 21:09:07 +02:00
})();