6405 lines
377 KiB
JavaScript
6405 lines
377 KiB
JavaScript
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);
|
||
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);
|
||
|
||
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'});
|
||
|
||
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);
|
||
|
||
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);
|
||
|
||
BDFDB.WebModules.patchModules(plugin);
|
||
|
||
BDFDB.addOnSwitchListener(plugin);
|
||
BDFDB.addSettingsButtonListener(plugin);
|
||
BDFDB.addContextListener(plugin);
|
||
|
||
BDFDB.translatePlugin(plugin);
|
||
|
||
BDFDB.checkChangeLog(plugin);
|
||
|
||
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);
|
||
|
||
plugin.started = true;
|
||
|
||
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);
|
||
|
||
delete BDFDB.myPlugins[plugin.name];
|
||
|
||
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'});
|
||
|
||
var url = typeof plugin.getRawUrl == 'function' && typeof plugin.getRawUrl() == 'string' ? plugin.getRawUrl() : `https://mwittrien.github.io/BetterDiscordAddons/Plugins/${plugin.name}/${plugin.name}.plugin.js`;
|
||
|
||
if (typeof plugin.css === 'string') BDFDB.removeLocalStyle(plugin.name);
|
||
|
||
BDFDB.WebModules.unpatchall(plugin);
|
||
|
||
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`);
|
||
|
||
BDFDB.killObservers(plugin);
|
||
|
||
delete window.PluginUpdates.plugins[url];
|
||
if (BDFDB.isObjectEmpty(window.PluginUpdates.plugins)) BDFDB.removeEles('#bd-settingspane-container .bd-updatebtn' + BDFDB.dotCN._repofolderbutton);
|
||
|
||
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;
|
||
}
|
||
};
|
||
|
||
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');
|
||
BDFDB.openChangeLogModal(plugin);
|
||
}
|
||
};
|
||
|
||
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"));
|
||
};
|
||
|
||
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);
|
||
}
|
||
};
|
||
|
||
BDFDB.killObservers = function (plugin) {
|
||
if (!BDFDB.isObjectEmpty(plugin.observers)) {
|
||
for (let observer in plugin.observers) for (let instance of plugin.observers[observer]) instance.disconnect();
|
||
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));};
|
||
|
||
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;
|
||
LibraryRequires.request(url, (error, response, result) => {
|
||
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);
|
||
});
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
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: <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) {
|
||
LibraryRequires.request(url, (error, response, result) => {
|
||
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, '');
|
||
LibraryRequires.fs.writeFileSync(LibraryRequires.path.join(BDFDB.getPluginsFolder(), (bdplugins[plugname] ? bdplugins[plugname].filename : url.split("/").slice(-1)[0])), result);
|
||
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);
|
||
}
|
||
const {type = '', icon = true, timeout = 3000, html = false, selector = '', nopointer = false, color = ''} = options;
|
||
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');
|
||
}
|
||
else if (color) {
|
||
var rgbcolor = BDFDB.colorCONVERT(color, 'RGB');
|
||
if (rgbcolor) toast.style.setProperty('background-color', rgbcolor);
|
||
}
|
||
BDFDB.addClass(toast, selector);
|
||
toasts.appendChild(toast);
|
||
toast.close = () => {
|
||
if (document.contains(toast)) {
|
||
BDFDB.addClass(toast, 'closing');
|
||
toast.style.setProperty("pointer-events", "none", "important");
|
||
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;
|
||
};
|
||
|
||
var DesktopNotificationQueue = {queue:[], running:false};
|
||
BDFDB.showDesktopNotification = function (parsedcontent, parsedoptions = {}) {
|
||
var queue = () => {
|
||
DesktopNotificationQueue.queue.push({parsedcontent, parsedoptions});
|
||
runqueue();
|
||
};
|
||
var runqueue = () => {
|
||
if (!DesktopNotificationQueue.running) {
|
||
var notification = DesktopNotificationQueue.queue.shift();
|
||
if (notification) notify(notification.parsedcontent, notification.parsedoptions);
|
||
}
|
||
};
|
||
var notify = (content, options) => {
|
||
DesktopNotificationQueue.running = true;
|
||
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();
|
||
DesktopNotificationQueue.running = false;
|
||
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;
|
||
var tooltip = BDFDB.htmlToElement(`<div class="${BDFDB.disCN.tooltip}"></div>`);
|
||
if (options.id) tooltip.id = options.id.split(' ').join('');
|
||
if (options.selector) BDFDB.addClass(tooltip, options.selector);
|
||
if (options.style) tooltip.style = options.style;
|
||
if (options.html === true) tooltip.innerHTML = text;
|
||
else tooltip.innerText = text;
|
||
if (options.type && BDFDB.disCN['tooltip' + options.type.toLowerCase()]) {
|
||
BDFDB.addClass(tooltip, BDFDB.disCN['tooltip' + options.type.toLowerCase()]);
|
||
tooltip.appendChild(BDFDB.htmlToElement(`<div class="${BDFDB.disCN.tooltippointer}"></div>`));
|
||
}
|
||
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);
|
||
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();
|
||
tooltip.anker = anker;
|
||
|
||
BDFDB.appendItemLayer(tooltip, anker, {css:options.css, ankerlistener:{'mouseleave':() => {BDFDB.removeEles(tooltip.parentElement);}}});
|
||
|
||
BDFDB.updateTooltipPosition(tooltip);
|
||
|
||
if (options.delay) {
|
||
BDFDB.toggleEles(tooltip);
|
||
setTimeout(() => {BDFDB.toggleEles(tooltip);}, options.delay);
|
||
}
|
||
return tooltip;
|
||
};
|
||
|
||
BDFDB.updateTooltipPosition = function (tooltip) {
|
||
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);
|
||
if (!Node.prototype.isPrototypeOf(tooltip) || !Node.prototype.isPrototypeOf(tooltip.anker) || !tooltip.position) return;
|
||
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};
|
||
var pointer = tooltip.querySelector(BDFDB.dotCN.tooltippointer);
|
||
if (pointer) positionoffsets = BDFDB.getRects(pointer);
|
||
switch (tooltip.position) {
|
||
case 'top':
|
||
top = trects.top - irects.height - positionoffsets.height + 2;
|
||
left = trects.left + (trects.width - irects.width) / 2;
|
||
break;
|
||
case 'bottom':
|
||
top = trects.top + trects.height + positionoffsets.height - 2;
|
||
left = trects.left + (trects.width - irects.width) / 2;
|
||
break;
|
||
case 'left':
|
||
top = trects.top + (trects.height - irects.height) / 2;
|
||
left = trects.left - irects.width - positionoffsets.width + 2;
|
||
break;
|
||
case 'right':
|
||
top = trects.top + (trects.height - irects.height) / 2;
|
||
left = trects.left + trects.width + positionoffsets.width - 2;
|
||
break;
|
||
}
|
||
itemlayer.style.setProperty('top', top + 'px');
|
||
itemlayer.style.setProperty('left', left + 'px');
|
||
|
||
pointer.style.removeProperty('margin-left');
|
||
pointer.style.removeProperty('margin-top');
|
||
if (tooltip.position == "top" || tooltip.position == "bottom") {
|
||
if (left < 0) {
|
||
itemlayer.style.setProperty('left', '5px');
|
||
pointer.style.setProperty('margin-left', `${left - 10}px`);
|
||
}
|
||
else {
|
||
var rightmargin = arects.width - (left + irects.width);
|
||
if (rightmargin < 0) {
|
||
itemlayer.style.setProperty('left', arects.width - irects.width - 5 + 'px');
|
||
pointer.style.setProperty('margin-left', `${-1*rightmargin}px`);
|
||
}
|
||
}
|
||
}
|
||
else if (tooltip.position == "left" || tooltip.position == "right") {
|
||
if (top < 0) {
|
||
itemlayer.style.setProperty('top', '5px');
|
||
pointer.style.setProperty('margin-top', `${top - 10}px`);
|
||
}
|
||
else {
|
||
var bottommargin = arects.height - (top + irects.height);
|
||
if (bottommargin < 0) {
|
||
itemlayer.style.setProperty('top', arects.height - irects.height - 5 + 'px');
|
||
pointer.style.setProperty('margin-top', `${-1*bottommargin}px`);
|
||
}
|
||
}
|
||
}
|
||
};
|
||
|
||
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});
|
||
};
|
||
|
||
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);
|
||
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>`);
|
||
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 || options.button) notice.appendChild(BDFDB.htmlToElement(`<button class="${BDFDB.disCNS.noticebutton + BDFDB.disCNS.size14 + BDFDB.disCN.weightmedium}">${options.btn || options.button}</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);
|
||
return LibraryRequires.path.resolve(LibraryRequires.electron.remote.app.getPath('appData'), built, BDFDB.getDiscordVersion());
|
||
};
|
||
|
||
BDFDB.getPluginsFolder = function () {
|
||
if (LibraryRequires.process.env.injDir) return LibraryRequires.path.resolve(LibraryRequires.process.env.injDir, 'plugins/');
|
||
switch (LibraryRequires.process.platform) {
|
||
case 'win32':
|
||
return LibraryRequires.path.resolve(LibraryRequires.process.env.appdata, 'BetterDiscord/plugins/');
|
||
case 'darwin':
|
||
return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, 'Library/Preferences/BetterDiscord/plugins/');
|
||
default:
|
||
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/');
|
||
}
|
||
};
|
||
|
||
BDFDB.getThemesFolder = function () {
|
||
if (LibraryRequires.process.env.injDir) return LibraryRequires.path.resolve(LibraryRequires.process.env.injDir, 'plugins/');
|
||
switch (LibraryRequires.process.platform) {
|
||
case 'win32':
|
||
return LibraryRequires.path.resolve(LibraryRequires.process.env.appdata, 'BetterDiscord/themes/');
|
||
case 'darwin':
|
||
return LibraryRequires.path.resolve(LibraryRequires.process.env.HOME, 'Library/Preferences/BetterDiscord/themes/');
|
||
default:
|
||
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/');
|
||
}
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
BDFDB.mapObject = function (obj, keyname) {
|
||
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;
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
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}
|
||
};
|
||
|
||
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;
|
||
try {built = require(LibraryRequires.electron.remote.app.getAppPath() + '/build_info.json').releaseChannel.toLowerCase();}
|
||
catch (err) {
|
||
try {built = require(LibraryRequires.electron.remote.app.getAppPath().replace('\app.asar', '') + '/build_info.json').releaseChannel.toLowerCase();}
|
||
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;
|
||
try {version = LibraryRequires.electron.remote.app.getVersion();}
|
||
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 () {
|
||
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);
|
||
return widthzoom < heightzoom ? widthzoom : heightzoom;
|
||
};
|
||
|
||
BDFDB.getDiscordFontScale = function () {
|
||
return parseInt(document.firstElementChild.style.fontSize.replace('%', ''));
|
||
};
|
||
|
||
BDFDB.isColorBlindModeEnabled = function () {
|
||
return true;
|
||
};
|
||
|
||
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;
|
||
|
||
function getInstance (instance) {
|
||
depth++;
|
||
if (!instance || Node.prototype.isPrototypeOf(instance) || BDFDB.getReactInstance(instance) || depth > maxdepth || performance.now() - start > maxtime) return null;
|
||
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);
|
||
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))) {
|
||
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';
|
||
for (let name of config.name) if (instance.type.displayName === name.split(' _ _ ')[0] || instance.type.name === name.split(' _ _ ')[0]) {
|
||
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;
|
||
}
|
||
};
|
||
|
||
var getWebModuleReq = function () {
|
||
if (!getWebModuleReq.req) {
|
||
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];
|
||
getWebModuleReq.req = req;
|
||
}
|
||
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;
|
||
if (m && (typeof m == "object" || typeof m == "function") && filter(m)) return m;
|
||
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];
|
||
}
|
||
};
|
||
|
||
BDFDB.WebModules.cachedData = {prop:{},name:{},string:{},proto:{}};
|
||
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 {
|
||
var m = BDFDB.WebModules.find(m => properties.every(prop => m[prop] !== undefined));
|
||
if (m) {
|
||
BDFDB.WebModules.cachedData.prop[cachestring] = m;
|
||
return m;
|
||
}
|
||
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 {
|
||
var m = BDFDB.WebModules.find(m => m.displayName === name);
|
||
if (m) {
|
||
BDFDB.WebModules.cachedData.name[cachestring] = m;
|
||
return m;
|
||
}
|
||
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [name] not found in WebModules');
|
||
}
|
||
};
|
||
|
||
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) {
|
||
BDFDB.WebModules.cachedData.string[cachestring] = m;
|
||
return m;
|
||
}
|
||
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [string] not found in WebModules');
|
||
}
|
||
};
|
||
|
||
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 {
|
||
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;
|
||
}
|
||
else console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', cachestring + ' [prototypes] not found in WebModules');
|
||
}
|
||
};
|
||
|
||
BDFDB.DiscordConstants = BDFDB.WebModules.findByProperties('Permissions', 'ActivityTypes');
|
||
|
||
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);
|
||
|
||
var LibraryModules = {};
|
||
LibraryModules.AckUtils = BDFDB.WebModules.findByProperties('localAck', 'bulkAck');
|
||
LibraryModules.APIUtils = BDFDB.WebModules.findByProperties('getAPIBaseURL');
|
||
LibraryModules.AnimationUtils = BDFDB.WebModules.findByProperties('spring', 'decay');
|
||
LibraryModules.BadgeUtils = BDFDB.WebModules.findByProperties('getBadgeCountString', 'getBadgeWidthForValue');
|
||
LibraryModules.ChannelStore = BDFDB.WebModules.findByProperties('getChannel', 'getChannels');
|
||
LibraryModules.ContextMenuUtils = BDFDB.WebModules.findByProperties('closeContextMenu', 'openContextMenu');
|
||
LibraryModules.CurrentUserStore = BDFDB.WebModules.findByProperties('getCurrentUser');
|
||
LibraryModules.DirectMessageUtils = BDFDB.WebModules.findByProperties('addRecipient', 'openPrivateChannel');
|
||
LibraryModules.FriendUtils = BDFDB.WebModules.findByProperties('getFriendIDs', 'getRelationships');
|
||
LibraryModules.GuildBoostUtils = BDFDB.WebModules.findByProperties('getTierName', 'getUserLevel');
|
||
LibraryModules.GuildStore = BDFDB.WebModules.findByProperties('getGuild', 'getGuilds');
|
||
LibraryModules.GuildChannelStore = BDFDB.WebModules.findByProperties('getChannels', 'getDefaultChannel');
|
||
LibraryModules.GuildEmojiStore = BDFDB.WebModules.findByProperties('getGuildEmoji', 'getDisambiguatedEmojiContext');
|
||
LibraryModules.GuildUtils = BDFDB.WebModules.findByProperties('transitionToGuildSync');
|
||
LibraryModules.HistoryUtils = BDFDB.WebModules.findByProperties('transitionTo', 'replaceWith', 'getHistory');;
|
||
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');
|
||
LibraryModules.LoginUtils = BDFDB.WebModules.findByProperties('login', 'logout');
|
||
LibraryModules.MemberStore = BDFDB.WebModules.findByProperties('getMember', 'getMembers');
|
||
LibraryModules.MentionUtils = BDFDB.WebModules.findByProperties('getMentionCount', 'getMentionCounts');
|
||
LibraryModules.MessageStore = BDFDB.WebModules.findByProperties('getMessage', 'getMessages');
|
||
LibraryModules.MessageCreationUtils = BDFDB.WebModules.findByProperties('parse', 'isMentioned');
|
||
LibraryModules.MessagePinUtils = BDFDB.WebModules.findByProperties('pinMessage', 'unpinMessage');
|
||
LibraryModules.MessageUtils = BDFDB.WebModules.findByProperties('receiveMessage', 'editMessage');
|
||
LibraryModules.MutedUtils = BDFDB.WebModules.findByProperties('isGuildOrCategoryOrChannelMuted');
|
||
LibraryModules.NotificationSettingsUtils = BDFDB.WebModules.findByProperties('setDesktopType', 'setTTSType');
|
||
LibraryModules.NotificationSettingsStore = BDFDB.WebModules.findByProperties('getDesktopType', 'getTTSType');
|
||
LibraryModules.PermissionUtils = BDFDB.WebModules.findByProperties('getChannelPermissions', 'canUser');
|
||
LibraryModules.PermissionRoleUtils = BDFDB.WebModules.findByProperties('getHighestRole', 'can');
|
||
LibraryModules.ReactionUtils = BDFDB.WebModules.findByProperties('addReaction', 'removeReaction');
|
||
LibraryModules.SearchPageUtils = BDFDB.WebModules.findByProperties('searchNextPage', 'searchPreviousPage');
|
||
LibraryModules.SelectChannelUtils = BDFDB.WebModules.findByProperties('selectChannel', 'selectPrivateChannel');
|
||
LibraryModules.SettingsUtils = BDFDB.WebModules.findByProperties('updateRemoteSettings', 'updateLocalSettings');
|
||
LibraryModules.SoundUtils = BDFDB.WebModules.findByProperties('playSound', 'createSound');
|
||
LibraryModules.StatusMetaUtils = BDFDB.WebModules.findByProperties('getApplicationActivity', 'getStatus');
|
||
LibraryModules.StreamingUtils = BDFDB.WebModules.findByProperties('isStreaming');
|
||
LibraryModules.UnreadGuildUtils = BDFDB.WebModules.findByProperties('hasUnread', 'getUnreadGuilds');
|
||
LibraryModules.UnreadChannelUtils = BDFDB.WebModules.findByProperties('getUnreadCount', 'getOldestUnreadMessageId');
|
||
LibraryModules.UploadUtils = BDFDB.WebModules.findByProperties('upload', 'instantBatchUpload');
|
||
LibraryModules.UserStore = BDFDB.WebModules.findByProperties('getUser', 'getUsers');
|
||
LibraryModules.VoiceUtils = BDFDB.WebModules.findByProperties('getAllVoiceStates', 'getVoiceStatesForChannel');
|
||
LibraryModules.ZoomUtils = BDFDB.WebModules.findByProperties('setZoom', 'setFontSize');
|
||
BDFDB.LibraryModules = Object.assign({}, LibraryModules);
|
||
|
||
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) {
|
||
if (Node.prototype.isPrototypeOf(instance)) return instance;
|
||
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;
|
||
};
|
||
};
|
||
|
||
var myDataUser = LibraryModules.CurrentUserStore && typeof LibraryModules.CurrentUserStore.getCurrentUser == 'function' ? LibraryModules.CurrentUserStore.getCurrentUser() : null;
|
||
BDFDB.myData = new Proxy(myDataUser || {}, {
|
||
get: function (list, item) {
|
||
if (!myDataUser) myDataUser = LibraryModules.CurrentUserStore.getCurrentUser();
|
||
return myDataUser ? myDataUser[item] : null;
|
||
}
|
||
});
|
||
|
||
var webModulesPatchtypes = ['before', 'instead', 'after'];
|
||
var webModulesPatchmap = {
|
||
Account: 'FluxContainer(Account)',
|
||
BannedCard: 'BannedUser',
|
||
InvitationCard: 'InviteRow',
|
||
InviteCard: 'InviteRow',
|
||
PopoutContainer: 'Popout',
|
||
MemberCard: 'Member',
|
||
Note: 'FluxContainer(Note)',
|
||
WebhookCard: 'Webhook'
|
||
};
|
||
var webModulesNotFindableModules = {
|
||
AuthWrapper: 'loginscreen',
|
||
BannedCard: 'guildsettingsbannedcard',
|
||
ChannelMember: 'member',
|
||
EmojiPicker: 'emojipicker',
|
||
FriendRow: 'friendsrow',
|
||
Guild: 'guildouter',
|
||
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) {
|
||
if (!module || !modulefunctions || !plugin || !Object.keys(patchfunctions).some(type => webModulesPatchtypes.includes(type))) return null;
|
||
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] = {};
|
||
for (let type of webModulesPatchtypes) module.BDFDBpatch[modulefunction][type] = {};
|
||
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)
|
||
};
|
||
if (window.BDFDB && typeof BDFDB === 'object' && BDFDB.loaded && module.BDFDBpatch[modulefunction]) {
|
||
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)) {
|
||
const tempreturn = surpressErrors(module.BDFDBpatch[modulefunction].after[id], '`after` callback of ' + module[modulefunction].displayName)(data);
|
||
if (tempreturn !== undefined) data.returnValue = tempreturn;
|
||
}
|
||
}
|
||
else data.callOriginalMethod();
|
||
return data.returnValue;
|
||
};
|
||
}
|
||
for (let type of webModulesPatchtypes) if (typeof patchfunctions[type] == 'function') module.BDFDBpatch[modulefunction][type][plugname] = patchfunctions[type];
|
||
}
|
||
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]) {
|
||
for (let type of webModulesPatchtypes) {
|
||
if (plugname) delete module.BDFDBpatch[modulefunction][type][plugname];
|
||
else delete module.BDFDBpatch[modulefunction][type];
|
||
}
|
||
var empty = true;
|
||
for (let type of webModulesPatchtypes) if (!BDFDB.isObjectEmpty(module.BDFDBpatch[modulefunction][type])) empty = false;
|
||
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) {
|
||
selectedtype = selectedtype && webModulesPatchmap[selectedtype] ? webModulesPatchmap[selectedtype] + ' _ _ ' + selectedtype : selectedtype;
|
||
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) {
|
||
try {
|
||
const appins = BDFDB.getOwnerInstance({node:app, name:filteredmodules, all:true, noCopies:true, group:true, depth:99999999, time:99999999});
|
||
for (let type in appins) for (let i in appins[type]) BDFDB.WebModules.initiateProcess(plugin, appins[type][i], null, type, ['componentDidMount', 'componentDidUpdate', 'render']);
|
||
if (bdsettings) {
|
||
const bdsettingsins = BDFDB.getOwnerInstance({node:bdsettings, name:filteredmodules, all:true, noCopies:true, group:true, depth:99999999, time:99999999});
|
||
for (let type in bdsettingsins) for (let i in bdsettingsins[type]) BDFDB.WebModules.initiateProcess(plugin, bdsettingsins[type][i], null, type, ['componentDidMount', 'componentDidUpdate', 'render']);
|
||
}
|
||
}
|
||
catch (err) {console.error(`%c[${plugin.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not force update components! ' + err);}
|
||
}
|
||
}
|
||
}
|
||
};
|
||
|
||
BDFDB.WebModules.patchModules = function (plugin) {
|
||
if (BDFDB.isObject(plugin) && BDFDB.isObject(plugin.patchModules)) {
|
||
for (let type in plugin.patchModules) {
|
||
var mapped = webModulesPatchmap[type];
|
||
var classname = webModulesNotFindableModules[type.split(' _ _ ')[1] || type];
|
||
var patchtype = mapped ? mapped + ' _ _ ' + type : type;
|
||
if (mapped) {
|
||
plugin.patchModules[patchtype] = plugin.patchModules[type];
|
||
delete plugin.patchModules[type];
|
||
}
|
||
if (!classname) patchInstance(BDFDB.WebModules.findByName(patchtype.split(' _ _ ')[0]), patchtype);
|
||
else if (DiscordClasses[classname]) checkForInstance(classname, patchtype);
|
||
}
|
||
function patchInstance(instance, type) {
|
||
if (instance) {
|
||
var name = type.split(' _ _ ')[0];
|
||
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
|
||
instance = instance.displayName == name ? instance : BDFDB.getOwnerInstance({instance, name, up:true});
|
||
if (instance) {
|
||
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
|
||
BDFDB.WebModules.patch(instance.prototype, plugin.patchModules[type], plugin, {after: e => {
|
||
if (window.BDFDB && typeof BDFDB === 'object' && BDFDB.loaded) BDFDB.WebModules.initiateProcess(plugin, e.thisObject, e.returnValue, type, [e.originalMethodName]);
|
||
}});
|
||
}
|
||
}
|
||
}
|
||
function checkForInstance(classname, type) {
|
||
const app = document.querySelector(BDFDB.dotCN.app), bdsettings = document.querySelector('#bd-settingspane-container ' + BDFDB.dotCN.scrollerwrap);
|
||
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) {
|
||
var found = false, instanceobserver = new MutationObserver(cs => {cs.forEach(c => {c.addedNodes.forEach(n => {
|
||
if (found || !n || !n.tagName) return;
|
||
var ele = null;
|
||
if ((ele = BDFDB.containsClass(n, BDFDB.disCN[classname]) ? n : n.querySelector(BDFDB.dotCN[classname])) != null) {
|
||
var ins = BDFDB.getReactInstance(ele);
|
||
if (isCorrectInstance(ins, type)) {
|
||
found = true;
|
||
instanceobserver.disconnect();
|
||
patchInstance(ins, type);
|
||
BDFDB.WebModules.forceAllUpdates(plugin, type);
|
||
}
|
||
}
|
||
});});});
|
||
BDFDB.addObserver(plugin, BDFDB.dotCN.appmount, {name:'checkForInstanceObserver', instance:instanceobserver, multi:true
|
||
}, {childList:true, subtree:true});
|
||
}
|
||
}
|
||
function isCorrectInstance(instance, type) {
|
||
if (!instance) return false;
|
||
instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance;
|
||
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');
|
||
}
|
||
}
|
||
};
|
||
|
||
BDFDB.WebModules.initiateProcess = function (plugin, instance, returnvalue, type, methodnames) {
|
||
if (BDFDB.isObject(plugin) && instance) {
|
||
type = (type.split(' _ _ ')[1] || type).replace(/[^A-z0-9]|_/g, '');
|
||
type = type[0].toUpperCase() + type.slice(1);
|
||
if (typeof plugin['process' + type] == 'function') {
|
||
var wrapper = BDFDB.React.findDOMNodeSafe(instance);
|
||
if (wrapper) plugin['process' + type](instance, wrapper, returnvalue, methodnames);
|
||
else setImmediate(() => {
|
||
wrapper = BDFDB.React.findDOMNodeSafe(instance);
|
||
if (wrapper) plugin['process' + type](instance, wrapper, returnvalue, methodnames);
|
||
});
|
||
}
|
||
}
|
||
};
|
||
|
||
BDFDB.addOnSwitchListener = function (plugin) {
|
||
if (typeof plugin.onSwitch === 'function') {
|
||
BDFDB.removeOnSwitchListener(plugin);
|
||
var spacer = document.querySelector(`${BDFDB.dotCN.guildswrapper} ~ * > ${BDFDB.dotCN.chatspacer}`);
|
||
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;
|
||
}
|
||
};
|
||
|
||
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};
|
||
|
||
BDFDB.addContextListener = function (plugin) {
|
||
if (!BDFDB.isObject(plugin)) return;
|
||
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);
|
||
}
|
||
};
|
||
|
||
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) {
|
||
if (module && module.prototype) {
|
||
BDFDB.WebModules.patch(module.prototype, 'componentDidMount', BDFDB, {after: e => {
|
||
if (!e.thisObject.BDFDBforceRenderTimeout && typeof e.thisObject.render == 'function') e.thisObject.render();
|
||
}});
|
||
BDFDB.WebModules.patch(module.prototype, 'componentDidUpdate', BDFDB, {after: e => {
|
||
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();
|
||
}
|
||
}});
|
||
BDFDB.WebModules.patch(module.prototype, 'render', BDFDB, {after: e => {
|
||
if (e.thisObject.props.BDFDBcontextMenu && e.thisObject.props.children && e.returnValue && e.returnValue.props) {
|
||
e.returnValue.props.children = e.thisObject.props.children;
|
||
delete e.thisObject.props.value;
|
||
delete e.thisObject.props.children;
|
||
delete e.thisObject.props.BDFDBcontextMenu;
|
||
}
|
||
if (BDFDB.React.findDOMNodeSafe(e.thisObject)) {
|
||
e.thisObject.BDFDBforceRenderTimeout = true;
|
||
setTimeout(() => {delete e.thisObject.BDFDBforceRenderTimeout;}, 1000);
|
||
}
|
||
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);
|
||
}
|
||
}
|
||
}
|
||
}});
|
||
}
|
||
};
|
||
var BDFDBpatchPopoutModuleLib = function (module, repatch) {
|
||
if (module && module.prototype) {
|
||
BDFDB.WebModules.patch(module.prototype, 'componentDidMount', BDFDB, {after: e => {
|
||
if (!e.thisObject.BDFDBforceRenderTimeout && !e.thisObject.BDFDBforceUpdateTimeout && typeof e.thisObject.render == 'function') e.thisObject.render();
|
||
}});
|
||
BDFDB.WebModules.patch(module.prototype, 'componentDidUpdate', BDFDB, {after: e => {
|
||
const updater = BDFDB.getReactValue(e, 'thisObject._reactInternalFiber.return.return.return.stateNode.updateOffsets');
|
||
if (updater) updater();
|
||
e.thisObject.BDFDBforceUpdateTimeout = true;
|
||
setTimeout(() => {delete e.thisObject.BDFDBforceUpdateTimeout;}, 1000);
|
||
}});
|
||
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);
|
||
}
|
||
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;
|
||
}
|
||
}
|
||
}
|
||
}});
|
||
}
|
||
};
|
||
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);
|
||
|
||
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', () => {
|
||
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>`);
|
||
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;
|
||
}
|
||
};
|
||
|
||
var LanguageStringsVars = {}, LanguageStrings = LibraryModules.LanguageStore && LibraryModules.LanguageStore._proxyContext ? Object.assign({}, LibraryModules.LanguageStore._proxyContext.defaultMessages) : {};
|
||
BDFDB.LanguageStrings = new Proxy(LanguageStrings, {
|
||
get: function (list, item) {
|
||
var stringobj = LibraryModules.LanguageStore.Messages[item];
|
||
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) {
|
||
return LibraryModules.LanguageStore.Messages[item];
|
||
}
|
||
});
|
||
BDFDB.LanguageStringsFormat = function (item, value) {
|
||
if (item && value) {
|
||
var stringobj = LibraryModules.LanguageStore.Messages[item];
|
||
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 "";
|
||
};
|
||
if (LibraryModules.LanguageStore) for (let string in LanguageStrings) {
|
||
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) {
|
||
var guild = LibraryModules.GuildStore.getGuild(typeof id == 'number' ? id.toFixed() : id);
|
||
if (!guild || !guild.icon) return null;
|
||
return LibraryModules.IconUtils.getGuildIconURL(guild).split('?')[0];
|
||
};
|
||
|
||
BDFDB.getGuildBanner = function (id) {
|
||
var guild = LibraryModules.GuildStore.getGuild(typeof id == 'number' ? id.toFixed() : id);
|
||
if (!guild || !guild.banner) return null;
|
||
return LibraryModules.IconUtils.getGuildBannerURL(guild).split('?')[0];
|
||
};
|
||
|
||
BDFDB.getUserStatus = function (id = BDFDB.myData.id) {
|
||
id = typeof id == 'number' ? id.toFixed() : id;
|
||
return LibraryModules.StreamingUtils.isStreaming(LibraryModules.StatusMetaUtils.getApplicationActivity(id)) ? 'streaming' : LibraryModules.StatusMetaUtils.getStatus(id);
|
||
};
|
||
|
||
BDFDB.getUserStatusColor = function (status) {
|
||
status = typeof status == "string" ? status.toLowerCase() : null;
|
||
switch (status) {
|
||
case 'online': return '#43b581';
|
||
case 'mobile': return '#43b581';
|
||
case 'idle': return '#faa61a';
|
||
case 'dnd': return '#f04747';
|
||
case 'playing': return '#7289da';
|
||
case 'listening': return '#1db954';
|
||
case 'streaming': return '#593695';
|
||
default: return '#747f8d';
|
||
}
|
||
};
|
||
|
||
BDFDB.getUserAvatar = function (id = BDFDB.myData.id) {
|
||
var user = LibraryModules.UserStore.getUser(typeof id == 'number' ? id.toFixed() : id);
|
||
if (!user) return 'https://discordapp.com/assets/322c936a8c8be1b803cd94861bdfa868.png';
|
||
else return ((user.avatar ? '' : 'https://discordapp.com') + LibraryModules.IconUtils.getUserAvatarURL(user)).split('?')[0];
|
||
};
|
||
|
||
BDFDB.isUserAllowedTo = function (permission, id = BDFDB.myData.id, channelid = LibraryModules.LastChannelStore.getChannelId()) {
|
||
if (!BDFDB.DiscordConstants.Permissions[permission]) console.warn(`%c[BDFDB]%c`, 'color:#3a71c1; font-weight:700;', '', permission + ' not found in Permissions');
|
||
else {
|
||
var channel = LibraryModules.ChannelStore.getChannel(channelid);
|
||
if (channel) return LibraryModules.PermissionUtils.canUser(id, BDFDB.DiscordConstants.Permissions[permission], channel);
|
||
}
|
||
return false;
|
||
};
|
||
|
||
BDFDB.getChannelIcon = function (id) {
|
||
var channel = LibraryModules.ChannelStore.getChannel(id = typeof id == 'number' ? id.toFixed() : id);
|
||
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);
|
||
return LibraryModules.IconUtils.getChannelIconURL(channel).split('?')[0];
|
||
};
|
||
|
||
BDFDB.getParsedLength = function (string, channelid = LibraryModules.LastChannelStore.getChannelId()) {
|
||
if (!string) return 0;
|
||
var channel = LibraryModules.ChannelStore.getChannel(channelid);
|
||
var length = (string.indexOf('/') == 0 || string.indexOf('s/') == 0 || string.indexOf('+:') == 0) ? string.length : LibraryModules.MessageCreationUtils.parse(channel, string).content.length;
|
||
return length > string.length ? length : string.length;
|
||
};
|
||
|
||
BDFDB.readServerList = function () {
|
||
var found = [], ins = BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.guilds), name:['Guild','GuildIcon'], all:true, noCopies:true, depth:99999999, time:99999999});
|
||
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]}));
|
||
return found;
|
||
};
|
||
|
||
BDFDB.readUnreadServerList = function (servers) {
|
||
var found = [];
|
||
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;
|
||
if (id && (LibraryModules.UnreadGuildUtils.hasUnread(id) || LibraryModules.MentionUtils.getMentionCount(id) > 0)) found.push(eleOrInfoOrId);
|
||
}
|
||
return found;
|
||
};
|
||
|
||
BDFDB.readMutedServerList = function (servers) {
|
||
var found = [];
|
||
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;
|
||
if (id && LibraryModules.MutedUtils.isGuildOrCategoryOrChannelMuted(id)) found.push(eleOrInfoOrId);
|
||
}
|
||
return found;
|
||
};
|
||
|
||
BDFDB.getSelectedServer = function () {
|
||
var info = LibraryModules.GuildStore.getGuild(LibraryModules.LastGuildStore.getGuildId());
|
||
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;
|
||
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});
|
||
}
|
||
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;
|
||
};
|
||
|
||
BDFDB.createServerDivCopy = function (infoOrId, functionality = {pill: false, hover: false, click:false, menu:false, size:null}) {
|
||
let id = typeof infoOrId == 'object' ? infoOrId.id : infoOrId;
|
||
let guild = id ? LibraryModules.GuildStore.getGuild(id) : null;
|
||
if (guild) {
|
||
let randomid = Math.round(Math.random() * 10000000000000000);
|
||
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>`);
|
||
let divinner = div.querySelector(BDFDB.dotCN.guildcontainer);
|
||
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);
|
||
|
||
let pillvisible = divpillitem.style.getPropertyValue("opacity") != 0;
|
||
|
||
let borderRadius = new LibraryModules.AnimationUtils.Value(0);
|
||
borderRadius
|
||
.interpolate({inputRange: [0, 1], outputRange: [50, 30]})
|
||
.addListener((value) => {divinner.style.setProperty("border-radius", `${value.value}%`);});
|
||
|
||
let pillHeight = new LibraryModules.AnimationUtils.Value(0);
|
||
pillHeight
|
||
.interpolate({inputRange: [0, 1], outputRange: [8, 20]})
|
||
.addListener((value) => {divpillitem.style.setProperty("height", `${value.value}px`);});
|
||
|
||
let pillOpacity = new LibraryModules.AnimationUtils.Value(0);
|
||
pillOpacity
|
||
.interpolate({inputRange: [0, 1], outputRange: [0, 0.7]})
|
||
.addListener((value) => {divpillitem.style.setProperty("opacity", `${value.value}`);});
|
||
|
||
let animate = (v) => {
|
||
LibraryModules.AnimationUtils.parallel([
|
||
LibraryModules.AnimationUtils.timing(borderRadius, {toValue: v, duration: 200}),
|
||
LibraryModules.AnimationUtils.spring(pillHeight, {toValue: v, friction: 5})
|
||
]).start();
|
||
};
|
||
|
||
let animate2 = (v) => {
|
||
LibraryModules.AnimationUtils.parallel([
|
||
LibraryModules.AnimationUtils.timing(pillOpacity, {toValue: v, duration: 200}),
|
||
]).start();
|
||
};
|
||
|
||
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);
|
||
}
|
||
});
|
||
}
|
||
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");
|
||
}
|
||
return div;
|
||
}
|
||
else return null;
|
||
};
|
||
|
||
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, {
|
||
type: BDFDB.DiscordConstants.ContextMenuTypes.GUILD_ICON_BAR,
|
||
guild: guild,
|
||
badge: LibraryModules.MentionUtils.getMentionCount(guild.id),
|
||
link: BDFDB.DiscordConstants.Routes.CHANNEL(guild.id, LibraryModules.LastChannelStore.getChannelId(guild.id)),
|
||
selected: guild.id == LibraryModules.LastGuildStore.getGuildId()
|
||
}));
|
||
});
|
||
};
|
||
|
||
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 () {
|
||
var info = LibraryModules.ChannelStore.getChannel(LibraryModules.LastChannelStore.getChannelId());
|
||
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;
|
||
};
|
||
|
||
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) {
|
||
type = BDFDB.DiscordConstants.ContextMenuTypes[(t == "GUILD_CATEGORY" ? "CHANNEL_" : "CHANNEL_LIST_") + t.replace("GUILD_", "")];
|
||
break;
|
||
}
|
||
if (type) LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) {
|
||
return BDFDB.React.createElement(BDFDB.WebModules.findByName("ChannelContextMenu"), Object.assign({}, e, {
|
||
type,
|
||
channel,
|
||
guild: LibraryModules.GuildStore.getGuild(channel.guild_id),
|
||
selected: channel.id == LibraryModules.LastChannelStore.getChannelId()
|
||
}));
|
||
});
|
||
}
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
BDFDB.markChannelAsRead = function (channels) {
|
||
if (!channels) return;
|
||
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);
|
||
}
|
||
if (unreadchannels.length > 0) LibraryModules.AckUtils.bulkAck(unreadchannels);
|
||
};
|
||
|
||
BDFDB.markGuildAsRead = function (servers) {
|
||
if (!servers) return;
|
||
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;
|
||
let channels = id ? LibraryModules.GuildChannelStore.getChannels(id) : null;
|
||
if (channels) for (let type in channels) if (Array.isArray(channels[type])) for (let channelobj of channels[type]) unreadchannels.push(channelobj.channel.id);
|
||
}
|
||
if (unreadchannels.length > 0) LibraryModules.AckUtils.bulkAck(unreadchannels);
|
||
};
|
||
|
||
BDFDB.saveAllData = function (data, plugin, key) {
|
||
var configpath, plugname;
|
||
if (!BDFDB.isBDv2()) {
|
||
plugname = typeof plugin === 'string' ? plugin : plugin.name;
|
||
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
|
||
}
|
||
else {
|
||
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
|
||
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
|
||
if (!contentpath) return;
|
||
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
|
||
}
|
||
var exists = LibraryRequires.fs.existsSync(configpath);
|
||
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];
|
||
if (exists) LibraryRequires.fs.unlinkSync(configpath);
|
||
}
|
||
else {
|
||
BDFDB.cachedData[plugname] = config;
|
||
LibraryRequires.fs.writeFileSync(configpath, JSON.stringify(config, null, ' '));
|
||
}
|
||
};
|
||
|
||
BDFDB.loadAllData = function (plugin, key) {
|
||
var configpath, plugname;
|
||
if (!BDFDB.isBDv2()) {
|
||
plugname = typeof plugin === 'string' ? plugin : plugin.name;
|
||
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
|
||
}
|
||
else {
|
||
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
|
||
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
|
||
if (!contentpath) return {};
|
||
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
|
||
}
|
||
if (!LibraryRequires.fs.existsSync(configpath)) {
|
||
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) {
|
||
var configpath, plugname;
|
||
if (!BDFDB.isBDv2()) {
|
||
plugname = typeof plugin === 'string' ? plugin : plugin.name;
|
||
configpath = LibraryRequires.path.join(BDFDB.getPluginsFolder(), plugname + '.config.json');
|
||
}
|
||
else {
|
||
plugname = typeof plugin === 'string' ? plugin.toLowerCase() : null;
|
||
var contentpath = plugname ? BDFDB.Plugins[plugname] ? BDFDB.Plugins[plugname].contentPath : null : plugin.contentPath;
|
||
if (!contentpath) return;
|
||
configpath = LibraryRequires.path.join(contentpath, 'settings.json');
|
||
}
|
||
var exists = LibraryRequires.fs.existsSync(configpath);
|
||
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];
|
||
if (exists) LibraryRequires.fs.unlinkSync(configpath);
|
||
}
|
||
else {
|
||
BDFDB.cachedData[plugname] = config;
|
||
LibraryRequires.fs.writeFileSync(configpath, JSON.stringify(config, null, ' '));
|
||
}
|
||
};
|
||
|
||
BDFDB.getAllData = function (plugin, key) {
|
||
plugin = typeof plugin == "string" && BDFDB.isObject(window.BdApi) ? window.BdApi.getPlugin(plugin) : plugin;
|
||
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) {
|
||
newconfig[k] = BDFDB.isObject(plugin.defaults[key][k].value) ? BDFDB.deepAssign({}, plugin.defaults[key][k].value) : plugin.defaults[key][k].value;
|
||
update = true;
|
||
}
|
||
else newconfig[k] = oldconfig[k];
|
||
}
|
||
if (update) BDFDB.saveAllData(newconfig, plugin, key);
|
||
return newconfig;
|
||
};
|
||
|
||
BDFDB.readConfig = function (path) {
|
||
try {return JSON.parse(LibraryRequires.fs.readFileSync(path));}
|
||
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);}));};
|
||
};
|
||
|
||
var setAlpha = (color, a, conv) => {
|
||
var comp = BDFDB.colorCONVERT(color, 'RGBCOMP');
|
||
if (comp) {
|
||
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;
|
||
comp[3] = a;
|
||
conv = (conv || BDFDB.colorTYPE(color)).toUpperCase();
|
||
conv = conv == 'HSL' || conv == 'RGB' ? conv + 'A' : conv;
|
||
return BDFDB.colorCONVERT(comp, conv);
|
||
}
|
||
return null;
|
||
};
|
||
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);
|
||
};
|
||
|
||
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;
|
||
};
|
||
BDFDB.colorCHANGE = function (color, value, conv) {
|
||
value = parseFloat(value);
|
||
if (color && typeof value == 'number' && !isNaN(value)) {
|
||
if (BDFDB.isObject(color)) {
|
||
var newcolor = {};
|
||
for (let pos in color) newcolor[pos] = colorChange(color[pos], value, conv);
|
||
return newcolor;
|
||
}
|
||
else return colorChange(color, value, conv);
|
||
}
|
||
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);};
|
||
};
|
||
|
||
BDFDB.colorGRADIENT = function (colorobj, direction = 'to right') {
|
||
var sortedgradient = {};
|
||
var gradientstring = 'linear-gradient(' + direction;
|
||
for (let pos of Object.keys(colorobj).sort()) gradientstring += `, ${colorobj[pos]} ${pos*100}%`
|
||
return gradientstring += ")";
|
||
};
|
||
|
||
BDFDB.setInnerText = function (node, stringOrNode) {
|
||
if (!node || !Node.prototype.isPrototypeOf(node)) return;
|
||
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")) {
|
||
textnode = child;
|
||
break;
|
||
}
|
||
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;
|
||
}
|
||
else node.appendChild(Node.prototype.isPrototypeOf(stringOrNode) ? stringOrNode : document.createTextNode(stringOrNode));
|
||
};
|
||
|
||
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) {
|
||
var hidenode = node;
|
||
while (hidenode) {
|
||
var hidden = BDFDB.isEleHidden(hidenode);
|
||
if (hidden) {
|
||
BDFDB.toggleEles(hidenode, true);
|
||
hidenode.BDFDBgetRectsHidden = true;
|
||
}
|
||
hidenode = hidenode.parentElement;
|
||
}
|
||
rects = node.getBoundingClientRect();
|
||
hidenode = node;
|
||
while (hidenode) {
|
||
if (hidenode.BDFDBgetRectsHidden) {
|
||
BDFDB.toggleEles(hidenode, false);
|
||
delete hidenode.BDFDBgetRectsHidden;
|
||
}
|
||
hidenode = hidenode.parentElement;
|
||
}
|
||
}
|
||
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');
|
||
try {template.innerHTML = html.replace(/(?<!pre)>[\t\r\n]+<(?!pre)/g, "><");}
|
||
catch (err) {template.innerHTML = html.replace(/>[\t\r\n]+<(?!pre)/g, "><");}
|
||
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();
|
||
container.querySelectorAll(".BDFDB-containertext").forEach(ele => {
|
||
if (BDFDB.containsClass(ele.nextElementSibling, "BDFDB-collapsecontainer")) {
|
||
if (BDFDB.containsClass(ele.firstElementChild, "closed")) BDFDB.toggleEles(ele.nextElementSibling, false);
|
||
ele.BDFDBupdateElement = () => {
|
||
BDFDB.toggleEles(ele.nextElementSibling, BDFDB.containsClass(ele.firstElementChild, "closed"));
|
||
BDFDB.toggleClass(ele.firstElementChild, "closed");
|
||
};
|
||
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
|
||
}
|
||
});
|
||
container.querySelectorAll(BDFDB.dotCN.switchinner).forEach(ele => {
|
||
setSwitch(ele, false);
|
||
ele.BDFDBupdateElement = () => {
|
||
setSwitch(ele, true);
|
||
};
|
||
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
|
||
});
|
||
container.querySelectorAll(BDFDB.dotCNS.checkboxwrapper + BDFDB.dotCN.checkboxinput).forEach(ele => {
|
||
setCheckbox(ele);
|
||
ele.BDFDBupdateElement = () => {
|
||
setCheckbox(ele);
|
||
};
|
||
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
|
||
});
|
||
container.querySelectorAll(BDFDB.dotCN.giffavoritebutton).forEach(ele => {
|
||
setGifFavButton(ele);
|
||
ele.BDFDBupdateElement = () => {
|
||
BDFDB.toggleClass(ele, BDFDB.disCN.giffavoriteselected);
|
||
setGifFavButton(ele);
|
||
};
|
||
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
|
||
var id = 'FAV_s' + Math.round(Math.random() * 10000000000000000);
|
||
addInitEventListener(ele, 'mouseenter', () => {
|
||
BDFDB.removeEles(`#${id}_tooltip`);
|
||
BDFDB.createTooltip(BDFDB.LanguageStrings[`GIF_TOOLTIP_${BDFDB.containsClass(ele, BDFDB.disCN.giffavoriteselected) ? 'REMOVE_FROM' : 'ADD_TO'}_FAVORITES`], ele, {type:'top', id:id+'_tooltip'});
|
||
});
|
||
});
|
||
container.querySelectorAll('.file-navigator').forEach(ele => {
|
||
ele.BDFDBupdateElement = () => {
|
||
var input = ele.querySelector('input[type="file"]');
|
||
if (input) input.click();
|
||
};
|
||
addInitEventListener(ele, 'click', ele.BDFDBupdateElement);
|
||
});
|
||
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);
|
||
});
|
||
});
|
||
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 => {
|
||
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');
|
||
ele.style.setProperty('margin-left', '8px', 'important');
|
||
}
|
||
});
|
||
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() {
|
||
Animation = new LibraryModules.AnimationUtils.Value(0);
|
||
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);
|
||
LibraryModules.AnimationUtils.parallel([LibraryModules.AnimationUtils.timing(Animation, {toValue:p, duration:Math.sqrt(w**2) * 4000 / (ele.getAttribute('speed') || 1)})]).start();
|
||
};
|
||
}
|
||
}
|
||
});
|
||
|
||
BDFDB.removeClass(container.querySelectorAll('.tab-content'), 'open');
|
||
BDFDB.addClass(container.querySelector('.tab-content'), 'open');
|
||
|
||
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;});
|
||
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;});
|
||
|
||
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);
|
||
}
|
||
|
||
var executeDelayedIfNotAppened = () => {
|
||
container.querySelectorAll('.BDFDB-tableheader').forEach(ele => {
|
||
var panel = BDFDB.getParentEle('.BDFDB-modal, .BDFDB-settings', ele);
|
||
var tableid = ele.getAttribute('table-id');
|
||
var text = ele.querySelector('.BDFDB-tableheadertext');
|
||
var columns = ele.querySelectorAll('.BDFDB-tableheadercolumns .BDFDB-tableheadercolumn');
|
||
if (panel && tableid && text && columns.length) {
|
||
let toobig = false, maxwidth = BDFDB.isObject(panel['BDFDB-tableheader-maxwidth']) ? panel['BDFDB-tableheader-maxwidth'][tableid] : 0;
|
||
if (!maxwidth) {
|
||
for (let column of columns) {
|
||
let width = BDFDB.getRects(column).width;
|
||
maxwidth = width > maxwidth ? width : maxwidth;
|
||
}
|
||
maxwidth += 4;
|
||
}
|
||
if (columns.length * maxwidth > 300) {
|
||
toobig = true;
|
||
maxwidth = parseInt(290 / columns.length);
|
||
}
|
||
else if (maxwidth < 36) {
|
||
maxwidth = 36;
|
||
}
|
||
columns.forEach((column, i) => {
|
||
column.style.setProperty('flex', `0 0 ${maxwidth}px`, 'important');
|
||
if (toobig) {
|
||
if (i == 0) column.style.setProperty('margin-left', `${-1 * (10 + maxwidth/2)}px`, 'important');
|
||
column.style.setProperty('margin-top', '0', 'important');
|
||
column.style.setProperty('text-align', 'right', 'important');
|
||
column.style.setProperty('writing-mode', 'vertical-rl', 'important');
|
||
}
|
||
else column.style.setProperty('text-align', 'center', 'important');
|
||
});
|
||
text.style.setProperty('flex', `0 0 ${556 - (columns.length * maxwidth)}px`, 'important');
|
||
columns[0].parentElement.style.setProperty('flex', `0 0 ${columns.length * maxwidth}px`, 'important');
|
||
if (!BDFDB.isObject(panel['BDFDB-tableheader-maxwidth'])) panel['BDFDB-tableheader-maxwidth'] = {}
|
||
panel['BDFDB-tableheader-maxwidth'][tableid] = maxwidth;
|
||
}
|
||
});
|
||
container.querySelectorAll('.BDFDB-tablecheckbox').forEach(ele => {
|
||
var panel = BDFDB.getParentEle('.BDFDB-modal, .BDFDB-settings', ele);
|
||
var tableid = ele.getAttribute('table-id');
|
||
if (panel && tableid && BDFDB.isObject(panel['BDFDB-tableheader-maxwidth']) && panel['BDFDB-tableheader-maxwidth'][tableid]) {
|
||
var style = getComputedStyle(ele);
|
||
ele.style.setProperty('flex', `0 0 ${panel['BDFDB-tableheader-maxwidth'][tableid] - parseInt(style.marginLeft) - parseInt(style.marginRight)}px`, 'important');
|
||
}
|
||
});
|
||
};
|
||
|
||
if (document.contains(container)) executeDelayedIfNotAppened();
|
||
else setImmediate(() => {executeDelayedIfNotAppened();});
|
||
|
||
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) {
|
||
if (!ele.BDFDBupdateElementsListeners) ele.BDFDBupdateElementsListeners = {};
|
||
if (ele.BDFDBupdateElementsListeners[action]) ele.removeEventListener(action, ele.BDFDBupdateElementsListeners[action]);
|
||
ele.BDFDBupdateElementsListeners[action] = callback;
|
||
ele.addEventListener(action, callback, true);
|
||
};
|
||
};
|
||
|
||
BDFDB.appendModal = function (modalwrapper) {
|
||
if (!Node.prototype.isPrototypeOf(modalwrapper)) return;
|
||
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}));
|
||
if (!BDFDB.appendModal.modals) return;
|
||
|
||
var modal = BDFDB.containsClass(modalwrapper, BDFDB.disCN.modal) ? modalwrapper : modalwrapper.querySelector(BDFDB.dotCN.modal);
|
||
var backdrop = modal ? modal.previousElementSibling : null;
|
||
|
||
var modalOpacity = new LibraryModules.AnimationUtils.Value(0);
|
||
modalOpacity
|
||
.interpolate({inputRange: [0, 1], outputRange: [0, 1]})
|
||
.addListener((value) => {if (modal) modal.style.setProperty("opacity", `${value.value}`);});
|
||
var modalTransform = new LibraryModules.AnimationUtils.Value(0);
|
||
modalTransform
|
||
.interpolate({inputRange: [0, 1], outputRange: [0.7, 1]})
|
||
.addListener((value) => {if (modal) modal.style.setProperty("transform", `scale(${value.value}) translateZ(0px)`);});
|
||
var backdropOpacity = new LibraryModules.AnimationUtils.Value(0);
|
||
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)");
|
||
}});
|
||
|
||
var animate = (v) => {
|
||
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}),
|
||
]).start();
|
||
};
|
||
|
||
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);
|
||
};
|
||
|
||
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]) : "";
|
||
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>`);
|
||
BDFDB.initElements(searchBar);
|
||
return searchBar;
|
||
};
|
||
|
||
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';
|
||
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>`;
|
||
};
|
||
|
||
BDFDB.openDropdownMenu = function (e, callback, createinner, values, above = false, dark = BDFDB.getDiscordTheme() == BDFDB.disCN.themedark) {
|
||
if (typeof callback != 'function' || typeof createinner != 'function' || !values || typeof values != 'object') return;
|
||
let selectControl = (BDFDB.getParentEle(BDFDB.dotCN.selectwrap, e.currentTarget) || e.currentTarget).querySelector(BDFDB.dotCN.selectcontrol);
|
||
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 (above) {
|
||
BDFDB.addClass(selectMenu, 'above-select');
|
||
selectMenu.style.setProperty('top', 'unset', 'important');
|
||
selectMenu.style.setProperty('bottom', BDFDB.getRects(selectWrap).height + 'px', 'important');
|
||
}
|
||
selectWrap.appendChild(selectMenu);
|
||
BDFDB.initElements(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 => {
|
||
if (!BDFDB.getParentEle(BDFDB.dotCN.giffavoritebutton, e2.target)) {
|
||
var newchoice = e2.currentTarget.getAttribute('value');
|
||
selectWrap.setAttribute('value', newchoice);
|
||
callback(selectWrap, type, newchoice);
|
||
}
|
||
});
|
||
|
||
var removeMenu = e2 => {
|
||
if (e2.target.parentElement != selectMenu && !BDFDB.getParentEle(BDFDB.dotCN.giffavoritebutton, e2.target)) {
|
||
document.removeEventListener('mousedown', removeMenu);
|
||
selectMenu.remove();
|
||
setTimeout(() => {BDFDB.removeClass(selectWrap, BDFDB.disCN.selectisopen);},100);
|
||
}
|
||
};
|
||
document.addEventListener('mousedown', removeMenu);
|
||
|
||
return selectMenu;
|
||
};
|
||
|
||
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?";
|
||
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>`);
|
||
BDFDB.appendModal(confirmModal);
|
||
if (typeof callback == 'function') confirmModal.querySelector('.btn-ok').addEventListener('click', () => {
|
||
setTimeout(() => {callback();}, 300);
|
||
});
|
||
return confirmModal;
|
||
};
|
||
|
||
BDFDB.updateContextPosition = function (menu, e = BDFDB.mousePosition) {
|
||
if (!Node.prototype.isPrototypeOf(menu)) return;
|
||
var itemlayer = BDFDB.getParentEle(BDFDB.dotCN.itemlayer, menu) || menu;
|
||
var arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount));
|
||
var irects = BDFDB.getRects(itemlayer);
|
||
var newpos = {
|
||
pageX: e.pageX - irects.width,
|
||
pageY: e.pageY - irects.height
|
||
};
|
||
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');
|
||
BDFDB.initElements(menu);
|
||
};
|
||
|
||
BDFDB.getContextMenuGroupAndIndex = function (startchildren, names) {
|
||
names = Array.isArray(names) ? names : (typeof names == "string" ? [names] : Array.from(names));
|
||
var startIsArray = Array.isArray(startchildren);
|
||
var parent = startchildren;
|
||
return search(startchildren);
|
||
function search (children) {
|
||
while (children && !Array.isArray(children) && children.props && children.props.children) {
|
||
parent = children;
|
||
children = children.props.children;
|
||
}
|
||
if (children && !Array.isArray(children)) {
|
||
if (parent && parent.props) {
|
||
var child = children;
|
||
parent.props.children = [];
|
||
parent.props.children.push(child);
|
||
return [parent.props.children, check(child) ? 0 : -1];
|
||
}
|
||
else return [startchildren, -1];
|
||
}
|
||
else {
|
||
if (!startIsArray) {
|
||
startchildren = children;
|
||
startIsArray = true;
|
||
}
|
||
var result = [startchildren, -1];
|
||
for (let i in children) if (children[i]) {
|
||
if (check(children[i])) result = [children, i];
|
||
else if (children[i].props) {
|
||
parent = children[i];
|
||
result = search(children[i].props.children);
|
||
}
|
||
if (result[1] > -1) break;
|
||
}
|
||
return result;
|
||
}
|
||
}
|
||
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);
|
||
}
|
||
};
|
||
|
||
BDFDB.openContextMenu = function (plugin, e, children) {
|
||
LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) {
|
||
return BDFDB.React.createElement(LibraryComponents.ContextMenu, Object.assign({}, e, {
|
||
BDFDBcontextMenu: true,
|
||
type: BDFDB.DiscordConstants.ContextMenuTypes.NATIVE_TEXT,
|
||
value: "",
|
||
className: `${BDFDB.disCN.contextmenu} BDFDB-contextMenu ${plugin.name}-contextMenuItem`,
|
||
children
|
||
}));
|
||
});
|
||
};
|
||
|
||
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);
|
||
BDFDB.initElements(popout);
|
||
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);
|
||
};
|
||
|
||
var setSwatch = (swatch, color, selected) => {
|
||
if (!swatch) return;
|
||
else if (selected) {
|
||
BDFDB.addClass(swatch, 'selected');
|
||
var iscustom = BDFDB.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom);
|
||
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>`));
|
||
if (iscustom) {
|
||
BDFDB.removeClass(swatch, BDFDB.disCN.colorpickerswatchnocolor);
|
||
swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute('fill', bright ? '#000000' : '#ffffff');
|
||
if (selectedcolor) {
|
||
if (isgradient) swatch.gradient = color;
|
||
swatch.style.setProperty(isgradient ? 'background-image' : 'background-color', selectedcolor, 'important');
|
||
}
|
||
}
|
||
}
|
||
else {
|
||
delete swatch.gradient;
|
||
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');
|
||
swatch.style.removeProperty('background-color');
|
||
swatch.style.removeProperty('background-image');
|
||
}
|
||
}
|
||
};
|
||
|
||
BDFDB.setColorSwatches = function (container, currentcolor) {
|
||
if (!Node.prototype.isPrototypeOf(container)) return;
|
||
|
||
var swatches = container.querySelector('.swatches:not([swatchnr])');
|
||
if (!swatches) return;
|
||
swatches.setAttribute('swatchnr', parseInt(container.querySelectorAll('.swatches[swatchnr]').length + 1));
|
||
|
||
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();
|
||
|
||
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>`));
|
||
|
||
if (currentcolor && !BDFDB.colorCOMPARE(currentcolor, [0, 0, 0, 0])) {
|
||
var selection = colorlist.indexOf(BDFDB.colorCONVERT(currentcolor, 'RGB'));
|
||
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);
|
||
}
|
||
else setSwatch(swatches.querySelector(BDFDB.dotCNS.colorpickerrow + BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchnocolor), null, true);
|
||
BDFDB.addChildEventListener(swatches, 'click', BDFDB.dotCN.colorpickerswatch, e => {
|
||
if (BDFDB.containsClass(swatches, 'disabled') || BDFDB.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchdisabled)) return;
|
||
else if (BDFDB.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchcustom)) {
|
||
BDFDB.openColorPicker(swatches, e.currentTarget, e.currentTarget.gradient || e.currentTarget.style.getPropertyValue("background-color"));
|
||
}
|
||
else {
|
||
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + ".selected"), null, false);
|
||
setSwatch(e.currentTarget, e.currentTarget.style.getPropertyValue('background-color'), true);
|
||
}
|
||
});
|
||
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'});
|
||
});
|
||
};
|
||
|
||
BDFDB.getSwatchColor = function (container, nr) {
|
||
if (!Node.prototype.isPrototypeOf(container)) return;
|
||
|
||
var swatch = container.querySelector(`.swatches[swatchnr="${nr}"] ${BDFDB.dotCN.colorpickerswatch}.selected`);
|
||
return swatch ? swatch.gradient || BDFDB.colorCONVERT(swatch.style.getPropertyValue('background-color'), 'RGBCOMP') : null;
|
||
};
|
||
|
||
BDFDB.openColorPicker = function (container, target, color, options = {gradient: true, comp: false, alpha: false}) {
|
||
if (!container || !target) return;
|
||
var isswatches = BDFDB.containsClass(container, 'swatches');
|
||
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');
|
||
|
||
var targetrects = BDFDB.getRects(target);
|
||
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.333333v85.333334H384z m170.666667 0h85.333333v85.333334h-85.333333z m85.333333-85.333333h85.333333v85.333333h-85.333333zM298.666667 384h85.333333v85.333333H298.666667z m512-256H213.333333c-46.933333 0-85.333333 38.4-85.333333 85.333333v597.333334c0 46.933333 38.4 85.333333 85.333333 85.333333h597.333334c46.933333 0 85.333333-38.4 85.333333-85.333333V213.333333c0-46.933333-38.4-85.333333-85.333333-85.333333zM384 768H298.666667v-85.333333h85.333333v85.333333z m170.666667 0h-85.333334v-85.333333h85.333334v85.333333z m170.666666 0h-85.333333v-85.333333h85.333333v85.333333z m85.333334-298.666667h-85.333334v85.333334h85.333334v85.333333h-85.333334v-85.333333h-85.333333v85.333333h-85.333333v-85.333333h-85.333334v85.333333H384v-85.333333H298.666667v85.333333H213.333333v-85.333333h85.333334v-85.333334H213.333333V213.333333h597.333334v256z"></path></svg></div></div></div><div class="move-corner" style="width: 10px; height: 10px; cursor: move; position: absolute; top: 0; left: 0;"></div><div class="move-corner" style="width: 10px; height: 10px; cursor: move; position: absolute; top: 0; right: 0;"></div><div class="move-corner" style="width: 10px; height: 10px; cursor: move; position: absolute; bottom: 0; right: 0;"></div><div class="move-corner" style="width: 10px; height: 10px; cursor: move; position: absolute; bottom: 0; left: 0;"></div></div>`);
|
||
document.querySelector(BDFDB.dotCN.popouts).appendChild(colorPicker);
|
||
|
||
var removePopout = e => {
|
||
if (!colorPicker.contains(e.target)) {
|
||
document.removeEventListener("mousedown", removePopout);
|
||
colorPicker.remove();
|
||
}
|
||
};
|
||
document.addEventListener("mousedown", removePopout);
|
||
|
||
var hexinput = colorPicker.querySelector(BDFDB.dotCNS.colorpickerhexinput + BDFDB.dotCN.input);
|
||
var gradientbutton = colorPicker.querySelector('.gradient-button');
|
||
var gradientbar = colorPicker.querySelector('.gradient-bar');
|
||
var gradientpane = colorPicker.querySelector('.gradient-horizontal');
|
||
var satpane = colorPicker.querySelector('.saturation-color');
|
||
var huepane = colorPicker.querySelector('.hue-horizontal');
|
||
var satcursor = colorPicker.querySelector('.saturation-cursor');
|
||
var huecursor = colorPicker.querySelector('.hue-cursor');
|
||
|
||
var gMinX, gMaxX, sMinX, sMaxX, sMinY, sMaxY, hMinX, hMaxX;
|
||
|
||
updateRects();
|
||
|
||
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>`));
|
||
|
||
updateColors(false);
|
||
|
||
if (!options.gradient) BDFDB.removeEles(colorPicker.querySelectorAll(".gradient-button, .gradient-bar"));
|
||
|
||
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);
|
||
}
|
||
});
|
||
});
|
||
satpane.addEventListener('mousedown', e => {
|
||
s = BDFDB.mapRange([sMinX, sMaxX], [0, 100], e.clientX) + '%';
|
||
l = BDFDB.mapRange([sMinY, sMaxY], [100, 0], e.clientY) + '%';
|
||
updateColors(true);
|
||
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) + '%';
|
||
updateColors(true);
|
||
};
|
||
document.addEventListener('mouseup', mouseup);
|
||
document.addEventListener('mousemove', mousemove);
|
||
});
|
||
huepane.addEventListener('mousedown', e => {
|
||
h = BDFDB.mapRange([hMinX, hMaxX], [0, 360], e.clientX);
|
||
updateColors(true);
|
||
var mouseup = () => {
|
||
document.removeEventListener('mouseup', mouseup);
|
||
document.removeEventListener('mousemove', mousemove);
|
||
};
|
||
var mousemove = e2 => {
|
||
h = BDFDB.mapRange([hMinX, hMaxX], [0, 360], e2.clientX);
|
||
updateColors(true);
|
||
};
|
||
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');
|
||
updateColors(false);
|
||
}
|
||
});
|
||
gradientbutton.addEventListener('click', e => {
|
||
isgradient = !isgradient;
|
||
BDFDB.toggleEles(gradientbar, isgradient);
|
||
BDFDB.toggleClass(gradientbutton, "selected", isgradient);
|
||
updateColors(true);
|
||
});
|
||
gradientbutton.addEventListener('mouseenter', e => {
|
||
BDFDB.createTooltip("Color Gradient", gradientbutton, {type: "bottom"});
|
||
});
|
||
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) {
|
||
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');
|
||
var hex = BDFDB.colorCONVERT([h, s, l], 'HEX');
|
||
if (isswatches) {
|
||
setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + '.selected'), null, false);
|
||
if (isgradient) {
|
||
gradientpane.querySelector('.gradient-cursor.selected').firstElementChild.style.setProperty('background-color', hex);
|
||
updateGradient();
|
||
}
|
||
else {
|
||
setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), [h, s, l], true);
|
||
}
|
||
}
|
||
else {
|
||
let input = container.querySelector(BDFDB.dotCN.input);
|
||
if (input) input.value = options.comp ? BDFDB.colorCONVERT(hex, 'RGBCOMP').join(',') : BDFDB.colorCONVERT(hex, 'RGB');
|
||
let swatch = container.querySelector('.single-swatch');
|
||
if (swatch) swatch.style.setProperty('background-color', hex, 'important');
|
||
}
|
||
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(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), gradient, true);
|
||
}
|
||
};
|
||
|
||
BDFDB.mapRange = function (from, to, value) {
|
||
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]));
|
||
};
|
||
|
||
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');
|
||
};
|
||
|
||
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;
|
||
};
|
||
|
||
(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;});
|
||
})();
|
||
|
||
(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;});
|
||
})();
|
||
|
||
var DiscordClassModules = {};
|
||
DiscordClassModules.BDFDB = {
|
||
BDFDBundefined: 'BDFDB_undefined',
|
||
cardInner: 'card-inner',
|
||
overflowEllipsis: 'overflowellipsis'
|
||
};
|
||
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 = {
|
||
_: '',
|
||
avatarStopAnimation: 'stop-animation',
|
||
badgeWrapper: 'wrapper-232cHJ',
|
||
nameContainerNameContainer: 'container-2ax-kl',
|
||
guildChannels: 'container-PNkimc',
|
||
guildBadgeWrapper: 'guild-badge-wrapper-deprecated',
|
||
highlight: 'highlight',
|
||
hoverCardButton: 'button-2CgfFz',
|
||
loginScreen: 'wrapper-3Q5DdO',
|
||
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',
|
||
themeLight: 'theme-light',
|
||
themeUndefined: 'theme-undefined'
|
||
};
|
||
|
||
DiscordClassModules.AccountDetails = BDFDB.WebModules.findByProperties('usernameContainer', 'container');
|
||
DiscordClassModules.ActivityFeed = BDFDB.WebModules.findByProperties('activityFeed');
|
||
DiscordClassModules.Anchor = BDFDB.WebModules.findByProperties('anchor', 'anchorUnderlineOnHover');
|
||
DiscordClassModules.AppBase = BDFDB.WebModules.findByProperties('container', 'base');
|
||
DiscordClassModules.AppInner = BDFDB.WebModules.findByProperties('app');
|
||
DiscordClassModules.AppMount = BDFDB.WebModules.findByProperties('appMount');
|
||
DiscordClassModules.ApplicationStore = BDFDB.WebModules.findByProperties('applicationStore', 'navigation');
|
||
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');
|
||
DiscordClassModules.Call = BDFDB.WebModules.findByProperties('callAvatarWrapper', 'video');
|
||
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');
|
||
DiscordClassModules.ColorPicker = BDFDB.WebModules.findByProperties('colorPickerCustom', 'customColorPickerInput');
|
||
DiscordClassModules.ColorPickerInner = BDFDB.WebModules.findByProperties('saturation', 'hue', 'wrapper');
|
||
DiscordClassModules.ContextMenu = BDFDB.WebModules.findByProperties('contextMenu', 'itemGroup');
|
||
DiscordClassModules.ContextMenuCheckbox = BDFDB.WebModules.findByProperties('checkboxInner', 'checkboxElement');
|
||
DiscordClassModules.CtaVerification = BDFDB.WebModules.findByProperties('attendeeCTA', 'verificationNotice');
|
||
DiscordClassModules.Cursor = BDFDB.WebModules.findByProperties('cursorDefault', 'userSelectNone');
|
||
DiscordClassModules.DmAddPopout = BDFDB.WebModules.findByProperties('popout', 'searchBarComponent');
|
||
DiscordClassModules.DmAddPopoutItems = BDFDB.WebModules.findByProperties('friendSelected', 'friendWrapper');
|
||
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.GameLibrary = BDFDB.WebModules.findByProperties('gameLibrary', 'scroller');
|
||
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', 'lowerBadge', 'svg');
|
||
DiscordClassModules.GuildChannels = BDFDB.WebModules.findByProperties('positionedContainer', 'unreadBar');
|
||
DiscordClassModules.GuildDiscovery = BDFDB.WebModules.findByProperties('pageWrapper', 'guildCard');
|
||
DiscordClassModules.GuildDm = BDFDB.WebModules.find(module => typeof module['pill'] == 'string' && Object.keys(module).length == 1);
|
||
DiscordClassModules.GuildEdges = BDFDB.WebModules.findByProperties('wrapper', 'edge', 'autoPointerEvents')
|
||
DiscordClassModules.GuildFolder = BDFDB.WebModules.findByProperties('folder', 'expandedGuilds')
|
||
DiscordClassModules.GuildHeader = BDFDB.WebModules.findByProperties('header', 'name', 'bannerImage');
|
||
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');
|
||
DiscordClassModules.GuildsItems = BDFDB.WebModules.findByProperties('guildSeparator', 'guildsError');
|
||
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');
|
||
DiscordClassModules.HomeIcon = BDFDB.WebModules.findByProperties('homeIcon');
|
||
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');
|
||
DiscordClassModules.ItemLayerContainer = BDFDB.WebModules.findByProperties('layer', 'layerContainer');
|
||
DiscordClassModules.Input = BDFDB.WebModules.findByProperties('inputMini', 'inputDefault');
|
||
DiscordClassModules.Layers = BDFDB.WebModules.findByProperties('layer', 'layers');
|
||
DiscordClassModules.LFG = BDFDB.WebModules.findByProperties('lfg', 'topSectionHeader');
|
||
DiscordClassModules.Margins = BDFDB.WebModules.findByProperties('marginBottom4', 'marginCenterHorz');
|
||
DiscordClassModules.Member = BDFDB.WebModules.findByProperties('member', 'ownerIcon');
|
||
DiscordClassModules.MembersWrap = BDFDB.WebModules.findByProperties('membersWrap', 'membersGroup');
|
||
DiscordClassModules.Mention = BDFDB.WebModules.findByProperties('wrapperHover', 'wrapperNoHover');
|
||
DiscordClassModules.Message = BDFDB.WebModules.findByProperties('containerCozy', 'content');
|
||
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);
|
||
DiscordClassModules.NameContainer = DiscordClassModules.ContextMenu.subMenuContext ? BDFDB.WebModules.findByProperties('nameAndDecorators', 'name') : {};
|
||
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);
|
||
DiscordClassModules.PrivateChannel = BDFDB.WebModules.findByProperties('channel', 'closeButton');
|
||
DiscordClassModules.PrivateChannelActivity = BDFDB.WebModules.findByProperties('activity', 'text');
|
||
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');
|
||
DiscordClassModules.TextSize = BDFDB.WebModules.findByProperties('size10', 'size14', 'size20');
|
||
DiscordClassModules.TextStyle = BDFDB.WebModules.findByProperties('large', 'primary', 'selectable');
|
||
DiscordClassModules.TextWeight = BDFDB.WebModules.findByProperties('weightBold', 'weightSemiBold');
|
||
DiscordClassModules.Title = BDFDB.WebModules.findByProperties('title', 'size18');
|
||
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: ['ApplicationStore', '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'],
|
||
callavatar: ['Call', DiscordClassModules.Call.callAvatar ? 'callAvatar' : 'callAvatarVideo'],
|
||
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'],
|
||
channelheaderheaderbarthemed: ['HeaderBar', 'themed'],
|
||
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'],
|
||
channelpanels: ['AppBase', 'panels'],
|
||
channels: ['AppBase', 'sidebar'],
|
||
channelselected: ['ChannelContainer', 'selected'],
|
||
channelsscroller: ['GuildChannels', 'scroller'],
|
||
channelunread: ['Channel', 'unread'],
|
||
channelwrapper: ['Channel', 'wrapper'],
|
||
chat: ['ChannelWindow', 'chat'],
|
||
chatbase: ['AppBase', 'base'],
|
||
chatcontent: ['ChannelWindow', 'content'],
|
||
chatspacer: ['AppBase', 'content'],
|
||
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'],
|
||
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'],
|
||
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'],
|
||
contextmenuitemclickable: [DiscordClassModules.ContextMenu.subMenuContext ? 'ContextMenu' : 'NotFound', DiscordClassModules.ContextMenu.subMenuContext ? 'clickable' : '_'],
|
||
contextmenuitemdanger: ['ContextMenu', 'danger'],
|
||
contextmenuitemdisabled: ['ContextMenu', 'disabled'],
|
||
contextmenuitemgroup: ['ContextMenu', 'itemGroup'],
|
||
contextmenuitemtoggle: ['ContextMenu', 'itemToggle'],
|
||
contextmenuitemselected: ['ContextMenu', 'selected'],
|
||
contextmenuitemslider: ['ContextMenu', 'itemSlider'],
|
||
contextmenuitemsubmenu: ['ContextMenu', 'itemSubMenu'],
|
||
contextmenuitemsubmenucaret: [DiscordClassModules.ContextMenu.subMenuContext ? 'ContextMenu' : 'NotFound', DiscordClassModules.ContextMenu.subMenuContext ? 'caret' : '_'],
|
||
contextmenulabel: ['ContextMenu', 'label'],
|
||
contextmenuscroller: ['ContextMenu', 'scroller'],
|
||
contextmenuslider: ['ContextMenu', 'slider'],
|
||
contextmenusubcontext: ['ContextMenu', 'subMenuContext'],
|
||
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'],
|
||
discriminator: ['NameTag', 'discriminator'],
|
||
dmchannel: ['PrivateChannel', 'channel'],
|
||
dmchannelactivity: ['PrivateChannelActivity', 'activity'],
|
||
dmchannelactivityicon: ['PrivateChannelActivity', 'icon'],
|
||
dmchannelactivitytext: ['PrivateChannelActivity', 'text'],
|
||
dmchannelclose: ['PrivateChannel', 'closeButton'],
|
||
dmchannelheader: ['PrivateChannelList', 'header'],
|
||
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'],
|
||
embedmediumbackgroundopacity: ['Embed', 'mediumBackgroundOpacity'],
|
||
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'],
|
||
flex: ['FlexChild', 'flex'],
|
||
flex2: ['Flex', 'flex'],
|
||
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: ['GameLibrary', '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: BDFDB.DiscordClassModules.Guild.badgeWrapper ? ['Guild', 'badgeWrapper'] : ['NotFound', 'guildBadgeWrapper'], // REMOVE
|
||
guildbuttoncontainer: ['GuildsItems', 'circleButtonMask'],
|
||
guildbuttoninner: ['GuildsItems', 'circleIconButton'],
|
||
guildbuttonicon: ['GuildsItems', 'circleIcon'],
|
||
guildbuttonpill: ['GuildsItems', 'pill'],
|
||
guildbuttonselected: ['GuildsItems', 'selected'],
|
||
guildchannels: ['NotFound', 'guildChannels'],
|
||
guildcontainer: ['GuildServer', 'blobContainer'],
|
||
guilddiscovery: ['GuildDiscovery', 'pageWrapper'],
|
||
guildedge: ['GuildEdges', 'edge'],
|
||
guildedgemiddle: ['GuildEdges', 'middle'],
|
||
guildedgewrapper: ['GuildEdges', 'wrapper'],
|
||
guildfolder: ['GuildFolder', 'folder'],
|
||
guildfolderexpandendbackground: ['GuildFolder', 'expandedFolderBackground'],
|
||
guildfolderexpandendbackgroundcollapsed: ['GuildFolder', 'collapsed'],
|
||
guildfolderexpandendbackgroundhover: ['GuildFolder', 'hover'],
|
||
guildfolderexpandedguilds: ['GuildFolder', 'expandedGuilds'],
|
||
guildfoldericonwrapperclosed: ['GuildFolder', 'closedFolderIconWrapper'],
|
||
guildfoldericonwrapperexpanded: ['GuildFolder', 'expandedFolderIconWrapper'],
|
||
guildfolderwrapper: ['GuildFolder', 'wrapper'],
|
||
guildheader: ['GuildHeader', 'container'],
|
||
guildheaderbanner: ['GuildHeader', 'banner'],
|
||
guildheaderbannerimage: ['GuildHeader', 'bannerImage'],
|
||
guildheaderhasdropdown: ['GuildHeader', 'hasDropdown'],
|
||
guildheaderheader: ['GuildHeader', 'header'],
|
||
guildheadername: ['GuildHeader', 'name'],
|
||
guildicon: ['GuildIcon', 'icon'],
|
||
guildiconacronym: ['GuildIcon', 'acronym'],
|
||
guildiconchildwrapper: ['GuildIcon', 'childWrapper'],
|
||
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'],
|
||
guilds: ['AppBase', 'guilds'],
|
||
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'],
|
||
guildsscroller: ['GuildsWrapper', 'scroller'],
|
||
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'],
|
||
height12: ['UserPopout', 'height12'],
|
||
height16: ['File', 'height16'],
|
||
height24: ['Title', 'height24'],
|
||
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'],
|
||
hovercardbutton: ['NotFound', 'hoverCardButton'],
|
||
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'],
|
||
itemlayer: ['ItemLayerContainer', 'layer'],
|
||
itemlayerconainer: ['ItemLayerContainer', 'layerContainer'],
|
||
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: ['LFG', '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'],
|
||
memberusername: ['Member', 'roleColor'],
|
||
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'],
|
||
modalminitext: ['HeaderBarTopic', 'content'],
|
||
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'],
|
||
namecontainer: ['NameContainer', 'container'],
|
||
namecontainerclickable: ['NameContainer', 'clickable'],
|
||
namecontainercontent: ['NameContainer', 'content'],
|
||
namecontainerlayout: ['NameContainer', 'layout'],
|
||
namecontainername: ['NameContainer', 'name'],
|
||
namecontainernamecontainer: ['NotFound', 'nameContainerNameContainer'],
|
||
namecontainernamewrapper: ['NameContainer', 'nameAndDecorators'],
|
||
namecontainerselected: ['NameContainer', 'selected'],
|
||
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'],
|
||
noticerichpresence: ['Notice', 'noticeRichPresence'],
|
||
noticespotify: ['Notice', 'noticeSpotify'],
|
||
noticestreamer: ['Notice', 'noticeStreamerMode'],
|
||
noticesuccess: ['Notice', 'noticeSuccess'],
|
||
noticesurvey: ['Notice', 'noticeSurvey'],
|
||
note: ['SettingsItems', 'note'],
|
||
nowrap: ['Flex', 'noWrap'],
|
||
optionpopout: ['OptionPopout', 'container'],
|
||
optionpopoutbutton: ['OptionPopout', 'button'],
|
||
optionpopoutbuttonicon: ['OptionPopout', 'icon'],
|
||
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'],
|
||
searchpopoutddmaddfriend: ['DmAddPopoutItems', 'friend'],
|
||
searchpopoutddmaddfriendwrapper: ['DmAddPopoutItems', 'friendWrapper'],
|
||
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'],
|
||
size10: ['UserPopout', 'size10'],
|
||
size12: ['UserPopout', 'size12'],
|
||
size14: ['UserPopout', 'size14'],
|
||
size16: ['UserPopout', 'size16'],
|
||
size18: ['Title', 'size18'],
|
||
size20: ['CtaVerification', 'size20'],
|
||
size24: ['TextSize', 'size24'],
|
||
size36: ['CtaVerification', 'size24'],
|
||
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'],
|
||
systempad: ['Scroller', 'systemPad'],
|
||
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'],
|
||
themeundefined: ['NotFound', 'themeUndefined'],
|
||
title: ['SettingsItems', 'title'],
|
||
titlebar: ['TitleBar', 'titleBar'],
|
||
titledefault: ['SettingsItems', 'titleDefault'],
|
||
titlemini: ['SettingsItems', 'titleMini'],
|
||
tooltip: ['Tooltip', 'tooltip'],
|
||
tooltipblack: ['Tooltip', 'tooltipBlack'],
|
||
tooltipbottom: ['Tooltip', 'tooltipBottom'],
|
||
tooltipbrand: ['Tooltip', 'tooltipBrand'],
|
||
tooltipgreen: ['Tooltip', 'tooltipGreen'],
|
||
tooltipgrey: ['Tooltip', 'tooltipGrey'],
|
||
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'],
|
||
username: ['NameTag', 'username'],
|
||
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;
|
||
}
|
||
};
|
||
|
||
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);
|
||
|
||
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);
|
||
|
||
${BDFDB.dotCN.optionpopoutbutton} svg.BDFDB-undefined,
|
||
${BDFDB.dotCN.optionpopoutbutton} .BDFDB-undefined svg {
|
||
display: none;
|
||
}
|
||
|
||
${BDFDB.dotCN.overflowellipsis} {
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
}
|
||
|
||
${BDFDB.dotCNS.messagegroup + BDFDB.dotCN.messageheadercozy} {
|
||
padding-top: 0;
|
||
}
|
||
${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=""] {
|
||
display: inline-flex;
|
||
align-items: baseline;
|
||
}
|
||
${BDFDB.dotCNS.messagegroup + BDFDB.dotCNS.messageheadercompact + BDFDB.dotCN.bottag},
|
||
${BDFDB.dotCNS.messagegroup + BDFDB.dotCNS.messageheadercompact + BDFDB.dotCN.messageusername} {
|
||
text-indent: 0px;
|
||
}
|
||
|
||
#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;
|
||
}
|
||
.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;
|
||
}
|
||
|
||
${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;
|
||
border-radius: 0 !important;
|
||
}
|
||
.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;
|
||
}
|
||
.BDFDB-itemlayerconainer, .BDFDB-itemlayer {
|
||
z-index: 3002;
|
||
}
|
||
${BDFDB.dotCN.tooltip}.tooltip-customcolor ${BDFDB.dotCN.tooltippointer} {
|
||
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-position: 6px 50%;
|
||
background-size: 20px 20px;
|
||
background-repeat: no-repeat;
|
||
}
|
||
.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();
|
||
}
|
||
.BDFDB-quickSelectPopout {
|
||
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;
|
||
}
|
||
.BDFDB-modal .BDFDB-settings-inner .BDFDB-containertext,
|
||
.BDFDB-settings .BDFDB-settings-inner .BDFDB-containertext {
|
||
margin-left: -18px;
|
||
}
|
||
.BDFDB-modal .BDFDB-containerarrow,
|
||
.BDFDB-settings .BDFDB-containerarrow {
|
||
background: url();
|
||
height: 16px;
|
||
width: 16px;
|
||
display: inline-block;
|
||
position: relative;
|
||
top: 2px;
|
||
transition: transform .3s ease;
|
||
transform: rotate(0);
|
||
}
|
||
.BDFDB-modal .BDFDB-containerarrow.closed,
|
||
.BDFDB-settings .BDFDB-containerarrow.closed {
|
||
transform: rotate(-90deg);
|
||
}
|
||
.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.selectmenuouter}.above-select {
|
||
border-radius: 3px 3px 0 0;
|
||
}
|
||
.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} {
|
||
display: flex;
|
||
align-items: center;
|
||
flex-direction: column;
|
||
margin-right: 5px;
|
||
margin-left: 5px;
|
||
}
|
||
.BDFDB-modal ${BDFDB.dotCN.checkboxcontainer}:before,
|
||
.BDFDB-settings ${BDFDB.dotCN.checkboxcontainer}:before {
|
||
display: none;
|
||
}
|
||
.BDFDB-modal .swatches.disabled,
|
||
.BDFDB-settings .swatches.disabled {
|
||
cursor: no-drop;
|
||
filter: grayscale(70%) brightness(50%);
|
||
}
|
||
.BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchnocolor},
|
||
.BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchnocolor} {
|
||
overflow: hidden;
|
||
}
|
||
.BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchnocolor}:after,
|
||
.BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchnocolor}:after {
|
||
content: "";
|
||
position: absolute;
|
||
top: 0;
|
||
right: 0;
|
||
bottom: 0;
|
||
left: 0;
|
||
background: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" width="8" height="8"><rect x="0" y="0" width="4" height="4" fill="black"></rect><rect x="0" y="4" width="4" height="4" fill="white"></rect><rect x="4" y="0" width="4" height="4" fill="white"></rect><rect x="4" y="4" width="4" height="4" fill="black"></rect></svg>') center repeat;
|
||
z-index: -1;
|
||
}
|
||
.BDFDB-modal .swatches.disabled ${BDFDB.dotCN.colorpickerswatch},
|
||
.BDFDB-settings .swatches.disabled ${BDFDB.dotCN.colorpickerswatch} {
|
||
cursor: no-drop;
|
||
}
|
||
.BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom}[style*="background"],
|
||
.BDFDB-settings ${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);
|
||
}
|
||
.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.open {
|
||
display: flex;
|
||
flex-direction: column;
|
||
flex-wrap: nowrap;
|
||
justify-content: flex-start;
|
||
align-items: stretch;
|
||
}
|
||
.BDFDB-modal .tab-content:not(.open) {
|
||
display: none;
|
||
}
|
||
.BDFDB-modal .tab-content.open > * {
|
||
padding: 0 20px 0 12px;
|
||
}
|
||
.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;
|
||
}`);
|
||
|
||
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;
|
||
});
|
||
|
||
BDFDB.patchModules = {
|
||
V2C_List: 'componentDidMount',
|
||
V2C_PluginCard: ['componentDidMount','componentDidUpdate'],
|
||
V2C_ThemeCard: ['componentDidMount','componentDidUpdate'],
|
||
UserPopout: ['componentDidMount'],
|
||
UserProfile: ['componentDidMount'],
|
||
Message: ['componentDidMount','componentDidUpdate','render']
|
||
};
|
||
|
||
BDFDB.WebModules.patch(LibraryModules.GuildStore, 'getGuild', BDFDB, {after: e => {
|
||
if (e.returnValue && e.methodArguments[0] == '410787888507256842' && !e.returnValue.banner) {
|
||
e.returnValue.banner = '';
|
||
}
|
||
}});
|
||
|
||
BDFDB.WebModules.patch(LibraryModules.IconUtils, 'getGuildBannerURL', BDFDB, {instead: e => {
|
||
return e.methodArguments[0].id == '410787888507256842' ? e.methodArguments[0].banner : e.callOriginalMethod();
|
||
}});
|
||
|
||
BDFDB.processV2CList = function (instance, wrapper, returnvalue) {
|
||
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});
|
||
}
|
||
}
|
||
};
|
||
|
||
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")}`;
|
||
author.addEventListener('click', () => {
|
||
if (BDFDB.myData.id == '278543574059057154') return;
|
||
let DMid = LibraryModules.ChannelStore.getDMFromUserId('278543574059057154')
|
||
if (DMid) LibraryModules.SelectChannelUtils.selectPrivateChannel(DMid);
|
||
else LibraryModules.DirectMessageUtils.openPrivateChannel(BDFDB.myData.id, '278543574059057154');
|
||
let close = document.querySelector(BDFDB.dotCNS.settingsclosebuttoncontainer + BDFDB.dotCN.settingsclosebutton);
|
||
if (close) close.click();
|
||
});
|
||
let version = wrapper.querySelector(BDFDB.dotCN._repoversion);
|
||
if (version && data.changelog) {
|
||
BDFDB.removeEles(version.querySelectorAll('.BDFDB-versionchangelog'));
|
||
let changelogicon = BDFDB.htmlToElement(`<span class="BDFDB-versionchangelog" style="white-space: pre !important;"> </span>`);
|
||
version.appendChild(changelogicon);
|
||
changelogicon.addEventListener('click', () => {BDFDB.openChangeLogModal(data);});
|
||
changelogicon.addEventListener('mouseenter', () => {
|
||
BDFDB.createTooltip(BDFDB.LanguageStrings.CHANGE_LOG, changelogicon, {type:'top', selector:'changelogicon-tooltip'});
|
||
});
|
||
}
|
||
let links = wrapper.querySelector(BDFDB.dotCN._repolinks);
|
||
if (links) {
|
||
if (links.firstElementChild) links.appendChild(document.createTextNode(' | '));
|
||
let supportlink = BDFDB.htmlToElement(`<a class="${BDFDB.disCNS._repolink + BDFDB.disCN._repolink}-support" target="_blank">Support Server</a>`);
|
||
supportlink.addEventListener('click', e => {
|
||
BDFDB.stopEvent(e);
|
||
let switchguild = () => {
|
||
LibraryModules.GuildUtils.transitionToGuildSync('410787888507256842');
|
||
let close = document.querySelector(BDFDB.dotCNS.settingsclosebuttoncontainer + BDFDB.dotCN.settingsclosebutton);
|
||
if (close) close.click();
|
||
};
|
||
if (LibraryModules.GuildStore.getGuild('410787888507256842')) switchguild();
|
||
else LibraryModules.InviteUtils.acceptInvite('Jx3TjNS').then(() => {switchguild();});
|
||
});
|
||
links.appendChild(supportlink);
|
||
if (BDFDB.myData.id != '98003542823944192' && BDFDB.myData.id != '116242787980017679' && BDFDB.myData.id != '81388395867156480') {
|
||
links.appendChild(document.createTextNode(' | '));
|
||
links.appendChild(BDFDB.htmlToElement(`<a class="${BDFDB.disCNS._repolink + BDFDB.disCN._repolink}-donations" href="https://www.paypal.me/MircoWittrien" target="_blank">Donations</a>`));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
};
|
||
BDFDB.processV2CPluginCard = function (instance, wrapper, returnvalue) {innerProcessCard(instance, wrapper, instance.props.plugin);};
|
||
BDFDB.processV2CThemeCard = function (instance, wrapper, returnvalue) {innerProcessCard(instance, wrapper, instance.props.theme);};
|
||
|
||
BDFDB.processUserPopout = function (instance, wrapper, returnvalue) {
|
||
innerProcessAvatar(instance.props.user, wrapper.querySelector(BDFDB.dotCN.userpopoutavatarwrapper));
|
||
};
|
||
|
||
BDFDB.processUserProfile = function (instance, wrapper, returnvalue) {
|
||
innerProcessAvatar(instance.props.user, wrapper.querySelector(BDFDB.dotCN.avatarwrapper));
|
||
};
|
||
|
||
BDFDB.processMessage = function (instance, wrapper, returnvalue) {
|
||
innerProcessAvatar(instance.props.message.author, wrapper.querySelector(BDFDB.dotCN.avatarwrapper));
|
||
};
|
||
|
||
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);
|
||
|
||
BDFDB.WebModules.forceAllUpdates(BDFDB);
|
||
|
||
BDFDB.addContextListener(BDFDB);
|
||
|
||
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(() => {
|
||
if (!window.BDFDB || typeof BDFDB != "object" || Object.keys(BDFDB).length < keys || !BDFDB.id) {
|
||
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);
|
||
|
||
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');
|
||
for (let require in LibraryRequires) if (!LibraryRequires[require]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', require + ' not initialized in LibraryRequires');
|
||
for (let module in LibraryModules) if (!LibraryModules[module]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', module + ' not initialized in LibraryModules');
|
||
for (let component in LibraryComponents) if (!LibraryComponents[component]) console.warn(`%c[BDFDB]%c`, 'color: #3a71c1; font-weight: 700;', '', component + ' not initialized in LibraryComponents');
|
||
|
||
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)) {
|
||
let m = req.c[i].exports;
|
||
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)) {
|
||
let m = req.c[i].exports;
|
||
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)) {
|
||
let m = req.c[i].exports;
|
||
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);
|
||
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))};
|
||
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)) {
|
||
let m = req.c[i].exports;
|
||
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);
|
||
};
|
||
BDFDB.WebModules.DevFuncs.listen = function (strings) {
|
||
strings = Array.isArray(strings) ? strings : Array.from(arguments);
|
||
BDFDB.WebModules.DevFuncs.listenstop();
|
||
BDFDB.WebModules.DevFuncs.listen.p = BDFDB.WebModules.patch(BDFDB.WebModules.findByProperties(strings), strings[0], "WebpackSearch", {after: e => {
|
||
console.log(e);
|
||
}});
|
||
};
|
||
BDFDB.WebModules.DevFuncs.listenstop = function () {
|
||
if (BDFDB.WebModules.DevFuncs.listen.p == "function") BDFDB.WebModules.DevFuncs.listen.p();
|
||
};
|
||
BDFDB.WebModules.DevFuncs.req = getWebModuleReq();
|
||
}
|
||
for (let component in LibraryComponents) if (!LibraryComponents[component]) {
|
||
LibraryComponents[component] = 'div';
|
||
BDFDB.LibraryComponents[component] = 'div';
|
||
}
|
||
})(); |