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); for (let modal of document.querySelectorAll(`.${plugin.name}-modal, .${plugin.name.toLowerCase()}-modal, .${plugin.name}-settingsmodal, .${plugin.name.toLowerCase()}-settingsmodal`)) { let closebutton = modal.querySelector(BDFDB.dotCN.modalclose); if (closebutton) closebutton.click(); } 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.generateID = function (array) { array = Array.isArray(array) ? array : null; let id = Math.floor(Math.random() * 10000000000000000); if (array && array.includes(id)) return BDFDB.generateID(array); else { array.push(id); return id; } }; 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:  ', {html:true, id:'pluginNotice', type:'info', btn:!BDFDB.isRestartNoMoreEnabled() ? 'Reload' : '', customicon:``}); 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(`, `)); var updateentry = BDFDB.htmlToElement(`${plugname}`); 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(), 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(`
`); document.querySelector(BDFDB.dotCN.app).appendChild(toasts); } const {type = '', icon = true, timeout = 3000, html = false, selector = '', nopointer = false, color = ''} = options; var toast = BDFDB.htmlToElement(`
${html === true ? text : BDFDB.encodeToHTML(text)}
`); 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(`
`); 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(`
`)); } 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 pointer = tooltip.querySelector(BDFDB.dotCN.tooltippointer); var left, top, trects = BDFDB.getRects(tooltip.anker), irects = BDFDB.getRects(itemlayer), arects = BDFDB.getRects(document.querySelector(BDFDB.dotCN.appmount)), positionoffsets = {height: pointer ? 10 : 0, width: pointer ? 10 : 0}; 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`); } } } }; var itemlayers = []; BDFDB.appendItemLayer = function (node, anker, options = {}) { var itemlayercontainernative = document.querySelector(BDFDB.dotCN.itemlayercontainer); if (!itemlayercontainernative || !Node.prototype.isPrototypeOf(node) || !anker || !Node.prototype.isPrototypeOf(anker) || !document.contains(anker)) return null; var itemlayercontainer = document.querySelector(".BDFDB-itemlayercontainer"); if (!itemlayercontainer) { itemlayercontainer = itemlayercontainernative.cloneNode(); BDFDB.addClass(itemlayercontainer, "BDFDB-itemlayercontainer"); itemlayercontainernative.parentElement.insertBefore(itemlayercontainer, itemlayercontainernative.nextSibling); } var id = BDFDB.generateID(itemlayers); var itemlayer = BDFDB.htmlToElement(`
`); itemlayer.appendChild(node); itemlayercontainer.appendChild(itemlayer); if (options.css) BDFDB.appendLocalStyle('BDFDBcustomItemLayer' + id, options.css, itemlayercontainer); 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) { BDFDB.removeFromArray(itemlayers, id); observer.disconnect(); itemlayer.remove(); BDFDB.removeLocalStyle('BDFDBcustomItemLayer' + id, itemlayercontainer); if (!itemlayercontainer.firstElementChild) BDFDB.removeEles(itemlayercontainer); 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}); }; var notificationbars = []; BDFDB.createNotificationsBar = function (text, options = {}) { if (!text) return; var layers = document.querySelector(BDFDB.dotCN.layers); if (!layers) return; var id = BDFDB.generateID(notificationbars); var notice = BDFDB.htmlToElement(`
`); 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(``); 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(``); 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(``)); if (options.id) notice.id = options.id.split(' ').join(''); if (options.selector) BDFDB.addClass(notice, options.selector); if (options.css) BDFDB.appendLocalStyle('BDFDBcustomnotificationbar' + 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 ? `` : 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(``), 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('BDFDBcustomnotificationbarColorCorrection' + 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.removeFromArray(notificationbars, id); BDFDB.removeLocalStyle('BDFDBcustomnotificationbar' + id); BDFDB.removeLocalStyle('BDFDBcustomnotificationbarColorCorrection' + 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, bykey = false) { return Object.keys(obj).filter(key => filter(bykey ? key : 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 = ``, suffix = ``; 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, values = valuepath.split('.').filter(n => n); for (let i = 0; i < values.length; i++) { found = found[values[i]]; if (found === undefined && i < values.length-1) return null; } return found; }; BDFDB.setReactValue = function (nodeOrInstance, valuepath, value) { if (!nodeOrInstance || !valuepath || !value) return false; let instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.getReactInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.isObject(instance)) return false; let found = instance, values = valuepath.split('.').filter(n => n); for (let i = 0; i < values.length; i++) { found = found[values[i]]; if (found === undefined && i < values.length-1) return false; } found = value; return true; }; 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.ColorUtils = BDFDB.WebModules.findByProperties('hex2int', 'hex2rgb'); 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.FolderStore = BDFDB.WebModules.findByProperties('getGuildFolderById', 'getFlattenedGuilds'); LibraryModules.FolderUtils = BDFDB.WebModules.findByProperties('isFolderExpanded', 'getExpandedFolders'); LibraryModules.GuildBoostUtils = BDFDB.WebModules.findByProperties('getTierName', 'getUserLevel'); LibraryModules.GuildChannelStore = BDFDB.WebModules.findByProperties('getChannels', 'getDefaultChannel'); LibraryModules.GuildEmojiStore = BDFDB.WebModules.findByProperties('getGuildEmoji', 'getDisambiguatedEmojiContext'); LibraryModules.GuildSettingsUtils = BDFDB.WebModules.findByProperties('updateChannelOverrideSettings', 'updateNotificationSettings'); LibraryModules.GuildStore = BDFDB.WebModules.findByProperties('getGuild', 'getGuilds'); 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.ModalUtils = BDFDB.WebModules.findByProperties('openModal', 'registerModalDispatch'); 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.SpellCheckUtils = BDFDB.WebModules.findByProperties('learnWord', 'toggleSpellcheck'); 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; }; BDFDB.React.createDiscordElement = function (type, props, key, children) { var defaultProps = type && type.defaultProps; if (props || 0 === arguments.length - 3 || (props = {children: void 0}), props && defaultProps) for (let i in defaultProps) void 0 === props[i] && (props[i] = defaultProps[i]); else props || (props = defaultProps || {}); if (children) props.children = (Array.isArray(children) ? children : Array.of(children)).filter(n => n); return { $$typeof: "function" == typeof Symbol && Symbol.for && Symbol.for("react.element") || 60103, type, key, ref: null, props, _owner: null } }; BDFDB.React.elementToReact = function (node) { if (BDFDB.React.isValidElement(node)) return node; else if (!Node.prototype.isPrototypeOf(node)) return BDFDB.React.createElement('DIV', {}); else if (node.nodeType == Node.TEXT_NODE) return node.nodeValue; let attributes = {}; for (let attr of node.attributes) attributes[attr.name] = attr.value; if (node.attributes.style) attributes.style = BDFDB.filterObject(node.style, n => node.style[n] && isNaN(parseInt(n)), true); attributes.children = []; for (let child of node.childNodes) attributes.children.push(BDFDB.React.elementToReact(child)); return BDFDB.React.createElement(node.tagName, attributes); }; }; 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', MessageDeveloperModeGroup: 'FluxContainer(MessageDeveloperModeGroup)', 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) { 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(`
`); 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(`

${plugin.name} Settings

`); 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())}` } 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())}` } 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 selected = LibraryModules.LastGuildStore.getGuildId() == guild.id; let unread = LibraryModules.UnreadGuildUtils.hasUnread(guild.id); let div = BDFDB.htmlToElement(`
`); let divinner = div.querySelector(BDFDB.dotCN.guildcontainer); let divpillitem = div.querySelector(BDFDB.dotCN.guildpillitem); BDFDB.toggleEles(divpillitem.parentElement, functionality.pill); if (functionality.pill) { divpillitem.style.setProperty("opacity", selected ? 1 : (unread ? 0.7 : 0)); divpillitem.style.setProperty("height", selected ? "40px" : "8px"); divpillitem.style.setProperty("transform", "translate3d(0px, 0px, 0px)"); BDFDB.toggleClass(div, BDFDB.disCN._bdguildselected, selected); BDFDB.toggleClass(div, BDFDB.disCN._bdguildunread, unread); BDFDB.toggleClass(divpillitem, BDFDB.disCN._bdguildunread, unread); } if (functionality.hover) { let diviconwrapper = div.querySelector(BDFDB.dotCN.guildiconwrapper); 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.readFolderList = function () { var found = [], ins = BDFDB.getOwnerInstance({node:document.querySelector(BDFDB.dotCN.guildswrapper), name:'GuildFolder', all:true, noCopies:true, depth:99999999, time:99999999}); for (let info in ins) if (ins[info].props && ins[info].props.folderId) { found.push(Object.assign({}, ins[info].props, {div:BDFDB.React.findDOMNodeSafe(ins[info]), instance:ins[info]})); } return found; }; BDFDB.getFolderID = function (div) { if (!Node.prototype.isPrototypeOf(div) || !BDFDB.getReactInstance(div)) return; div = BDFDB.getParentEle(BDFDB.dotCN.guildfolderwrapper, div); if (!div) return; return BDFDB.getReactValue(div, "return.stateNode.props.folderId"); }; BDFDB.getFolderDiv = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let info = BDFDB.getFolderData(eleOrInfoOrId); return info ? info.div : null; }; BDFDB.getFolderData = 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.readFolderList()) if (info && info.folderId == id) return info; return null; }; 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] = BDFDB.isObject(data) ? BDFDB.sortObject(data) : data; if (BDFDB.isObjectEmpty(config[key])) delete config[key]; if (BDFDB.isObjectEmpty(config)) { delete BDFDB.cachedData[plugname]; if (exists) LibraryRequires.fs.unlinkSync(configpath); } else { config = BDFDB.sortObject(config); BDFDB.cachedData[plugname] = BDFDB.deepAssign({}, 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' && typeof BDFDB.cachedData[plugname][key] !== 'undefined' ? BDFDB.cachedData[plugname] : BDFDB.readConfig(configpath); BDFDB.cachedData[plugname] = BDFDB.deepAssign({}, config); return BDFDB.deepAssign({}, 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] = BDFDB.isObject(data) ? BDFDB.sortObject(data) : 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(``)); 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(``)); }; 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(``)); 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(``)); }; 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(``)); 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(``)); }; 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 == null) return null; conv = conv === undefined || !conv ? conv = 'RGBCOMP' : conv.toUpperCase(); type = type === undefined || !type || !['RGB', 'RGBA', 'RGBCOMP', 'HSL', 'HSLA', 'HSLCOMP', 'HEX', 'HEXA', 'INT'].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) { let a = processA(color.pop()); return processRGB(color).concat(a); } break; case 'RGB': return processRGB(color.replace(/\s/g, '').slice(4, -1).split(',')); case 'RGBA': let comp = color.replace(/\s/g, '').slice(5, -1).split(','); let a = processA(comp.pop()); return processRGB(comp).concat(a); case 'HSLCOMP': if (color.length == 3) return BDFDB.colorCONVERT(`hsl(${processHSL(color).join(',')})`, 'RGBCOMP'); else if (color.length == 4) { let a = processA(color.pop()); return BDFDB.colorCONVERT(`hsl(${processHSL(color).join(',')})`, 'RGBCOMP').concat(a); } break; 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(','); return BDFDB.colorCONVERT(`hsl(${hslcomp.join(',')})`, 'RGBCOMP').concat(processA(hslcomp.pop())); 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[5], 16).toString(), parseInt(hex[3] + hex[3] || hex[6], 16).toString()]; case 'HEXA': var hex = /^#([a-f\d]{1})([a-f\d]{1})([a-f\d]{1})([a-f\d]{1})$|^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(color); return [parseInt(hex[1] + hex[1] || hex[5], 16).toString(), parseInt(hex[2] + hex[2] || hex[6], 16).toString(), parseInt(hex[3] + hex[3] || hex[7], 16).toString(), Math.floor(BDFDB.mapRange([0, 255], [0, 100], parseInt(hex[4] + hex[4] || hex[8], 16).toString()))/100]; case 'INT': color = processINT(color); return [(color >> 16 & 255).toString(), (color >> 8 & 255).toString(), (color & 255).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(); case 'HEXA': return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1) + Math.round(BDFDB.mapRange([0, 100], [0, 255], processA(rgbcomp[3]) * 100)).toString(16)).toUpperCase(); case 'INT': return processINT(rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16); default: return null; } } function processC(c) {if (c == null) {return 255;} else {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) {if (a == null) {return 1;} else {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) {if (sl == null) {return "100%";} else {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);}));}; function processINT(c) {if (c == null) {return 16777215;} else {c = parseInt(c.toString().replace(/[^0-9]/g, ''));return isNaN(c) || c > 16777215 ? 16777215 : c < 0 ? 0 : c;}}; }; 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 == 'RGB' || conv == 'HSL' || conv == 'HEX' ? 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); }; BDFDB.colorGETALPHA = function (color) { var comp = BDFDB.colorCONVERT(color, 'RGBCOMP'); if (comp) { if (comp.length == 3) return 1; else if (comp.length == 4) { let a = comp[3].toString(); a = (a.indexOf('%') > -1 ? 0.01 : 1) * parseFloat(a.replace(/[^0-9\.\-]/g, '')); return isNaN(a) || a > 1 ? 1 : a < 0 ? 0 : a; } } else return null; }; 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 != null && 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 != null) { 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, 'RGBA'); color2 = BDFDB.colorCONVERT(color2, 'RGBA'); if (color1 && color2) return BDFDB.equals(color1, color2); } return null; }; BDFDB.colorISBRIGHT = function (color, value) { color = BDFDB.colorCONVERT(color, 'INT'); if (color == null) return false; return LibraryModules.ColorUtils.getDarkness(color) < (typeof value == 'number' ? value : 0.3); }; BDFDB.colorTYPE = function (color) { if (color != null) { 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 (/^#[a-f\d]{3}$|^#[a-f\d]{6}$/i.test(color)) return 'HEX'; else if (/^#[a-f\d]{4}$|^#[a-f\d]{8}$/i.test(color)) return 'HEXA'; 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'; } } else if (typeof color === 'number' && parseInt(color) == color && color > -1 && color < 16777216) return 'INT'; } 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(/(?[\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 = `
${BDFDB.encodeToHTML(ele.innerText)}
`; }); container.querySelectorAll('.BDFDB-contextMenuItemHint, .BDFDB-contextMenuItem ' + BDFDB.dotCN.contextmenuhint).forEach(ele => { if (ele.innerText) { ele.innerHTML = `
${BDFDB.encodeToHTML(ele.innerText)}
`; 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-add ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.ADD;}); container.querySelectorAll('.btn-all ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = languagestrings.btn_all_text;}); container.querySelectorAll('.btn-cancel ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.CANCEL;}); container.querySelectorAll('.btn-done ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.DONE;}); container.querySelectorAll('.btn-download ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.DOWNLOAD;}); container.querySelectorAll('.btn-ok ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.OKAY;}); container.querySelectorAll('.btn-save ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.SAVE;}); container.querySelectorAll('.btn-send ' + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageStrings.SEND;}); 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) { if (!switchitem) return; 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) { if (!checkbox) return; 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)'); if (checkboxstyleinner) checkboxstyleinner.setAttribute('stroke', '#ffffff'); } else { BDFDB.removeClass(checkboxstyle, BDFDB.disCN.checkboxchecked); checkboxstyle.style.removeProperty('background-color'); checkboxstyle.style.removeProperty('border-color'); if (checkboxstyleinner) checkboxstyleinner.setAttribute('stroke', 'transparent'); } }; function setGifFavButton(button) { var selected = BDFDB.containsClass(button, BDFDB.disCN.giffavoriteselected); var icon = button.querySelector(BDFDB.dotCN.giffavoriteicon); if (icon) { icon.setAttribute('name', selected ? 'FavoriteFilled' : 'Favorite'); icon.innerHTML = selected ? '' : ''; } if (selected) { BDFDB.addClass(button, BDFDB.disCN.giffavoriteshowpulse); setTimeout(() => {BDFDB.removeClass(button, BDFDB.disCN.giffavoriteshowpulse);}, 500); } }; function setTabitem(item, state) { if (!item) return; 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, .btn-done', () => { 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(`
`); 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(`
`); var suffix = dark ? 'dark' : 'light'; return `
${inner}
`; }; 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 = `
`; for (var key in values) menuhtml += `
${createinner(key)}
`; menuhtml += `
`; 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; }; var modals = []; BDFDB.openModal = function (plugin, config) { if (!BDFDB.isObject(plugin) || !BDFDB.isObject(config)) return; var modal, modalobserver, id, contentchildren = [], footerchildren = [], modalprops, cancels = [], closeModal = _ => { if (id) BDFDB.removeFromArray(modals, id); if (typeof config.onClose == 'function') config.onClose(modal); if (BDFDB.isObject(modalprops) && typeof modalprops.onClose == 'function') modalprops.onClose(); if (typeof modalobserver.disconnect == 'function') modalobserver.disconnect(); }; if (typeof config.text == 'string') { contentchildren.push(LibraryComponents.TextElement.default({ color: LibraryComponents.TextElement.Colors.PRIMARY, children: [config.text] })); } if (config.html) { if (typeof config.html == 'string') contentchildren.push(BDFDB.React.elementToReact(BDFDB.htmlToElement(config.html))); else if (Node.prototype.isPrototypeOf(config.html)) contentchildren.push(BDFDB.React.elementToReact(config.html)); else if (NodeList.prototype.isPrototypeOf(config.html)) for (let node of config.html) contentchildren.push(BDFDB.React.elementToReact(node)); else if (BDFDB.React.isValidElement(config.html)) contentchildren.push(config.html); } if (typeof config.onClose != 'function') config.onClose = _ => {}; if (typeof config.onOpen != 'function') config.onOpen = _ => {}; if (Array.isArray(config.buttons)) for (let button of config.buttons) { let contents = typeof button.contents == 'string' ? button.contents : null; let type = typeof button.type == 'string' ? button.type : null; if (contents || type) { let color = typeof button.color == 'string' && LibraryComponents.Button.Colors[button.color.toUpperCase()]; let look = typeof button.look == 'string' && LibraryComponents.Button.Looks[button.look.toUpperCase()]; let click = typeof button.click == 'function' ? button.click : _ => {}; if (button.cancel) cancels.push(click); footerchildren.push(BDFDB.React.createDiscordElement(LibraryComponents.Button, { type: 'button', className: type || "", look: look || (color ? LibraryComponents.Button.Looks.FILLED : LibraryComponents.Button.Looks.LINK), color: color ? color : LibraryComponents.Button.Colors.PRIMARY, onClick: _ => { click(modal); if (button.close) { for (let cancel of cancels) if (cancel != click) cancel(modal); closeModal(); } } }, null, contents || 'placeholder')); } } if (contentchildren.length) { id = BDFDB.generateID(modals); modalobserver = new MutationObserver(changes => {changes.forEach(change => {change.addedNodes.forEach(node => { if (node.tagName && (node = node.querySelector(`.BDFDB-modal-${id}`)) != null) { modal = node; if (typeof config.onOpen == 'function') config.onOpen(modal); BDFDB.initElements(modal); } })})}); modalobserver.observe(document.querySelector(BDFDB.dotCN.itemlayercontainer), {subtree:true, childList:true}); LibraryModules.ModalUtils.openModal(props => { modalprops = props; let name = plugin.name || (typeof plugin.getName == "function" ? plugin.getName() : null); name = typeof name == 'string' ? name : null; let size = typeof config.size == 'string' && LibraryComponents.ModalComponents.ModalSize[config.size.toUpperCase()]; return BDFDB.React.createElement(function (e) { return BDFDB.React.createDiscordElement(LibraryComponents.ModalComponents.ModalRoot, { className: `BDFDB-modal BDFDB-modal-${id} ${name ? name + '-modal' : ''} ${props.transitionState == 2 ? 'BDFDB-modal-open' : ''} ${config.selector ? config.selector : ''}`.split(' ').filter(n => n).join(' '), size: size ? size : LibraryComponents.ModalComponents.ModalSize.SMALL, transitionState: e.transitionState }, null, [ BDFDB.React.createDiscordElement(LibraryComponents.ModalComponents.ModalHeader, { separator: false }, null, [ BDFDB.React.createDiscordElement(LibraryComponents.Flex.Child, { grow: 1, shrink: 1 }, null, [ BDFDB.React.createDiscordElement(LibraryComponents.FormComponents.FormTitle, { tag: LibraryComponents.FormComponents.FormTitle.Tags.H4 }, null, typeof config.header == 'string' ? config.header : ""), LibraryComponents.TextElement.default({ size: LibraryComponents.TextElement.Sizes.SMALL, color: LibraryComponents.TextElement.Colors.PRIMARY, children: [typeof config.subheader == 'string' ? config.subheader : (name || "")] }) ]), BDFDB.React.createDiscordElement(LibraryComponents.ModalComponents.ModalCloseButton, { onClick: _ => { for (let cancel of cancels) cancel(modal); closeModal(); } }) ]), BDFDB.React.createDiscordElement(LibraryComponents.ModalComponents.ModalContent, {}, null, contentchildren), footerchildren.length ? BDFDB.React.createDiscordElement(LibraryComponents.ModalComponents.ModalFooter, {}, null, footerchildren) : null ]) }, props); }, { onCloseRequest: _ => { for (let cancel of cancels) cancel(modal); closeModal(); } }); } }; BDFDB.openConfirmModal = function (plugin, text, callback) { if (!BDFDB.isObject(plugin) || typeof text != 'string') return; callback = typeof callback == 'function' ? callback : _ => {}; BDFDB.openModal(plugin, {text, header:'Are you sure?', selector:'BDFDB-confirmmodal', buttons:[ {type:"btn-ok", close:true, color:"RED", click:callback}, {type:"btn-cancel", close:true} ]}); }; BDFDB.openChangeLogModal = function (plugin) { if (!BDFDB.isObject(plugin) || !plugin.changelog) return; var changeLogHTML = `
`, logs = false, 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) { logs = true; changeLogHTML += `

${headers[type]}

` } } changeLogHTML += `
` if (logs) BDFDB.openModal(plugin, {header:BDFDB.LanguageStrings.CHANGE_LOG, html:changeLogHTML, selector:'BDFDB-changelogmodal'}); }; 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(``); 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, 'RGBA') : BDFDB.colorGRADIENT(color); var bright = selectedcolor && !isgradient ? BDFDB.colorISBRIGHT(selectedcolor) : false; if (!swatch.querySelector(".swatch-checkmark")) swatch.appendChild(BDFDB.htmlToElement(``)); 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, 'rgba(82,233,30,1)', 'rgba(46,204,113,1)', 'rgba(26,188,156,1)', 'rgba(52,152,219,1)', 'rgba(52,84,219,1)', 'rgba(134,30,233,1)', 'rgba(155,89,182,1)', 'rgba(233,30,99,1)', 'rgba(233,65,30,1)', 'rgba(231,76,60,1)', 'rgba(230,126,34,1)', 'rgba(241,196,15,1)', 'rgba(199,204,205,1)', 'rgba(112,128,136,1)', 'rgba(99,99,99,1)', 'rgba(255,255,255,1)', 'rgba(59,173,20,1)', 'rgba(31,139,76,1)', 'rgba(17,128,106,1)', 'rgba(32,102,148,1)', 'rgba(32,57,148,1)', 'rgba(109,20,173,1)', 'rgba(113,54,138,1)', 'rgba(173,20,87,1)', 'rgba(173,32,20,1)', 'rgba(153,45,34,1)', 'rgba(168,67,0,1)', 'rgba(194,124,14,1)', 'rgba(151,156,159,1)', 'rgba(93,104,109,1)', 'rgba(44,44,44,1)']; var colorrows = [colorlist.slice(0, parseInt(colorlist.length/2)), colorlist.slice(parseInt(colorlist.length/2))]; colorlist.shift(); swatches.appendChild(BDFDB.htmlToElement(`
${colorrows.map(row => '
' + row.map(c => '').join('') + '
').join('')}
`)); if (currentcolor && !BDFDB.colorCOMPARE(currentcolor, [0, 0, 0, 0])) { var selection = colorlist.indexOf(BDFDB.colorCONVERT(currentcolor, 'RGBA')); 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: true, callback: _ => {}}) { if (!container || !target) return; if (options.comp) { options.gradient = false; options.alpha = false; } if (typeof options.callback != 'function') options.callback = _ => {}; var hexformat = options.alpha ? 'HEXA' : 'HEX'; var hexregex = options.alpha ? /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i : /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i; var isswatches = BDFDB.containsClass(container, 'swatches'); var isgradient = color && BDFDB.isObject(color); var selectedcolor = BDFDB.colorCONVERT(isgradient ? color[Object.keys(color)[0]] : color, hexformat) || (options.alpha ? '#000000FF' : '#000000'); var [h, s, l] = BDFDB.colorCONVERT(selectedcolor, 'HSLCOMP'); var a = BDFDB.colorGETALPHA(isgradient ? color[Object.keys(color)[0]] : color); a = a == null ? 1 : a; var targetrects = BDFDB.getRects(target); var colorPicker = BDFDB.htmlToElement(``); 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 satpane = colorPicker.querySelector('.saturation-color'); var satcursor = colorPicker.querySelector('.saturation-cursor'); var huepane = colorPicker.querySelector('.hue-horizontal'); var huecursor = colorPicker.querySelector('.hue-cursor'); var alphabar = colorPicker.querySelector('.alpha-bar'); var alphapane = colorPicker.querySelector('.alpha-horizontal'); var alphacursor = colorPicker.querySelector('.alpha-cursor'); var gradientbutton = colorPicker.querySelector('.gradient-button'); var gradientbar = colorPicker.querySelector('.gradient-bar'); var gradientpane = colorPicker.querySelector('.gradient-horizontal'); var sMinX, sMaxX, sMinY, sMaxY, hMinX, hMaxX, aMinX, aMaxX, gMinX, gMaxX; updateRects(); if (isgradient) for (let pos in color) if (pos > 0 && pos < 1) gradientpane.appendChild(BDFDB.htmlToElement(`
`)); updateColors(false); if (!options.gradient) BDFDB.removeEles(colorPicker.querySelectorAll(".gradient-button, .gradient-bar")); if (!options.alpha) BDFDB.removeEles(colorPicker.querySelectorAll(".alpha-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); }); 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); }); alphapane.addEventListener('mousedown', e => { a = BDFDB.mapRange([aMinX, aMaxX], [0, 1], e.clientX); updateColors(true); var bubble = BDFDB.htmlToElement(``); var mouseup = () => { bubble.remove(); document.removeEventListener('mouseup', mouseup); document.removeEventListener('mousemove', mousemove); }; var mousemove = e2 => { if (!bubble.parentElement) alphacursor.appendChild(bubble); a = Math.floor(BDFDB.mapRange([aMinX, aMaxX], [0, 100], e2.clientX))/100; bubble.innerText = a; updateColors(true); }; 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'); a = BDFDB.colorGETALPHA(e.target.style.getPropertyValue("background-color")); 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'); a = BDFDB.colorGETALPHA(firstElementChild.style.getPropertyValue("background-color")); } updateColors(true); } } else if (gradientpane == e.target && e.which == 1) { BDFDB.removeClass(gradientpane.querySelectorAll(".gradient-cursor.selected"), "selected"); var newcursor = BDFDB.htmlToElement(`
`); gradientpane.appendChild(newcursor); [h, s, l] = [0, "0%", "0%"]; a = 1; 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); } }); }); hexinput.addEventListener('input', e => { if (hexregex.test(hexinput.value)) { [h, s, l, a] = BDFDB.colorCONVERT(hexinput.value, 'HSLCOMP'); if (a == null) a = 1; 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 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; var alphapanerects = BDFDB.getRects(alphapane); aMinX = alphapanerects.left; aMaxX = aMinX + alphapanerects.width; var gradientpanerects = BDFDB.getRects(gradientpane); gMinX = gradientpanerects.left; gMaxX = gMinX + gradientpanerects.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'); alphapane.style.setProperty('background', `linear-gradient(to right, ${BDFDB.colorSETALPHA([h, s, l], 0, "RGBA")}, ${BDFDB.colorSETALPHA([h, s, l], 1, "RGBA")}`, 'important'); alphacursor.style.setProperty('left', (a * 100) + '%', 'important'); var hex = BDFDB.colorCONVERT([h, s, l, a], hexformat); var rgb = BDFDB.colorCONVERT(hex, 'RGBA'); if (isswatches) { setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + '.selected'), null, false); if (isgradient) { gradientpane.querySelector('.gradient-cursor.selected').firstElementChild.style.setProperty('background-color', rgb); updateGradient(); } else { setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), rgb, true); } } else { let input = container.querySelector(BDFDB.dotCN.input); if (input) input.value = options.comp ? BDFDB.colorCONVERT(hex, 'RGBCOMP').join(',') : rgb; let swatch = container.querySelector('.single-swatch'); if (swatch) swatch.style.setProperty('background-color', rgb, 'important'); } if (setinput) hexinput.value = hex; options.callback(rgb); } 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 BdApi.isPluginEnabled(plugname); else return BDFDB.Plugins[plugname.toLowerCase()] ? BDFDB.Plugins[plugname.toLowerCase()].enabled : null; }; BDFDB.getPlugin = function (plugname, hasToBeEnabled = false) { if (!hasToBeEnabled || BDFDB.isPluginEnabled(plugname)) return BdApi.getPlugin(plugname); return 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 BdApi.isThemeEnabled(themename) else return BDFDB.Themes[themename.toLowerCase()] ? BDFDB.Themes[themename.toLowerCase()].enabled : null; }; BDFDB.getTheme = function (themename, hasToBeEnabled = false) { if (window.bdthemes && (!hasToBeEnabled || BDFDB.isThemeEnabled(themename))) return window.bdthemes[themename]; return 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', channelPanelTitle: 'title-eS5yk3', guildChannels: 'container-PNkimc', highlight: 'highlight', hoverCardButton: 'button-2CgfFz', loginScreen: 'wrapper-3Q5DdO', nameContainerNameContainer: 'container-2ax-kl', 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', selectIsSelected: 'css-bdfdb-isSelected', 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', subtext: 'subtext-3CDbHg', themeDark: 'theme-dark', themeLight: 'theme-light', themeUndefined: 'theme-undefined', voiceDraggable: 'draggable-1KoBzC' }; DiscordClassModules.AccountDetails = BDFDB.WebModules.findByProperties('usernameContainer', 'container'); DiscordClassModules.AccountDetailsButtons = BDFDB.WebModules.findByProperties('button', 'enabled', 'disabled'); 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', 'layers'); DiscordClassModules.AppMount = BDFDB.WebModules.findByProperties('appMount'); DiscordClassModules.ApplicationStore = BDFDB.WebModules.findByProperties('applicationStore', 'navigation'); DiscordClassModules.AppOuter = BDFDB.WebModules.find(module => typeof module['app'] == 'string' && Object.keys(module).length == 1); 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.ChannelLimit = BDFDB.WebModules.findByProperties('users', 'total', 'wrapper'); DiscordClassModules.ChannelTextArea = BDFDB.WebModules.findByProperties('textArea', 'attachButtonDivider'); DiscordClassModules.ChannelTextAreaButton = BDFDB.WebModules.findByProperties('buttonWrapper', 'active'); DiscordClassModules.ChatWindow = 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.FlowerStar = BDFDB.WebModules.findByProperties('flowerStarContainer', 'flowerStar'); DiscordClassModules.FormText = BDFDB.WebModules.findByProperties('description', 'modeDefault'); DiscordClassModules.Friends = BDFDB.WebModules.findByProperties('friendsColumn', 'friendsRow'); DiscordClassModules.Game = BDFDB.WebModules.findByProperties('game', 'gameName'); DiscordClassModules.GameIcon = BDFDB.WebModules.findByProperties('gameIcon', 'small', 'xsmall'); DiscordClassModules.GameLibrary = BDFDB.WebModules.findByProperties('gameLibrary', 'scroller'); DiscordClassModules.GifFavoriteButton = BDFDB.WebModules.findByProperties('gifFavoriteButton', 'showPulse'); DiscordClassModules.GiftInventory = BDFDB.WebModules.findByProperties('root', 'body', 'scroller'); DiscordClassModules.GoLiveDetails = BDFDB.WebModules.findByProperties('panel', 'gameWrapper'); 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.GuildHeaderButton = BDFDB.WebModules.findByProperties('button', 'open'); 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.HeaderBarSearch = BDFDB.WebModules.findByProperties('search', 'searchBar', 'open'); 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.LayerModal = BDFDB.WebModules.findByProperties('root', 'small', 'medium'); DiscordClassModules.Layers = BDFDB.WebModules.findByProperties('layer', 'layers'); DiscordClassModules.LiveTag = BDFDB.WebModules.findByProperties('liveRed', 'live'); 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.MessageElements = BDFDB.WebModules.findByProperties('messageGroupBlockedBtn', 'dividerRed'); 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.TextColor = BDFDB.WebModules.findByProperties('colorStandard', 'colorMuted', 'colorError'); DiscordClassModules.TextColor2 = BDFDB.WebModules.findByProperties('base', 'muted', 'wrapper'); 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.UnreadBar = BDFDB.WebModules.findByProperties('active', 'bar', 'unread'); DiscordClassModules.UserPopout = BDFDB.WebModules.findByProperties('userPopout', 'headerPlaying'); DiscordClassModules.UserProfile = BDFDB.WebModules.findByProperties('topSectionNormal', 'tabBarContainer'); DiscordClassModules.Video = BDFDB.WebModules.findByProperties('video', 'fullScreen'); DiscordClassModules.VoiceChannel = BDFDB.WebModules.findByProperties('avatarSpeaking', 'voiceUser'); DiscordClassModules.VoiceChannelList = BDFDB.WebModules.findByProperties('list', 'collapsed'); DiscordClassModules.VoiceDetails = BDFDB.WebModules.findByProperties('container', 'customStatusContainer'); DiscordClassModules.VoiceDetailsPing = BDFDB.WebModules.findByProperties('rtcConnectionQualityBad', 'rtcConnectionQualityFine'); 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'], accountinfoavatar: ['AccountDetails', 'avatar'], accountinfoavatarwrapper: ['AccountDetails', 'avatarWrapper'], accountinfobutton: ['AccountDetailsButtons', 'button'], accountinfobuttondisabled: ['AccountDetailsButtons', 'disabled'], accountinfobuttonenabled: ['AccountDetailsButtons', 'enabled'], accountinfodetails: ['AccountDetails', 'usernameContainer'], accountinfonametag: ['AccountDetails', 'nameTag'], 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'], applayers: ['AppInner', 'layers'], applicationstore: ['ApplicationStore', 'applicationStore'], appold: ['AppInner', 'app'], auditlog: ['AuditLog', 'auditLog'], auditloguserhook: ['AuditLog', 'userHook'], authbox: ['AuthBox', 'authBox'], autocomplete: ['Autocomplete', 'autocomplete'], autocomplete2: ['ChannelTextArea', 'autocomplete'], 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: ['Avatar', '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'], avatariconsizesmol: ['AvatarIcon', 'iconSizeSmol'], avatariconsizesmall: ['AvatarIcon', 'iconSizeSmall'], avatariconsizexlarge: ['AvatarIcon', 'iconSizeXLarge'], avatarmask: ['Avatar', 'mask'], avatarnoicon: ['AvatarIcon', 'noIcon'], avatarpointer: ['Avatar', 'pointer'], avatarpointerevents: ['Avatar', 'pointerEvents'], avatarwrapper: ['Avatar', 'wrapper'], backdrop: ['Backdrop', 'backdrop'], badgewrapper: ['NotFound', 'badgeWrapper'], bottag: ['BotTag', 'botTag'], bottaginvert: ['BotTag', 'botTagInvert'], bottagmember: ['Member', 'botTag'], 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'], callavatarvideo: ['Call', 'callAvatarVideo'], callavatarvoice: ['Call', 'callAvatarVoice'], 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'], categoryaddbutton: ['CategoryContainer', 'addButton'], categoryaddbuttonicon: ['CategoryContainer', 'addButtonIcon'], categorychildren: ['Category', 'children'], categoryclickable: ['Category', 'clickable'], categorycollapsed: ['Category', 'collapsed'], categorycontainerdefault: ['CategoryContainer', 'containerDefault'], categoryforcevisible: ['CategoryContainer', 'forceVisible'], categoryicon: ['Category', 'icon'], categoryiconvisibility: ['CategoryContainer', 'iconVisibility'], categorymuted: ['Category', 'muted'], categoryname: ['Category', 'name'], categorywrapper: ['Category', 'wrapper'], changelogadded: ['ChangeLog', 'added'], changelogfixed: ['ChangeLog', 'fixed'], changelogimproved: ['ChangeLog', 'improved'], changelogprogress: ['ChangeLog', 'added'], changelogtitle: ['ChangeLog', 'title'], channelactionicon: ['ChannelContainer', 'actionIcon'], channelchildicon: ['ChannelContainer', 'iconItem'], channelchildiconbase: ['ChannelContainer', 'iconBase'], channelchildren: ['Channel', 'children'], channelcontainerdefault: ['ChannelContainer', 'containerDefault'], channelcontent: ['Channel', 'content'], channeldisabled: ['ChannelContainer', 'disabled'], channelheaderchannelname: ['ChatWindow', '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: ['ChatWindow', 'title'], channelheadertitlewrapper: ['ChatWindow', 'titleWrapper'], channelheadersearch: ['HeaderBarExtras', 'search'], channelheadersearchbar: ['HeaderBarSearch', 'searchBar'], channelheadersearchicon: ['HeaderBarSearch', 'icon'], channelheadersearchinner: ['HeaderBarSearch', 'search'], channelheadertoolbar: ['HeaderBar', 'toolbar'], channelheadertoolbar2: ['HeaderBarExtras', 'toolbar'], channelheadertopic: ['HeaderBarTopic', 'topic'], channelheadertopicexpandable: ['HeaderBarTopic', 'expandable'], channelicon: ['Channel', 'icon'], channeliconvisibility: ['ChannelContainer', 'iconVisibility'], channelmentionsbadge: ['ChannelContainer', 'mentionsBadge'], channelmodeconnected: ['Channel', 'modeConnected'], channelmodelocked: ['Channel', 'modeLocked'], channelmodemuted: ['Channel', 'modeMuted'], channelmodeselected: ['Channel', 'modeSelected'], channelmodeunread: ['Channel', 'modeUnread'], channelname: ['Channel', 'name'], channelpanel: ['AppBase', 'activityPanel'], channelpaneltitle: ['NotFound', 'channelPanelTitle'], channelpanels: ['AppBase', 'panels'], channels: ['AppBase', 'sidebar'], channelselected: ['ChannelContainer', 'selected'], channelsscroller: ['GuildChannels', 'scroller'], channelsunreadbar: ['GuildChannels', 'unreadBar'], channelsunreadbarcontainer: ['GuildChannels', 'positionedContainer'], channelsunreadbarbottom: ['GuildChannels', 'unreadBottom'], channelsunreadbarunread: ['GuildChannels', 'unread'], channelsunreadbartop: ['GuildChannels', 'unreadTop'], channelunread: ['Channel', 'unread'], channeluserlimit: ['ChannelLimit', 'wrapper'], channeluserlimitcontainer: ['ChannelContainer', 'userLimit'], channeluserlimittotal: ['ChannelLimit', 'total'], channeluserlimitusers: ['ChannelLimit', 'users'], channelwrapper: ['Channel', 'wrapper'], chat: ['ChatWindow', 'chat'], chatbase: ['AppBase', 'base'], chatcontent: ['ChatWindow', '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'], colorbase: ['TextColor2', 'base'], colorerror: ['TextColor', 'colorError'], colormuted: ['TextColor', 'colorMuted'], colormuted2: ['TextColor2', 'muted'], 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'], colorstandard: ['TextColor', 'colorStandard'], contentregion: ['SettingsWindow', 'contentRegion'], contextmenu: ['ContextMenu', 'contextMenu'], contextmenucheckbox: ['ContextMenuCheckbox', 'checkbox'], contextmenucheckbox2: ['ContextMenu', 'checkbox'], contextmenucheckboxdisabled: ['ContextMenuCheckbox', 'disabled'], contextmenucheckboxinner: ['ContextMenuCheckbox', 'checkboxInner'], contextmenucheckboxelement: ['ContextMenuCheckbox', 'checkboxElement'], contextmenuhint: ['ContextMenu', 'hint'], contextmenuitem: ['ContextMenu', 'item'], contextmenuitembrand: ['ContextMenu', 'brand'], contextmenuitemclickable: ['ContextMenu', 'clickable'], contextmenuitemdanger: ['ContextMenu', 'danger'], contextmenuitemdisabled: ['ContextMenu', 'disabled'], contextmenuitemgroup: ['ContextMenu', 'itemGroup'], contextmenuitemtoggle: ['ContextMenu', 'itemToggle'], contextmenuitemselected: ['ContextMenu', 'selected'], contextmenuitemslider: ['ContextMenu', 'itemSlider'], contextmenuitemsubmenu: ['ContextMenu', 'itemSubMenu'], contextmenuitemsubmenucaret: ['ContextMenu', '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'], 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'], flexspacer: ['Flex', 'spacer'], flowerstar: ['FlowerStar', 'flowerStar'], flowerstarchild: ['FlowerStar', 'childContainer'], flowerstarcontainer: ['FlowerStar', 'flowerStarContainer'], 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'], gameicon: ['GameIcon', 'gameIcon'], gameiconlarge: ['GameIcon', 'large'], gameiconmedium: ['GameIcon', 'medium'], gameiconsmall: ['GameIcon', 'small'], gameiconxsmall: ['GameIcon', 'xsmall'], 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'], goliveactions: ['GoLiveDetails', 'actions'], golivebody: ['GoLiveDetails', 'body'], goliveclickablegamewrapper: ['GoLiveDetails', 'clickableGameWrapper'], golivegameicon: ['GoLiveDetails', 'gameIcon'], golivegamename: ['GoLiveDetails', 'gameName'], golivegamewrapper: ['GoLiveDetails', 'gameWrapper'], golivepanel: ['GoLiveDetails', 'panel'], guildbadgebase: ['Badge', 'base'], guildbadgeicon: ['Badge', 'icon'], guildbadgeiconbadge: ['Badge', 'iconBadge'], guildbadgeiconbadge2: ['GuildsItems', 'iconBadge'], guildbadgenumberbadge: ['Badge', 'numberBadge'], guildbadgetextbadge: ['Badge', 'textBadge'], 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'], guildedgehalf: ['GuildEdges', 'half'], guildedgehigher: ['GuildEdges', 'higher'], guildedgemiddle: ['GuildEdges', 'middle'], guildedgewrapper: ['GuildEdges', 'wrapper'], guildserror: ['GuildsItems', 'guildsError'], guildserrorinner: ['GuildsItems', 'errorInner'], guildfolder: ['GuildFolder', 'folder'], guildfolderexpandendbackground: ['GuildFolder', 'expandedFolderBackground'], guildfolderexpandendbackgroundcollapsed: ['GuildFolder', 'collapsed'], guildfolderexpandendbackgroundhover: ['GuildFolder', 'hover'], guildfolderexpandedguilds: ['GuildFolder', 'expandedGuilds'], guildfolderguildicon: ['GuildFolder', 'guildIcon'], guildfoldericonwrapper: ['GuildFolder', 'folderIconWrapper'], guildfoldericonwrapperclosed: ['GuildFolder', 'closedFolderIconWrapper'], guildfoldericonwrapperexpanded: ['GuildFolder', 'expandedFolderIconWrapper'], guildfolderwrapper: ['GuildFolder', 'wrapper'], guildheader: ['GuildHeader', 'container'], guildheaderbannerimage: ['GuildHeader', 'bannerImage'], guildheaderbannerimagecontainer: ['GuildHeader', 'animatedContainer'], guildheaderbannervisible: ['GuildHeader', 'bannerVisible'], guildheaderbutton: ['GuildHeaderButton', 'button'], guildheaderbuttonopen: ['GuildHeaderButton', 'open'], guildheaderclickable: ['GuildHeader', 'clickable'], guildheaderhasbanner: ['GuildHeader', 'hasBanner'], guildheadericoncontainer: ['GuildHeader', 'guildIconContainer'], guildheadericonbgtiernone: ['GuildHeader', 'iconBackgroundTierNone'], guildheadericonbgtierone: ['GuildHeader', 'iconBackgroundTierOne'], guildheadericonbgtierthree: ['GuildHeader', 'iconBackgroundTierThree'], guildheadericonbgtiertwo: ['GuildHeader', 'iconBackgroundTierTwo'], guildheadericonpremiumgem: ['GuildHeader', 'premiumGuildIconGem'], guildheadericontiernone: ['GuildHeader', 'iconTierNone'], guildheadericontierone: ['GuildHeader', 'iconTierOne'], guildheadericontierthree: ['GuildHeader', 'iconTierThree'], guildheadericontiertwo: ['GuildHeader', 'iconTierTwo'], 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'], guildswrapperunreadmentionsbar: ['GuildsWrapper', 'unreadMentionsBar'], guildswrapperunreadmentionsbarbottom: ['GuildsWrapper', 'unreadMentionsIndicatorBottom'], guildswrapperunreadmentionsbartop: ['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'], homebuttonicon: ['HomeIcon', 'homeIcon'], homebuttonpill: ['HomeIcon', 'pill'], 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'], itemlayercontainer: ['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'], layermodal: ['LayerModal', 'root'], layermodallarge: ['LayerModal', 'large'], layermodalmedium: ['LayerModal', 'medium'], layermodalsmall: ['LayerModal', 'small'], layer: ['Layers', 'layer'], layerbase: ['Layers', 'baseLayer'], layers: ['Layers', 'layers'], layersbg: ['Layers', 'bg'], lfg: ['LFG', 'lfg'], livetag: ['LiveTag', 'live'], livetaggray: ['LiveTag', 'liveGray'], livetaglarge: ['LiveTag', 'liveLarge'], livetagred: ['LiveTag', 'liveRed'], livetagsmall: ['LiveTag', 'liveSmall'], 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'], membericon: ['Member', 'icon'], 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'], 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'], messagedivider: ['Message', 'divider'], messagedividerenabled: ['Message', 'dividerEnabled'], messageedited: ['MessageBody', 'edited'], messagebarbase: ['MessageElements', 'barBase'], messagebarbuttonalt: ['MessageElements', 'barButtonAlt'], messagebarbuttonbase: ['MessageElements', 'barButtonBase'], messagebarbuttonicon: ['MessageElements', 'barButtonIcon'], messagebarbuttonmain: ['MessageElements', 'barButtonMain'], messagebarhasmore: ['MessageElements', 'hasMore'], messagebarjumptopresentbar: ['MessageElements', 'jumpToPresentBar'], messagebarloadingmore: ['MessageElements', 'loadingMore'], messagebarnewmessagesbar: ['MessageElements', 'newMessagesBar'], messagebarspan: ['MessageElements', 'span'], messagebarspinner: ['MessageElements', 'spinner'], messagebarspinneritem: ['MessageElements', 'spinnerItem'], messagegroup: ['Message', 'container'], messagegroupblocked: ['MessageElements', 'messageGroupBlocked'], messagegroupblockedbtn: ['MessageElements', 'messageGroupBlockedBtn'], messagegroupblockedrevealed: ['MessageElements', 'revealed'], 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'], messagetimedivider: ['MessageElements', 'divider'], messagetimedividerred: ['MessageElements', 'dividerRed'], messagetimedividercontent: ['MessageElements', 'dividerContent'], 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: ['ChatWindow', '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'], scrollerfade: ['Scroller', 'scrollerFade'], scrollersystempad: ['Scroller', 'systemPad'], scrollerthemed: ['Scroller', 'scrollerThemed'], scrollerthemeghost: ['Scroller', 'themeGhost'], scrollerthemeghosthairline: ['Scroller', 'themeGhostHairline'], scrollerthemeghosthairlinechannels: ['Scroller', 'themeGhostHairlineChannels'], scrollerwrap: ['Scroller', 'scrollerWrap'], searchbar: ['SearchBar', 'container'], searchbarclear: ['SearchBar', 'clear'], searchbarclose: ['SearchBar', 'close'], searchbaricon: ['SearchBar', 'icon'], searchbariconlayout: ['SearchBar', 'iconLayout'], searchbariconwrap: ['SearchBar', 'iconContainer'], searchbarinner: ['SearchBar', 'inner'], searchbarinput: ['SearchBar', 'input'], searchbarlarge: ['SearchBar', 'large'], 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: ['TextSize', 'size10'], size12: ['TextSize', 'size12'], size14: ['TextSize', 'size14'], size16: ['TextSize', 'size16'], size20: ['TextSize', 'size20'], size24: ['TextSize', 'size24'], size32: ['TextSize', 'size32'], 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'], subtext: ['NotFound', 'subtext'], 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: ['ChatWindow', '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'], titlesize10: ['UserPopout', 'size10'], titlesize12: ['UserPopout', 'size12'], titlesize14: ['UserPopout', 'size14'], titlesize16: ['UserPopout', 'size16'], size18: ['Title', 'size18'], titlesize18: ['Title', 'size18'], 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'], unreadbar: ['UnreadBar', 'bar'], unreadbaractive: ['UnreadBar', 'active'], unreadbarcontainer: ['UnreadBar', 'container'], unreadbaricon: ['UnreadBar', 'icon'], unreadbarmention: ['UnreadBar', 'mention'], unreadbartext: ['UnreadBar', 'text'], unreadbarunread: ['UnreadBar', 'unread'], 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'], userpopoutrole: ['Role', 'role'], userpopoutrolecircle: ['Role', 'roleCircle'], userpopoutrolelist: ['UserPopout', 'rolesList'], userpopoutrolename: ['Role', 'roleName'], userprofile: ['UserProfile', 'root'], userprofilebody: ['UserProfile', 'body'], userprofilebottag: ['UserProfile', 'botTag'], userprofilecustomstatus: ['UserProfile', 'customStatusText'], userprofilecustomstatusemoji: ['UserProfile', 'customStatusEmoji'], 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: ['VoiceChannel', 'avatar'], voiceavatarcontainer: ['VoiceChannel', 'avatarContainer'], voiceavatarlarge: ['VoiceChannel', 'avatarLarge'], voiceavatarsmall: ['VoiceChannel', 'avatarSmall'], voiceavatarspeaking: ['VoiceChannel', 'avatarSpeaking'], voiceclickable: ['VoiceChannel', 'clickable'], voicecontent: ['VoiceChannel', 'content'], voicedetails: ['VoiceDetails', 'container'], voicedetailsactive: ['VoiceDetailsPing', 'active'], voicedetailschannel: ['VoiceDetails', 'channel'], voicedetailscustomstatuscontainer: ['VoiceDetails', 'customStatusContainer'], voicedetailshotspot: ['VoiceDetails', 'hotspot'], voicedetailsinactive: ['VoiceDetailsPing', 'inactive'], voicedetailsinner: ['VoiceDetails', 'inner'], voicedetailslabelwrapper: ['VoiceDetailsPing', 'labelWrapper'], voicedetailsping: ['VoiceDetailsPing', 'ping'], voicedetailsqualityaverage: ['VoiceDetailsPing', 'rtcConnectionQualityAverage'], voicedetailsqualitybad: ['VoiceDetailsPing', 'rtcConnectionQualityBad'], voicedetailsqualityfine: ['VoiceDetailsPing', 'rtcConnectionQualityFine'], voicedetailsstatus: ['VoiceDetailsPing', 'rtcConnectionStatus'], voicedetailsstatusconnected: ['VoiceDetailsPing', 'rtcConnectionStatusConnected'], voicedetailsstatusconnecting: ['VoiceDetailsPing', 'rtcConnectionStatusConnecting'], voicedetailsstatuserror: ['VoiceDetailsPing', 'rtcConnectionStatusError'], voicedetailsstatustooltip: ['VoiceDetails', 'statusTooltip'], voicedetailsstatuswithpopout: ['VoiceDetails', 'statusWithPopout'], voicedraggable: ['NotFound', 'voiceDraggable'], voiceflipped: ['VoiceChannel', 'flipped'], voiceicon: ['VoiceChannel', 'icon'], voiceicons: ['VoiceChannel', 'icons'], voiceiconspacing: ['VoiceChannel', 'iconSpacing'], voicelist: ['VoiceChannel', 'list'], voicelist2: ['VoiceChannelList', 'list'], voicelistcollapsed: ['VoiceChannel', 'listCollapse'], voicelistcollapsed2: ['VoiceChannelList', 'collapsed'], voicelistdefault: ['VoiceChannel', 'listDefault'], voiceliveicon: ['VoiceChannel', 'liveIcon'], voicename: ['VoiceChannel', 'username'], voicenamefont: ['VoiceChannel', 'usernameFont'], voicenamespeaking: ['VoiceChannel', 'usernameSpeaking'], voiceselected: ['VoiceChannel', 'selected'], voiceuser: ['VoiceChannel', 'voiceUser'], voiceuserlarge: ['VoiceChannel', 'userLarge'], voiceusersmall: ['VoiceChannel', '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 || 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:i.default.label}', '{className:i.default.hint}'); 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 ContextMenuToggleItem 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; LibraryComponents.Flex = BDFDB.WebModules.findByProperties('Wrap', 'Direction', 'Child'); LibraryComponents.FormComponents = BDFDB.WebModules.findByProperties('FormSection', 'FormText'); LibraryComponents.ModalComponents = BDFDB.WebModules.findByProperties('ModalContent', 'ModalFooter'); LibraryComponents.SvgIcon = BDFDB.WebModules.findByProperties('Gradients', 'Names'); LibraryComponents.TextElement = BDFDB.WebModules.findByProperties('Sizes', 'Weights'); 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, ') 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-itemlayercontainer, .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.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.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault} { overflow: hidden; } .BDFDB-colorpicker .gradient-bar .gradient-cursor > div:after, .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: -1; } .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchdefault}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchdefault}:after { border-radius: 3px; } .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchdefault}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom + BDFDB.notCN.colorpickerswatchdefault}:after { border-radius: 5px; } .BDFDB-colorpicker .alpha-checker, .BDFDB-colorpicker .gradient-bar .gradient-cursor > div:after, .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after { background: url('data:image/svg+xml; utf8, ') center repeat } .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, ${BDFDB.dotCN.themelight} .BDFDB-colorpicker .alpha-bar > 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 { cursor: pointer; opacity: 0.3; transition: all 200ms ease; } .BDFDB-colorpicker .gradient-button:hover { opacity: 0.6; } .BDFDB-colorpicker .gradient-button.selected, .BDFDB-colorpicker .gradient-button.selected:hover { opacity: 1; } ${BDFDB.dotCN.themelight} .BDFDB-colorpicker .gradient-button { color: #4f545c; } ${BDFDB.dotCN.themedark} .BDFDB-colorpicker .gradient-button { color: #fff; } .BDFDB-colorpicker .alpha-checker, .BDFDB-colorpicker .alpha-horizontal, .BDFDB-colorpicker .gradient-horizontal { border-radius: 3px; } .BDFDB-colorpicker .alpha-bar .alpha-cursor, .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); transform-style: preserve-3d; } .BDFDB-colorpicker .gradient-bar .gradient-cursor > div:after { border-radius: 3px; transform: translateZ(-1px); } .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, 0.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, 0.7); } .BDFDB-modal ${BDFDB.dotCN.inputdefault}.invalid { background-color: rgba(241, 71, 71, 0.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, 0.7); } .BDFDB-modal ${BDFDB.dotCN.inputdefault}:disabled { color: #555555; cursor: no-drop; background-color: rgba(0, 0, 0, 0.5); } .BDFDB-modal ${BDFDB.dotCN.tabbarcontainer} { border: none !important; background: rgba(0, 0, 0, 0.1); box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.05); } ${BDFDB.dotCN.themedark} .BDFDB-modal ${BDFDB.dotCN.tabbarcontainer} { background: rgba(0, 0, 0, 0.2); box-shadow: 0 2px 3px 0 rgba(0, 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 *${BDFDB.notCN.modalsubinner} > .tab-content.open${BDFDB.notCN.modalsubinner} > * { 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 => { clearTimeout(keydowntimeouts[e.which]); BDFDB.removeFromArray(BDFDB.pressedKeys, e.which, true); }); BDFDB.addEventListener(BDFDB, document, 'mousedown.BDFDBMousePosition', e => { BDFDB.mousePosition = e; }); BDFDB.addEventListener(BDFDB, window, 'focus.BDFDBPressedKeysReset', e => { BDFDB.pressedKeys = []; }); 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(``); 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 = `DevilBro${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(` `); 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(`Support Server`); 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(`Donations`)); } } } } }; 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.addObserver(BDFDB, document.querySelector(BDFDB.dotCN.itemlayercontainer), {name:"layerObserverBDFDB", instance: new MutationObserver(changes => {changes.forEach(change => {change.addedNodes.forEach(node => { if (node.tagName && (BDFDB.containsClass(node, BDFDB.disCN.contextmenu) || (node = node.querySelector(BDFDB.dotCN.contextmenu)) != null)) BDFDB.initElements(node); })})}) }, {childList: true}); 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 keys = Object.keys(BDFDB).length - 10, 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); reloadLib(); } else if (BDFDB.id != id) { clearInterval(crashInterval); } else if (!BDFDB.creationTime || performance.now() - BDFDB.creationTime > 18000000) { clearInterval(crashInterval); 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'; } })();