(_ => { if (window.BDFDB && window.BDFDB.ListenerUtils && typeof window.BDFDB.ListenerUtils.remove == "function") window.BDFDB.ListenerUtils.remove(window.BDFDB); if (window.BDFDB && window.BDFDB.ObserverUtils && typeof window.BDFDB.ObserverUtils.disconnect == "function") window.BDFDB.ObserverUtils.disconnect(window.BDFDB); if (window.BDFDB && window.BDFDB.ModuleUtils && typeof window.BDFDB.ModuleUtils.unpatch == "function") window.BDFDB.ModuleUtils.unpatch(window.BDFDB); if (window.BDFDB && window.BDFDB.WindowUtils && typeof window.BDFDB.WindowUtils.closeAll == "function") window.BDFDB.WindowUtils.closeAll(window.BDFDB); if (window.BDFDB && window.BDFDB.WindowUtils && typeof window.BDFDB.WindowUtils.removeListener == "function") window.BDFDB.WindowUtils.removeListener(window.BDFDB); var BDFDB = { myPlugins: Object.assign({}, window.BDFDB && window.BDFDB.myPlugins), InternalData: Object.assign({ pressedKeys: [], mousePosition: { pageX: 0, pageY: 0 }, componentPatchQueries: {} }, window.BDFDB && window.BDFDB.InternalData, { creationTime: performance.now() }), BDv2Api: window.BDFDB && window.BDFDB.BDv2Api || undefined, name: "$BDFDB" }; var loadid = Math.round(Math.random() * 10000000000000000), InternalBDFDB = {}; BDFDB.InternalData.loadid = loadid; if (typeof Array.prototype.flat != "function") Array.prototype.flat = function () {return this;} InternalBDFDB.defaults = { settings: { showToasts: {value:true, description:"Show Plugin start and stop Toasts"}, showSupportBadges: {value:true, description:"Show little Badges for Users who support my Patreon"}, addSupportLinks: {value:true, description:"Add PayPal/Patreon links to my Plugin Entries"} } }; BDFDB.LogUtils = {}; BDFDB.LogUtils.log = function (string, name) { if (typeof string != "string") string = ""; if (typeof name != "string" || name == "$BDFDB") name = "BDFDB"; console.log(`%c[${name}]`, "color: #3a71c1; font-weight: 700;", string.trim()); }; BDFDB.LogUtils.warn = function (string, name) { if (typeof string != "string") string = ""; if (typeof name != "string" || name == "$BDFDB") name = "BDFDB"; console.warn(`%c[${name}]`, "color: #3a71c1; font-weight: 700;", string.trim()); }; BDFDB.LogUtils.error = function (string, name) { if (typeof string != "string") string = ""; if (typeof name != "string" || name == "$BDFDB") name = "BDFDB"; console.error(`%c[${name}]`, "color: #3a71c1; font-weight: 700;", "Fatal Error: " + string.trim()); }; BDFDB.LogUtils.log("Loading library."); BDFDB.PluginUtils = {}; BDFDB.PluginUtils.init = function (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); if (plugin.patchModules) { plugin.patchedModules = {after: plugin.patchModules}; delete plugin.patchModules; } plugin.patchedModules = BDFDB.ObjectUtils.filter(plugin.patchedModules, type => WebModulesData.Patchtypes.includes(type), true); InternalBDFDB.clearStartTimeout(plugin); let loadmessage = BDFDB.LanguageUtils.LibraryStringsFormat("toast_plugin_started", "v" + plugin.version); BDFDB.LogUtils.log(loadmessage, plugin.name); if (!BDFDB.BDUtils.getSettings("fork-ps-2") && BDFDB.DataUtils.get(BDFDB, "settings", "showToasts")) BDFDB.NotificationUtils.toast(plugin.name + " " + loadmessage, {nopointer: true, selector: "plugin-started-toast"}); let url = typeof plugin.getRawUrl == "function" && typeof plugin.getRawUrl() == "string" ? plugin.getRawUrl() : `https://mwittrien.github.io/BetterDiscordAddons/Plugins/${plugin.name}/${plugin.name}.plugin.js`; BDFDB.PluginUtils.checkUpdate(plugin.name, url); if (BDFDB.ObjectUtils.is(plugin.classes)) InternalBDFDB.addPluginClasses(plugin); if (typeof plugin.initConstructor === "function") BDFDB.TimeUtils.suppress(plugin.initConstructor.bind(plugin), "Could not initiate constructor!", plugin.name)(); if (typeof plugin.css === "string") BDFDB.DOMUtils.appendLocalStyle(plugin.name, plugin.css); InternalBDFDB.patchPlugin(plugin); InternalBDFDB.addSpecialListeners(plugin); BDFDB.PluginUtils.translate(plugin); BDFDB.PluginUtils.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 = BDFDB.TimeUtils.interval(_ => {BDFDB.PluginUtils.checkAllUpdates();}, 1000*60*60*2); plugin.started = true; delete plugin.stopping; for (let name in BDFDB.myPlugins) if (!BDFDB.myPlugins[name].started && typeof BDFDB.myPlugins[name].initialize == "function") setImmediate(_ => {BDFDB.TimeUtils.suppress(BDFDB.myPlugins[name].initialize.bind(BDFDB.myPlugins[name]), "Could not initiate plugin!", name)();}); }; BDFDB.PluginUtils.clear = function (plugin) { InternalBDFDB.clearStartTimeout(plugin); delete BDFDB.myPlugins[plugin.name]; let unloadmessage = BDFDB.LanguageUtils.LibraryStringsFormat("toast_plugin_stopped", "v" + plugin.version); BDFDB.LogUtils.log(unloadmessage, plugin.name); if (!BDFDB.BDUtils.getSettings("fork-ps-2") && BDFDB.DataUtils.get(BDFDB, "settings", "showToasts")) BDFDB.NotificationUtils.toast(plugin.name + " " + unloadmessage, {nopointer: true, selector: "plugin-stopped-toast"}); let url = typeof plugin.getRawUrl == "function" && typeof plugin.getRawUrl() == "string" ? plugin.getRawUrl() : `https://mwittrien.github.io/BetterDiscordAddons/Plugins/${plugin.name}/${plugin.name}.plugin.js`; if (BDFDB.ObjectUtils.is(plugin.classes)) InternalBDFDB.removePluginClasses(plugin); if (typeof plugin.css === "string") BDFDB.DOMUtils.removeLocalStyle(plugin.name); BDFDB.ModuleUtils.unpatch(plugin); BDFDB.ListenerUtils.remove(plugin); BDFDB.ObserverUtils.disconnect(plugin); BDFDB.WindowUtils.closeAll(plugin); BDFDB.WindowUtils.removeListener(plugin); for (let type in BDFDB.InternalData.componentPatchQueries) BDFDB.ArrayUtils.remove(BDFDB.InternalData.componentPatchQueries[type].query, plugin, true); 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(); } delete BDFDB.DataUtils.cached[plugin.name] delete window.PluginUpdates.plugins[url]; delete plugin.started; BDFDB.TimeUtils.timeout(_ => {delete plugin.stopping;}); }; BDFDB.PluginUtils.translate = function (plugin) { plugin.labels = {}; if (typeof plugin.setLabelsByLanguage === "function" || typeof plugin.changeLanguageStrings === "function") { if (document.querySelector("html").lang) translate(); else { var translateinterval = BDFDB.TimeUtils.interval(_ => { if (document.querySelector("html").lang) { BDFDB.TimeUtils.clear(translateinterval); translate(); } }, 100); } function translate() { var language = BDFDB.LanguageUtils.getLanguage(); if (typeof plugin.setLabelsByLanguage === "function") plugin.labels = plugin.setLabelsByLanguage(language.id); if (typeof plugin.changeLanguageStrings === "function") plugin.changeLanguageStrings(); BDFDB.LogUtils.log(BDFDB.LanguageUtils.LibraryStringsFormat("toast_plugin_translated", language.ownlang), plugin.name); } } }; BDFDB.PluginUtils.checkUpdate = function (pluginName, url) { if (BDFDB.BDUtils.isBDv2() || !pluginName || !url) 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.NumberUtils.getVersionDifference(newversion[0], window.PluginUpdates.plugins[url].version) > 0.2) { BDFDB.NotificationUtils.toast(`${pluginName} will be force updated, because your version is heavily outdated.`, {type:"warn", nopointer:true, selector:"plugin-forceupdate-toast"}); BDFDB.PluginUtils.downloadUpdate(pluginName, url); } else if (BDFDB.NumberUtils.compareVersions(newversion[0], window.PluginUpdates.plugins[url].version)) BDFDB.PluginUtils.showUpdateNotice(pluginName, url); else BDFDB.PluginUtils.removeUpdateNotice(pluginName); }); }; BDFDB.PluginUtils.checkAllUpdates = function () { for (let url in window.PluginUpdates.plugins) { var plugin = window.PluginUpdates.plugins[url]; BDFDB.PluginUtils.checkUpdate(plugin.name, plugin.raw); } }; BDFDB.PluginUtils.showUpdateNotice = function (pluginName, url) { if (!pluginName || !url) return; var updatenotice = document.querySelector("#pluginNotice"); if (!updatenotice) { updatenotice = BDFDB.NotificationUtils.notice(`The following plugins need to be updated:  `, {html:true, id:"pluginNotice", type:"info", btn:!BDFDB.BDUtils.isAutoLoadEnabled() ? "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.DOMUtils.remove(".update-clickme-tooltip"); }); let reloadbutton = updatenotice.querySelector(BDFDB.dotCN.noticebutton); if (reloadbutton) { BDFDB.DOMUtils.toggle(reloadbutton, true); reloadbutton.addEventListener("click", _ => { LibraryRequires.electron.remote.getCurrentWindow().reload(); }); reloadbutton.addEventListener("mouseenter", _ => { if (window.PluginUpdates.downloaded) BDFDB.TooltipUtils.create(reloadbutton, window.PluginUpdates.downloaded.join(", "), {type:"bottom", selector:"update-notice-tooltip", style: "max-width: 420px"}); }); } } if (updatenotice) { var updatenoticelist = updatenotice.querySelector("#outdatedPlugins"); if (updatenoticelist && !updatenoticelist.querySelector(`#${pluginName}-notice`)) { if (updatenoticelist.querySelector("span")) updatenoticelist.appendChild(BDFDB.DOMUtils.create(`, `)); var updateentry = BDFDB.DOMUtils.create(`${pluginName}`); updateentry.addEventListener("click", _ => {BDFDB.PluginUtils.downloadUpdate(pluginName, url);}); updatenoticelist.appendChild(updateentry); if (!document.querySelector(".update-clickme-tooltip")) BDFDB.TooltipUtils.create(updatenoticelist, "Click us!", {type:"bottom", selector:"update-clickme-tooltip", delay:500}); } } }; BDFDB.PluginUtils.removeUpdateNotice = function (pluginName, updatenotice = document.querySelector("#pluginNotice")) { if (!pluginName || !updatenotice) return; var updatenoticelist = updatenotice.querySelector("#outdatedPlugins"); if (updatenoticelist) { var noticeentry = updatenoticelist.querySelector(`#${pluginName}-notice`); if (noticeentry) { var nextsibling = noticeentry.nextSibling; var prevsibling = noticeentry.prevSibling; if (nextsibling && BDFDB.DOMUtils.containsClass(nextsibling, "separator")) nextsibling.remove(); else if (prevsibling && BDFDB.DOMUtils.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.DOMUtils.toggle(reloadbutton, false); } else updatenotice.querySelector(BDFDB.dotCN.noticedismiss).click(); } } }; BDFDB.PluginUtils.downloadUpdate = function (pluginName, url) { if (!pluginName || !url) return; LibraryRequires.request(url, (error, response, result) => { if (error) return BDFDB.LogUtils.warn("Unable to get update for " + pluginName); BDFDB.InternalData.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.BDUtils.getPluginsFolder(), url.split("/").slice(-1)[0]), result); BDFDB.NotificationUtils.toast(`${pluginName} v${window.PluginUpdates.plugins[url].version} has been replaced by ${pluginName} 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(pluginName)) window.PluginUpdates.downloaded.push(pluginName); } BDFDB.PluginUtils.removeUpdateNotice(pluginName, updatenotice); } }); }; BDFDB.PluginUtils.checkChangeLog = function (plugin) { if (!BDFDB.ObjectUtils.is(plugin) || !plugin.changelog) return; var changelog = BDFDB.DataUtils.load(plugin, "changelog"); if (!changelog.currentversion || BDFDB.NumberUtils.compareVersions(plugin.version, changelog.currentversion)) { changelog.currentversion = plugin.version; BDFDB.DataUtils.save(changelog, plugin, "changelog"); BDFDB.PluginUtils.openChangeLog(plugin); } }; BDFDB.PluginUtils.openChangeLog = function (plugin) { if (!BDFDB.ObjectUtils.is(plugin) || !plugin.changelog) return; var changeLogHTML = "", headers = { added: "New Features", fixed: "Bug Fixes", improved: "Improvements", progress: "Progress" }; for (let type in plugin.changelog) { type = type.toLowerCase(); var classname = BDFDB.disCN["changelog" + type]; if (classname) { changeLogHTML += `

${headers[type]}

` } } if (changeLogHTML) BDFDB.ModalUtils.open(plugin, {header:`${plugin.name} ${BDFDB.LanguageUtils.LanguageStrings.CHANGE_LOG}`, subheader:`Version ${plugin.version}`, children:BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(changeLogHTML)), className:BDFDB.disCN.modalchangelogmodal, contentClassName:BDFDB.disCNS.changelogcontainer + BDFDB.disCN.modalminicontent}); }; BDFDB.PluginUtils.addLoadingIcon = function (icon) { if (!Node.prototype.isPrototypeOf(icon)) return; BDFDB.DOMUtils.addClass(icon, BDFDB.disCN.loadingicon); let loadingiconwrapper = document.querySelector(BDFDB.dotCN.app + ">" + BDFDB.dotCN.loadingiconwrapper); if (!loadingiconwrapper) { loadingiconwrapper = BDFDB.DOMUtils.create(`
`); document.querySelector(BDFDB.dotCN.app).appendChild(loadingiconwrapper); let killObserver = new MutationObserver(changes => {if (!loadingiconwrapper.firstElementChild) BDFDB.DOMUtils.remove(loadingiconwrapper);}); killObserver.observe(loadingiconwrapper, {childList:true}); } loadingiconwrapper.appendChild(icon); }; BDFDB.PluginUtils.createSettingsPanel = function (plugin, children) { if (!BDFDB.ObjectUtils.is(plugin) || !children || (!BDFDB.ReactUtils.isValidElement(children) && !BDFDB.ArrayUtils.is(children)) || (BDFDB.ArrayUtils.is(children) && !children.length)) return; let settingspanel = BDFDB.DOMUtils.create(`
`); BDFDB.ReactUtils.render(BDFDB.ReactUtils.createElement(LibraryComponents.SettingsPanel, { key: `${plugin.name}-settingspanel`, title: plugin.name == "$BDFDB" ? "BDFDB" : plugin.name, children }), settingspanel); return settingspanel; }; BDFDB.PluginUtils.refreshSettingsPanel = function (plugin, settingspanel, ...args) { if (!BDFDB.ObjectUtils.is(plugin) || typeof plugin.getSettingsPanel != "function" || !Node.prototype.isPrototypeOf(settingspanel) || !settingspanel.parentElement) return; settingspanel.parentElement.appendChild(plugin.getSettingsPanel(...args)); settingspanel.remove(); }; InternalBDFDB.clearStartTimeout = function (plugin) { if (!BDFDB.ObjectUtils.is(plugin)) return; BDFDB.TimeUtils.clear(plugin.startTimeout, plugin.libLoadTimeout); delete plugin.startTimeout; delete plugin.libLoadTimeout; }; InternalBDFDB.addSpecialListeners = function (plugin) { if (BDFDB.ObjectUtils.is(plugin)) { if (typeof plugin.onSettingsClosed === "function") { let SettingsLayer = BDFDB.ModuleUtils.findByName("StandardSidebarView"); if (SettingsLayer) BDFDB.ModuleUtils.patch(plugin, SettingsLayer.prototype, "componentWillUnmount", {after: e => { plugin.onSettingsClosed(); }}); } if (typeof plugin.onSwitch === "function") { let spacer = document.querySelector(`${BDFDB.dotCN.guildswrapper} ~ * > ${BDFDB.dotCN.chatspacer}`); if (spacer) { let noChannelObserver = new MutationObserver(changes => {changes.forEach(change => { if (change.target && BDFDB.DOMUtils.containsClass(change.target, BDFDB.disCN.nochannel)) plugin.onSwitch(); });}); BDFDB.ObserverUtils.connect(plugin, spacer.querySelector(BDFDB.dotCNC.chat + BDFDB.dotCN.nochannel), {name:"switchFixNoChannelObserver", instance:noChannelObserver}, {attributes: true}); let spacerObserver = new MutationObserver(changes => {changes.forEach(change => {if (change.addedNodes) {change.addedNodes.forEach(node => { if (BDFDB.DOMUtils.containsClass(node, BDFDB.disCN.chat, BDFDB.disCN.nochannel, false)) { BDFDB.ObserverUtils.connect(plugin, node, {name:"switchFixNoChannelObserver", instance:noChannelObserver}, {attributes: true}); } });}});}); BDFDB.ObserverUtils.connect(plugin, spacer, {name:"switchFixSpacerObserver", instance:spacerObserver}, {childList: true}); } } InternalBDFDB.addContextListeners(plugin); } }; BDFDB.ObserverUtils = {}; BDFDB.ObserverUtils.connect = function (plugin, eleOrSelec, observer, config = {childList: true}) { if (!BDFDB.ObjectUtils.is(plugin) || !eleOrSelec || !observer) return; if (BDFDB.ObjectUtils.isEmpty(plugin.observers)) plugin.observers = {}; if (!BDFDB.ArrayUtils.is(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.ObserverUtils.disconnect = function (plugin, observer) { if (BDFDB.ObjectUtils.is(plugin) && !BDFDB.ObjectUtils.isEmpty(plugin.observers)) { let observername = typeof observer == "string" ? observer : (BDFDB.ObjectUtils.is(observer) ? observer.name : null); if (!observername) { for (let observer in plugin.observers) for (let instance of plugin.observers[observer]) instance.disconnect(); delete plugin.observers; } else if (!BDFDB.ArrayUtils.is(plugin.observers[observername])) { for (let instance of plugin.observers[observername]) instance.disconnect(); delete plugin.observers[observername]; } } }; BDFDB.ListenerUtils = {}; BDFDB.ListenerUtils.add = function (plugin, ele, actions, selectorOrCallback, callbackOrNothing) { if (!BDFDB.ObjectUtils.is(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.ListenerUtils.remove(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 (!BDFDB.ArrayUtils.is(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.ListenerUtils.copyEvent(e, child)); let mouseout = e2 => { if (e2.target.contains(child) || e2.target == child || !child.contains(e2.target)) { if (origeventname == "mouseleave") callback(BDFDB.ListenerUtils.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.ListenerUtils.copyEvent(e, child)); break; } }; } } else eventcallback = e => {callback(BDFDB.ListenerUtils.copyEvent(e, ele));}; plugin.listeners.push({ele, eventname, origeventname, namespace, selector, eventcallback}); ele.addEventListener(eventname, eventcallback, true); } }; BDFDB.ListenerUtils.remove = function (plugin, ele, actions = "", selector) { if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ArrayUtils.is(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.ListenerUtils.multiAdd = function (node, actions, callback) { if (!Node.prototype.isPrototypeOf(node) || !actions || typeof callback != "function") return; for (var action of actions.trim().split(" ").filter(n => n)) node.addEventListener(action, callback, true); }; BDFDB.ListenerUtils.multiRemove = function (node, actions, callback) { if (!Node.prototype.isPrototypeOf(node) || !actions || typeof callback != "function") return; for (var action of actions.trim().split(" ").filter(n => n)) node.removeEventListener(action, callback, true); }; BDFDB.ListenerUtils.addToChildren = 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(" ").filter(n => n)) { 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.ListenerUtils.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.ListenerUtils.stopEvent = function (e) { if (BDFDB.ObjectUtils.is(e)) { if (typeof e.preventDefault == "function") e.preventDefault(); if (typeof e.stopPropagation == "function") e.stopPropagation(); if (typeof e.stopImmediatePropagation == "function") e.stopImmediatePropagation(); if (BDFDB.ObjectUtils.is(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(); } } }; var NotificationBars = [], DesktopNotificationQueue = {queue:[], running:false}; BDFDB.NotificationUtils = {}; BDFDB.NotificationUtils.toast = function (text, options = {}) { let toasts = document.querySelector(".toasts, .bd-toasts"); if (!toasts) { let channels = document.querySelector(BDFDB.dotCN.channels + " + div"); let channelrects = channels ? BDFDB.DOMUtils.getRects(channels) : null; let members = channels ? channels.querySelector(BDFDB.dotCN.memberswrap) : null; let left = channelrects ? channelrects.left : 310; let width = channelrects ? (members ? channelrects.width - BDFDB.DOMUtils.getRects(members).width : channelrects.width) : window.outerWidth - 0; let form = channels ? channels.querySelector("form") : null; let bottom = form ? BDFDB.DOMUtils.getRects(form).height : 80; toasts = BDFDB.DOMUtils.create(`
`); (document.querySelector(BDFDB.dotCN.app) || document.body).appendChild(toasts); } const {type = "", icon = true, timeout = 3000, html = false, selector = "", nopointer = false, color = ""} = options; let toast = BDFDB.DOMUtils.create(`
${html === true ? text : BDFDB.StringUtils.htmlEscape(text)}
`); if (type) { BDFDB.DOMUtils.addClass(toast, "toast-" + type); if (icon) BDFDB.DOMUtils.addClass(toast, "icon"); } else if (color) { let rgbcolor = BDFDB.ColorUtils.convert(color, "RGB"); if (rgbcolor) toast.style.setProperty("background-color", rgbcolor); } BDFDB.DOMUtils.addClass(toast, selector); toasts.appendChild(toast); toast.close = _ => { if (document.contains(toast)) { BDFDB.DOMUtils.addClass(toast, "closing"); toast.style.setProperty("pointer-events", "none", "important"); BDFDB.TimeUtils.timeout(_ => { 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); BDFDB.TimeUtils.timeout(_ => {toast.close();}, timeout > 0 ? timeout : 600000); return toast; }; BDFDB.NotificationUtils.desktop = 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 = BDFDB.TimeUtils.timeout(_ => {close();}, options.timeout ? options.timeout : 3000); if (typeof options.click == "function") notification.onclick = _ => { BDFDB.TimeUtils.clear(timeout); close(); options.click(); }; if (!muted && options.sound) { audio.src = options.sound; audio.play(); } var close = _ => { audio.pause(); notification.close(); DesktopNotificationQueue.running = false; BDFDB.TimeUtils.timeout(_ => {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.NotificationUtils.notice = function (text, options = {}) { if (!text) return; var layers = document.querySelector(BDFDB.dotCN.layers); if (!layers) return; var id = BDFDB.NumberUtils.generateId(NotificationBars); var notice = BDFDB.DOMUtils.create(`
`); 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.DOMUtils.create(``); BDFDB.DOMUtils.addClass(icon, BDFDB.disCN.noticeplatformicon); BDFDB.DOMUtils.removeClass(icon, BDFDB.disCN.noticeicon); notice.insertBefore(icon, noticemessage); } if (options.customicon) { let iconinner = BDFDB.DOMUtils.create(options.customicon) let icon = BDFDB.DOMUtils.create(``); if (iconinner.tagName == "span" && !iconinner.firstElementChild) icon.style.setProperty("background", `url(${options.customicon}) center/cover no-repeat`); else icon.appendChild(iconinner); BDFDB.DOMUtils.addClass(icon, BDFDB.disCN.noticeplatformicon); BDFDB.DOMUtils.removeClass(icon, BDFDB.disCN.noticeicon); notice.insertBefore(icon, noticemessage); } if (options.btn || options.button) notice.appendChild(BDFDB.DOMUtils.create(``)); if (options.id) notice.id = options.id.split(" ").join(""); if (options.selector) BDFDB.DOMUtils.addClass(notice, options.selector); if (options.css) BDFDB.DOMUtils.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.StringUtils.htmlEscape(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.DOMUtils.addClass(notice, type); if (options.type == "premium") { var noticebutton = notice.querySelector(BDFDB.dotCN.noticebutton); if (noticebutton) BDFDB.DOMUtils.addClass(noticebutton, BDFDB.disCN.noticepremiumaction); BDFDB.DOMUtils.addClass(noticemessage, BDFDB.disCN.noticepremiumtext); notice.insertBefore(BDFDB.DOMUtils.create(``), noticemessage); } } if (!type) { var comp = BDFDB.ColorUtils.convert(options.color, "RGBCOMP"); if (comp) { var fontcolor = comp[0] > 180 && comp[1] > 180 && comp[2] > 180 ? "#000" : "#FFF"; var backgroundcolor = BDFDB.ColorUtils.convert(comp, "HEX"); var filter = comp[0] > 180 && comp[1] > 180 && comp[2] > 180 ? "brightness(0%)" : "brightness(100%)"; BDFDB.DOMUtils.appendLocalStyle("BDFDBcustomnotificationbarColorCorrection" + id, `${BDFDB.dotCN.noticewrapper}[notice-id="${id}"]{background-color:${backgroundcolor} !important;}${BDFDB.dotCN.noticewrapper}[notice-id="${id}"] .notice-message {color:${fontcolor} !important;}${BDFDB.dotCN.noticewrapper}[notice-id="${id}"] ${BDFDB.dotCN.noticebutton} {color:${fontcolor} !important;border-color:${BDFDB.ColorUtils.setAlpha(fontcolor,0.25,"RGBA")} !important;}${BDFDB.dotCN.noticewrapper}[notice-id="${id}"] ${BDFDB.dotCN.noticebutton}:hover {color:${backgroundcolor} !important;background-color:${fontcolor} !important;}${BDFDB.dotCN.noticewrapper}[notice-id="${id}"] ${BDFDB.dotCN.noticedismiss} {filter:${filter} !important;}`); } else BDFDB.DOMUtils.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.DOMUtils.getWidth(document.body.firstElementChild) - BDFDB.DOMUtils.getWidth(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"); BDFDB.TimeUtils.timeout(_ => { BDFDB.ArrayUtils.remove(NotificationBars, id); BDFDB.DOMUtils.removeLocalStyle("BDFDBcustomnotificationbar" + id); BDFDB.DOMUtils.removeLocalStyle("BDFDBcustomnotificationbarColorCorrection" + id); notice.remove(); }, 500); }); return notice; }; BDFDB.NotificationUtils.alert = function (header, body) { if (typeof header == "string" && typeof header == "string" && window.BdApi && typeof BdApi.alert == "function") BdApi.alert(header, body); }; var Tooltips = []; BDFDB.TooltipUtils = {}; BDFDB.TooltipUtils.create = function (anker, text, options = {}) { var itemlayercontainer = document.querySelector(BDFDB.dotCN.appmount + " > * > " + BDFDB.dotCN.itemlayercontainer); if (!itemlayercontainer || (typeof text != "string" && !BDFDB.ObjectUtils.is(options.guild)) || !Node.prototype.isPrototypeOf(anker) || !document.contains(anker)) return null; var id = BDFDB.NumberUtils.generateId(Tooltips); var itemlayer = BDFDB.DOMUtils.create(`
`); itemlayercontainer.appendChild(itemlayer); var tooltip = itemlayer.firstElementChild; if (options.id) tooltip.id = options.id.split(" ").join(""); if (!options.type || !BDFDB.disCN["tooltip" + options.type.toLowerCase()]) options.type = "top"; BDFDB.DOMUtils.addClass(tooltip, BDFDB.disCN["tooltip" + options.type.toLowerCase()]); tooltip.type = options.type.toLowerCase(); let fontColorIsGradient = false, customBackgroundColor = false, style = ""; if (options.style) style += options.style; if (options.fontColor) { fontColorIsGradient = BDFDB.ObjectUtils.is(options.fontColor); if (!fontColorIsGradient) style = (style ? (style + " ") : "") + `color: ${BDFDB.ColorUtils.convert(options.fontColor, "RGBA")} !important;` } if (options.backgroundColor) { customBackgroundColor = true; let backgroundColorIsGradient = BDFDB.ObjectUtils.is(options.backgroundColor); let backgroundColor = !backgroundColorIsGradient ? BDFDB.ColorUtils.convert(options.backgroundColor, "RGBA") : BDFDB.ColorUtils.createGradient(options.backgroundColor); style = (style ? (style + " ") : "") + `background: ${backgroundColor} !important; border-color: ${backgroundColorIsGradient ? BDFDB.ColorUtils.convert(options.backgroundColor[options.type == "left" ? 100 : 0], "RGBA") : backgroundColor} !important;`; } if (style) tooltip.style = style; if (customBackgroundColor) BDFDB.DOMUtils.addClass(tooltip, BDFDB.disCN.tooltipcustom); else if (options.color && BDFDB.disCN["tooltip" + options.color.toLowerCase()]) BDFDB.DOMUtils.addClass(tooltip, BDFDB.disCN["tooltip" + options.color.toLowerCase()]); else BDFDB.DOMUtils.addClass(tooltip, BDFDB.disCN.tooltipblack); if (options.list || BDFDB.ObjectUtils.is(options.guild)) BDFDB.DOMUtils.addClass(tooltip, BDFDB.disCN.tooltiplistitem); if (options.selector) BDFDB.DOMUtils.addClass(tooltip, options.selector); if (BDFDB.ObjectUtils.is(options.guild)) { let streamOwnerIds = LibraryModules.StreamUtils.getAllApplicationStreams().filter(app => app.guildId === options.guild.id).map(app => app.ownerId); let streamOwners = streamOwnerIds.map(ownerId => LibraryModules.UserStore.getUser(ownerId)).filter(n => n); let connectedUsers = Object.keys(LibraryModules.VoiceUtils.getVoiceStates(options.guild.id)).map(userId => !streamOwnerIds.includes(userId) && BDFDB.LibraryModules.UserStore.getUser(userId)).filter(n => n); let tooltiptext = text || options.guild.toString(); if (fontColorIsGradient) tooltiptext = `${BDFDB.StringUtils.htmlEscape(tooltiptext)}`; BDFDB.ReactUtils.render(BDFDB.ReactUtils.createElement(BDFDB.ReactUtils.Fragment, { children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tooltiprow, BDFDB.disCN.tooltiprowguildname), children: [ BDFDB.ReactUtils.createElement(LibraryComponents.GuildComponents.Badge, { guild: options.guild, size: LibraryModules.StringUtils.cssValueToNumber(DiscordClassModules.TooltipGuild.iconSize), className: BDFDB.disCN.tooltiprowicon }), BDFDB.ReactUtils.createElement("span", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tooltipguildnametext, (connectedUsers.length || streamOwners.length) && BDFDB.disCN.tooltipguildnametextlimitedsize), children: fontColorIsGradient || options.html ? BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(tooltiptext)) : tooltiptext }) ] }), connectedUsers.length ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.tooltiprow, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { name: LibraryComponents.SvgIcon.Names.SPEAKER, className: BDFDB.disCN.tooltipactivityicon }), BDFDB.ReactUtils.createElement(LibraryComponents.UserSummaryItem, { users: connectedUsers, max: 6 }) ] }) : null, streamOwners.length ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.tooltiprow, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { name: LibraryComponents.SvgIcon.Names.STREAM, className: BDFDB.disCN.tooltipactivityicon }), BDFDB.ReactUtils.createElement(LibraryComponents.UserSummaryItem, { users: streamOwners, max: 6 }) ] }) : null ].filter(n => n) }), tooltip); } else { if (fontColorIsGradient) tooltip.innerHTML = `${BDFDB.StringUtils.htmlEscape(text)}`; else if (options.html === true) tooltip.innerHTML = text; else tooltip.innerText = text; } tooltip.appendChild(BDFDB.DOMUtils.create(`
`)); tooltip.anker = anker; if (options.hide) BDFDB.DOMUtils.appendLocalStyle("BDFDBhideOtherTooltips" + id, `#app-mount ${BDFDB.dotCN.tooltip}:not([tooltip-id="${id}"]) {display: none !important;}`, itemlayercontainer); let mouseleave = _ => {BDFDB.DOMUtils.remove(itemlayer);}; anker.addEventListener("mouseleave", mouseleave); let observer = new MutationObserver(changes => changes.forEach(change => { let nodes = Array.from(change.removedNodes); if (nodes.indexOf(itemlayer) > -1 || nodes.indexOf(anker) > -1 || nodes.some(n => n.contains(anker))) { BDFDB.ArrayUtils.remove(Tooltips, id); observer.disconnect(); BDFDB.DOMUtils.remove(itemlayer); BDFDB.DOMUtils.removeLocalStyle("BDFDBhideOtherTooltips" + id, itemlayercontainer); anker.removeEventListener("mouseleave", mouseleave); } })); observer.observe(document.body, {subtree:true, childList:true}); BDFDB.TooltipUtils.update(tooltip); if (options.delay) { BDFDB.DOMUtils.toggle(itemlayer); BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.toggle(itemlayer);}, options.delay); } return itemlayer; }; BDFDB.TooltipUtils.update = function (tooltip) { if (!Node.prototype.isPrototypeOf(tooltip)) return; let itemlayer = BDFDB.DOMUtils.getParent(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.type) return; var pointer = tooltip.querySelector(BDFDB.dotCN.tooltippointer); var left, top, trects = BDFDB.DOMUtils.getRects(tooltip.anker), irects = BDFDB.DOMUtils.getRects(itemlayer), arects = BDFDB.DOMUtils.getRects(document.querySelector(BDFDB.dotCN.appmount)), positionoffsets = {height: 10, width: 10}; switch (tooltip.type) { 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.type == "top" || tooltip.type == "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.type == "left" || tooltip.type == "right") { if (top < 0) { itemlayer.style.setProperty("top", "5px"); pointer.style.setProperty("margin-top", `${top - 10}px`); } else { var bottommargin = arects.height - (top + irects.height); if (bottommargin < 0) { itemlayer.style.setProperty("top", arects.height - irects.height - 5 + "px"); pointer.style.setProperty("margin-top", `${-1*bottommargin}px`); } } } }; BDFDB.ObjectUtils = {}; BDFDB.ObjectUtils.is = function (obj) { return obj && Object.prototype.isPrototypeOf(obj) && !Array.prototype.isPrototypeOf(obj); }; BDFDB.ObjectUtils.extract = function (obj, ...keys) { let newobj = {}; if (BDFDB.ObjectUtils.is(obj)) for (let key of keys.flat(10).filter(n => n)) if (obj[key]) newobj[key] = obj[key]; return newobj; }; BDFDB.ObjectUtils.exclude = function (obj, ...keys) { let newobj = Object.assign({}, obj); BDFDB.ObjectUtils.delete(newobj, ...keys) return newobj; }; BDFDB.ObjectUtils.delete = function (obj, ...keys) { if (BDFDB.ObjectUtils.is(obj)) for (let key of keys.flat(10).filter(n => n)) delete obj[key]; }; BDFDB.ObjectUtils.sort = function (obj, sort, except) { if (!BDFDB.ObjectUtils.is(obj)) return {}; 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.ArrayUtils.keySort(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.ObjectUtils.reverse = function (obj, sort) { if (!BDFDB.ObjectUtils.is(obj)) return {}; 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.ObjectUtils.filter = function (obj, filter, bykey = false) { if (!BDFDB.ObjectUtils.is(obj)) return {}; if (typeof filter != "function") return obj; return Object.keys(obj).filter(key => filter(bykey ? key : obj[key])).reduce((newobj, key) => (newobj[key] = obj[key], newobj), {}); }; BDFDB.ObjectUtils.push = function (obj, value) { if (BDFDB.ObjectUtils.is(obj)) obj[Object.keys(obj).length] = value; }; BDFDB.ObjectUtils.pop = function (obj, value) { if (BDFDB.ObjectUtils.is(obj)) { let keys = Object.keys(obj); if (!keys.length) return; let value = obj[keys[keys.length-1]]; delete obj[keys[keys.length-1]]; return value; } }; BDFDB.ObjectUtils.map = function (obj, mapfunc) { if (!BDFDB.ObjectUtils.is(obj)) return {}; if (typeof mapfunc != "string" && typeof mapfunc != "function") return obj; var newobj = {}; for (let key in obj) if (BDFDB.ObjectUtils.is(obj[key])) newobj[key] = typeof mapfunc == "string" ? obj[key][mapfunc] : mapfunc(obj[key], key); return newobj; }; BDFDB.ObjectUtils.toArray = function (obj) { if (!BDFDB.ObjectUtils.is(obj)) return []; return Object.entries(obj).map(n => n[1]); }; BDFDB.ObjectUtils.deepAssign = function (obj, ...objs) { if (!objs.length) return obj; let nextobj = objs.shift(); if (BDFDB.ObjectUtils.is(obj) && BDFDB.ObjectUtils.is(nextobj)) { for (let key in nextobj) { if (BDFDB.ObjectUtils.is(nextobj[key])) { if (!obj[key]) Object.assign(obj, {[key]:{}}); BDFDB.ObjectUtils.deepAssign(obj[key], nextobj[key]); } else Object.assign(obj, {[key]:nextobj[key]}); } } return BDFDB.ObjectUtils.deepAssign(obj, ...objs); }; BDFDB.ObjectUtils.isEmpty = function (obj) { return !BDFDB.ObjectUtils.is(obj) || Object.getOwnPropertyNames(obj).length == 0; }; BDFDB.ArrayUtils = {}; BDFDB.ArrayUtils.is = function (array) { return array && Array.isArray(array); }; BDFDB.ArrayUtils.sum = function (array) { return Array.isArray(array) ? array.reduce((total, num) => total + Math.round(num), 0) : 0; }; BDFDB.ArrayUtils.keySort = function (array, key, except) { if (!BDFDB.ArrayUtils.is(array)) return []; if (key == null) return array; if (except === undefined) except = null; return array.sort((x, y) => { var xvalue = x[key], yvalue = y[key]; if (xvalue !== except) return xvalue < yvalue ? -1 : xvalue > yvalue ? 1 : 0; }); }; BDFDB.ArrayUtils.numSort = function (array) { return array.sort((x, y) => {return x < y ? -1 : x > y ? 1 : 0;}); }; BDFDB.ArrayUtils.remove = function (array, value, all = false) { if (!BDFDB.ArrayUtils.is(array)) return []; if (!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.ArrayUtils.getAllIndexes = function (array, value) { if (!BDFDB.ArrayUtils.is(array) && typeof array != "string") return []; var indexes = [], index = -1; while ((index = array.indexOf(value, index + 1)) !== -1) indexes.push(index); return indexes; }; BDFDB.ArrayUtils.removeCopies = function (array) { if (!BDFDB.ArrayUtils.is(array)) return []; return [...new Set(array)]; }; BDFDB.ModuleUtils = {}; BDFDB.ModuleUtils.cached = window.BDFDB && window.BDFDB.ModuleUtils && window.BDFDB.ModuleUtils.cached || {}; BDFDB.ModuleUtils.find = function (filter, getExport) { getExport = typeof getExport != "boolean" ? true : getExport; var req = InternalBDFDB.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 getExport ? m : req.c[i]; if (m && m.__esModule) { for (let j in m) if (m[j] && (typeof m[j] == "object" || typeof m[j] == "function") && filter(m[j])) return getExport ? m[j] : req.c[i]; if (m.default && (typeof m.default == "object" || typeof m.default == "function")) for (let j in m.default) if (m.default[j] && (typeof m.default[j] == "object" || typeof m.default[j] == "function") && filter(m.default[j])) return getExport ? m.default[j] : req.c[i]; } } }; BDFDB.ModuleUtils.findByProperties = function (...properties) { properties = properties.flat(10); let getExport = properties.pop(); if (typeof getExport != "boolean") { properties.push(getExport); getExport = true; } return InternalBDFDB.findModule("prop", JSON.stringify(properties), m => properties.every(prop => m[prop] !== undefined), getExport); }; BDFDB.ModuleUtils.findByName = function (name, getExport) { return InternalBDFDB.findModule("name", JSON.stringify(name), m => m.displayName === name || m.render && m.render.displayName === name, typeof getExport != "boolean" ? true : getExport); }; BDFDB.ModuleUtils.findByString = function (...strings) { strings = strings.flat(10); let getExport = strings.pop(); if (typeof getExport != "boolean") { strings.push(getExport); getExport = true; } return InternalBDFDB.findModule("string", JSON.stringify(strings), m => strings.every(string => typeof m == "function" && (m.toString().indexOf(string) > -1 || m.__originalMethod && m.__originalMethod.toString().indexOf(string) > -1 || m.__originalFunction && m.__originalFunction.toString().indexOf(string) > -1) || BDFDB.ObjectUtils.is(m) && typeof m.type == "function" && (m.type.toString().indexOf(string) > -1 || m.type.__originalMethod && m.type.__originalMethod.toString().indexOf(string) > -1 || m.type.__originalFunction && m.type.__originalFunction.toString().indexOf(string) > -1)), getExport); }; BDFDB.ModuleUtils.findByPrototypes = function (...protoprops) { protoprops = protoprops.flat(10); let getExport = protoprops.pop(); if (typeof getExport != "boolean") { protoprops.push(getExport); getExport = true; } return InternalBDFDB.findModule("proto", JSON.stringify(protoprops), m => m.prototype && protoprops.every(prop => m.prototype[prop] !== undefined), getExport); }; InternalBDFDB.findModule = function (type, cachestring, filter, getExport) { if (!BDFDB.ObjectUtils.is(BDFDB.ModuleUtils.cached[type])) BDFDB.ModuleUtils.cached[type] = {module:{}, export:{}}; if (getExport && BDFDB.ModuleUtils.cached[type].export[cachestring]) return BDFDB.ModuleUtils.cached[type].export[cachestring]; else if (!getExport && BDFDB.ModuleUtils.cached[type].module[cachestring]) return BDFDB.ModuleUtils.cached[type].module[cachestring]; else { var m = BDFDB.ModuleUtils.find(filter, getExport); if (m) { if (getExport) BDFDB.ModuleUtils.cached[type].export[cachestring] = m; else BDFDB.ModuleUtils.cached[type].module[cachestring] = m; return m; } else BDFDB.LogUtils.warn(`${cachestring} [${type}] not found in WebModules`); } }; InternalBDFDB.getWebModuleReq = function () { if (!InternalBDFDB.getWebModuleReq.req) { const id = "BDFDB-WebModules"; const req = window.webpackJsonp.push([[], {[id]: (module, exports, req) => module.exports = req}, [[id]]]); delete req.m[id]; delete req.c[id]; InternalBDFDB.getWebModuleReq.req = req; } return InternalBDFDB.getWebModuleReq.req; }; var WebModulesData = {}; WebModulesData.Patchtypes = ["before", "instead", "after"]; WebModulesData.Patchmap = { BannedCard: "BannedUser", ChannelWindow: "Channel", InvitationCard: "InviteRow", InviteCard: "InviteRow", MemberCard: "Member", PopoutContainer: "Popout", QuickSwitchChannelResult: "Channel", QuickSwitchGuildResult: "Guild", QuickSwitchResult: "Result", UserProfile: "UserProfileBody", WebhookCard: "Webhook" }; WebModulesData.ForceObserve = [ "DirectMessage", "GuildIcon", "QuickSwitchChannelResult", "QuickSwitchGuildResult" ]; WebModulesData.DefaultRender = [ "DiscordTag", "NameTag", "Message", "MessageHeader", "MessageTimestamp", "SystemMessage", "SimpleMessageAccessories" ]; WebModulesData.MemoComponent = [ "MessageContent" ]; WebModulesData.NonPrototype = [].concat(WebModulesData.DefaultRender, WebModulesData.MemoComponent, [ "ChannelTextAreaContainer" ]); WebModulesData.LoadedInComponents = { AutocompleteChannelResult: "AutocompleteComponents.Channel", AutocompleteUserResult: "AutocompleteComponents.User" }; WebModulesData.Patchfinder = { Account: "accountinfo", App: "app", AppSkeleton: "app", AppView: "appcontainer", AuthWrapper: "loginscreen", BannedCard: "guildsettingsbannedcard", ChannelMember: "member", ChannelTextAreaForm: "chatform", ChannelWindow: "chatcontent", DirectMessage: "guildouter", EmojiPicker: "emojipicker", FriendRow: "friendsrow", Guild: "guildouter", GuildIcon: "avataricon", GuildSettingsBans: "guildsettingsbannedcard", GuildSettingsEmoji: "guildsettingsemojicard", GuildSettingsMembers: "guildsettingsmembercard", GuildSidebar: "guildchannels", I18nLoaderWrapper: "app", InstantInviteModal: "invitemodalwrapper", InvitationCard: "invitemodalinviterow", InviteCard: "guildsettingsinvitecard", PopoutContainer: "popout", PrivateChannelCall: "callcurrentcontainer", PrivateChannelRecipientsInvitePopout: "searchpopoutdmaddpopout", PrivateChannelsList: "dmchannelsscroller", QuickSwitchChannelResult: "quickswitchresult", QuickSwitchGuildResult: "quickswitchresult", QuickSwitchResult: "quickswitchresult", MemberCard: "guildsettingsmembercard", Messages: "messages", MessagesPopout: "messagespopout", MutualGuilds: "userprofilebody", MutualFriends: "userprofilebody", NameTag: "nametag", Note: "usernote", SearchResults: "searchresultswrap", TypingUsers: "typing", UnreadDMs: "guildsscroller", Upload: "uploadmodal", UserPopout: "userpopout", UserProfile: "userprofile", V2C_ContentColumn: "contentcolumn", V2C_List: "_repolist", V2C_PluginCard: "_repoheader", V2C_ThemeCard: "_repoheader" }; WebModulesData.GlobalModules = {}; try {WebModulesData.GlobalModules["V2C_ContentColumn"] = V2C_ContentColumn;} catch(err) {BDFDB.LogUtils.warn(`Could not find global Module "V2C_ContentColumn"`);} try {WebModulesData.GlobalModules["V2C_List"] = V2C_List;} catch(err) {BDFDB.LogUtils.warn(`Could not find global Module "V2C_List"`);} try {WebModulesData.GlobalModules["V2C_PluginCard"] = V2C_PluginCard;} catch(err) {BDFDB.LogUtils.warn(`Could not find global Module "V2C_PluginCard"`);} try {WebModulesData.GlobalModules["V2C_ThemeCard"] = V2C_ThemeCard;} catch(err) {BDFDB.LogUtils.warn(`Could not find global Module "V2C_ThemeCard"`);} BDFDB.ModuleUtils.isPatched = function (plugin, module, modulefunction) { if (!plugin || !BDFDB.ObjectUtils.is(module) || !module.BDFDBpatch || !modulefunction) return false; const pluginId = (typeof plugin === "string" ? plugin : plugin.name).toLowerCase(); return pluginId && module[modulefunction] && module[modulefunction].isBDFDBpatched && module.BDFDBpatch[modulefunction] && Object.keys(module.BDFDBpatch[modulefunction]).some(patchfunc => Object.keys(module.BDFDBpatch[modulefunction][patchfunc]).includes(pluginId)); }; BDFDB.ModuleUtils.patch = function (plugin, module, modulefunctions, patchfunctions, forceRepatch = false) { if (!plugin || !BDFDB.ObjectUtils.is(module) || !modulefunctions || !BDFDB.ObjectUtils.is(patchfunctions)) return null; patchfunctions = BDFDB.ObjectUtils.filter(patchfunctions, type => WebModulesData.Patchtypes.includes(type), true); if (BDFDB.ObjectUtils.isEmpty(patchfunctions)) return null; const pluginName = typeof plugin === "string" ? plugin : plugin.name; const pluginId = pluginName.toLowerCase(); if (!module.BDFDBpatch) module.BDFDBpatch = {}; modulefunctions = [modulefunctions].flat(10).filter(n => n); for (let modulefunction of modulefunctions) if (module[modulefunction] == null || typeof module[modulefunction] == "function") { if (!module.BDFDBpatch[modulefunction] || forceRepatch && (!module[modulefunction] || !module[modulefunction].isBDFDBpatched)) { if (!module.BDFDBpatch[modulefunction]) { module.BDFDBpatch[modulefunction] = {}; for (let type of WebModulesData.Patchtypes) module.BDFDBpatch[modulefunction][type] = {}; } if (!module[modulefunction]) module[modulefunction] = (_ => {}); const originalfunction = module[modulefunction]; module.BDFDBpatch[modulefunction].originalMethod = originalfunction; module[modulefunction] = function () { let callInstead = false, stopCall = false; const data = { thisObject: this, methodArguments: arguments, originalMethod: originalfunction, originalMethodName: modulefunction, callOriginalMethod: _ => {if (!stopCall) data.returnValue = data.originalMethod.apply(data.thisObject, data.methodArguments)}, callOriginalMethodAfterwards: _ => {callInstead = true;}, stopOriginalMethodCall: _ => {stopCall = true;} }; if (module.BDFDBpatch && module.BDFDBpatch[modulefunction]) { if (!BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[modulefunction].before)) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[modulefunction].before)) { BDFDB.TimeUtils.suppress(module.BDFDBpatch[modulefunction].before[id], `"before" callback of ${modulefunction} in ${module.constructor ? module.constructor.displayName || module.constructor.name : "module"}`, module.BDFDBpatch[modulefunction].before[id].pluginName)(data); } let hasInsteadPatches = !BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[modulefunction].instead); if (hasInsteadPatches) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[modulefunction].instead)) { let tempreturn = BDFDB.TimeUtils.suppress(module.BDFDBpatch[modulefunction].instead[id], `"instead" callback of ${modulefunction} in ${module.constructor ? module.constructor.displayName || module.constructor.name : "module"}`, module.BDFDBpatch[modulefunction].instead[id].pluginName)(data); if (tempreturn !== undefined) data.returnValue = tempreturn; } if ((!hasInsteadPatches || callInstead) && !stopCall) BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${modulefunction} in ${module.constructor ? module.constructor.displayName || module.constructor.name : "module"}`)(); if (!BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[modulefunction].after)) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[modulefunction].after)) { let tempreturn = BDFDB.TimeUtils.suppress(module.BDFDBpatch[modulefunction].after[id], `"after" callback of ${modulefunction} in ${module.constructor ? module.constructor.displayName || module.constructor.name : "module"}`, module.BDFDBpatch[modulefunction].after[id].pluginName)(data); if (tempreturn !== undefined) data.returnValue = tempreturn; } } else BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${modulefunction} in ${module.constructor ? module.constructor.displayName || module.constructor.name : "module"}`)(); callInstead = false, stopCall = false; return modulefunction == "render" && data.returnValue === undefined ? null : data.returnValue; }; for (let key of Object.keys(originalfunction)) module[modulefunction][key] = originalfunction[key]; module[modulefunction].__originalMethod = originalfunction; module[modulefunction].isBDFDBpatched = true; } for (let type in patchfunctions) if (typeof patchfunctions[type] == "function") { module.BDFDBpatch[modulefunction][type][pluginId] = patchfunctions[type]; module.BDFDBpatch[modulefunction][type][pluginId].pluginName = pluginName; } } let cancel = _ => {BDFDB.ModuleUtils.unpatch(plugin, module, modulefunctions);}; if (BDFDB.ObjectUtils.is(plugin)) { if (!BDFDB.ArrayUtils.is(plugin.patchCancels)) plugin.patchCancels = []; plugin.patchCancels.push(cancel); } return cancel; }; BDFDB.ModuleUtils.unpatch = function (plugin, module, modulefunctions) { if (!module && !modulefunctions) { if (BDFDB.ObjectUtils.is(plugin) && BDFDB.ArrayUtils.is(plugin.patchCancels)) { for (let cancel of plugin.patchCancels) cancel(); plugin.patchCancels = []; } } else { if (!BDFDB.ObjectUtils.is(module) || !module.BDFDBpatch) return; const pluginName = !plugin ? null : (typeof plugin === "string" ? plugin : plugin.name).toLowerCase(); if (modulefunctions) { for (let modulefunction of [modulefunctions].flat(10).filter(n => n)) if (module[modulefunction] && module.BDFDBpatch[modulefunction]) unpatch(modulefunction, pluginName); } else for (let patchedfunction of module.BDFDBpatch) unpatch(patchedfunction, pluginName); } function unpatch (func, pluginName) { for (let type of WebModulesData.Patchtypes) { if (pluginName) delete module.BDFDBpatch[func][type][pluginName]; else delete module.BDFDBpatch[func][type]; } let empty = true; for (let type of WebModulesData.Patchtypes) if (!BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[func][type])) empty = false; if (empty) { module[func] = module.BDFDBpatch[func].originalMethod; delete module.BDFDBpatch[func]; if (BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch)) delete module.BDFDBpatch; } } }; BDFDB.ModuleUtils.forceAllUpdates = function (plugin, selectedtypes) { if (BDFDB.ObjectUtils.is(plugin) && BDFDB.ObjectUtils.is(plugin.patchedModules)) { const app = document.querySelector(BDFDB.dotCN.app); const bdsettings = document.querySelector("#bd-settingspane-container " + BDFDB.dotCN.scrollerwrap); if (app) { let filteredmodules = [], patchtypes = {}; for (let patchtype in plugin.patchedModules) for (let type in plugin.patchedModules[patchtype]) { let methodnames = [plugin.patchedModules[patchtype][type]].flat(10).filter(n => n); if (methodnames.includes("componentDidMount") || methodnames.includes("componentDidUpdate") || methodnames.includes("render")) { filteredmodules.push(type); let unmappedtype = type.split(" _ _ ")[0]; if (!patchtypes[unmappedtype]) patchtypes[unmappedtype] = []; patchtypes[unmappedtype].push(patchtype); } } selectedtypes = [selectedtypes].flat(10).filter(n => n); if (selectedtypes.length) { selectedtypes = selectedtypes.map(type => type && WebModulesData.Patchmap[type] ? WebModulesData.Patchmap[type] + " _ _ " + type : type); filteredmodules = filteredmodules.filter(type => selectedtypes.indexOf(type) > -1); } filteredmodules = BDFDB.ArrayUtils.removeCopies(filteredmodules); if (filteredmodules.length) { try { const appinsdown = BDFDB.ReactUtils.findOwner(app, {name:filteredmodules, all:true, group:true, unlimited:true}); const appinsup = BDFDB.ReactUtils.findOwner(app, {name:filteredmodules, all:true, group:true, unlimited:true, up:true}); for (let type in appinsdown) for (let ins of appinsdown[type]) InternalBDFDB.forceInitiateProcess(plugin, ins, type, patchtypes[type]); for (let type in appinsup) for (let ins of appinsup[type]) InternalBDFDB.forceInitiateProcess(plugin, ins, type, patchtypes[type]); if (bdsettings) { const bdsettingsins = BDFDB.ReactUtils.findOwner(bdsettings, {name:filteredmodules, all:true, group:true, unlimited:true}); for (let type in bdsettingsins) for (let ins of bdsettingsins[type]) InternalBDFDB.forceInitiateProcess(plugin, ins, type, patchtypes[type]); } } catch (err) {BDFDB.LogUtils.error("Could not force update components! " + err, plugin.name);} } } } }; InternalBDFDB.forceInitiateProcess = function (plugin, instance, type, patchtypes) { if (!plugin || !instance || !type) return; let methodnames = []; for (let patchtype in plugin.patchedModules) if (plugin.patchedModules[patchtype][type]) methodnames.push(plugin.patchedModules[patchtype][type]); methodnames = BDFDB.ArrayUtils.removeCopies(methodnames).flat(10).filter(n => n); if (methodnames.includes("componentDidMount")) InternalBDFDB.initiateProcess(plugin, type, {instance, methodname:"componentDidMount", patchtypes}); if (methodnames.includes("render")) BDFDB.ReactUtils.forceUpdate(instance); else if (methodnames.includes("componentDidUpdate")) InternalBDFDB.initiateProcess(plugin, type, {instance, methodname:"componentDidUpdate", patchtypes}); }; InternalBDFDB.initiateProcess = function (plugin, type, e) { if (BDFDB.ObjectUtils.is(plugin) && !plugin.stopping && e.instance) { // REMOVE let isLib = plugin.name == "$BDFDB"; if (plugin.name == "$BDFDB") plugin = InternalBDFDB; type = (type.split(" _ _ ")[1] || type).replace(/[^A-z0-9]|_/g, ""); type = type.charAt(0).toUpperCase() + type.slice(1); if (typeof plugin["process" + type] == "function") { // REMOVE let isOldType = !isLib && plugin["process" + type].toString().split("\n")[0].replace(/ /g, "").split(",").length > 1; if (isOldType) { if (e.methodname == "render") { if (e.returnvalue) plugin["process" + type](e.instance, null, e.returnvalue, [e.methodname]); } else { let wrapper = BDFDB.ReactUtils.findDOMNode(e.instance); if (wrapper) plugin["process" + type](e.instance, wrapper, e.returnvalue, [e.methodname]); else BDFDB.TimeUtils.timeout(_ => { wrapper = BDFDB.ReactUtils.findDOMNode(e.instance); if (wrapper) plugin["process" + type](e.instance, wrapper, e.returnvalue, [e.methodname]); }); } } else { if (typeof e.methodname == "string" && (e.methodname.indexOf("componentDid") == 0 || e.methodname.indexOf("componentWill") == 0)) { e.node = BDFDB.ReactUtils.findDOMNode(e.instance); if (e.node) plugin["process" + type](e); else BDFDB.TimeUtils.timeout(_ => { e.node = BDFDB.ReactUtils.findDOMNode(e.instance); if (e.node) plugin["process" + type](e); }); } else if (e.returnvalue || e.patchtypes.includes("before")) plugin["process" + type](e); } } } }; InternalBDFDB.patchPlugin = function (plugin) { if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ObjectUtils.is(plugin.patchedModules)) return; BDFDB.ModuleUtils.unpatch(plugin); for (let patchtype in plugin.patchedModules) for (let type in plugin.patchedModules[patchtype]) { if (WebModulesData.GlobalModules[type] && typeof WebModulesData.GlobalModules[type] == "function") patchInstance(WebModulesData.GlobalModules[type], type, patchtype); else { let component = WebModulesData.LoadedInComponents[type] && BDFDB.ReactUtils.getValue(LibraryComponents, WebModulesData.LoadedInComponents[type]); if (component) patchInstance(component, type, patchtype); else { let mapped = WebModulesData.Patchmap[type]; let classname = WebModulesData.Patchfinder[type.split(" _ _ ")[1] || type]; let mappedtype = mapped ? mapped + " _ _ " + type : type; if (mapped) { plugin.patchedModules[patchtype][mappedtype] = plugin.patchedModules[patchtype][type]; delete plugin.patchedModules[patchtype][type]; } if (WebModulesData.DefaultRender.includes(type.split(" _ _ ")[1] || type)) patchInstance((BDFDB.ModuleUtils.findByName(mappedtype.split(" _ _ ")[0], false) || {}).exports, mappedtype, patchtype, true); else if (WebModulesData.MemoComponent.includes(type.split(" _ _ ")[1] || type)) patchInstance((BDFDB.ModuleUtils.findByName(mappedtype.split(" _ _ ")[0], false) || {exports:{}}).exports.default, mappedtype, patchtype, true); else if (!classname) patchInstance(BDFDB.ModuleUtils.findByName(mappedtype.split(" _ _ ")[0]), mappedtype, patchtype); else if (DiscordClasses[classname]) checkForInstance(classname, mappedtype, patchtype, WebModulesData.ForceObserve.includes(type.split(" _ _ ")[1] || type)); } } } function patchInstance(instance, type, patchtype, exported) { if (instance) { let name = type.split(" _ _ ")[0]; instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance; instance = exported || InternalBDFDB.isInstanceCorrect(instance, name) || WebModulesData.LoadedInComponents[type] ? instance : (BDFDB.ReactUtils.findConstructor(instance, name) || BDFDB.ReactUtils.findConstructor(instance, name, {up:true})); if (instance) { instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance; let patchfunctions = {}; patchfunctions[patchtype] = e => {InternalBDFDB.initiateProcess(plugin, type, {instance:window != e.thisObject ? e.thisObject : {props:e.methodArguments[0]}, returnvalue:e.returnValue, methodname:e.originalMethodName, patchtypes:[patchtype]})}; BDFDB.ModuleUtils.patch(plugin, WebModulesData.NonPrototype.includes(name) ? instance : instance.prototype, plugin.patchedModules[patchtype][type], patchfunctions); } } } function checkForInstance(classname, type, patchtype, forceobserve) { const app = document.querySelector(BDFDB.dotCN.app), bdsettings = document.querySelector("#bd-settingspane-container " + BDFDB.dotCN.scrollerwrap); let instancefound = false; if (!forceobserve) { if (app) { let appins = BDFDB.ReactUtils.findConstructor(app, type, {unlimited:true}) || BDFDB.ReactUtils.findConstructor(app, type, {unlimited:true, up:true}); if (appins && (instancefound = true)) patchInstance(appins, type, patchtype); } if (!instancefound && bdsettings) { let bdsettingsins = BDFDB.ReactUtils.findConstructor(bdsettings, type, {unlimited:true}); if (bdsettingsins && (instancefound = true)) patchInstance(bdsettingsins, type, patchtype); } } if (!instancefound) { let found = false, disclass = BDFDB.disCN[classname], dotclass = BDFDB.dotCN[classname]; for (let ele of document.querySelectorAll(dotclass)) { let ins = BDFDB.ReactUtils.getInstance(ele); if (isCorrectInstance(ins, type)) { found = true; patchInstance(ins, type, patchtype); BDFDB.ModuleUtils.forceAllUpdates(plugin, type); break; } } if (!found) { let instanceobserver = new MutationObserver(cs => {cs.forEach(c => {c.addedNodes.forEach(n => { if (found || !n || !n.tagName) return; let ele = null; if ((ele = BDFDB.DOMUtils.containsClass(n, disclass) ? n : n.querySelector(dotclass)) != null) { let ins = BDFDB.ReactUtils.getInstance(ele); if (isCorrectInstance(ins, type)) { found = true; instanceobserver.disconnect(); patchInstance(ins, type, patchtype); BDFDB.ModuleUtils.forceAllUpdates(plugin, type); } } });});}); BDFDB.ObserverUtils.connect(plugin, BDFDB.dotCN.appmount, {name:"checkForInstanceObserver", instance:instanceobserver, multi:true }, {childList:true, subtree:true}); } } } function isCorrectInstance(instance, name) { if (!instance) return false; instance = instance._reactInternalFiber && instance._reactInternalFiber.type ? instance._reactInternalFiber.type : instance; instance = InternalBDFDB.isInstanceCorrect(instance, name) ? instance : (BDFDB.ReactUtils.findConstructor(instance, name) || BDFDB.ReactUtils.findConstructor(instance, name, {up:true})); return !!instance; } }; InternalBDFDB.isInstanceCorrect = function (instance, name) { return instance && ((instance.type && (instance.type.render && instance.type.render.displayName === name || instance.type.displayName === name || instance.type.name === name || instance.type === name)) || instance.render && (instance.render.displayName === name || instance.render.name === name) || instance.displayName == name || instance.name === name); }; InternalBDFDB.addContextListeners = function (plugin) { for (let type of ComponentTypeData.NormalContextMenus) if (typeof plugin[`on${type}`] === "function") InternalBDFDB.patchContextMenuPlugin(plugin, type, LibraryComponents.ContextMenus[type]); for (let type of ComponentTypeData.FluxContextMenus) if (typeof plugin[`on${type}`] === "function") { if (BDFDB.InternalData.componentPatchQueries[type].module) InternalBDFDB.patchContextMenuPlugin(plugin, type, BDFDB.InternalData.componentPatchQueries[type].module); else { BDFDB.InternalData.componentPatchQueries[type].query.push(plugin); BDFDB.InternalData.componentPatchQueries[type].query.sort((x, y) => {return x.name < y.name ? -1 : x.name > y.name ? 1 : 0;}); } } for (let type of ComponentTypeData.QueuedComponents) if (typeof plugin[`on${type}`] === "function") { if (BDFDB.InternalData.componentPatchQueries[type].module) InternalBDFDB.patchExportedContextMenuPlugin(plugin, type, BDFDB.InternalData.componentPatchQueries[type].module); else { BDFDB.InternalData.componentPatchQueries[type].query.push(plugin); BDFDB.InternalData.componentPatchQueries[type].query.sort((x, y) => {return x.name < y.name ? -1 : x.name > y.name ? 1 : 0;}); } } }; InternalBDFDB.patchContextMenuPlugin = function (plugin, type, module) { if (module && module.prototype) { // REMOVE let isOldType = plugin["on" + type].toString().split("\n")[0].replace(/ /g, "").split(",").length > 1; if (isOldType) { BDFDB.ModuleUtils.patch(plugin, module.prototype, "render", {after: e => { let instance = e.thisObject, menu = BDFDB.ReactUtils.findDOMNode(e.thisObject), returnvalue = e.returnValue; if (instance && menu && returnvalue && typeof plugin[`on${type}`] === "function") plugin[`on${type}`](instance, menu, returnvalue); }}); } else { BDFDB.ModuleUtils.patch(plugin, module.prototype, "render", {after: e => { if (e.thisObject && e.returnValue && typeof plugin[`on${type}`] === "function") plugin[`on${type}`]({instance:e.thisObject, returnvalue:e.returnValue, methodname:"render"}); }}); } } }; InternalBDFDB.patchExportedContextMenuPlugin = function (plugin, type, module) { if (module && module.exports) { // REMOVE let isOldType = plugin["on" + type].toString().split("\n")[0].replace(/ /g, "").split(",").length > 1; if (isOldType) BDFDB.ModuleUtils.patch(plugin, module.exports, "default", {after: e => { if (e.returnValue && typeof plugin[`on${type}`] === "function") plugin[`on${type}`]({props:e.methodArguments[0]}, document, e.returnValue); }}); else BDFDB.ModuleUtils.patch(plugin, module.exports, "default", {after: e => { if (e.returnValue && typeof plugin[`on${type}`] === "function") plugin[`on${type}`]({instance:{props:e.methodArguments[0]}, returnvalue:e.returnValue, methodname:"default"}); }}); } }; InternalBDFDB.executeExtraPatchedPatches = function (type, e) { if (BDFDB.ObjectUtils.is(BDFDB.InternalData.componentPatchQueries[type]) && BDFDB.ArrayUtils.is(BDFDB.InternalData.componentPatchQueries[type].query)) for (let plugin of BDFDB.InternalData.componentPatchQueries[type].query) if (e.returnvalue && typeof plugin[`on${type}`] === "function") plugin[`on${type}`](e); }; InternalBDFDB.patchContextMenuLib = function (module, repatch) { if (module && module.prototype) { // REMOVE BDFDB.ModuleUtils.patch(BDFDB, module.prototype, "componentDidMount", {after: e => { if (!e.thisObject.BDFDBforceRenderTimeout && typeof e.thisObject.render == "function") e.thisObject.render(); }}); BDFDB.ModuleUtils.patch(BDFDB, module.prototype, "componentDidUpdate", {after: e => { var menu = BDFDB.ReactUtils.findDOMNode(e.thisObject); if (menu) { const updater = BDFDB.ReactUtils.getValue(e, "thisObject._reactInternalFiber.stateNode.props.onHeightUpdate"); const mrects = BDFDB.DOMUtils.getRects(menu), arects = BDFDB.DOMUtils.getRects(document.querySelector(BDFDB.dotCN.appmount)); if (updater && (mrects.top + mrects.height > arects.height)) updater(); } }}); BDFDB.ModuleUtils.patch(BDFDB, module.prototype, "render", {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.ReactUtils.findDOMNode(e.thisObject)) { e.thisObject.BDFDBforceRenderTimeout = true; BDFDB.TimeUtils.timeout(_ => {delete e.thisObject.BDFDBforceRenderTimeout;}, 1000); } if (repatch) { let newmodule = BDFDB.ReactUtils.getValue(e, "thisObject._reactInternalFiber.child.type"); if (newmodule && newmodule.displayName && BDFDB.InternalData.componentPatchQueries[newmodule.displayName] && !BDFDB.InternalData.componentPatchQueries[newmodule.displayName].module) { BDFDB.InternalData.componentPatchQueries[newmodule.displayName].module = newmodule; InternalBDFDB.patchContextMenuLib(newmodule, false); while (BDFDB.InternalData.componentPatchQueries[newmodule.displayName].query.length) InternalBDFDB.patchContextMenuPlugin(BDFDB.InternalData.componentPatchQueries[newmodule.displayName].query.pop(), newmodule.displayName, newmodule); } } }}); } }; InternalBDFDB.patchExportedContextMenuLib = function (menu, type, shouldCloseOnPatch) { let module = BDFDB.ModuleUtils.find(m => m == menu.type, false); if (module && module.exports && module.exports.default) { if (!LibraryComponents.ContextMenus[type]) { LibraryComponents.ContextMenus[type] = module.exports.default; BDFDB.LibraryComponents.ContextMenus[type] = module.exports.default; } if (!LibraryComponents.ContextMenus._Exports[type]) { LibraryComponents.ContextMenus._Exports[type] = module.exports; BDFDB.LibraryComponents.ContextMenus._Exports[type] = module.exports; } if (BDFDB.InternalData.componentPatchQueries[type] && !BDFDB.InternalData.componentPatchQueries[type].module) { BDFDB.InternalData.componentPatchQueries[type].module = module; while (BDFDB.InternalData.componentPatchQueries[type].query.length) InternalBDFDB.patchExportedContextMenuPlugin(BDFDB.InternalData.componentPatchQueries[type].query.pop(), type, module); let close = shouldCloseOnPatch && BDFDB.ReactUtils.getValue(menu, "memoizedProps.onClose"); if (typeof close == "function") close(); } if (!module.exports.default.displayName) module.exports.default.displayName = type; } }; InternalBDFDB.getContextMenuType = function (menutype, component) { if (menutype) { if (menutype == "MessageContextMenu" && component && component.type != LibraryComponents.ContextMenus.MessageContextMenu) return "MessageOptionContextMenu"; else if (menutype.endsWith("ContextMenu")) return menutype; else if (LibraryComponents.ContextMenus._Types.includes(menutype)) { if (menutype.indexOf("USER_") == 0) return "UserContextMenu"; else if (menutype.indexOf("CHANNEL_") == 0) return "ChannelContextMenu"; else if (menutype.indexOf("GUILD_") == 0) return "GuildContextMenu"; } } return null; }; BDFDB.DiscordConstants = BDFDB.ModuleUtils.findByProperties("Permissions", "ActivityTypes"); var DiscordObjects = {}; DiscordObjects.Channel = BDFDB.ModuleUtils.findByPrototypes("getRecipientId", "isManaged", "getGuildId"); DiscordObjects.Guild = BDFDB.ModuleUtils.findByPrototypes("getIconURL", "getMaxEmojiSlots", "getRole"); DiscordObjects.Invite = BDFDB.ModuleUtils.findByPrototypes("getExpiresAt", "isExpired"); DiscordObjects.Message = BDFDB.ModuleUtils.findByPrototypes("getReaction", "getAuthorName", "getChannelId"); DiscordObjects.Messages = BDFDB.ModuleUtils.findByPrototypes("jumpToMessage", "hasAfterCached", "forEach"); DiscordObjects.Timestamp = BDFDB.ModuleUtils.findByPrototypes("add", "dayOfYear", "hasAlignedHourOffset"); DiscordObjects.User = BDFDB.ModuleUtils.findByPrototypes("hasFlag", "isLocalBot", "isClaimed"); BDFDB.DiscordObjects = Object.assign({}, DiscordObjects); 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.ModuleUtils.findByProperties("localAck", "bulkAck"); LibraryModules.APIUtils = BDFDB.ModuleUtils.findByProperties("getAPIBaseURL"); LibraryModules.AnalyticsUtils = BDFDB.ModuleUtils.findByProperties("isThrottled", "track"); LibraryModules.AnimationUtils = BDFDB.ModuleUtils.findByProperties("spring", "decay"); LibraryModules.BadgeUtils = BDFDB.ModuleUtils.findByProperties("getBadgeCountString", "getBadgeWidthForValue"); LibraryModules.CategoryCollapseStore = BDFDB.ModuleUtils.findByProperties("getCollapsedCategories", "isCollapsed"); LibraryModules.CategoryCollapseUtils = BDFDB.ModuleUtils.findByProperties("categoryCollapse", "categoryCollapseAll"); LibraryModules.ChannelStore = BDFDB.ModuleUtils.findByProperties("getChannel", "getChannels"); LibraryModules.ColorUtils = BDFDB.ModuleUtils.findByProperties("hex2int", "hex2rgb"); LibraryModules.ContextMenuUtils = BDFDB.ModuleUtils.findByProperties("closeContextMenu", "openContextMenu"); LibraryModules.CopyLinkUtils = BDFDB.ModuleUtils.findByProperties("SUPPORTS_COPY", "copy"); LibraryModules.CurrentUserStore = BDFDB.ModuleUtils.findByProperties("getCurrentUser"); LibraryModules.CurrentVoiceUtils = BDFDB.ModuleUtils.findByProperties("getAveragePing", "isConnected"); LibraryModules.DirectMessageStore = BDFDB.ModuleUtils.findByProperties("getPrivateChannelIds", "getPrivateChannelTimestamps"); LibraryModules.DirectMessageUnreadStore = BDFDB.ModuleUtils.findByProperties("getUnreadPrivateChannelIds"); LibraryModules.DispatchApiUtils = BDFDB.ModuleUtils.findByProperties("dirtyDispatch", "isDispatching"); LibraryModules.DispatchUtils = BDFDB.ModuleUtils.findByProperties("ComponentDispatch"); LibraryModules.DirectMessageUtils = BDFDB.ModuleUtils.findByProperties("addRecipient", "openPrivateChannel"); LibraryModules.FriendUtils = BDFDB.ModuleUtils.findByProperties("getFriendIDs", "getRelationships"); LibraryModules.FolderStore = BDFDB.ModuleUtils.findByProperties("getGuildFolderById", "getFlattenedGuilds"); LibraryModules.FolderUtils = BDFDB.ModuleUtils.findByProperties("isFolderExpanded", "getExpandedFolders"); LibraryModules.GuildBoostUtils = BDFDB.ModuleUtils.findByProperties("getTierName", "getUserLevel"); LibraryModules.GuildChannelStore = BDFDB.ModuleUtils.findByProperties("getChannels", "getDefaultChannel"); LibraryModules.GuildEmojiStore = BDFDB.ModuleUtils.findByProperties("getGuildEmoji", "getDisambiguatedEmojiContext"); LibraryModules.GuildSettingsUtils = BDFDB.ModuleUtils.findByProperties("updateChannelOverrideSettings", "updateNotificationSettings"); LibraryModules.GuildStore = BDFDB.ModuleUtils.findByProperties("getGuild", "getGuilds"); LibraryModules.GuildUtils = BDFDB.ModuleUtils.findByProperties("transitionToGuildSync"); LibraryModules.HistoryUtils = BDFDB.ModuleUtils.findByProperties("transitionTo", "replaceWith", "getHistory");; LibraryModules.IconUtils = BDFDB.ModuleUtils.findByProperties("getGuildIconURL", "getGuildBannerURL"); LibraryModules.InviteUtils = BDFDB.ModuleUtils.findByProperties("acceptInvite", "createInvite"); LibraryModules.KeyCodeUtils = Object.assign({}, BDFDB.ModuleUtils.findByProperties("toCombo", "keyToCode")); LibraryModules.KeyCodeUtils.getString = function (keyarray) { return LibraryModules.KeyCodeUtils.toString([keyarray].flat(10).filter(n => n).map(keycode => [BDFDB.DiscordConstants.KeyboardDeviceTypes.KEYBOARD_KEY, keycode, BDFDB.DiscordConstants.KeyboardEnvs.BROWSER]), true); }; LibraryModules.KeyEvents = BDFDB.ModuleUtils.findByProperties("aliases", "code", "codes"); LibraryModules.LanguageStore = BDFDB.ModuleUtils.findByProperties("getLanguages", "Messages"); LibraryModules.LastChannelStore = BDFDB.ModuleUtils.findByProperties("getLastSelectedChannelId"); LibraryModules.LastGuildStore = BDFDB.ModuleUtils.findByProperties("getLastSelectedGuildId"); LibraryModules.LoginUtils = BDFDB.ModuleUtils.findByProperties("login", "logout"); LibraryModules.MemberStore = BDFDB.ModuleUtils.findByProperties("getMember", "getMembers"); LibraryModules.MessagePinUtils = BDFDB.ModuleUtils.findByProperties("pinMessage", "unpinMessage"); LibraryModules.MessageStore = BDFDB.ModuleUtils.findByProperties("getMessage", "getMessages"); LibraryModules.MessageUtils = BDFDB.ModuleUtils.findByProperties("receiveMessage", "editMessage"); LibraryModules.ModalUtils = BDFDB.ModuleUtils.findByProperties("openModal", "hasModalOpen"); LibraryModules.MutedUtils = BDFDB.ModuleUtils.findByProperties("isGuildOrCategoryOrChannelMuted"); LibraryModules.NoteStore = BDFDB.ModuleUtils.findByProperties("getNotes", "getNote"); LibraryModules.NotificationSettingsUtils = BDFDB.ModuleUtils.findByProperties("setDesktopType", "setTTSType"); LibraryModules.NotificationSettingsStore = BDFDB.ModuleUtils.findByProperties("getDesktopType", "getTTSType"); LibraryModules.PlatformUtils = BDFDB.ModuleUtils.findByProperties("isWindows", "isLinux"); LibraryModules.PermissionUtils = BDFDB.ModuleUtils.findByProperties("getChannelPermissions", "canUser"); LibraryModules.PermissionRoleUtils = BDFDB.ModuleUtils.findByProperties("getHighestRole", "can"); LibraryModules.QuoteUtils = BDFDB.ModuleUtils.findByProperties("canQuote", "createQuotedText"); LibraryModules.ReactionUtils = BDFDB.ModuleUtils.findByProperties("addReaction", "removeReaction"); LibraryModules.SearchPageUtils = BDFDB.ModuleUtils.findByProperties("searchNextPage", "searchPreviousPage"); LibraryModules.SelectChannelUtils = BDFDB.ModuleUtils.findByProperties("selectChannel", "selectPrivateChannel"); LibraryModules.SettingsUtils = BDFDB.ModuleUtils.findByProperties("updateRemoteSettings", "updateLocalSettings"); LibraryModules.SoundUtils = BDFDB.ModuleUtils.findByProperties("playSound", "createSound"); LibraryModules.SpellCheckUtils = BDFDB.ModuleUtils.findByProperties("learnWord", "toggleSpellcheck"); LibraryModules.SlateUtils = BDFDB.ModuleUtils.findByProperties("serialize", "deserialize"); LibraryModules.SlateSelectionUtils = BDFDB.ModuleUtils.findByProperties("serialize", "serializeSelection"); LibraryModules.StateStoreUtils = BDFDB.ModuleUtils.findByProperties("useStateFromStores", "useStateFromStoresArray"); LibraryModules.StatusMetaUtils = BDFDB.ModuleUtils.findByProperties("getApplicationActivity", "getStatus"); LibraryModules.StoreUtils = BDFDB.ModuleUtils.findByProperties("get", "set", "clear", "remove"); LibraryModules.StreamUtils = BDFDB.ModuleUtils.findByProperties("getStreamForUser", "getActiveStream"); LibraryModules.StringUtils = BDFDB.ModuleUtils.findByProperties("cssValueToNumber", "upperCaseFirstChar"); LibraryModules.UnreadGuildUtils = BDFDB.ModuleUtils.findByProperties("hasUnread", "getUnreadGuilds"); LibraryModules.UnreadChannelUtils = BDFDB.ModuleUtils.findByProperties("getUnreadCount", "getOldestUnreadMessageId"); LibraryModules.UploadUtils = BDFDB.ModuleUtils.findByProperties("upload", "instantBatchUpload"); LibraryModules.UserNameUtils = BDFDB.ModuleUtils.findByProperties("getName", "getNickname"); LibraryModules.UserStore = BDFDB.ModuleUtils.findByProperties("getUser", "getUsers"); LibraryModules.Utilities = BDFDB.ModuleUtils.findByProperties("flatMap", "cloneDeep"); LibraryModules.VoiceUtils = BDFDB.ModuleUtils.findByProperties("getAllVoiceStates", "getVoiceStatesForChannel"); LibraryModules.ZoomUtils = BDFDB.ModuleUtils.findByProperties("setZoom", "setFontSize"); BDFDB.LibraryModules = Object.assign({}, LibraryModules); LibraryModules.React = BDFDB.ModuleUtils.findByProperties("createElement", "cloneElement"); LibraryModules.ReactDOM = BDFDB.ModuleUtils.findByProperties("render", "findDOMNode"); BDFDB.ReactUtils = Object.assign({}, LibraryModules.React, LibraryModules.ReactDOM); BDFDB.ReactUtils.childrenToArray = function (parent) { if (parent && parent.props && parent.props.children && !BDFDB.ArrayUtils.is(parent.props.children)) { var child = parent.props.children; parent.props.children = []; parent.props.children.push(child); } return parent.props.children; } BDFDB.ReactUtils.createElement = function (component, props) { if (component && component.defaultProps) for (let key in component.defaultProps) if (props[key] == null) props[key] = component.defaultProps[key]; try {return LibraryModules.React.createElement(component || "div", props || {}) || null;} catch (err) {BDFDB.LogUtils.error("Fatal Error: Could not create react element! " + err);} return null; }; BDFDB.ReactUtils.elementToReact = function (node) { if (BDFDB.ReactUtils.isValidElement(node)) return node; else if (!Node.prototype.isPrototypeOf(node)) return null; else if (node.nodeType == Node.TEXT_NODE) return node.nodeValue; let attributes = {}, importantstyleprops = {}; for (let attr of node.attributes) attributes[attr.name] = attr.value; if (node.attributes.style) attributes.style = BDFDB.ObjectUtils.filter(node.style, n => node.style[n] && isNaN(parseInt(n)), true); attributes.children = []; if (node.style && node.style.cssText) for (let propstr of node.style.cssText.split(";")) if (propstr.endsWith("!important")) { let importantprop = propstr.split(":")[0]; let camelprop = importantprop.replace(/-([a-z]?)/g, (m, g) => g.toUpperCase()); if (attributes.style[camelprop] != null) importantstyleprops[importantprop] = attributes.style[camelprop]; } if (Object.keys(importantstyleprops).length) attributes.ref = instance => { let ele = BDFDB.ReactUtils.findDOMNode(instance); if (ele) for (let importantprop in importantstyleprops) ele.style.setProperty(importantprop, importantstyleprops[importantprop], "important"); } for (let child of node.childNodes) attributes.children.push(BDFDB.ReactUtils.elementToReact(child)); return BDFDB.ReactUtils.createElement(node.tagName, attributes); }; BDFDB.ReactUtils.findChildren = function (nodeOrInstance, config) { if (!nodeOrInstance || !BDFDB.ObjectUtils.is(config) || !config.name && !config.key && !config.props && !config.filter) return [null, -1]; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance) && !BDFDB.ArrayUtils.is(instance)) return [null, -1]; config.name = config.name && [config.name].flat().filter(n => n); config.key = config.key && [config.key].flat().filter(n => n); config.props = config.props && [config.props].flat().filter(n => n); config.filter = typeof config.filter == "function" && config.filter; var parent = firstarray = instance; while (!BDFDB.ArrayUtils.is(firstarray) && firstarray.props && firstarray.props.children) firstarray = firstarray.props.children; if (!BDFDB.ArrayUtils.is(firstarray)) { if (parent && parent.props) { parent.props.children = [parent.props.children]; firstarray = parent.props.children; } else firstarray = []; } return getChildren(instance); function getChildren (children) { var result = [firstarray, -1]; if (!children) return result; if (!BDFDB.ArrayUtils.is(children)) { if (check(children)) result = found(children); else if (children.props && children.props.children) { parent = children; result = getChildren(children.props.children); } } else { for (let i = 0; result[1] == -1 && i < children.length; i++) if (children[i]) { if (BDFDB.ArrayUtils.is(children[i])) { parent = children; result = getChildren(children[i]); } else if (check(children[i])) { parent = children; result = found(children[i]); } else if (children[i].props && children[i].props.children) { parent = children[i]; result = getChildren(children[i].props.children); } } } return result; } function found (child) { if (BDFDB.ArrayUtils.is(parent)) return [parent, parent.indexOf(child)]; else { parent.props.children = []; parent.props.children.push(child); return [parent.props.children, 0]; } } function check (instance) { if (!instance) return false; let props = instance.stateNode ? instance.stateNode.props : instance.props; return instance.type && config.name && config.name.some(name => InternalBDFDB.isInstanceCorrect(instance, name)) || config.key && config.key.some(key => instance.key == key) || props && config.props && config.props.every(prop => BDFDB.ArrayUtils.is(prop) ? (BDFDB.ArrayUtils.is(prop[1]) ? prop[1].some(checkvalue => propCheck(props, prop[0], checkvalue)) : propCheck(props, prop[0], prop[1])) : props[prop] !== undefined) || config.filter && config.filter(instance); } function propCheck (props, key, value) { return key != null && props[key] != null && value != null && (key == "className" ? (" " + props[key] + " ").indexOf(" " + value + " ") > -1 : BDFDB.equals(props[key], value)); } }; BDFDB.ReactUtils.findConstructor = function (nodeOrInstance, types, config = {}) { if (!BDFDB.ObjectUtils.is(config)) return null; if (!nodeOrInstance || !types) return config.all ? (config.group ? {} : []) : null; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance)) return config.all ? (config.group ? {} : []) : null; types = types && [types].flat(10).filter(n => typeof n == "string"); if (!types.length) return config.all ? (config.group ? {} : []) : null;; var depth = -1; var start = performance.now(); var maxdepth = config.unlimited ? 999999999 : (config.depth === undefined ? 30 : config.depth); var maxtime = config.unlimited ? 999999999 : (config.time === undefined ? 150 : config.time); var whitelist = config.up ? {return:true, sibling:true, default:true, _reactInternalFiber:true} : {child:true, sibling:true, default:true, _reactInternalFiber:true}; var foundconstructors = config.group ? {} : []; var singleconstructor = getConstructor(instance); if (config.all) { for (let i in foundconstructors) { if (config.group) for (let j in foundconstructors[i]) delete foundconstructors[i][j].BDFDBreactSearch; else delete foundconstructors[i].BDFDBreactSearch; } return foundconstructors; } else return singleconstructor; function getConstructor (instance) { depth++; var result = undefined; if (instance && !Node.prototype.isPrototypeOf(instance) && !BDFDB.ReactUtils.getInstance(instance) && depth < maxdepth && performance.now() - start < maxtime) { if (instance.type && types.some(name => (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name) === name.split(" _ _ ")[0])) { if (config.all === undefined || !config.all) result = instance.type; else if (config.all) { if (!instance.type.BDFDBreactSearch) { instance.type.BDFDBreactSearch = true; if (config.group) { if (instance.type && (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name)) { let group = config.name.find(n => (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name || instance.type).split(" _ _ ")[0] == n) || "Default"; if (!BDFDB.ArrayUtils.is(foundinstances[group])) foundinstances[group] = []; foundinstances[group].push(instance.stateNode); } } else foundinstances.push(instance.type); } } } if (result === undefined) { let keys = Object.getOwnPropertyNames(instance); for (let i = 0; result === undefined && i < keys.length; i++) { let key = keys[i]; if (key && whitelist[key] && (typeof instance[key] === "object" || typeof instance[key] === "function")) result = getConstructor(instance[key]); } } } depth--; return result; } }; BDFDB.ReactUtils.findDOMNode = 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.ReactUtils.getValue(instance, "child.stateNode"); return Node.prototype.isPrototypeOf(node) ? node : null; }; BDFDB.ReactUtils.findOwner = function (nodeOrInstance, config) { if (!BDFDB.ObjectUtils.is(config)) return null; if (!nodeOrInstance || !config.name && !config.key && !config.props) return config.all ? (config.group ? {} : []) : null; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance)) return config.all ? (config.group ? {} : []) : null; config.name = config.name && [config.name].flat().filter(n => n); config.key = config.key && [config.key].flat().filter(n => n); config.props = config.props && [config.props].flat().filter(n => n); var depth = -1; var start = performance.now(); var maxdepth = config.unlimited ? 999999999 : (config.depth === undefined ? 30 : config.depth); var maxtime = config.unlimited ? 999999999 : (config.time === undefined ? 150 : config.time); var whitelist = config.up ? {return:true, sibling:true, _reactInternalFiber:true} : {child:true, sibling:true, _reactInternalFiber:true}; var foundinstances = config.group ? {} : []; var singleinstance = getOwner(instance); if (config.all) { for (let i in foundinstances) { if (config.group) for (let j in foundinstances[i]) delete foundinstances[i][j].BDFDBreactSearch; else delete foundinstances[i].BDFDBreactSearch; } return foundinstances; } else return singleinstance; function getOwner (instance) { depth++; var result = undefined; if (instance && !Node.prototype.isPrototypeOf(instance) && !BDFDB.ReactUtils.getInstance(instance) && depth < maxdepth && performance.now() - start < maxtime) { let props = instance.stateNode ? instance.stateNode.props : instance.props; if (instance.stateNode && !Node.prototype.isPrototypeOf(instance.stateNode) && (instance.type && config.name && config.name.some(name => InternalBDFDB.isInstanceCorrect(instance, name.split(" _ _ ")[0])) || config.key && config.key.some(key => instance.key == key) || props && config.props && config.props.every(prop => BDFDB.ArrayUtils.is(prop) ? (BDFDB.ArrayUtils.is(prop[1]) ? prop[1].some(checkvalue => BDFDB.equals(props[prop[0]], checkvalue)) : BDFDB.equals(props[prop[0]], prop[1])) : props[prop] !== undefined))) { if (config.all === undefined || !config.all) result = instance.stateNode; else if (config.all) { if (!instance.stateNode.BDFDBreactSearch) { instance.stateNode.BDFDBreactSearch = true; if (config.group) { if (config.name && instance.type && (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name || instance.type)) { let group = config.name.find(n => (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name || instance.type).split(" _ _ ")[0] == n) || "Default"; if (!BDFDB.ArrayUtils.is(foundinstances[group])) foundinstances[group] = []; foundinstances[group].push(instance.stateNode); } } else foundinstances.push(instance.stateNode); } } } if (result === undefined) { let keys = Object.getOwnPropertyNames(instance); for (let i = 0; result === undefined && i < keys.length; i++) { let key = keys[i]; if (key && whitelist[key] && (typeof instance[key] === "object" || typeof instance[key] === "function")) result = getOwner(instance[key]); } } } depth--; return result; } }; BDFDB.ReactUtils.findProps = function (nodeOrInstance, config) { if (!BDFDB.ObjectUtils.is(config)) return null; if (!nodeOrInstance || !config.name && !config.key) return null; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance)) return null; config.name = config.name && [config.name].flat().filter(n => n); config.key = config.key && [config.key].flat().filter(n => n); var depth = -1; var start = performance.now(); var maxdepth = config.unlimited ? 999999999 : (config.depth === undefined ? 30 : config.depth); var maxtime = config.unlimited ? 999999999 : (config.time === undefined ? 150 : config.time); var whitelist = config.up ? {return:true, sibling:true, _reactInternalFiber:true} : {child:true, sibling:true, _reactInternalFiber:true}; return findProps(instance); function findProps (instance) { depth++; var result = undefined; if (instance && !Node.prototype.isPrototypeOf(instance) && !BDFDB.ReactUtils.getInstance(instance) && depth < maxdepth && performance.now() - start < maxtime) { if (instance.memoizedProps && (instance.type && config.name && config.name.some(name => (instance.type.render && instance.type.render.displayName || instance.type.displayName || instance.type.name || instance.type) === name.split(" _ _ ")[0]) || config.key && config.key.some(key => instance.key == key))) result = instance.memoizedProps; if (result === undefined) { let keys = Object.getOwnPropertyNames(instance); for (let i = 0; result === undefined && i < keys.length; i++) { let key = keys[i]; if (key && whitelist[key] && (typeof instance[key] === "object" || typeof instance[key] === "function")) result = findProps(instance[key]); } } } depth--; return result; } }; BDFDB.ReactUtils.findValue = function (nodeOrInstance, searchkey, config = {}) { if (!BDFDB.ObjectUtils.is(config)) return null; if (!nodeOrInstance || typeof searchkey != "string") return config.all ? [] : null; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance)) return config.all ? [] : null; instance = instance._reactInternalFiber || instance; var depth = -1; var start = performance.now(); var maxdepth = config.unlimited ? 999999999 : (config.depth === undefined ? 30 : config.depth); var maxtime = config.unlimited ? 999999999 : (config.time === undefined ? 150 : config.time); var whitelist = { props: true, state: true, stateNode: true, updater: true, prototype: true, type: true, children: config.up ? false : true, memoizedProps: true, memoizedState: true, child: config.up ? false : true, return: config.up ? true : false, sibling: config.up ? false : true }; var blacklist = { contextSection: true }; if (BDFDB.ObjectUtils.is(config.whitelist)) Object.assign(whitelist, config.whiteList); if (BDFDB.ObjectUtils.is(config.blacklist)) Object.assign(blacklist, config.blacklist); var foundkeys = []; var singlekey = getKey(instance); if (config.all) return foundkeys; else return singlekey; function getKey(instance) { depth++; var result = undefined; if (instance && !Node.prototype.isPrototypeOf(instance) && !BDFDB.ReactUtils.getInstance(instance) && depth < maxdepth && performance.now() - start < maxtime) { let keys = Object.getOwnPropertyNames(instance); for (let i = 0; result === undefined && i < keys.length; i++) { let key = keys[i]; if (key && !blacklist[key]) { var value = instance[key]; if (searchkey === key && (config.value === undefined || BDFDB.equals(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; } }; BDFDB.ReactUtils.forceUpdate = function (...instances) { for (let ins of instances.flat(10).filter(n => n)) if (ins.updater && typeof ins.updater.isMounted == "function" && ins.updater.isMounted(ins)) ins.forceUpdate(); }; BDFDB.ReactUtils.getInstance = function (node) { if (!BDFDB.ObjectUtils.is(node)) return null; return node[Object.keys(node).find(key => key.startsWith("__reactInternalInstance"))]; }; BDFDB.ReactUtils.getValue = function (nodeOrInstance, valuepath) { if (!nodeOrInstance || !valuepath) return null; var instance = Node.prototype.isPrototypeOf(nodeOrInstance) ? BDFDB.ReactUtils.getInstance(nodeOrInstance) : nodeOrInstance; if (!BDFDB.ObjectUtils.is(instance)) return null; var found = instance, values = valuepath.split(".").filter(n => n); for (value of values) { if (!found) return null; found = found[value]; } return found; }; BDFDB.ReactUtils.render = function (component, node) { if (!BDFDB.ReactUtils.isValidElement(component) || !Node.prototype.isPrototypeOf(node)) return; try { LibraryModules.ReactDOM.render(component, node); let observer = new MutationObserver(changes => changes.forEach(change => { let nodes = Array.from(change.removedNodes); if (nodes.indexOf(node) > -1 || nodes.some(n => n.contains(node))) { observer.disconnect(); BDFDB.ReactUtils.unmountComponentAtNode(node); } })); observer.observe(document.body, {subtree:true, childList:true}); } catch (err) {BDFDB.LogUtils.error("Fatal Error: Could not render react element! " + err);} }; InternalBDFDB.setDefaultProps = function (component, defaultProps) { if (BDFDB.ObjectUtils.is(component)) component.defaultProps = Object.assign({}, component.defaultProps, defaultProps); }; 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.MessageUtils = {}; BDFDB.MessageUtils.rerenderAll = function () { let MessagesIns = BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.app), {name:"Messages", unlimited:true}); let MessagesPrototype = BDFDB.ReactUtils.getValue(MessagesIns, "_reactInternalFiber.type.prototype"); if (MessagesIns && MessagesPrototype) { let patchCancel = BDFDB.ModuleUtils.patch({name:"tempPatch"}, MessagesPrototype, "render", {after:e => { patchCancel(); let [children, index] = BDFDB.ReactUtils.findChildren(e.returnValue, {props: ["message", "channel"]}); if (index > -1) { for (let i in children) children[i].props.message = new BDFDB.DiscordObjects.Message({author: new BDFDB.DiscordObjects.User({})}); BDFDB.ReactUtils.forceUpdate(e.thisObject); } }}); BDFDB.ReactUtils.forceUpdate(MessagesIns); } }; BDFDB.UserUtils = {}; var myDataUser = LibraryModules.CurrentUserStore ? LibraryModules.CurrentUserStore.getCurrentUser() : null; BDFDB.UserUtils.is = function (user) { return user && user instanceof BDFDB.DiscordObjects.User; }; BDFDB.UserUtils.me = new Proxy(myDataUser || {}, { get: function (list, item) { if (!myDataUser) myDataUser = LibraryModules.CurrentUserStore.getCurrentUser(); return myDataUser ? myDataUser[item] : null; } }); BDFDB.UserUtils.getStatus = function (id = BDFDB.UserUtils.me.id) { id = typeof id == "number" ? id.toFixed() : id; let activity = BDFDB.UserUtils.getActivitiy(id); return activity && activity.type == BDFDB.DiscordConstants.ActivityTypes.STREAMING ? "streaming" : LibraryModules.StatusMetaUtils.getStatus(id); }; BDFDB.UserUtils.getStatusColor = function (status) { status = typeof status == "string" ? status.toLowerCase() : null; switch (status) { case "online": return BDFDB.DiscordConstants.Colors.STATUS_GREEN; case "mobile": return BDFDB.DiscordConstants.Colors.STATUS_GREEN; case "idle": return BDFDB.DiscordConstants.Colors.STATUS_YELLOW; case "dnd": return BDFDB.DiscordConstants.Colors.STATUS_RED; case "playing": return BDFDB.DiscordConstants.Colors.BRAND; case "listening": return BDFDB.DiscordConstants.Colors.SPOTIFY; case "streaming": return BDFDB.DiscordConstants.Colors.TWITCH; default: return BDFDB.DiscordConstants.Colors.STATUS_GREY; } }; BDFDB.UserUtils.getActivitiy = function (id = BDFDB.UserUtils.me.id) { for (let activity of LibraryModules.StatusMetaUtils.getActivities(id)) if (activity.type != BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS) return activity; return null; }; BDFDB.UserUtils.getAvatar = function (id = BDFDB.UserUtils.me.id) { var user = LibraryModules.UserStore.getUser(typeof id == "number" ? id.toFixed() : id); if (!user) return window.location.origin + "/assets/322c936a8c8be1b803cd94861bdfa868.png"; else return ((user.avatar ? "" : window.location.origin) + LibraryModules.IconUtils.getUserAvatarURL(user)).split("?")[0]; }; BDFDB.UserUtils.can = function (permission, id = BDFDB.UserUtils.me.id, channelid = LibraryModules.LastChannelStore.getChannelId()) { if (!BDFDB.DiscordConstants.Permissions[permission]) BDFDB.LogUtils.warn(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.GuildUtils = {}; BDFDB.GuildUtils.is = function (guild) { return guild && guild instanceof BDFDB.DiscordObjects.Guild; }; BDFDB.GuildUtils.getIcon = 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.GuildUtils.getBanner = 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.GuildUtils.getFolder = function (id) { return BDFDB.LibraryModules.FolderStore.guildFolders.filter(n => n.folderId).find(n => n.guildIds.includes(id)); }; BDFDB.GuildUtils.getId = function (div) { if (!Node.prototype.isPrototypeOf(div) || !BDFDB.ReactUtils.getInstance(div)) return; let guilddiv = BDFDB.DOMUtils.getParent(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.GuildUtils.getData = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.GuildUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; for (let info of BDFDB.GuildUtils.getAll()) if (info && info.id == id) return info; return null; }; BDFDB.GuildUtils.getAll = function () { var found = [], objs = []; for (let ins of BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.guilds), {name:["Guild","GuildIcon"], all:true, unlimited:true})) { if (ins.props && ins.props.guild) objs.push(Object.assign(new ins.props.guild.constructor(ins.props.guild), {div:ins.handleContextMenu && BDFDB.ReactUtils.findDOMNode(ins), instance:ins})); } for (let id of BDFDB.LibraryModules.FolderStore.getFlattenedGuildIds()) { let foundobj = null; for (let obj of objs) if (obj.id == id) { foundobj = obj break; } if (foundobj) found.push(foundobj); else { let guild = BDFDB.LibraryModules.GuildStore.getGuild(id); found.push(Object.assign(new guild.constructor(guild), {div:null, instance:null})) } } return found; }; BDFDB.GuildUtils.getUnread = function (servers) { var found = []; for (let eleOrInfoOrId of servers === undefined || !BDFDB.ArrayUtils.is(servers) ? BDFDB.GuildUtils.getAll() : servers) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.GuildUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; if (id && (LibraryModules.UnreadGuildUtils.hasUnread(id) || LibraryModules.UnreadGuildUtils.getMentionCount(id) > 0)) found.push(eleOrInfoOrId); } return found; }; BDFDB.GuildUtils.getPinged = function (servers) { var found = []; for (let eleOrInfoOrId of servers === undefined || !BDFDB.ArrayUtils.is(servers) ? BDFDB.GuildUtils.getAll() : servers) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.GuildUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; if (id && LibraryModules.UnreadGuildUtils.getMentionCount(id) > 0) found.push(eleOrInfoOrId); } return found; }; BDFDB.GuildUtils.getMuted = function (servers) { var found = []; for (let eleOrInfoOrId of servers === undefined || !BDFDB.ArrayUtils.is(servers) ? BDFDB.GuildUtils.getAll() : servers) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.GuildUtils.getId(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.GuildUtils.getSelected = function () { var info = LibraryModules.GuildStore.getGuild(LibraryModules.LastGuildStore.getGuildId()); if (info) return BDFDB.GuildUtils.getData(info.id) || Object.assign(new info.constructor(info), {div:null, instance:null}); else return null; }; BDFDB.GuildUtils.openMenu = function (eleOrInfoOrId, e = BDFDB.InternalData.mousePosition) { if (!eleOrInfoOrId) return; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.GuildUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); let guild = LibraryModules.GuildStore.getGuild(id); if (guild) LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) { return BDFDB.ReactUtils.createElement(LibraryComponents.ContextMenus._Exports.GuildContextMenu && LibraryComponents.ContextMenus._Exports.GuildContextMenu.default, Object.assign({}, e, { type: BDFDB.DiscordConstants.ContextMenuTypes.GUILD_ICON_BAR, guild: guild, badge: LibraryModules.UnreadGuildUtils.getMentionCount(guild.id), link: BDFDB.DiscordConstants.Routes.CHANNEL(guild.id, LibraryModules.LastChannelStore.getChannelId(guild.id)), selected: guild.id == LibraryModules.LastGuildStore.getGuildId() })); }); }; BDFDB.GuildUtils.markAsRead = function (guilds) { if (!guilds) return; var unreadchannels = []; for (let guild of BDFDB.ArrayUtils.is(guilds) ? guilds : (typeof guilds == "string" || typeof guilds == "number" ? Array.of(guilds) : Array.from(guilds))) { let id = Node.prototype.isPrototypeOf(guild) ? BDFDB.GuildUtils.getId(guild) : (guild && typeof guild == "object" ? guild.id : guild); let channels = id && LibraryModules.GuildChannelStore.getChannels(id); if (channels) for (let type in channels) if (BDFDB.ArrayUtils.is(channels[type])) for (let channelobj of channels[type]) unreadchannels.push(channelobj.channel.id); } if (unreadchannels.length) LibraryModules.AckUtils.bulkAck(unreadchannels); }; BDFDB.FolderUtils = {}; BDFDB.FolderUtils.getId = function (div) { if (!Node.prototype.isPrototypeOf(div) || !BDFDB.ReactUtils.getInstance(div)) return; div = BDFDB.DOMUtils.getParent(BDFDB.dotCN.guildfolderwrapper, div); if (!div) return; return BDFDB.ReactUtils.findValue(div, "folderId", {up:true}); }; BDFDB.FolderUtils.getDefaultName = function (folderId) { let folder = BDFDB.LibraryModules.FolderStore.getGuildFolderById(folderId); if (!folder) return ""; let rest = 2 * BDFDB.DiscordConstants.MAX_GUILD_FOLDER_NAME_LENGTH; let names = [], allNames = folder.guildIds.map(guildId => (BDFDB.LibraryModules.GuildStore.getGuild(guildId) || {}).name).filter(n => n); for (let name of allNames) if (name.length < rest || names.length === 0) { names.push(name); rest -= name.length; } return names.join(", ") + (names.length < allNames.length ? ", ..." : ""); }; BDFDB.FolderUtils.getDiv = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let info = BDFDB.FolderUtils.getData(eleOrInfoOrId); return info ? info.div : null; }; BDFDB.FolderUtils.getData = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.FolderUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; for (let info of BDFDB.FolderUtils.getAll()) if (info && info.folderId == id) return info; return null; }; BDFDB.FolderUtils.getAll = function () { var found = []; for (let ins of BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.guildswrapper), {name:"GuildFolder", all:true, unlimited:true})) { if (ins.props && ins.props.folderId) found.push(Object.assign({}, ins.props, {div:BDFDB.ReactUtils.findDOMNode(ins), instance:ins})); } return found; }; BDFDB.ChannelUtils = {}; BDFDB.ChannelUtils.is = function (channel) { return channel && channel instanceof BDFDB.DiscordObjects.Channel; }; BDFDB.ChannelUtils.isTextChannel = function (channelOrId) { let channel = typeof channelOrId == "string" ? LibraryModules.ChannelStore.getChannel(channelOrId) : channelOrId; return BDFDB.ObjectUtils.is(channel) && (channel.type == BDFDB.DiscordConstants.ChannelTypes.GUILD_TEXT || channel.type == BDFDB.DiscordConstants.ChannelTypes.GUILD_STORE || channel.type == BDFDB.DiscordConstants.ChannelTypes.GUILD_ANNOUNCEMENT); }; BDFDB.ChannelUtils.getId = function (div) { if (!Node.prototype.isPrototypeOf(div) || !BDFDB.ReactUtils.getInstance(div)) return; div = BDFDB.DOMUtils.getParent(BDFDB.dotCNC.categorycontainerdefault + BDFDB.dotCNC.channelcontainerdefault + BDFDB.dotCN.dmchannel, div); if (!div) return; var info = BDFDB.ReactUtils.findValue(div, "channel"); return info ? info.id.toString() : null; }; BDFDB.ChannelUtils.getDiv = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let info = BDFDB.ChannelUtils.getData(eleOrInfoOrId); return info ? info.div : null; }; BDFDB.ChannelUtils.getData = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.ChannelUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; for (let info of BDFDB.ChannelUtils.getAll()) if (info && info.id == id) return info; return null; }; BDFDB.ChannelUtils.getAll = function () { var found = []; for (let ins of BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.channels), {name: ["ChannelCategoryItem", "ChannelItem", "PrivateChannel"], all:true, unlimited:true})) if (ins.props && !ins.props.ispin && ins.props.channel && ins._reactInternalFiber.return) { var div = BDFDB.ReactUtils.findDOMNode(ins); div = div && BDFDB.DOMUtils.containsClass(div.parentElement, BDFDB.disCN.categorycontainerdefault, BDFDB.disCN.channelcontainerdefault, false) ? div.parentElement : div; found.push(Object.assign(new ins.props.channel.constructor(ins.props.channel), {div, instance:ins})); } return found; }; BDFDB.ChannelUtils.getSelected = function () { var info = LibraryModules.ChannelStore.getChannel(LibraryModules.LastChannelStore.getChannelId()); if (info) return BDFDB.ChannelUtils.getData(info.id) || Object.assign(new info.constructor(info), {div:null, instance:null}); else return null; }; BDFDB.ChannelUtils.openMenu = function (eleOrInfoOrId, e = BDFDB.InternalData.mousePosition) { if (!eleOrInfoOrId) return; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.ChannelUtils.getId(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.ReactUtils.createElement(LibraryComponents.ContextMenus._Exports.ChannelContextMenu && LibraryComponents.ContextMenus._Exports.ChannelContextMenu.default, Object.assign({}, e, { type: type, channel: channel, guild: LibraryModules.GuildStore.getGuild(channel.guild_id), selected: channel.id == LibraryModules.LastChannelStore.getChannelId() })); }); } }; BDFDB.ChannelUtils.markAsRead = function (channels) { if (!channels) return; var unreadchannels = []; for (let channel of channels = BDFDB.ArrayUtils.is(channels) ? channels : (typeof channels == "string" || typeof channels == "number" ? Array.of(channels) : Array.from(channels))) { let id = Node.prototype.isPrototypeOf(channel) ? BDFDB.ChannelUtils.getId(channel) : (channel && typeof channel == "object" ? channel.id : channel); if (id) unreadchannels.push(id); } if (unreadchannels.length) LibraryModules.AckUtils.bulkAck(unreadchannels); }; BDFDB.DMUtils = {}; BDFDB.DMUtils.isDMChannel = function (channelOrId) { let channel = typeof channelOrId == "string" ? LibraryModules.ChannelStore.getChannel(channelOrId) : channelOrId; return BDFDB.ObjectUtils.is(channel) && (channel.type == BDFDB.DiscordConstants.ChannelTypes.DM || channel.type == BDFDB.DiscordConstants.ChannelTypes.GROUP_DM); }; BDFDB.DMUtils.getIcon = 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.UserUtils.getAvatar(channel.recipients[0]) : (channel.type == 3 ? window.location.origin + LibraryModules.IconUtils.getChannelIconURL(channel).split("?")[0] : null); return LibraryModules.IconUtils.getChannelIconURL(channel).split("?")[0]; }; BDFDB.DMUtils.getId = function (div) { if (!Node.prototype.isPrototypeOf(div) || !BDFDB.ReactUtils.getInstance(div)) return; let dmdiv = BDFDB.DOMUtils.getParent(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.DMUtils.getDiv = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; if (Node.prototype.isPrototypeOf(eleOrInfoOrId)) { var div = BDFDB.DOMUtils.getParent(BDFDB.dotCN.guildouter, eleOrInfoOrId); return div ? div.parentElement : div; } else { let id = typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId; if (id) { var div = BDFDB.DOMUtils.getParent(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.DMUtils.getData = function (eleOrInfoOrId) { if (!eleOrInfoOrId) return null; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.BDFDB.DMUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); id = typeof id == "number" ? id.toFixed() : id; for (let info of BDFDB.DMUtils.getAll()) if (info && info.id == id) return info; return null; }; BDFDB.DMUtils.getAll = function () { var found = []; for (let ins of BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.guilds), {name:"DirectMessage", all:true, unlimited:true})) { if (ins.props && ins.props.channel) found.push(Object.assign(new ins.props.channel.constructor(ins.props.channel), {div:BDFDB.ReactUtils.findDOMNode(ins), instance:ins})); } return found; }; BDFDB.DMUtils.openMenu = function (eleOrInfoOrId, e = BDFDB.InternalData.mousePosition) { if (!eleOrInfoOrId) return; let id = Node.prototype.isPrototypeOf(eleOrInfoOrId) ? BDFDB.ChannelUtils.getId(eleOrInfoOrId) : (typeof eleOrInfoOrId == "object" ? eleOrInfoOrId.id : eleOrInfoOrId); let channel = LibraryModules.ChannelStore.getChannel(id); if (channel) { if (channel.isMultiUserDM()) LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) { return BDFDB.ReactUtils.createElement(LibraryComponents.ContextMenus.GroupDMContextMenu, Object.assign({}, e, { channelId: channel.id, selected: channel.id == LibraryModules.LastChannelStore.getChannelId() })); }, {noBlurEvent: true}); else LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) { return BDFDB.ReactUtils.createElement(LibraryComponents.ContextMenus._Exports.UserContextMenu && LibraryComponents.ContextMenus._Exports.UserContextMenu.default, Object.assign({}, e, { type: BDFDB.DiscordConstants.ContextMenuTypes.USER_PRIVATE_CHANNELS, user: LibraryModules.UserStore.getUser(channel.recipients[0]), channelId: channel.id, selected: channel.id == LibraryModules.LastChannelStore.getChannelId() })); }); } }; BDFDB.DMUtils.markAsRead = function (dms) { if (!dms) return; var unreadchannels = []; for (let dm of dms = BDFDB.ArrayUtils.is(dms) ? dms : (typeof dms == "string" || typeof dms == "number" ? Array.of(dms) : Array.from(dms))) { let id = Node.prototype.isPrototypeOf(dm) ? BDFDB.BDFDB.DMUtils.getId(dm) : (dm && typeof dm == "object" ? dm.id : dm); if (id) unreadchannels.push(id); } for (let i in unreadchannels) BDFDB.TimeUtils.timeout(_ => {LibraryModules.AckUtils.ack(unreadchannels[i]);}, i * 1000); }; BDFDB.DataUtils = {}; BDFDB.DataUtils.cached = window.BDFDB && window.BDFDB.DataUtils && window.BDFDB.DataUtils.cached || {}; BDFDB.DataUtils.save = function (data, plugin, key, id) { let configPath, pluginName; if (!BDFDB.BDUtils.isBDv2()) { pluginName = typeof plugin === "string" ? plugin : plugin.name; configPath = LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), pluginName + ".config.json"); } else { pluginName = typeof plugin === "string" ? plugin.toLowerCase() : null; let contentpath = pluginName ? BDFDB.Plugins[pluginName] ? BDFDB.Plugins[pluginName].contentPath : null : plugin.contentPath; if (!contentpath) return; configPath = LibraryRequires.path.join(contentpath, "settings.json"); } let config = BDFDB.DataUtils.cached[pluginName] !== undefined ? BDFDB.DataUtils.cached[pluginName] : (InternalBDFDB.readConfig(configPath) || {}); if (key === undefined) config = BDFDB.ObjectUtils.is(data) ? BDFDB.ObjectUtils.sort(data) : data; else { if (id === undefined) config[key] = BDFDB.ObjectUtils.is(data) ? BDFDB.ObjectUtils.sort(data) : data; else { if (!BDFDB.ObjectUtils.is(config[key])) config[key] = {}; config[key][id] = BDFDB.ObjectUtils.is(data) ? BDFDB.ObjectUtils.sort(data) : data; } } let configIsObject = BDFDB.ObjectUtils.is(config); if (key !== undefined && configIsObject && BDFDB.ObjectUtils.is(config[key]) && BDFDB.ObjectUtils.isEmpty(config[key])) delete config[key]; if (BDFDB.ObjectUtils.isEmpty(config)) { delete BDFDB.DataUtils.cached[pluginName]; if (LibraryRequires.fs.existsSync(configPath)) LibraryRequires.fs.unlinkSync(configPath); } else { if (configIsObject) config = BDFDB.ObjectUtils.sort(config); BDFDB.DataUtils.cached[pluginName] = configIsObject ? BDFDB.ObjectUtils.deepAssign({}, config) : config; LibraryRequires.fs.writeFileSync(configPath, JSON.stringify(config, null, " ")); } }; BDFDB.DataUtils.load = function (plugin, key, id) { let configPath, pluginName; if (!BDFDB.BDUtils.isBDv2()) { pluginName = typeof plugin === "string" ? plugin : plugin.name; configPath = LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), pluginName + ".config.json"); } else { pluginName = typeof plugin === "string" ? plugin.toLowerCase() : null; let contentpath = pluginName ? BDFDB.Plugins[pluginName] ? BDFDB.Plugins[pluginName].contentPath : null : plugin.contentPath; if (!contentpath) return {}; configPath = LibraryRequires.path.join(contentpath, "settings.json"); } let config = BDFDB.DataUtils.cached[pluginName] !== undefined ? BDFDB.DataUtils.cached[pluginName] : (InternalBDFDB.readConfig(configPath) || {}); let configIsObject = BDFDB.ObjectUtils.is(config); BDFDB.DataUtils.cached[pluginName] = configIsObject ? BDFDB.ObjectUtils.deepAssign({}, config) : config; if (key === undefined) return config; else { let keydata = configIsObject ? (BDFDB.ObjectUtils.is(config[key]) || config[key] == undefined ? BDFDB.ObjectUtils.deepAssign({}, config[key]) : config[key]) : null; if (id === undefined) return keydata; else return !BDFDB.ObjectUtils.is(keydata) || keydata[id] === undefined ? null : keydata[id]; } }; BDFDB.DataUtils.remove = function (plugin, key, id) { let configPath, pluginName; if (!BDFDB.BDUtils.isBDv2()) { pluginName = typeof plugin === "string" ? plugin : plugin.name; configPath = LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), pluginName + ".config.json"); } else { pluginName = typeof plugin === "string" ? plugin.toLowerCase() : null; let contentpath = pluginName ? BDFDB.Plugins[pluginName] ? BDFDB.Plugins[pluginName].contentPath : null : plugin.contentPath; if (!contentpath) return; configPath = LibraryRequires.path.join(contentpath, "settings.json"); } let config = BDFDB.DataUtils.cached[pluginName] !== undefined ? BDFDB.DataUtils.cached[pluginName] : (InternalBDFDB.readConfig(configPath) || {}); let configIsObject = BDFDB.ObjectUtils.is(config); if (key === undefined || !configIsObject) config = {}; else { if (id === undefined) delete config[key]; else if (BDFDB.ObjectUtils.is(config[key])) delete config[key][id]; } if (BDFDB.ObjectUtils.is(config[key]) && BDFDB.ObjectUtils.isEmpty(config[key])) delete config[key]; if (BDFDB.ObjectUtils.isEmpty(config)) { delete BDFDB.DataUtils.cached[pluginName]; if (LibraryRequires.fs.existsSync(configPath)) LibraryRequires.fs.unlinkSync(configPath); } else { if (configIsObject) config = BDFDB.ObjectUtils.sort(config); BDFDB.DataUtils.cached[pluginName] = configIsObject ? BDFDB.ObjectUtils.deepAssign({}, config) : config; LibraryRequires.fs.writeFileSync(configPath, JSON.stringify(config, null, " ")); } }; BDFDB.DataUtils.get = function (plugin, key, id) { plugin = typeof plugin == "string" ? BDFDB.BDUtils.getPlugin(plugin) : plugin; if (!BDFDB.ObjectUtils.is(plugin)) return id === undefined ? {} : null; let defaults = (plugin.name == "$BDFDB" ? InternalBDFDB : plugin).defaults; if (!BDFDB.ObjectUtils.is(defaults) || !defaults[key]) return id === undefined ? {} : null; var oldconfig = BDFDB.DataUtils.load(plugin, key), newconfig = {}, update = false; for (let k in defaults[key]) { if (oldconfig[k] == null) { newconfig[k] = BDFDB.ObjectUtils.is(defaults[key][k].value) ? BDFDB.ObjectUtils.deepAssign({}, defaults[key][k].value) : defaults[key][k].value; update = true; } else newconfig[k] = oldconfig[k]; } if (update) BDFDB.DataUtils.save(newconfig, plugin, key); if (id === undefined) return newconfig; else return newconfig[id] === undefined ? null : newconfig[id]; }; InternalBDFDB.readConfig = function (path) { try {return JSON.parse(LibraryRequires.fs.readFileSync(path));} catch (err) {return {};} }; BDFDB.ColorUtils = {}; BDFDB.ColorUtils.convert = function (color, conv, type) { if (BDFDB.ObjectUtils.is(color)) { var newcolor = {}; for (let pos in color) newcolor[pos] = BDFDB.ColorUtils.convert(color[pos], conv, type); return newcolor; } else { 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.ColorUtils.getType(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.ColorUtils.convert(`hsl(${processHSL(color).join(",")})`, "RGBCOMP"); else if (color.length == 4) { let a = processA(color.pop()); return BDFDB.ColorUtils.convert(`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.ColorUtils.convert(`hsl(${hslcomp.slice(0, 3).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.NumberUtils.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.ColorUtils.convert(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.ColorUtils.convert(rgbcomp, "HSL").replace(/\s/g, "").split(",")); return a != null ? 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.ColorUtils.convert(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) + (0x100 + Math.round(BDFDB.NumberUtils.mapRange([0, 100], [0, 255], processA(rgbcomp[3]) * 100))).toString(16).slice(1)).toUpperCase(); case "INT": return processINT(rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16); default: return null; } } } 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;}}; }; BDFDB.ColorUtils.setAlpha = function (color, a, conv) { if (BDFDB.ObjectUtils.is(color)) { var newcolor = {}; for (let pos in color) newcolor[pos] = BDFDB.ColorUtils.setAlpha(color[pos], a, conv); return newcolor; } else { var comp = BDFDB.ColorUtils.convert(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.ColorUtils.getType(color)).toUpperCase(); conv = conv == "RGB" || conv == "HSL" || conv == "HEX" ? conv + "A" : conv; return BDFDB.ColorUtils.convert(comp, conv); } } return null; }; BDFDB.ColorUtils.getAlpha = function (color) { var comp = BDFDB.ColorUtils.convert(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; } } return null; }; BDFDB.ColorUtils.change = function (color, value, conv) { value = parseFloat(value); if (color != null && typeof value == "number" && !isNaN(value)) { if (BDFDB.ObjectUtils.is(color)) { var newcolor = {}; for (let pos in color) newcolor[pos] = BDFDB.ColorUtils.change(color[pos], value, conv); return newcolor; } else { var comp = BDFDB.ColorUtils.convert(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.ColorUtils.convert([Math.round(comp[0] * (1 + value)), Math.round(comp[1] * (1 + value)), Math.round(comp[2] * (1 + value))], conv || BDFDB.ColorUtils.getType(color)); } else return BDFDB.ColorUtils.convert([Math.round(comp[0] + value), Math.round(comp[1] + value), Math.round(comp[2] + value)], conv || BDFDB.ColorUtils.getType(color)); } } } return null; }; BDFDB.ColorUtils.invert = function (color, conv) { if (BDFDB.ObjectUtils.is(color)) { var newcolor = {}; for (let pos in color) newcolor[pos] = BDFDB.ColorUtils.invert(color[pos], conv); return newcolor; } else { var comp = BDFDB.ColorUtils.convert(color, "RGBCOMP"); if (comp) return BDFDB.ColorUtils.convert([255 - comp[0], 255 - comp[1], 255 - comp[2]], conv || BDFDB.ColorUtils.getType(color)); } return null; }; BDFDB.ColorUtils.compare = function (color1, color2) { if (color1 && color2) { color1 = BDFDB.ColorUtils.convert(color1, "RGBA"); color2 = BDFDB.ColorUtils.convert(color2, "RGBA"); if (color1 && color2) return BDFDB.equals(color1, color2); } return null; }; BDFDB.ColorUtils.isBright = function (color, compare = 160) { color = BDFDB.ColorUtils.convert(color, "RGBCOMP"); if (!color) return false; return parseInt(compare) < Math.sqrt(0.299 * color[0]**2 + 0.587 * color[1]**2 + 0.144 * color[2]**2); }; BDFDB.ColorUtils.getType = 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.ColorUtils.createGradient = function (colorobj, direction = "to right") { var sortedgradient = {}; var gradientstring = "linear-gradient(" + direction; for (let pos of Object.keys(colorobj).sort()) { let color = BDFDB.ColorUtils.convert(colorobj[pos], "RGBA"); gradientstring += color ? `, ${color} ${pos*100}%` : '' } return gradientstring += ")"; }; BDFDB.ColorUtils.getSwatchColor = function (container, number) { if (!Node.prototype.isPrototypeOf(container)) return; var swatches = container.querySelector(`${BDFDB.dotCN.colorpickerswatches}[number="${number}"], ${BDFDB.dotCN.colorpickerswatch}[number="${number}"]`); if (!swatches) return null; var ins = BDFDB.ReactUtils.getInstance(swatches); if (ins) return BDFDB.ColorUtils.convert(BDFDB.ReactUtils.findValue(ins, "selectedColor", {up:true, blacklist:{"props":true}})); else { // REMOVE ONCE REWRITTEN var swatch = swatches.querySelector(`${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchselected}`); return swatch ? BDFDB.ColorUtils.convert(swatch.gradient || swatch.style.getPropertyValue("background-color"), "RGBCOMP") : null; } }; BDFDB.ColorUtils.openPicker = function (container, target, color, options = {gradient: true, alpha: true, callback: _ => {}}) { if (!container || !target) return; 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 isreact = BDFDB.ObjectUtils.is(container) && !!container._reactInternalFiber; var isswatches = !isreact && BDFDB.DOMUtils.containsClass(container, "swatches"); var isgradient = color && BDFDB.ObjectUtils.is(color); var selectedcolor = BDFDB.ColorUtils.convert(isgradient ? color[Object.keys(color)[0]] : color, hexformat) || (options.alpha ? "#000000FF" : "#000000"); var [h, s, l] = BDFDB.ColorUtils.convert(selectedcolor, "HSLCOMP"); var a = BDFDB.ColorUtils.getAlpha(isgradient ? color[Object.keys(color)[0]] : color); a = a == null ? 1 : a; var targetrects = BDFDB.DOMUtils.getRects(target); var colorPicker = BDFDB.DOMUtils.create(``); 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.DOMUtils.create(`
`)); updateColors(false); if (!options.gradient) BDFDB.DOMUtils.remove(colorPicker.querySelectorAll(".gradient-button, .gradient-bar")); if (!options.alpha) BDFDB.DOMUtils.remove(colorPicker.querySelectorAll(".alpha-bar")); BDFDB.ListenerUtils.addToChildren(colorPicker, "mousedown", ".move-corner", e => { var rects = BDFDB.DOMUtils.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.DOMUtils.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.NumberUtils.mapRange([sMinX, sMaxX], [0, 100], e.clientX) + "%"; l = BDFDB.NumberUtils.mapRange([sMinY, sMaxY], [100, 0], e.clientY) + "%"; updateColors(true); var mouseup = _ => { document.removeEventListener("mouseup", mouseup); document.removeEventListener("mousemove", mousemove); }; var mousemove = e2 => { s = BDFDB.NumberUtils.mapRange([sMinX, sMaxX], [0, 100], e2.clientX) + "%"; l = BDFDB.NumberUtils.mapRange([sMinY, sMaxY], [100, 0], e2.clientY) + "%"; updateColors(true); }; document.addEventListener("mouseup", mouseup); document.addEventListener("mousemove", mousemove); }); huepane.addEventListener("mousedown", e => { h = BDFDB.NumberUtils.mapRange([hMinX, hMaxX], [0, 360], e.clientX); updateColors(true); var mouseup = _ => { document.removeEventListener("mouseup", mouseup); document.removeEventListener("mousemove", mousemove); }; var mousemove = e2 => { h = BDFDB.NumberUtils.mapRange([hMinX, hMaxX], [0, 360], e2.clientX); updateColors(true); }; document.addEventListener("mouseup", mouseup); document.addEventListener("mousemove", mousemove); }); alphapane.addEventListener("mousedown", e => { a = BDFDB.NumberUtils.mapRange([aMinX, aMaxX], [0, 1], e.clientX); updateColors(true); var bubble = BDFDB.DOMUtils.create(``); 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.NumberUtils.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 => { BDFDB.TimeUtils.timeout(_ => { if (BDFDB.DOMUtils.containsClass(e.target.parentElement, "gradient-cursor")) { if (e.which == 1) { if (!BDFDB.DOMUtils.containsClass(e.target.parentElement, "selected")) { BDFDB.DOMUtils.removeClass(gradientpane.querySelectorAll(".gradient-cursor.selected"), "selected"); BDFDB.DOMUtils.addClass(e.target.parentElement, "selected"); [h, s, l] = BDFDB.ColorUtils.convert(e.target.style.getPropertyValue("background-color"), "HSLCOMP"); a = BDFDB.ColorUtils.getAlpha(e.target.style.getPropertyValue("background-color")); updateColors(true); } if (!BDFDB.DOMUtils.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.NumberUtils.mapRange([gMinX, gMaxX], [1, 99], e2.clientX) + "%"); updateGradient(); }; document.addEventListener("mouseup", mouseup); document.addEventListener("mousemove", mousemove); } } else if (e.which == 3 && !BDFDB.DOMUtils.containsClass(e.target.parentElement, "edge")) { BDFDB.DOMUtils.remove(e.target.parentElement); if (BDFDB.DOMUtils.containsClass(e.target.parentElement, "selected")) { var firstcursor = gradientpane.querySelector(".gradient-cursor"); BDFDB.DOMUtils.addClass(firstcursor, "selected"); [h, s, l] = BDFDB.ColorUtils.convert(firstcursor.firstElementChild.style.getPropertyValue("background-color"), "HSLCOMP"); a = BDFDB.ColorUtils.getAlpha(firstElementChild.style.getPropertyValue("background-color")); } updateColors(true); } } else if (gradientpane == e.target && e.which == 1) { BDFDB.DOMUtils.removeClass(gradientpane.querySelectorAll(".gradient-cursor.selected"), "selected"); var newcursor = BDFDB.DOMUtils.create(`
`); 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.NumberUtils.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.ColorUtils.convert(hexinput.value, "HSLCOMP"); if (a == null) a = 1; updateColors(false); } }); gradientbutton.addEventListener("click", e => { isgradient = !isgradient; BDFDB.DOMUtils.toggle(gradientbar, isgradient); BDFDB.DOMUtils.toggleClass(gradientbutton, "selected", isgradient); updateColors(true); }); gradientbutton.addEventListener("mouseenter", e => { BDFDB.TooltipUtils.create(gradientbutton, "Color Gradient", {type: "bottom"}); }); function updateRects () { var satpanerects = BDFDB.DOMUtils.getRects(satpane); sMinX = satpanerects.left; sMaxX = sMinX + satpanerects.width; sMinY = satpanerects.top; sMaxY = sMinY + satpanerects.height; var huepanerects = BDFDB.DOMUtils.getRects(huepane); hMinX = huepanerects.left; hMaxX = hMinX + huepanerects.width; var alphapanerects = BDFDB.DOMUtils.getRects(alphapane); aMinX = alphapanerects.left; aMaxX = aMinX + alphapanerects.width; var gradientpanerects = BDFDB.DOMUtils.getRects(gradientpane); gMinX = gradientpanerects.left; gMaxX = gMinX + gradientpanerects.width; } function updateColors (setinput) { satpane.style.setProperty("background", BDFDB.ColorUtils.convert([h, "100%", "100%"], "RGB"), "important"); satcursor.style.setProperty("left", s, "important"); satcursor.style.setProperty("top", BDFDB.NumberUtils.mapRange([0, 100], [100, 0], parseFloat(l)) + "%", "important"); huecursor.style.setProperty("left", BDFDB.NumberUtils.mapRange([0, 360], [0, 100], h) + "%", "important"); alphapane.style.setProperty("background", `linear-gradient(to right, ${BDFDB.ColorUtils.setAlpha([h, s, l], 0, "RGBA")}, ${BDFDB.ColorUtils.setAlpha([h, s, l], 1, "RGBA")}`, "important"); alphacursor.style.setProperty("left", (a * 100) + "%", "important"); var hex = BDFDB.ColorUtils.convert([h, s, l, a], hexformat); var rgb = BDFDB.ColorUtils.convert(hex, "RGBA"); if (isreact) { if (isgradient) { gradientpane.querySelector(".gradient-cursor.selected").firstElementChild.style.setProperty("background-color", rgb); updateGradient(); } else { container.setState({ selectedColor: rgb, customColor: rgb }); if (container.refInput) { container.refInput.props.value = !rgb ? "" : (container.state.compMode ? BDFDB.ColorUtils.convert(rgb, "RGBCOMP").slice(0,3).join(",") : rgb); BDFDB.ReactUtils.forceUpdate(container.refInput); } } } else if (isswatches) { setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchselected), 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); } 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.ColorUtils.createGradient(gradient)); if (isreact) container.setState({ selectedColor: gradient, customColor: gradient }); else setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), gradient, true); } }; BDFDB.DOMUtils = {}; BDFDB.DOMUtils.getSelection = function () { let selection = document.getSelection(); return selection && selection.anchorNode ? selection.getRangeAt(0).toString() : ""; }; BDFDB.DOMUtils.addClass = function (eles, ...classes) { if (!eles || !classes) return; for (let ele of [eles].flat(10).filter(n => n)) { 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 [cla].flat(10).filter(n => n)) if (typeof cl == "string") for (let c of cl.split(" ")) if (c) node.classList.add(c); } }; BDFDB.DOMUtils.removeClass = function (eles, ...classes) { if (!eles || !classes) return; for (let ele of [eles].flat(10).filter(n => n)) { 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 [cla].flat(10).filter(n => n)) if (typeof cl == "string") for (let c of cl.split(" ")) if (c) node.classList.remove(c); } }; BDFDB.DOMUtils.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 [eles].flat(10).filter(n => n)) { 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 [cla].flat(10).filter(n => n)) if (typeof cl == "string") for (let c of cl.split(" ")) if (c) node.classList.toggle(c, force); } }; BDFDB.DOMUtils.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 BDFDB.ArrayUtils.is(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.DOMUtils.replaceClass = function (eles, oldclass, newclass) { if (!eles || typeof oldclass != "string" || typeof newclass != "string") return; for (let ele of [eles].flat(10).filter(n => n)) { 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.DOMUtils.formatClassName = function (...classes) { return BDFDB.ArrayUtils.removeCopies(classes.flat(10).filter(n => n).join(" ").split(" ")).join(" ").trim(); }; BDFDB.DOMUtils.removeClassFromDOM = function (...classes) { for (let c of classes.flat(10).filter(n => n)) if (typeof c == "string") for (let a of c.split(",")) if (a && (a = a.replace(/\.|\s/g, ""))) BDFDB.DOMUtils.removeClass(document.querySelectorAll("." + a), a); }; BDFDB.DOMUtils.show = function (...eles) { BDFDB.DOMUtils.toggle(...eles, true); }; BDFDB.DOMUtils.hide = function (...eles) { BDFDB.DOMUtils.toggle(...eles, false); }; BDFDB.DOMUtils.toggle = 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.flat(10).filter(n => n)) { if (Node.prototype.isPrototypeOf(ele)) toggle(ele); else if (NodeList.prototype.isPrototypeOf(ele)) for (let node of ele) toggle(node); else if (typeof ele == "string") for (let c of ele.split(",")) if (c && (c = c.trim())) for (let node of document.querySelectorAll(c)) toggle(node); } function toggle(node) { if (!node || !Node.prototype.isPrototypeOf(node)) return; var hidden = force === undefined ? !BDFDB.DOMUtils.isHidden(node) : !force; if (hidden) node.style.setProperty("display", "none", "important"); else node.style.removeProperty("display"); } }; BDFDB.DOMUtils.isHidden = function (node) { if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) return getComputedStyle(node, null).getPropertyValue("display") == "none"; }; BDFDB.DOMUtils.remove = function (...eles) { for (let ele of eles.flat(10).filter(n => n)) { if (Node.prototype.isPrototypeOf(ele)) ele.remove(); else if (NodeList.prototype.isPrototypeOf(ele)) { let nodes = Array.from(ele); while (nodes.length) nodes.shift().remove(); } else if (typeof ele == "string") for (let c of ele.split(",")) if (c && (c = c.trim())) { let nodes = Array.from(document.querySelectorAll(c)); while (nodes.length) nodes.shift().remove(); } } }; BDFDB.DOMUtils.create = function (html) { if (typeof html != "string" || !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.childNodes.length == 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.DOMUtils.getParent = 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.DOMUtils.setText = 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.DOMUtils.containsClass(child, "BDFDB-textnode")) { textnode = child; break; } if (textnode) { if (Node.prototype.isPrototypeOf(stringOrNode) && stringOrNode.nodeType != Node.TEXT_NODE) { BDFDB.DOMUtils.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.DOMUtils.getText = 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.DOMUtils.getRects = function (node) { var rects = {}; if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) { var hidenode = node; while (hidenode) { var hidden = BDFDB.DOMUtils.isHidden(hidenode); if (hidden) { BDFDB.DOMUtils.toggle(hidenode, true); hidenode.BDFDBgetRectsHidden = true; } hidenode = hidenode.parentElement; } rects = node.getBoundingClientRect(); hidenode = node; while (hidenode) { if (hidenode.BDFDBgetRectsHidden) { BDFDB.DOMUtils.toggle(hidenode, false); delete hidenode.BDFDBgetRectsHidden; } hidenode = hidenode.parentElement; } } return rects; }; BDFDB.DOMUtils.getHeight = function (node) { if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) { var rects = BDFDB.DOMUtils.getRects(node); var style = getComputedStyle(node); return rects.height + parseInt(style.marginTop) + parseInt(style.marginBottom); } return 0; }; BDFDB.DOMUtils.getInnerHeight = function (node) { if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) { let rects = BDFDB.DOMUtils.getRects(node); let style = getComputedStyle(node); return rects.height - parseInt(style.paddingTop) - parseInt(style.paddingBottom); } return 0; }; BDFDB.DOMUtils.getWidth = function (node) { if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) { let rects = BDFDB.DOMUtils.getRects(node); let style = getComputedStyle(node); return rects.width + parseInt(style.marginLeft) + parseInt(style.marginRight); } return 0; }; BDFDB.DOMUtils.getInnerWidth = function (node) { if (Node.prototype.isPrototypeOf(node) && node.nodeType != Node.TEXT_NODE) { let rects = BDFDB.DOMUtils.getRects(node); let style = getComputedStyle(node); return rects.width - parseInt(style.paddingLeft) - parseInt(style.paddingRight); } return 0; }; BDFDB.DOMUtils.appendWebScript = function (path, container) { if (!container && !document.head.querySelector("bd-head bd-scripts")) document.head.appendChild(BDFDB.DOMUtils.create(``)); container = container || document.head.querySelector("bd-head bd-scripts") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.removeWebScript(path, container); container.appendChild(BDFDB.DOMUtils.create(``)); }; BDFDB.DOMUtils.removeWebScript = function (path, container) { container = container || document.head.querySelector("bd-head bd-scripts") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.remove(container.querySelectorAll(`script[src="${path}"]`)); }; BDFDB.DOMUtils.appendWebStyle = function (path, container) { if (!container && !document.head.querySelector("bd-head bd-styles")) document.head.appendChild(BDFDB.DOMUtils.create(``)); container = container || document.head.querySelector("bd-head bd-styles") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.removeWebStyle(path, container); container.appendChild(BDFDB.DOMUtils.create(``)); }; BDFDB.DOMUtils.removeWebStyle = function (path, container) { container = container || document.head.querySelector("bd-head bd-styles") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.remove(container.querySelectorAll(`link[href="${path}"]`)); }; BDFDB.DOMUtils.appendLocalStyle = function (id, css, container) { if (!container && !document.head.querySelector("bd-head bd-styles")) document.head.appendChild(BDFDB.DOMUtils.create(``)); container = container || document.head.querySelector("bd-head bd-styles") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.removeLocalStyle(id, container); container.appendChild(BDFDB.DOMUtils.create(``)); }; BDFDB.DOMUtils.removeLocalStyle = function (id, container) { container = container || document.head.querySelector("bd-head bd-styles") || document.head; container = Node.prototype.isPrototypeOf(container) ? container : document.head; BDFDB.DOMUtils.remove(container.querySelectorAll(`style[id="${id}CSS"]`)); }; BDFDB.triggerSend = function (textarea) { if (!textarea) return; BDFDB.TimeUtils.timeout(_ => { 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.DiscordUtils.getTheme() == BDFDB.disCN.themelight; container.querySelectorAll(".BDFDB-containertext").forEach(ele => { if (BDFDB.DOMUtils.containsClass(ele.nextElementSibling, "BDFDB-collapsecontainer")) { if (BDFDB.DOMUtils.containsClass(ele.firstElementChild, "closed")) BDFDB.DOMUtils.toggle(ele.nextElementSibling, false); ele.BDFDBupdateElement = _ => { BDFDB.DOMUtils.toggle(ele.nextElementSibling, BDFDB.DOMUtils.containsClass(ele.firstElementChild, "closed")); BDFDB.DOMUtils.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.DOMUtils.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.DOMUtils.remove(`#${id}_tooltip`); BDFDB.TooltipUtils.create(ele, BDFDB.LanguageUtils.LanguageStrings[`GIF_TOOLTIP_${BDFDB.DOMUtils.containsClass(ele, BDFDB.disCN.giffavoriteselected) ? "REMOVE_FROM" : "ADD_TO"}_FAVORITES`], {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", BDFDB.LanguageUtils.LanguageStrings.SEARCHING); addInitEventListener(ele, "keyup", e => { let icons = ele.parentElement.querySelectorAll(BDFDB.dotCN.searchbaricon); BDFDB.DOMUtils.toggleClass(icons[0], BDFDB.disCN.searchbarvisible, ele.value.length == 0); BDFDB.DOMUtils.toggleClass(icons[1], BDFDB.disCN.searchbarvisible, ele.value.length); }); }); container.querySelectorAll(BDFDB.dotCNS.searchbar + BDFDB.dotCN.searchbarclear).forEach(ele => { addInitEventListener(ele, "click", e => { if (BDFDB.DOMUtils.containsClass(ele, BDFDB.disCN.searchbarvisible)) { var input = BDFDB.DOMUtils.getParent(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.DOMUtils.addClass(ele.parentElement.querySelectorAll(BDFDB.dotCN.searchbaricon)[0], BDFDB.disCN.searchbarvisible); BDFDB.DOMUtils.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.DOMUtils.addClass(ele.parentElement, "pressed"); BDFDB.TimeUtils.clear(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 = BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.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.DOMUtils.addClass(ele.parentElement, "pressed"); BDFDB.TimeUtils.clear(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 = BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.removeClass(ele.parentElement, "pressed");}, 3000); } }); }); container.querySelectorAll(".amount-input").forEach(ele => { addInitEventListener(ele, "input", e => { if (BDFDB.ObjectUtils.is(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.DataUtils.save(newv, plugin, "amounts", option); 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.DOMUtils.removeClass(container.querySelectorAll(BDFDB.dotCN.modaltabcontent + BDFDB.dotCN.modaltabcontentopen), BDFDB.disCN.modaltabcontentopen); ele.parentElement.querySelectorAll(BDFDB.dotCNC.tabbaritem + BDFDB.dotCN.tabbarheaderitem).forEach(ele => {setTabitem(ele, 0);}); var tab = container.querySelector(`${BDFDB.dotCN.modaltabcontent}[tab="${ele.getAttribute("tab")}"]`); if (tab) BDFDB.DOMUtils.addClass(tab, BDFDB.disCN.modaltabcontentopen); setTabitem(ele, 2); }); addInitEventListener(ele, "mouseenter", e => { if (!BDFDB.DOMUtils.containsClass(ele, BDFDB.disCN.settingsitemselected)) setTabitem(ele, 1); }); addInitEventListener(ele, "mouseleave", e => { if (!BDFDB.DOMUtils.containsClass(ele, BDFDB.disCN.settingsitemselected)) setTabitem(ele, 0); }); }); container.querySelectorAll(".BDFDB-textscrollwrapper").forEach(ele => { var inner = ele.querySelector(".BDFDB-textscroll"); if (inner) { if (BDFDB.DOMUtils.containsClass(ele.parentElement, BDFDB.disCN.contextmenuitemsubmenu)) ele.style.setProperty("margin-right", "10px"); if (BDFDB.DOMUtils.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.DOMUtils.getRects(ele).width < BDFDB.DOMUtils.getRects(inner).width) { BDFDB.DOMUtils.addClass(ele, "scrolling"); if (!Animation || !animate) initAnimation(); animate(1); inner.style.setProperty("display", "block", "important"); } }); addInitEventListener(ele, "mouseleave", e => { if (BDFDB.DOMUtils.containsClass(ele, "scrolling")) { BDFDB.DOMUtils.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.DOMUtils.getRects(inner).width - BDFDB.DOMUtils.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.DOMUtils.getRects(inner).width - BDFDB.DOMUtils.getRects(ele).width); w = isNaN(w) || !isFinite(w) ? p : w; w *= BDFDB.DOMUtils.getRects(inner).width / (BDFDB.DOMUtils.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.DOMUtils.removeClass(container.querySelectorAll(BDFDB.dotCN.modaltabcontent), BDFDB.disCN.modaltabcontentopen); BDFDB.DOMUtils.addClass(container.querySelector(BDFDB.dotCN.modaltabcontent), BDFDB.disCN.modaltabcontentopen); container.querySelectorAll(".btn-add " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.ADD;}); container.querySelectorAll(".btn-all " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.FORM_LABEL_ALL;}); container.querySelectorAll(".btn-cancel " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.CANCEL;}); container.querySelectorAll(".btn-done " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.DONE;}); container.querySelectorAll(".btn-download " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.DOWNLOAD;}); container.querySelectorAll(".btn-ok " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.OKAY;}); container.querySelectorAll(".btn-save " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.SAVE;}); container.querySelectorAll(".btn-send " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LanguageStrings.SEND;}); container.querySelectorAll(".file-navigator " + BDFDB.dotCN.buttoncontents).forEach(ele => {ele.innerText = BDFDB.LanguageUtils.LibraryStrings.file_navigator_text;}); if (islighttheme) { BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectcontroldark), BDFDB.disCN.selectcontroldark, BDFDB.disCN.selectcontrollight); BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectsingledark), BDFDB.disCN.selectsingledark, BDFDB.disCN.selectsinglelight); BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectarrowcontainerdark), BDFDB.disCN.selectarrowcontainerdark, BDFDB.disCN.selectarrowcontainerlight); } else { BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectcontrollight), BDFDB.disCN.selectcontrollight, BDFDB.disCN.selectcontroldark); BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectsinglelight), BDFDB.disCN.selectsinglelight, BDFDB.disCN.selectsingledark); BDFDB.DOMUtils.replaceClass(container.querySelectorAll(BDFDB.dotCN.selectarrowcontainerlight), BDFDB.disCN.selectarrowcontainerlight, BDFDB.disCN.selectarrowcontainerdark); } var executeDelayedIfNotAppened = _ => { container.querySelectorAll(".BDFDB-tableheader").forEach(ele => { var panel = BDFDB.DOMUtils.getParent(".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.ObjectUtils.is(panel["BDFDB-tableheader-maxwidth"]) ? panel["BDFDB-tableheader-maxwidth"][tableid] : 0; if (!maxwidth) { for (let column of columns) { let width = BDFDB.DOMUtils.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.ObjectUtils.is(panel["BDFDB-tableheader-maxwidth"])) panel["BDFDB-tableheader-maxwidth"] = {} panel["BDFDB-tableheader-maxwidth"][tableid] = maxwidth; } }); container.querySelectorAll(".BDFDB-tablecheckbox").forEach(ele => { var panel = BDFDB.DOMUtils.getParent(".BDFDB-modal, .BDFDB-settings", ele); var tableid = ele.getAttribute("table-id"); if (panel && tableid && BDFDB.ObjectUtils.is(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 BDFDB.TimeUtils.timeout(_ => {executeDelayedIfNotAppened();}); function setSwitch(switchitem, triggered) { if (!switchitem) return; var checked = switchitem.checked; BDFDB.DOMUtils.toggleClass(switchitem.parentElement, BDFDB.disCN.switchvaluechecked, checked); BDFDB.DOMUtils.toggleClass(switchitem.parentElement, BDFDB.disCN.switchvalueunchecked, !checked); if (triggered && BDFDB.ObjectUtils.is(plugin) && BDFDB.DOMUtils.containsClass(switchitem, "settings-switch")) { let keys = switchitem.getAttribute("value").trim().split(" ").filter(n => n); let option = keys.shift(); if (option) { var data = BDFDB.DataUtils.load(plugin, option); var newdata = ""; for (let key of keys) newdata += `{"${key}":`; newdata += checked + "}".repeat(keys.length); newdata = JSON.parse(newdata); if (BDFDB.ObjectUtils.is(newdata)) BDFDB.ObjectUtils.deepAssign(data, newdata); else data = newdata; BDFDB.DataUtils.save(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.DOMUtils.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.DOMUtils.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.DOMUtils.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.DOMUtils.addClass(button, BDFDB.disCN.giffavoriteshowpulse); BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.removeClass(button, BDFDB.disCN.giffavoriteshowpulse);}, 500); } }; function setTabitem(item, state) { if (!item) return; switch (state) { case 0: BDFDB.DOMUtils.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.DOMUtils.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.DOMUtils.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); }; }; // REMOVE ONCE REWRITTEN BDFDB.appendModal = function (modalwrapper) { if (!Node.prototype.isPrototypeOf(modalwrapper)) return; if (!BDFDB.appendModal.modals || !document.contains(BDFDB.appendModal.modals)) BDFDB.appendModal.modals = BDFDB.ReactUtils.findDOMNode(BDFDB.ReactUtils.findOwner(document.querySelector(BDFDB.dotCN.app), {name:"Modals", unlimited:true})); if (!BDFDB.appendModal.modals) return; var modal = BDFDB.DOMUtils.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.ListenerUtils.addToChildren(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); BDFDB.TimeUtils.timeout(_ => {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.DOMUtils.create(`
`); BDFDB.initElements(searchBar); return searchBar; }; BDFDB.createSelectMenu = function (inner, value, type = "", dark = BDFDB.DiscordUtils.getTheme() == BDFDB.disCN.themedark) { if (typeof inner != "string" || (typeof value != "string" && typeof value != "number")) return BDFDB.DOMUtils.create(`
`); var suffix = dark ? "dark" : "light"; return `
${inner}
`; }; BDFDB.openDropdownMenu = function (e, callback, createinner, values, above = false, dark = BDFDB.DiscordUtils.getTheme() == BDFDB.disCN.themedark) { if (typeof callback != "function" || typeof createinner != "function" || !values || typeof values != "object") return; let selectControl = (BDFDB.DOMUtils.getParent(BDFDB.dotCN.selectwrap, e.currentTarget) || e.currentTarget).querySelector(BDFDB.dotCN.selectcontrol); let selectWrap = selectControl.parentElement; if (BDFDB.DOMUtils.containsClass(selectWrap, BDFDB.disCN.selectisopen)) return; BDFDB.DOMUtils.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.DOMUtils.create(menuhtml); if (above) { BDFDB.DOMUtils.addClass(selectMenu, "above-select"); selectMenu.style.setProperty("top", "unset", "important"); selectMenu.style.setProperty("bottom", BDFDB.DOMUtils.getRects(selectWrap).height + "px", "important"); } selectWrap.appendChild(selectMenu); BDFDB.initElements(selectMenu); BDFDB.ListenerUtils.addToChildren(selectMenu, "mouseenter", BDFDB.dotCN.selectoption + BDFDB.notCN.selectoptionselectlight + BDFDB.notCN.selectoptionselectdark, e2 => { if (dark) { BDFDB.DOMUtils.removeClass(e2.currentTarget, BDFDB.disCN.selectoptiondark); BDFDB.DOMUtils.addClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverdark); } else { BDFDB.DOMUtils.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionlight); BDFDB.DOMUtils.addClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverlight); } }); BDFDB.ListenerUtils.addToChildren(selectMenu, "mouseleave", BDFDB.dotCN.selectoption + BDFDB.notCN.selectoptionselectlight + BDFDB.notCN.selectoptionselectdark, e2 => { if (dark) { BDFDB.DOMUtils.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverdark); BDFDB.DOMUtils.addClass(e2.currentTarget, BDFDB.disCN.selectoptiondark); } else { BDFDB.DOMUtils.removeClass(e2.currentTarget, BDFDB.disCN.selectoptionhoverlight); BDFDB.DOMUtils.addClass(e2.currentTarget, BDFDB.disCN.selectoptionlight); } }); BDFDB.ListenerUtils.addToChildren(selectMenu, "mousedown", BDFDB.dotCN.selectoption, e2 => { if (!BDFDB.DOMUtils.getParent(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.DOMUtils.getParent(BDFDB.dotCN.giffavoritebutton, e2.target)) { document.removeEventListener("mousedown", removeMenu); selectMenu.remove(); BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.removeClass(selectWrap, BDFDB.disCN.selectisopen);},100); } }; document.addEventListener("mousedown", removeMenu); return selectMenu; }; BDFDB.ModalUtils = {}; BDFDB.ModalUtils.open = function (plugin, config) { if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ObjectUtils.is(config)) return; var modal, modalInstance, headerchildren = [], contentchildren = [], footerchildren = [], modalprops, cancels = [], closeModal = _ => { if (BDFDB.ObjectUtils.is(modalprops) && typeof modalprops.onClose == "function") modalprops.onClose(); }; if (typeof config.text == "string") { contentchildren.push(BDFDB.ReactUtils.createElement(LibraryComponents.TextElement, { color: LibraryComponents.TextElement.Colors.PRIMARY, children: config.text })); } if (config.children) { let selectedtab, tabbaritems = []; for (let child of [config.children].flat(10).filter(n => n)) if (LibraryModules.React.isValidElement(child)) { if (child.type == LibraryComponents.ModalComponents.ModalTabContent) { if (!tabbaritems.length) child.props.open = true; else delete child.props.open; tabbaritems.push({value:child.props.tab}); } contentchildren.push(child); } if (tabbaritems.length) headerchildren.push(BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.tabbarcontainer, children: BDFDB.ReactUtils.createElement(LibraryComponents.TabBar, { className: BDFDB.disCN.tabbar, itemClassName: BDFDB.disCN.tabbaritem, type: LibraryComponents.TabBar.Types.TOP, items: tabbaritems, onItemSelect: (value, instance) => { let tabContentInstances = BDFDB.ReactUtils.findOwner(modal, {name:"BDFDB_ModalTabContent", all:true, unlimited:true}); for (let ins of tabContentInstances) { if (ins.props.tab == value) ins.props.open = true; else delete ins.props.open; } BDFDB.ReactUtils.forceUpdate(tabContentInstances); } }) })); } if (BDFDB.ArrayUtils.is(config.buttons)) for (let button of config.buttons) { let contents = typeof button.contents == "string" ? button.contents : null; if (contents) { 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.ReactUtils.createElement(LibraryComponents.Button, BDFDB.ObjectUtils.exclude(Object.assign({}, button, { look: look || (color ? LibraryComponents.Button.Looks.FILLED : LibraryComponents.Button.Looks.LINK), color: color || LibraryComponents.Button.Colors.PRIMARY, onClick: _ => { if (button.close) closeModal(); if (!(button.close && button.cancel)) click(modal, modalInstance); }, children: contents }), "click", "close", "cancel", "contents"))); } } contentchildren = contentchildren.filter(n => n && (typeof n == "string" || BDFDB.ReactUtils.isValidElement(n))); headerchildren = headerchildren.filter(n => n && (typeof n == "string" || BDFDB.ReactUtils.isValidElement(n))); footerchildren = footerchildren.filter(n => n && (typeof n == "string" || BDFDB.ReactUtils.isValidElement(n))); if (contentchildren.length) { if (typeof config.onClose != "function") config.onClose = _ => {}; if (typeof config.onOpen != "function") config.onOpen = _ => {}; 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()]; let oldTransitionState = 0; LibraryModules.ModalUtils.openModal(props => { modalprops = props; return BDFDB.ReactUtils.createElement(class BDFDB_Modal extends LibraryModules.React.Component { render () { return BDFDB.ReactUtils.createElement(LibraryComponents.ModalComponents.ModalRoot, { className: BDFDB.DOMUtils.formatClassName(name && `${name}-modal`, BDFDB.disCN.modalwrapper, config.className), size: size || LibraryComponents.ModalComponents.ModalSize.SMALL, transitionState: props.transitionState, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.ModalComponents.ModalHeader, { className: BDFDB.DOMUtils.formatClassName(config.headerClassName, headerchildren.length && BDFDB.disCN.modalheaderhassibling), separator: config.headerSeparator || false, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { children: [ BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormTitle, { tag: LibraryComponents.FormComponents.FormTitle.Tags.H4, children: typeof config.header == "string" ? config.header : "" }), BDFDB.ReactUtils.createElement(LibraryComponents.TextElement, { size: LibraryComponents.TextElement.Sizes.SMALL, color: LibraryComponents.TextElement.Colors.PRIMARY, children: typeof config.subheader == "string" ? config.subheader : (name || "") }) ] }), BDFDB.ReactUtils.createElement(LibraryComponents.ModalComponents.ModalCloseButton, { onClick: closeModal }) ] }), headerchildren.length ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { grow: 0, shrink: 0, children: headerchildren }) : null, BDFDB.ReactUtils.createElement(LibraryComponents.ModalComponents.ModalContent, { className: config.contentClassName, scroller: config.scroller, children: contentchildren }), footerchildren.length ? BDFDB.ReactUtils.createElement(LibraryComponents.ModalComponents.ModalFooter, { className: config.footerClassName, children: footerchildren }) : null ] }); } componentDidMount () { modalInstance = this; modal = BDFDB.ReactUtils.findDOMNode(this); modal = modal && modal.parentElement ? modal.parentElement.querySelector(BDFDB.dotCN.modalwrapper) : null; if (modal && props.transitionState == 2 && props.transitionState > oldTransitionState) config.onOpen(modal, this); oldTransitionState = props.transitionState; } componentWillUnmount () { if (modal && props.transitionState == 4) { for (let cancel of cancels) cancel(modal); config.onClose(modal, this); } } }, props); }, { onCloseRequest: closeModal }); } }; BDFDB.ModalUtils.confirm = function (plugin, text, callback) { if (!BDFDB.ObjectUtils.is(plugin) || typeof text != "string") return; callback = typeof callback == "function" ? callback : _ => {}; BDFDB.ModalUtils.open(plugin, {text, header:"Are you sure?", className:BDFDB.disCN.modalconfirmmodal, scroller:false, buttons:[ {contents: BDFDB.LanguageUtils.LanguageStrings.OKAY, close:true, color:"RED", click:callback}, {contents: BDFDB.LanguageUtils.LanguageStrings.CANCEL, close:true} ]}); }; BDFDB.ContextMenuUtils = {}; BDFDB.ContextMenuUtils.open = function (plugin, e, children) { LibraryModules.ContextMenuUtils.openContextMenu(e, function (e) { return BDFDB.ReactUtils.createElement(LibraryComponents.ContextMenus.NativeContextMenu, Object.assign({}, e, { BDFDBcontextMenu: true, type: BDFDB.DiscordConstants.ContextMenuTypes.NATIVE_TEXT, value: "", className: BDFDB.disCN.contextmenu, children: children })); }); }; BDFDB.ContextMenuUtils.close = function (nodeOrInstance) { if (!BDFDB.ObjectUtils.is(nodeOrInstance)) return; var instance = BDFDB.ReactUtils.findOwner(nodeOrInstance, {props:"closeContextMenu", up:true}); if (BDFDB.ObjectUtils.is(instance) && instance.props && typeof instance.props.closeContextMenu == "function") instance.props.closeContextMenu(); else BDFDB.LibraryModules.ContextMenuUtils.closeContextMenu(); }; BDFDB.createSortPopout = function (anker, markup, callback) { if (!anker || !markup || typeof callback != "function" || BDFDB.DOMUtils.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.DOMUtils.addClass(anker, "popout-open"); var popout = BDFDB.DOMUtils.create(markup); var ankerrects = BDFDB.DOMUtils.getRects(anker); popout.style.setProperty("left", ankerrects.left + ankerrects.width + "px"); popout.style.setProperty("top", ankerrects.top + BDFDB.DOMUtils.getRects(valueinput).height + "px"); BDFDB.DOMUtils.addClass(popout.querySelector(BDFDB.dotCN.contextmenu), BDFDB.DiscordUtils.getTheme()); BDFDB.ListenerUtils.addToChildren(popout, "click", BDFDB.dotCN.contextmenuitem, e => { valueinput.innerText = e.currentTarget.innerText; valueinput.setAttribute("option", e.currentTarget.getAttribute("option")); document.removeEventListener("mousedown", mousedown); popout.remove(); BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.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(); BDFDB.TimeUtils.timeout(_ => {BDFDB.DOMUtils.removeClass(anker, "popout-open");}, 300); } }; document.addEventListener("mousedown", mousedown); }; // REMOVE ONCE REWRITTEN var setSwatch = (swatch, color, selected) => { if (!swatch) return; else if (selected) { BDFDB.DOMUtils.addClass(swatch, BDFDB.disCN.colorpickerswatchselected); var iscustom = BDFDB.DOMUtils.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom); var isgradient = color && BDFDB.ObjectUtils.is(color); var selectedcolor = BDFDB.ObjectUtils.is(color) ? BDFDB.ColorUtils.createGradient(color) : BDFDB.ColorUtils.convert(color, "RGBA"); var bright = selectedcolor && !isgradient ? BDFDB.ColorUtils.isBright(selectedcolor) : false; if (!swatch.querySelector(`svg[name="Checkmark"]`)) swatch.appendChild(BDFDB.DOMUtils.create(``)); if (iscustom) { BDFDB.DOMUtils.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.DOMUtils.removeClass(swatch, BDFDB.disCN.colorpickerswatchselected); BDFDB.DOMUtils.remove(swatch.querySelectorAll(".swatch-checkmark")); if (BDFDB.DOMUtils.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom)) { BDFDB.DOMUtils.addClass(swatch, BDFDB.disCN.colorpickerswatchnocolor); swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute("fill", "#ffffff"); swatch.style.removeProperty("background-color"); swatch.style.removeProperty("background-image"); } } }; // REMOVE ONCE REWRITTEN BDFDB.setColorSwatches = function (container, currentcolor) { if (!Node.prototype.isPrototypeOf(container)) return; var swatches = container.querySelector(`${BDFDB.dotCN.colorpickerswatches}:not([number])`); if (!swatches) return; swatches.setAttribute("number", parseInt(container.querySelectorAll(`${BDFDB.dotCN.colorpickerswatches}[number]`).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.DOMUtils.create(`
${colorrows.map(row => `
` + row.map(c => ``).join("") + `
`).join("")}
`)); if (currentcolor && !BDFDB.ColorUtils.compare(currentcolor, [0, 0, 0, 0])) { var selection = colorlist.indexOf(BDFDB.ColorUtils.convert(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.ListenerUtils.addToChildren(swatches, "click", BDFDB.dotCN.colorpickerswatch, e => { if (BDFDB.DOMUtils.containsClass(swatches, BDFDB.disCN.colorpickerswatchesdisabled) || BDFDB.DOMUtils.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchdisabled)) return; else if (BDFDB.DOMUtils.containsClass(e.currentTarget, BDFDB.disCN.colorpickerswatchcustom)) { BDFDB.ColorUtils.openPicker(swatches, e.currentTarget, e.currentTarget.gradient || e.currentTarget.style.getPropertyValue("background-color")); } else { setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchselected), null, false); setSwatch(e.currentTarget, e.currentTarget.style.getPropertyValue("background-color"), true); } }); BDFDB.ListenerUtils.addToChildren(swatches, "mouseenter", BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom, e => { BDFDB.TooltipUtils.create(e.currentTarget, BDFDB.LanguageUtils.LanguageStrings.CUSTOM_COLOR, {type: "bottom"}); }); BDFDB.ListenerUtils.addToChildren(swatches, "mouseenter", BDFDB.dotCNS.colorpickerrow + BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchnocolor, e => { BDFDB.TooltipUtils.create(e.currentTarget, BDFDB.LanguageUtils.LanguageStrings.DEFAULT, {type: "bottom"}); }); }; BDFDB.TimeUtils = {}; BDFDB.TimeUtils.interval = function (callback, delay) { if (typeof callback != "function" || typeof delay != "number" || delay < 1) return; else return setInterval(_ => {BDFDB.TimeUtils.suppress(callback, "Interval")();}, delay); }; BDFDB.TimeUtils.timeout = function (callback, delay) { if (typeof callback != "function") return; else if (typeof delay != "number" || delay < 1) return setImmediate(_ => {BDFDB.TimeUtils.suppress(callback, "Immediate")();}); else return setTimeout(_ => {BDFDB.TimeUtils.suppress(callback, "Timeout")();}, delay); }; BDFDB.TimeUtils.clear = function (...timeobjects) { for (let t of timeobjects.flat(10).filter(n => n)) { if (typeof t == "number") { clearInterval(t); clearTimeout(t); } else if (typeof t == "object") clearImmediate(t); } }; BDFDB.TimeUtils.suppress = function (callback, string, name) {return function (...args) { try {return callback(...args);} catch (err) { if (typeof string != "string") string = ""; BDFDB.LogUtils.error(string + " " + err, name); } }}; BDFDB.StringUtils = {}; BDFDB.StringUtils.htmlEscape = function (string) { var ele = document.createElement("div"); ele.innerText = string; return ele.innerHTML; }; BDFDB.StringUtils.regEscape = function (string) { return typeof string == "string" && string.replace(/([\-\/\\\^\$\*\+\?\.\(\)\|\[\]\{\}])/g, "\\$1"); }; BDFDB.StringUtils.insertNRST = function (string) { return typeof string == "string" && string.replace(/\\r/g, "\r").replace(/\\n/g, "\n").replace(/\\t/g, "\t").replace(/\\s/g, " "); }; BDFDB.StringUtils.highlight = function (string, searchstring, prefix = ``, suffix = ``) { if (typeof string != "string" || !searchstring || searchstring.length < 1) return string; var offset = 0, original = string; BDFDB.ArrayUtils.getAllIndexes(string.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.ArrayUtils.getAllIndexes(string.substring(0, index), "<")); var d4 = [-1].concat(BDFDB.ArrayUtils.getAllIndexes(string.substring(0, index), ">")); if (d3[d3.length - 1] > d4[d4.length - 1]) return; string = string.substring(0, index) + prefix + string.substring(index, d2) + suffix + string.substring(d2); offset++; }); return string || original; }; BDFDB.SlateUtils = {}; BDFDB.SlateUtils.isRichValue = function (richValue) { return BDFDB.ObjectUtils.is(richValue) && LibraryModules.SlateUtils.deserialize("").constructor.prototype.isPrototypeOf(richValue); }; BDFDB.SlateUtils.copyRichValue = function (string, richValue) { let newRichValue = LibraryModules.SlateUtils.deserialize(string); if (BDFDB.SlateUtils.isRichValue(richValue) && richValue._map && richValue._map._root && BDFDB.ArrayUtils.is(richValue._map._root.entries)) { for (let i in richValue._map._root.entries) if (richValue._map._root.entries[i][0] == "selection") { newRichValue._map._root.entries[i] = richValue._map._root.entries[i]; break; } } return newRichValue; }; BDFDB.SlateUtils.hasOpenPlainTextCodeBlock = function (editor) { let richValue = BDFDB.ReactUtils.getValue(editor, "props.richValue"); if (!BDFDB.SlateUtils.isRichValue(richValue)) return false; let codeMatches = BDFDB.LibraryModules.SlateSelectionUtils.serializeSelection(richValue.document, { start: { key: richValue.document.getFirstText().key, offset: 0 }, end: richValue.selection.start }, "raw").match(/```/g); return codeMatches && codeMatches.length && codeMatches.length % 2 != 0; }; BDFDB.SlateUtils.getCurrentWord = function (editor) { let richValue = BDFDB.ReactUtils.getValue(editor, "props.richValue"); if (!BDFDB.SlateUtils.isRichValue(richValue) || !richValue.selection.isCollapsed || BDFDB.SlateUtils.hasOpenPlainTextCodeBlock(editor) || richValue.document.text.trim().length == 0) return {word: null, isAtStart: false}; if (editor.props.useSlate) { if (richValue.document.text.startsWith("/giphy ") || richValue.document.text.startsWith("/tenor ")) { let node = richValue.document.getNode(richValue.selection.start.key); if (node) return { word: node.text.substring(0, richValue.selection.start.offset), isAtStart: true } } let node = richValue.document.getNode(richValue.selection.start.key); if (node == null) return { word: null, isAtStart: false }; let word = "", atStart = false; let offset = richValue.selection.start.offset; let block = richValue.document.getClosestBlock(node.key); while (true) { if (--offset < 0) { if ((node = block.getPreviousNode(node.key) == null)) { atStart = true; break; } if (node.object!== "text") break; offset = node.text.length - 1; } if (node.object !== "text") break; let prefix = node.text[offset]; if (/(\t|\s)/.test(prefix)) break; word = prefix + word; } return { word: !word ? null : word, isAtStart: atStart && block.type == "line" && richValue.document.nodes.get(0) === block }; } else { let textarea = BDFDB.ReactUtils.findDOMNode(editor.ref.current); if (!Node.prototype.isPrototypeOf(textarea) || textarea.tagName != "TEXTAREA" || !textarea.value.length || /\s/.test(textarea.value.slice(textarea.selectionStart, textarea.selectionEnd))) return { word: null, isAtStart: true }; else { if (textarea.selectionEnd == textarea.value.length) { let words = textarea.value.split(/\s/).reverse(); return { word: !words[0] ? null : words[0], isAtStart: words.length > 1 }; } else { let chars = textarea.value.split(""), word = "", currentWord = "", isCurrentWord = false, isAtStart = true; for (let i in chars) { if (i == textarea.selectionStart) isCurrentWord = true; if (/\s/.test(chars[i])) { word = ""; isAtStart = currentWord.length > 0 && isAtStart || false; isCurrentWord = false; } else { word += chars[i]; if (isCurrentWord) currentWord = word; } } return { word: !currentWord ? null : currentWord, isAtStart: isAtStart }; } } } }; BDFDB.NumberUtils = {}; BDFDB.NumberUtils.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.NumberUtils.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.NumberUtils.generateId = function (array) { array = BDFDB.ArrayUtils.is(array) ? array : []; let id = Math.floor(Math.random() * 10000000000000000); if (array.includes(id)) return BDFDB.NumberUtils.generateId(array); else { array.push(id); return id; } }; BDFDB.NumberUtils.compareVersions = 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.NumberUtils.getVersionDifference = 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.DiscordUtils = {}; BDFDB.DiscordUtils.openLink = function (url, inbuilt, minimized) { if (!inbuilt) window.open(url, "_blank"); else { let browserWindow = new LibraryRequires.electron.remote.BrowserWindow({ frame: true, resizeable: true, show: true, darkTheme: BDFDB.DiscordUtils.getTheme() == BDFDB.disCN.themedark, webPreferences: { nodeIntegration: false, nodeIntegrationInWorker: false } }); browserWindow.setMenu(null); browserWindow.loadURL(url); if (minimized) browserWindow.minimize(null); } }; BDFDB.DiscordUtils.getFolder = function () { var built = BDFDB.DiscordUtils.getBuilt(); built = "discord" + (built == "stable" ? "" : built); return LibraryRequires.path.resolve(LibraryRequires.electron.remote.app.getPath("appData"), built, BDFDB.DiscordUtils.getVersion()); }; BDFDB.DiscordUtils.getBuilt = function () { if (BDFDB.DiscordUtils.getBuilt.built) return BDFDB.DiscordUtils.getBuilt.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.DiscordUtils.getVersion(); 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.DiscordUtils.getBuilt.built = built; return built; } }; BDFDB.DiscordUtils.getVersion = function () { if (BDFDB.DiscordUtils.getBuilt.version) return BDFDB.DiscordUtils.getBuilt.version; else { var version = null; try {version = LibraryRequires.electron.remote.app.getVersion();} catch (err) {version = "";} BDFDB.DiscordUtils.getBuilt.version = version; return version; } }; BDFDB.DiscordUtils.isDevModeEnabled = function () { return LibraryModules.StoreUtils.get("UserSettingsStore").developerMode; }; BDFDB.DiscordUtils.getTheme = function () { return LibraryModules.StoreUtils.get("UserSettingsStore").theme == "dark" ? BDFDB.disCN.themedark : BDFDB.disCN.themelight; }; BDFDB.DiscordUtils.getMode = function () { return LibraryModules.StoreUtils.get("UserSettingsStore").message_display_compact ? "compact" : "cozy"; }; BDFDB.DiscordUtils.getZoomFactor = function () { var arects = BDFDB.DOMUtils.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.DiscordUtils.getFontScale = function () { return parseInt(document.firstElementChild.style.fontSize.replace("%", "")); }; BDFDB.DiscordUtils.shake = function () { BDFDB.ReactUtils.getInstance(document.querySelector(BDFDB.dotCN.appold)).return.stateNode.shake(); }; BDFDB.WindowUtils = {}; BDFDB.WindowUtils.open = function (plugin, url, options) { if (!BDFDB.ObjectUtils.is(plugin) || !url) return; if (!BDFDB.ArrayUtils.is(plugin.browserWindows)) plugin.browserWindows = []; let browserWindow = new LibraryRequires.electron.remote.BrowserWindow(Object.assign({ show: false, webPreferences: { nodeIntegration: true, nodeIntegrationInWorker: true } }, options)); if (typeof browserWindow.removeMenu == "function") browserWindow.removeMenu(); else browserWindow.setMenu(null); browserWindow.loadURL(url); plugin.browserWindows.push(browserWindow); return browserWindow; }; BDFDB.WindowUtils.close = function (browserWindow) { if (BDFDB.ObjectUtils.is(browserWindow) && !browserWindow.isDestroyed() && browserWindow.closeable) browserWindow.close(); }; BDFDB.WindowUtils.closeAll = function (plugin) { if (BDFDB.ObjectUtils.is(plugin) && BDFDB.ArrayUtils.is(plugin.browserWindows)) { for (let browserWindow of plugin.browserWindows) BDFDB.WindowUtils.close(browserWindow); plugin.browserWindows = []; } }; BDFDB.WindowUtils.addListener = function (plugin, actions, callback) { if (!BDFDB.ObjectUtils.is(plugin) || !actions || typeof callback != "function") return; BDFDB.WindowUtils.removeListener(plugin, actions); for (let action of actions.split(" ")) { action = action.split("."); let eventname = action.shift(); if (!eventname) return; let namespace = (action.join(".") || "") + plugin.name; if (!BDFDB.ArrayUtils.is(plugin.ipcListeners)) plugin.ipcListeners = []; plugin.ipcListeners.push({eventname, namespace, callback}); LibraryRequires.electron.ipcRenderer.on(eventname, callback); } }; BDFDB.WindowUtils.removeListener = function (plugin, actions = "") { if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ArrayUtils.is(plugin.ipcListeners)) return; if (actions) { for (let action of actions.split(" ")) { action = action.split("."); let eventname = action.shift(); let namespace = (action.join(".") || "") + plugin.name; for (let listener of plugin.ipcListeners) { let removedlisteners = []; if (listener.eventname == eventname && listener.namespace == namespace) { LibraryRequires.electron.ipcRenderer.off(listener.eventname, listener.callback); removedlisteners.push(listener); } if (removedlisteners.length) plugin.ipcListeners = plugin.ipcListeners.filter(listener => {return removedlisteners.indexOf(listener) < 0;}); } } } else { for (let listener of plugin.ipcListeners) LibraryRequires.electron.ipcRenderer.off(listener.eventname, listener.callback); plugin.ipcListeners = []; } }; BDFDB.BDUtils = {}; BDFDB.BDUtils.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.BDUtils.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.BDUtils.checkRepoPage = 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.BDUtils.isBDv2 = function () { return typeof BDFDB.BDv2Api !== "undefined"; }; BDFDB.BDUtils.isPluginEnabled = function (pluginName) { if (!pluginName) return false; if (!BDFDB.BDUtils.isBDv2()) return BdApi.isPluginEnabled(pluginName); else return BDFDB.Plugins[pluginName.toLowerCase()] ? BDFDB.Plugins[pluginName.toLowerCase()].enabled : null; }; BDFDB.BDUtils.getPlugin = function (pluginName, hasToBeEnabled = false) { if (!hasToBeEnabled || BDFDB.BDUtils.isPluginEnabled(pluginName)) return BdApi.getPlugin(pluginName); return null; }; BDFDB.BDUtils.isThemeEnabled = function (themename) { if (!BDFDB.BDUtils.isBDv2()) return BdApi.isThemeEnabled(themename) else return BDFDB.Themes[themename.toLowerCase()] ? BDFDB.Themes[themename.toLowerCase()].enabled : null; }; BDFDB.BDUtils.getTheme = function (themename, hasToBeEnabled = false) { if (window.bdthemes && (!hasToBeEnabled || BDFDB.BDUtils.isThemeEnabled(themename))) return window.bdthemes[themename]; return null; }; BDFDB.BDUtils.getSettings = function (key) { if (!window.settingsCookie) return null; if (!key) return window.settingsCookie; return window.settingsCookie[key]; }; BDFDB.BDUtils.isAutoLoadEnabled = function () { return BDFDB.BDUtils.getSettings("fork-ps-5") === true || BDFDB.BDUtils.isPluginEnabled("Restart-No-More") || BDFDB.BDUtils.isPluginEnabled("Restart No More"); }; (BDFDB.BDUtils.setPluginCache = function () { if (!BDFDB.BDUtils.isBDv2()) return; BDFDB.Plugins = {}; for (let plugin of BDFDB.BDv2Api.Plugins.listPlugins()) BDFDB.BDv2Api.Plugins.getPlugin(plugin).then(plugindata => {BDFDB.Plugins[plugin] = plugindata;}); })(); (BDFDB.BDUtils.setThemeCache = function () { if (!BDFDB.BDUtils.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", avatarStatusHovered: "statusHovered-gF2976", cardInner: "inner-OP_8zd", cardWrapper: "card-rT4Wbb", charCounter: "counter-uAzbKp", changeLogIcon: "icon-vGGh7_", changeLogModal: "changeLogModal-ny_dHC", collapseContainer: "container-fAVkOf", collapseContainerArrow: "arrow-uglXxc", collapseContainerCollapsed: "collapsed-2BUBZm", collapseContainerHeader: "header-2s6x-5", collapseContainerInner: "inner-TkGytd", collapseContainerMini: "container-fAVkOf containerMini-_k6Rts", collapseContainerTitle: "title-ROsJi-", colorPickerSwatches: "swatches", //swatches-QxZw_N colorPickerSwatchesDisabled: "disabled-2JgNxl", colorPickerSwatchSingle: "single-Fbb1wB", colorPickerSwatchSelected: "selected-f5IVXN", confirmModal: "confirmModal-t-WDWJ", dev: "dev-A7f2Rx", favButtonContainer: "favbutton-8Fzu45", guild: "guild-r3yAE_", guildLowerLeftBadge: "lowerLeftBadge-zr4T_9", guildUpperLeftBadge: "upperLeftBadge-e35IpL", hotkeyResetButton: "resetButton-hI9Ax7", hotkeyWrapper: "recorder-can0vx", inputNumberButton: "button-J9muv5", inputNumberButtonDown: "down-cOY7Qp button-J9muv5", inputNumberButtonUp: "up-mUs_72 button-J9muv5", inputNumberButtons: "buttons-our3p-", inputNumberWrapper: "numberInputWrapper-j4svZS", inputNumberWrapperDefault: "numberInputWrapperDefault-gRxcuK numberInputWrapper-j4svZS", inputNumberWrapperMini: "numberInputWrapperMini-wtUU31 numberInputWrapper-j4svZS", loadingIcon: "loadingIcon-cOYMPl", loadingIconWrapper: "loadingIconWrapper-PsVJ9m", lineThrough: "lineThrough-MPlPsV", overflowEllipsis: "ellipsis-qlo9sA", popoutWrapper: "popout-xwjvsX", quickSelectWrapper: "quickSelectWrapper-UCfTKz", quickSelectPopoutWrapper: "quickSelectPopout-u2dtIf", modalHeaderHasSibling: "hasSiblings-fRyjyl", modalInnerScrollerLess: "inner-YgPpF3", modalTabContent: "tab-content", modalTabContentOpen: "open", modalWrapper: "modal-6GHvdM", noticeWrapper: "noticeWrapper-8z511t", selectWrapper: "selectWrapper-yPjeij", settingsPanel: "settingsPanel-w2ySNR", settingsPanelInner: "settingsInner-zw1xAY", settingsPanelList: "settingsList-eZjkXj", settingsPanelTitle: "title-GTF_8J", settingsTableCard: "settingsTableCard-628t52", settingsTableCardConfigs: "settingsTableCardConfigs-w5X9-Z", settingsTableCardLabel: "settingsTableCardLabel-MElgIg", settingsTableHeaders: "settingsTableHeaders-WKzw9_", settingsTableHeaderVertical: "headerVertical-4MNxqk", settingsTableList: "settingsTableList-f6sW2y", supporter: "supporter-Z3FfwL", svgIcon: "icon-GhnIRB", table: "table-moqjM0", tableBodyCell: "bodyCell-dQam9V", tableHeader: "header-g67q9_", tableHeaderCell: "headerCell-T6Fo3K", tableHeaderCellSorted: "headerCellSorted-FMjMWK", tableHeaderSortIcon: "sortIcon-WZjMja", tableRow: "row-_9Ehcp", tableStickyHeader: "stickyHeader-JabwjW header-g67q9_", textScroller: "textScroller-dc9_kz", themedPopout: "themedPopout-1TrfdI", tooltipCustom: "tooltipCustom-hH39_Z", underline: "underline-6nu217" }; 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", bdUpdatebtn: "bd-updatebtn", settingsOpen: "settings-open", settingsClosed: "settings-closed", switch: "ui-switch", switchCheckbox: "ui-switch-checkbox", switchChecked: "checked", switchItem: "ui-switch-item", switchWrapper: "ui-switch-wrapper" }; DiscordClassModules.CharCounter = { charCounter: "charCounter-7fw40k charcounter", counterAdded: "counterAdded-zz9O4t" }; DiscordClassModules.EmojiStatistics = { statisticsButton: "statisticsButton-nW2KoM", amountCell: "amountCell-g_W6Rx", iconCell: "iconCell--wniOu", nameCell: "nameCell-xyXENZ" }; DiscordClassModules.GoogleTranslateOption = { reverseButton: "reverseButton-5S47qV", translateButton: "translateButton-DhP9x8", translated: "translated-5YO8i3", translating: "translating-Yi-YxC" }; DiscordClassModules.ImageGallery = { gallery: "gallery-JViwKR", previous: "previous-xsNq6B", next: "next-SHEZrz" }; DiscordClassModules.ImageZoom = { backdrop: "lenseBackdrop-yEm7Om", lense: "zoomLense-uOK8xV", modal: "imageModal-8J0ttB" }; DiscordClassModules.PinDMs = { dragPreview: "dragPreview-nXiByA", dmChannelPinned: "pinned-0lM4wD", dmChannelPlaceholder: "placeholder-7bhR5s", pinnedChannelsHeaderAmount: "headerAmount-_-7GrS", pinnedChannelsHeaderArrow: "pinnedChannelsHeaderArrow-44rrTz", pinnedChannelsHeaderCollapsed: "collapsed-3w_-ff", pinnedChannelsHeaderColored: "colored-oIzG5s", pinnedChannelsHeaderContainer: "pinnedChannelsHeaderContainer-89Gjv4", recentPinned: "pinned-jHvFrr", recentPlaceholder: "placeholder-Uff-gH", unpinButton: "unpinButton-z3-UVO", unpinIcon: "unpinIcon-79ZnEr" }; DiscordClassModules.ReadAllNotificationsButton = { button: "button-Jt-tIg", frame: "frame-oXWS21", innerFrame: "innerFrame-8Hg64E" }; DiscordClassModules.ServerFolders = { dragPreview: "dragPreview-nXiByA", guildPlaceholder: "placeholder-7bhR5s", folderContent: "content-Pph8t6 foldercontent", folderContentClosed: "closed-j55_T- foldercontentclosed", folderContentIsOpen: "folderContentIsOpen-zz6FgW foldercontentopened", iconSwatch: "iconSwatch-_78Ghj", iconSwatchInner: "iconInner-aOY-qk", iconSwatchPreview: "preview-Bbg_24", iconSwatchSelected: "selected-P5oePO" }; DiscordClassModules.ShowImageDetails = { details: "details-1t6Zms", detailsAdded: "detailsAdded-SAy48f" }; DiscordClassModules.SpellCheck = { error: "error-k9z2IV", overlay: "spellCheckOverlay-cNSap5" }; DiscordClassModules.TopRolesEverywhere = { badgeStyle: "badgeStyle-tFiEQ8", chatTag: "chatTag-Y-5TDc", memberTag: "memberTag-QVWzGc", roleStyle: "roleStyle-jQ7KI2", tag: "tag-wWVHyf" }; DiscordClassModules.NotFound = { _: "", badgeWrapper: "wrapper-232cHJ", channelPanelTitle: "title-eS5yk3", emoji: "emoji", guildChannels: "container-PNkimc", highlight: "highlight", hoverCardButton: "button-2CgfFz", loginScreen: "wrapper-3Q5DdO", mention: "mention", mentionWrapper: "wrapper-3WhCwL", nameContainerNameContainer: "container-2ax-kl", quickSelectPopoutOptionSelected: "selected", 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", stopAnimations: "stop-animations", subtext: "subtext-3CDbHg", themeDark: "theme-dark", themeLight: "theme-light", themeUndefined: "theme-undefined", voiceDraggable: "draggable-1KoBzC" }; DiscordClassModules.AccountDetails = BDFDB.ModuleUtils.findByProperties("usernameContainer", "container"); DiscordClassModules.AccountDetailsButtons = BDFDB.ModuleUtils.findByProperties("button", "enabled", "disabled"); DiscordClassModules.Anchor = BDFDB.ModuleUtils.findByProperties("anchor", "anchorUnderlineOnHover"); DiscordClassModules.AnimationContainer = BDFDB.ModuleUtils.findByProperties("animatorLeft", "didRender"); DiscordClassModules.AppBase = BDFDB.ModuleUtils.findByProperties("container", "base"); DiscordClassModules.AppInner = BDFDB.ModuleUtils.findByProperties("app", "layers"); DiscordClassModules.AppMount = BDFDB.ModuleUtils.findByProperties("appMount"); DiscordClassModules.ApplicationStore = BDFDB.ModuleUtils.findByProperties("applicationStore", "navigation"); DiscordClassModules.AppOuter = BDFDB.ModuleUtils.find(m => typeof m.app == "string" && Object.keys(m).length == 1); DiscordClassModules.AuditLog = BDFDB.ModuleUtils.findByProperties("auditLog"); DiscordClassModules.AuthBox = BDFDB.ModuleUtils.findByProperties("authBox"); DiscordClassModules.Autocomplete = BDFDB.ModuleUtils.findByProperties("autocomplete", "autocompleteRow"); DiscordClassModules.Avatar = BDFDB.ModuleUtils.findByProperties("avatar", "mask", "wrapper"); DiscordClassModules.AvatarIcon = BDFDB.ModuleUtils.findByProperties("iconActiveLarge", "iconActiveMedium"); DiscordClassModules.Backdrop = BDFDB.ModuleUtils.findByProperties("backdrop"); DiscordClassModules.Badge = BDFDB.ModuleUtils.findByProperties("numberBadge", "textBadge", "iconBadge"); DiscordClassModules.BotTag = BDFDB.ModuleUtils.findByProperties("botTag", "botTagInvert"); DiscordClassModules.Button = BDFDB.ModuleUtils.findByProperties("colorBlack", "button"); DiscordClassModules.Call = BDFDB.ModuleUtils.findByProperties("callAvatarWrapper", "video"); DiscordClassModules.CallCurrent = BDFDB.ModuleUtils.findByProperties("wrapper", "fullScreen"); DiscordClassModules.CallDetails = BDFDB.ModuleUtils.findByProperties("container", "hotspot"); DiscordClassModules.CallIncoming = BDFDB.ModuleUtils.findByProperties("incomingCall", "container"); DiscordClassModules.CallIncomingInner = BDFDB.ModuleUtils.findByProperties("incomingCallInner", "members"); DiscordClassModules.Card = BDFDB.ModuleUtils.findByProperties("card", "cardBrand"); DiscordClassModules.CardStatus = BDFDB.ModuleUtils.findByProperties("reset", "error", "card"); DiscordClassModules.Category = BDFDB.ModuleUtils.findByProperties("wrapper", "children", "muted"); DiscordClassModules.CategoryContainer = BDFDB.ModuleUtils.findByProperties("addButtonIcon", "containerDefault"); DiscordClassModules.ChangeLog = BDFDB.ModuleUtils.findByProperties("added", "fixed", "improved", "progress"); DiscordClassModules.Channel = BDFDB.ModuleUtils.findByProperties("wrapper", "content", "modeSelected"); DiscordClassModules.ChannelContainer = BDFDB.ModuleUtils.findByProperties("actionIcon", "containerDefault"); DiscordClassModules.ChannelLimit = BDFDB.ModuleUtils.findByProperties("users", "total", "wrapper"); DiscordClassModules.ChannelTextArea = BDFDB.ModuleUtils.findByProperties("textArea", "buttons"); DiscordClassModules.ChannelTextAreaAttachButton = BDFDB.ModuleUtils.findByProperties("attachButton", "attachWrapper"); DiscordClassModules.ChannelTextAreaButton = BDFDB.ModuleUtils.findByProperties("buttonWrapper", "active"); DiscordClassModules.ChannelTextAreaCharCounter = BDFDB.ModuleUtils.findByProperties("characterCount", "error"); DiscordClassModules.ChannelTextAreaSlate = BDFDB.ModuleUtils.findByProperties("slateContainer", "placeholder"); DiscordClassModules.ChatWindow = BDFDB.ModuleUtils.findByProperties("chat", "channelTextArea"); DiscordClassModules.Checkbox = BDFDB.ModuleUtils.findByProperties("checkboxWrapper", "round"); DiscordClassModules.ColorPicker = BDFDB.ModuleUtils.findByProperties("colorPickerCustom", "customColorPickerInput"); DiscordClassModules.ColorPickerInner = BDFDB.ModuleUtils.findByProperties("saturation", "hue", "wrapper"); DiscordClassModules.ContextMenu = BDFDB.ModuleUtils.findByProperties("contextMenu", "itemGroup"); DiscordClassModules.ContextMenuCheckbox = BDFDB.ModuleUtils.findByProperties("checkboxInner", "checkboxElement"); DiscordClassModules.CtaVerification = BDFDB.ModuleUtils.findByProperties("attendeeCTA", "verificationNotice"); DiscordClassModules.Cursor = BDFDB.ModuleUtils.findByProperties("cursorDefault", "userSelectNone"); DiscordClassModules.CustomStatus = BDFDB.ModuleUtils.findByProperties("customStatusContentIcon", "customStatus"); DiscordClassModules.CustomStatusIcon = BDFDB.ModuleUtils.findByProperties("icon", "emoji"); DiscordClassModules.DmAddPopout = BDFDB.ModuleUtils.findByProperties("popout", "searchBarComponent"); DiscordClassModules.DmAddPopoutItems = BDFDB.ModuleUtils.findByProperties("friendSelected", "friendWrapper"); DiscordClassModules.DownloadLink = BDFDB.ModuleUtils.findByProperties("downloadLink"); DiscordClassModules.Embed = BDFDB.ModuleUtils.findByProperties("embed", "embedAuthorIcon"); DiscordClassModules.EmbedActions = BDFDB.ModuleUtils.findByProperties("iconPlay", "iconWrapperActive"); DiscordClassModules.Emoji = BDFDB.ModuleUtils.find(m => typeof m.emoji == "string" && Object.keys(m).length == 1); DiscordClassModules.EmojiButton = BDFDB.ModuleUtils.findByProperties("emojiButton", "sprite"); DiscordClassModules.EmojiPicker = BDFDB.ModuleUtils.findByProperties("emojiPicker", "categories"); DiscordClassModules.File = BDFDB.ModuleUtils.findByProperties("downloadButton", "fileNameLink"); DiscordClassModules.Flex = BDFDB.ModuleUtils.findByProperties("alignBaseline", "alignCenter"); DiscordClassModules.FlexChild = BDFDB.ModuleUtils.findByProperties("flexChild", "flex"); DiscordClassModules.FlowerStar = BDFDB.ModuleUtils.findByProperties("flowerStarContainer", "flowerStar"); DiscordClassModules.FormText = BDFDB.ModuleUtils.findByProperties("description", "modeDefault"); DiscordClassModules.Friends = BDFDB.ModuleUtils.findByProperties("friendsColumn", "friendsRow"); DiscordClassModules.Game = BDFDB.ModuleUtils.findByProperties("game", "gameName"); DiscordClassModules.GameIcon = BDFDB.ModuleUtils.findByProperties("gameIcon", "small", "xsmall"); DiscordClassModules.GameLibraryTable = BDFDB.ModuleUtils.findByProperties("stickyHeader", "emptyStateText"); DiscordClassModules.GifFavoriteButton = BDFDB.ModuleUtils.findByProperties("gifFavoriteButton", "showPulse"); DiscordClassModules.GoLiveDetails = BDFDB.ModuleUtils.findByProperties("panel", "gameWrapper"); DiscordClassModules.Guild = BDFDB.ModuleUtils.findByProperties("wrapper", "lowerBadge", "svg"); DiscordClassModules.GuildChannels = BDFDB.ModuleUtils.findByProperties("positionedContainer", "unreadBar"); DiscordClassModules.GuildDiscovery = BDFDB.ModuleUtils.findByProperties("pageWrapper", "guildCard"); DiscordClassModules.GuildDm = BDFDB.ModuleUtils.find(m => typeof m.pill == "string" && Object.keys(m).length == 1); DiscordClassModules.GuildEdges = BDFDB.ModuleUtils.findByProperties("wrapper", "edge", "autoPointerEvents") DiscordClassModules.GuildFolder = BDFDB.ModuleUtils.findByProperties("folder", "expandedGuilds") DiscordClassModules.GuildHeader = BDFDB.ModuleUtils.findByProperties("header", "name", "bannerImage"); DiscordClassModules.GuildHeaderButton = BDFDB.ModuleUtils.findByProperties("button", "open"); DiscordClassModules.GuildIcon = BDFDB.ModuleUtils.findByProperties("acronym", "selected", "wrapper"); DiscordClassModules.GuildInvite = BDFDB.ModuleUtils.findByProperties("wrapper", "guildIconJoined"); DiscordClassModules.GuildSettingsBanned = BDFDB.ModuleUtils.findByProperties("bannedUser", "bannedUserAvatar"); DiscordClassModules.GuildSettingsEmoji = BDFDB.ModuleUtils.findByProperties("emojiRow", "emojiAliasPlaceholder"); DiscordClassModules.GuildSettingsInvite = BDFDB.ModuleUtils.findByProperties("countdownColumn", "inviteSettingsInviteRow"); DiscordClassModules.GuildSettingsMember = BDFDB.ModuleUtils.findByProperties("member", "membersFilterPopout"); DiscordClassModules.GuildServer = BDFDB.ModuleUtils.findByProperties("blobContainer", "pill"); DiscordClassModules.GuildsItems = BDFDB.ModuleUtils.findByProperties("guildSeparator", "guildsError"); DiscordClassModules.GuildsWrapper = BDFDB.ModuleUtils.findByProperties("scrollerWrap", "unreadMentionsBar", "wrapper"); DiscordClassModules.HeaderBar = BDFDB.ModuleUtils.findByProperties("container", "children", "toolbar"); DiscordClassModules.HeaderBarExtras = BDFDB.ModuleUtils.findByProperties("headerBarLoggedOut", "search"); DiscordClassModules.HeaderBarSearch = BDFDB.ModuleUtils.findByProperties("search", "searchBar", "open"); DiscordClassModules.HeaderBarTopic = BDFDB.ModuleUtils.findByProperties("topic", "expandable", "content"); DiscordClassModules.HomeIcon = BDFDB.ModuleUtils.findByProperties("homeIcon"); DiscordClassModules.HotKeyRecorder = BDFDB.ModuleUtils.findByProperties("editIcon", "recording"); DiscordClassModules.HoverCard = BDFDB.ModuleUtils.findByProperties("card", "active"); DiscordClassModules.IconDirection = BDFDB.ModuleUtils.findByProperties("directionDown", "directionUp"); DiscordClassModules.ImageWrapper = BDFDB.ModuleUtils.findByProperties("clickable", "imageWrapperBackground"); DiscordClassModules.InviteModal = BDFDB.ModuleUtils.findByProperties("inviteRow", "modal"); DiscordClassModules.Item = BDFDB.ModuleUtils.findByProperties("item", "side", "header"); DiscordClassModules.ItemRole = BDFDB.ModuleUtils.findByProperties("role", "dragged"); DiscordClassModules.ItemLayerContainer = BDFDB.ModuleUtils.findByProperties("layer", "layerContainer"); DiscordClassModules.Input = BDFDB.ModuleUtils.findByProperties("inputMini", "inputDefault"); DiscordClassModules.LayerModal = BDFDB.ModuleUtils.findByProperties("root", "small", "medium"); DiscordClassModules.Layers = BDFDB.ModuleUtils.findByProperties("layer", "layers"); DiscordClassModules.LiveTag = BDFDB.ModuleUtils.findByProperties("liveLarge", "live"); DiscordClassModules.Margins = BDFDB.ModuleUtils.findByProperties("marginBottom4", "marginCenterHorz"); DiscordClassModules.Member = BDFDB.ModuleUtils.findByProperties("member", "ownerIcon"); DiscordClassModules.MembersWrap = BDFDB.ModuleUtils.findByProperties("membersWrap", "membersGroup"); DiscordClassModules.Message = BDFDB.ModuleUtils.findByProperties("message", "mentioned"); DiscordClassModules.MessageAccessory = BDFDB.ModuleUtils.findByProperties("embedWrapper", "gifFavoriteButton"); DiscordClassModules.MessageBody = BDFDB.ModuleUtils.findByProperties("markupRtl", "edited"); DiscordClassModules.MessageElements = BDFDB.ModuleUtils.findByProperties("messageGroupBlockedBtn", "dividerRed"); DiscordClassModules.MessageFile = BDFDB.ModuleUtils.findByProperties("cancelButton", "filenameLinkWrapper"); DiscordClassModules.MessageItems = BDFDB.ModuleUtils.findByProperties("avatar", "botTag", "timestampVisibleOnHover"); DiscordClassModules.MessageMarkup = BDFDB.ModuleUtils.findByProperties("markup"); DiscordClassModules.MessageOperations = BDFDB.ModuleUtils.find(m => typeof m.operations == "string" && Object.keys(m).length == 1); DiscordClassModules.MessageSystem = BDFDB.ModuleUtils.findByProperties("container", "actionAnchor"); DiscordClassModules.MessageToolbar = BDFDB.ModuleUtils.findByProperties("container", "icon", "isHeader"); DiscordClassModules.MessageToolbarItems = BDFDB.ModuleUtils.findByProperties("wrapper", "button", "separator"); DiscordClassModules.MessagesPopout = BDFDB.ModuleUtils.findByProperties("messagesPopoutWrap", "jumpButton"); DiscordClassModules.MessagesWelcome = BDFDB.ModuleUtils.findByProperties("welcomeMessage", "h1"); DiscordClassModules.MessagesWrap = BDFDB.ModuleUtils.findByProperties("messagesWrapper", "messageGroupBlocked"); DiscordClassModules.Modal = BDFDB.ModuleUtils.findByProperties("modal", "sizeLarge"); DiscordClassModules.ModalDivider = BDFDB.ModuleUtils.find(m => typeof m.divider == "string" && Object.keys(m).length == 1); DiscordClassModules.ModalItems = BDFDB.ModuleUtils.findByProperties("guildName", "checkboxContainer"); DiscordClassModules.ModalMiniContent = BDFDB.ModuleUtils.find(m => typeof m.modal == "string" && typeof m.content == "string" && Object.keys(m).length == 2); DiscordClassModules.ModalWrap = BDFDB.ModuleUtils.find(m => typeof m.modal == "string" && typeof m.inner == "string" && Object.keys(m).length == 2); DiscordClassModules.NameContainer = DiscordClassModules.ContextMenu.subMenuContext ? BDFDB.ModuleUtils.findByProperties("nameAndDecorators", "name") : {}; DiscordClassModules.NameTag = BDFDB.ModuleUtils.findByProperties("bot", "nameTag"); DiscordClassModules.Note = BDFDB.ModuleUtils.find(m => typeof m.note == "string" && Object.keys(m).length == 1); DiscordClassModules.Notice = BDFDB.ModuleUtils.findByProperties("notice", "noticeFacebook"); DiscordClassModules.Peoples = BDFDB.ModuleUtils.findByProperties("peopleColumn", "tabBar"); DiscordClassModules.PictureInPicture = BDFDB.ModuleUtils.findByProperties("pictureInPicture", "pictureInPictureWindow"); DiscordClassModules.PillWrapper = BDFDB.ModuleUtils.find(m => typeof m.item == "string" && typeof m.wrapper == "string" && Object.keys(m).length == 2); DiscordClassModules.PrivateChannel = BDFDB.ModuleUtils.findByProperties("channel", "closeButton"); DiscordClassModules.PrivateChannelList = BDFDB.ModuleUtils.findByProperties("privateChannels", "searchBar"); DiscordClassModules.PrivateChannelListScroller = BDFDB.ModuleUtils.findByProperties("scroller", "empty"); DiscordClassModules.Popout = BDFDB.ModuleUtils.findByProperties("popout", "arrowAlignmentTop"); DiscordClassModules.PopoutActivity = BDFDB.ModuleUtils.findByProperties("ellipsis", "activityActivityFeed"); DiscordClassModules.QuickMessage = BDFDB.ModuleUtils.findByProperties("quickMessage", "isBlocked"); DiscordClassModules.QuickSelect = BDFDB.ModuleUtils.findByProperties("quickSelectArrow", "selected"); DiscordClassModules.QuickSwitch = BDFDB.ModuleUtils.findByProperties("resultFocused", "guildIconContainer"); DiscordClassModules.QuickSwitchWrap = BDFDB.ModuleUtils.findByProperties("container", "miscContainer"); DiscordClassModules.Reactions = BDFDB.ModuleUtils.findByProperties("reactionBtn", "reaction"); DiscordClassModules.RecentMentions = BDFDB.ModuleUtils.findByProperties("recentMentionsFilterPopout", "mentionFilter"); DiscordClassModules.Role = BDFDB.ModuleUtils.findByProperties("roleCircle", "roleName"); DiscordClassModules.Scrollbar = BDFDB.ModuleUtils.findByProperties("scrollbar", "scrollbarGhost"); DiscordClassModules.Scroller = BDFDB.ModuleUtils.findByProperties("scrollerThemed", "scroller"); DiscordClassModules.SearchBar = BDFDB.ModuleUtils.findByProperties("container", "clear"); DiscordClassModules.SearchPopout = BDFDB.ModuleUtils.findByProperties("datePicker", "searchResultChannelIconBackground"); DiscordClassModules.SearchPopoutWrap = BDFDB.ModuleUtils.findByProperties("container", "queryContainer"); DiscordClassModules.SearchResults = BDFDB.ModuleUtils.findByProperties("messageGroupCozy", "searchResultsWrap"); DiscordClassModules.Select = BDFDB.ModuleUtils.findByProperties("select", "error", "errorMessage"); DiscordClassModules.SettingsCloseButton = BDFDB.ModuleUtils.findByProperties("closeButton", "keybind"); DiscordClassModules.SettingsItems = BDFDB.ModuleUtils.findByProperties("dividerMini", "note"); DiscordClassModules.SettingsTable = BDFDB.ModuleUtils.findByProperties("headerOption", "headerSize"); DiscordClassModules.SettingsWindow = BDFDB.ModuleUtils.findByProperties("contentRegion", "standardSidebarView"); DiscordClassModules.Slider = BDFDB.ModuleUtils.findByProperties("slider", "grabber"); DiscordClassModules.Spoiler = BDFDB.ModuleUtils.findByProperties("spoilerContainer", "hidden"); DiscordClassModules.Switch = BDFDB.ModuleUtils.findByProperties("switchDisabled", "valueChecked"); DiscordClassModules.Table = BDFDB.ModuleUtils.findByProperties("stickyHeader", "sortIcon"); DiscordClassModules.Text = BDFDB.ModuleUtils.findByProperties("defaultColor", "defaultMarginh1"); DiscordClassModules.TextColor = BDFDB.ModuleUtils.findByProperties("colorStandard", "colorMuted", "colorError"); DiscordClassModules.TextColor2 = BDFDB.ModuleUtils.findByProperties("base", "muted", "wrapper"); DiscordClassModules.TextSize = BDFDB.ModuleUtils.findByProperties("size10", "size14", "size20"); DiscordClassModules.TextStyle = BDFDB.ModuleUtils.findByProperties("large", "primary", "selectable"); DiscordClassModules.Tip = BDFDB.ModuleUtils.findByProperties("pro", "inline"); DiscordClassModules.Title = BDFDB.ModuleUtils.findByProperties("title", "size18"); DiscordClassModules.TitleBar = BDFDB.ModuleUtils.findByProperties("titleBar", "wordmark"); DiscordClassModules.Tooltip = BDFDB.ModuleUtils.findByProperties("tooltip", "tooltipTop"); DiscordClassModules.TooltipGuild = BDFDB.ModuleUtils.findByProperties("rowIcon", "rowGuildName"); DiscordClassModules.Typing = BDFDB.ModuleUtils.findByProperties("cooldownWrapper", "typing"); DiscordClassModules.UnreadBar = BDFDB.ModuleUtils.findByProperties("active", "bar", "unread"); DiscordClassModules.UploadModal = BDFDB.ModuleUtils.findByProperties("uploadModal", "bgScale"); DiscordClassModules.UserPopout = BDFDB.ModuleUtils.findByProperties("userPopout", "headerPlaying"); DiscordClassModules.UserProfile = BDFDB.ModuleUtils.findByProperties("topSectionNormal", "tabBarContainer"); DiscordClassModules.Video = BDFDB.ModuleUtils.findByProperties("video", "fullScreen"); DiscordClassModules.VoiceChannel = BDFDB.ModuleUtils.findByProperties("avatarSpeaking", "voiceUser"); DiscordClassModules.VoiceChannelList = BDFDB.ModuleUtils.findByProperties("list", "collapsed"); DiscordClassModules.VoiceDetails = BDFDB.ModuleUtils.findByProperties("container", "customStatusContainer"); DiscordClassModules.VoiceDetailsPing = BDFDB.ModuleUtils.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"], _charcountercounter: ["CharCounter", "charCounter"], _charcountercounteradded: ["CharCounter", "counterAdded"], _emojistatisticsstatisticsbutton: ["EmojiStatistics", "statisticsButton"], _emojistatisticsamountcell: ["EmojiStatistics", "amountCell"], _emojistatisticsiconcell: ["EmojiStatistics", "iconCell"], _emojistatisticsnamecell: ["EmojiStatistics", "nameCell"], _imagegallerygallery: ["ImageGallery", "gallery"], _imagegalleryprevious: ["ImageGallery", "previous"], _imagegallerynext: ["ImageGallery", "next"], _imagezoombackdrop: ["ImageZoom", "backdrop"], _imagezoomimagemodal: ["ImageZoom", "modal"], _imagezoomlense: ["ImageZoom", "lense"], _googletranslateoptionreversebutton: ["GoogleTranslateOption", "reverseButton"], _googletranslateoptiontranslatebutton: ["GoogleTranslateOption", "translateButton"], _googletranslateoptiontranslated: ["GoogleTranslateOption", "translated"], _googletranslateoptiontranslating: ["GoogleTranslateOption", "translating"], _pindmsdragpreview: ["PinDMs", "dragPreview"], _pindmsdmchannelpinned: ["PinDMs", "dmChannelPinned"], _pindmsdmchannelplaceholder: ["PinDMs", "dmChannelPlaceholder"], _pindmspinnedchannelsheaderamount: ["PinDMs", "pinnedChannelsHeaderAmount"], _pindmspinnedchannelsheaderarrow: ["PinDMs", "pinnedChannelsHeaderArrow"], _pindmspinnedchannelsheadercollapsed: ["PinDMs", "pinnedChannelsHeaderCollapsed"], _pindmspinnedchannelsheadercolored: ["PinDMs", "pinnedChannelsHeaderColored"], _pindmspinnedchannelsheadercontainer: ["PinDMs", "pinnedChannelsHeaderContainer"], _pindmsrecentpinned: ["PinDMs", "recentPinned"], _pindmsrecentplaceholder: ["PinDMs", "recentPlaceholder"], _pindmsunpinbutton: ["PinDMs", "unpinButton"], _pindmsunpinicon: ["PinDMs", "unpinIcon"], _readallnotificationsbuttonbutton: ["ReadAllNotificationsButton", "button"], _readallnotificationsbuttonframe: ["ReadAllNotificationsButton", "frame"], _readallnotificationsbuttoninner: ["ReadAllNotificationsButton", "innerFrame"], _serverfoldersdragpreview: ["ServerFolders", "dragPreview"], _serverfoldersfoldercontent: ["ServerFolders", "folderContent"], _serverfoldersfoldercontentclosed: ["ServerFolders", "folderContentClosed"], _serverfoldersfoldercontentisopen: ["ServerFolders", "folderContentIsOpen"], _serverfoldersguildplaceholder: ["ServerFolders", "guildPlaceholder"], _serverfoldersiconswatch: ["ServerFolders", "iconSwatch"], _serverfoldersiconswatchinner: ["ServerFolders", "iconSwatchInner"], _serverfoldersiconswatchpreview: ["ServerFolders", "iconSwatchPreview"], _serverfoldersiconswatchselected: ["ServerFolders", "iconSwatchSelected"], _showimagedetailsdetails: ["ShowImageDetails", "details"], _showimagedetailsdetailsadded: ["ShowImageDetails", "detailsAdded"], _spellcheckerror: ["SpellCheck", "error"], _spellcheckoverlay: ["SpellCheck", "overlay"], _toproleseverywherebadgestyle: ["TopRolesEverywhere", "badgeStyle"], _toproleseverywherechattag: ["TopRolesEverywhere", "chatTag"], _toproleseverywheremembertag: ["TopRolesEverywhere", "memberTag"], _toproleseverywhererolestyle: ["TopRolesEverywhere", "roleStyle"], _toproleseverywheretag: ["TopRolesEverywhere", "tag"], _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"], _repoupdatebutton: ["BDrepo", "bdUpdatebtn"], _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"], alignbaseline: ["Flex", "alignBaseline"], aligncenter: ["Flex", "alignCenter"], alignend: ["Flex", "alignEnd"], alignstart: ["Flex", "alignStart"], alignstretch: ["Flex", "alignStretch"], anchor: ["Anchor", "anchor"], anchorunderlineonhover: ["Anchor", "anchorUnderlineOnHover"], animationcontainerbottom: ["AnimationContainer", "animatorBottom"], animationcontainerleft: ["AnimationContainer", "animatorLeft"], animationcontainerright: ["AnimationContainer", "animatorRight"], animationcontainertop: ["AnimationContainer", "animatorTop"], animationcontainerrender: ["AnimationContainer", "didRender"], animationcontainerscale: ["AnimationContainer", "scale"], animationcontainertranslate: ["AnimationContainer", "translate"], app: ["AppOuter", "app"], appcontainer: ["AppBase", "container"], appmount: ["AppMount", "appMount"], applayers: ["AppInner", "layers"], applicationstore: ["ApplicationStore", "applicationStore"], appold: ["AppInner", "app"], auditlog: ["AuditLog", "auditLog"], auditlogoverflowellipsis: ["AuditLog", "overflowEllipsis"], auditloguserhook: ["AuditLog", "userHook"], authbox: ["AuthBox", "authBox"], autocomplete: ["Autocomplete", "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"], avatarstatushovered: ["BDFDB", "avatarStatusHovered"], avatarwrapper: ["Avatar", "wrapper"], backdrop: ["Backdrop", "backdrop"], badgewrapper: ["NotFound", "badgeWrapper"], bdfdbdev: ["BDFDB", "dev"], bdfdbsupporter: ["BDFDB", "supporter"], bottag: ["BotTag", "botTag"], bottaginvert: ["BotTag", "botTagInvert"], bottagmember: ["Member", "botTag"], 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"], 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"], changelogcontainer: ["ChangeLog", "container"], changelogfixed: ["ChangeLog", "fixed"], changelogicon: ["BDFDB", "changeLogIcon"], 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"], charcounter: ["BDFDB", "charCounter"], chat: ["ChatWindow", "chat"], chatbase: ["AppBase", "base"], chatcontent: ["ChatWindow", "chatContent"], chatform: ["ChatWindow", "form"], chatinner: ["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"], collapsecontainer: ["BDFDB", "collapseContainer"], collapsecontainerarrow: ["BDFDB", "collapseContainerArrow"], collapsecontainercollapsed: ["BDFDB", "collapseContainerCollapsed"], collapsecontainerheader: ["BDFDB", "collapseContainerHeader"], collapsecontainerinner: ["BDFDB", "collapseContainerInner"], collapsecontainermini: ["BDFDB", "collapseContainerMini"], collapsecontainertitle: ["BDFDB", "collapseContainerTitle"], 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"], colorpickerswatches: ["BDFDB", "colorPickerSwatches"], colorpickerswatchesdisabled: ["BDFDB", "colorPickerSwatchesDisabled"], colorpickerswatchcustom: ["ColorPicker", "custom"], colorpickerswatchdefault: ["ColorPicker", "default"], colorpickerswatchdisabled: ["ColorPicker", "disabled"], colorpickerswatchdropper: ["ColorPicker", "colorPickerDropper"], colorpickerswatchdropperfg: ["ColorPicker", "colorPickerDropperFg"], colorpickerswatchnocolor: ["ColorPicker", "noColor"], colorpickerswatchselected: ["BDFDB", "colorPickerSwatchSelected"], colorpickerswatchsingle: ["BDFDB", "colorPickerSwatchSingle"], colorstandard: ["TextColor", "colorStandard"], contentcolumn: ["SettingsWindow", "contentColumn"], 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"], cursordefault: ["Cursor", "cursorDefault"], cursorpointer: ["Cursor", "cursorPointer"], customstatus: ["CustomStatus", "customStatus"], customstatuscontenticon: ["CustomStatus", "customStatusContentIcon"], customstatusemoji: ["CustomStatusIcon", "emoji"], customstatusicon: ["CustomStatusIcon", "icon"], 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"], divider: ["ModalDivider", "divider"], dividerdefault: ["SettingsItems", "dividerDefault"], dividermini: ["SettingsItems", "dividerMini"], modaldivider: ["ModalDivider", "divider"], // REMOVE modaldividerdefault: ["SettingsItems", "dividerDefault"], // REMOVE modaldividermini: ["SettingsItems", "dividerMini"], // REMOVE dmchannel: ["PrivateChannel", "channel"], dmchannelactivity: ["PrivateChannel", "activity"], dmchannelactivityemoji: ["PrivateChannel", "activityEmoji"], dmchannelactivitytext: ["PrivateChannel", "activityText"], dmchannelclose: ["PrivateChannel", "closeButton"], dmchannelheader: ["PrivateChannelList", "header"], dmchannelheadercontainer: ["PrivateChannelList", "privateChannelsHeaderContainer"], dmchannelheadertext: ["PrivateChannelList", "headerText"], dmchannels: ["PrivateChannelList", "privateChannels"], dmchannelsempty: ["PrivateChannelListScroller", "empty"], dmchannelsscroller: ["PrivateChannelListScroller", "scroller"], 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"], embeddescription: ["Embed", "embedDescription"], embedfield: ["Embed", "embedField"], embedfieldname: ["Embed", "embedFieldName"], embedfields: ["Embed", "embedFields"], embedfieldvalue: ["Embed", "embedFieldValue"], embedfooter: ["Embed", "embedFooter"], embedfootericon: ["Embed", "embedFooterIcon"], embedfooterseparator: ["Embed", "embedFooterSeparator"], embedfootertext: ["Embed", "embedFooterText"], embedfull: ["Embed", "embedFull"], embedgiftag: ["Embed", "embedGIFTag"], embedgrid: ["Embed", "grid"], embedhasthumbnail: ["Embed", "hasThumbnail"], embedhiddenspoiler: ["Embed", "hiddenSpoiler"], embediframe: ["Embed", "embedIframe"], embedimage: ["Embed", "embedImage"], embedlink: ["Embed", "embedLink"], embedmargin: ["Embed", "embedMargin"], embedmedia: ["Embed", "embedMedia"], embedprovider: ["Embed", "embedProvider"], 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"], emoji: ["Emoji", "emoji"], emojiold: ["NotFound", "emoji"], emojibutton: ["EmojiButton", "emojiButton"], emojibuttonhovered: ["EmojiButton", "emojiButtonHovered"], emojibuttonnormal: ["EmojiButton", "emojiButtonNormal"], emojibuttonsprite: ["EmojiButton", "sprite"], emojipicker: ["EmojiPicker", "emojiPicker"], emojipickerbutton: ["Reactions", "reactionBtn"], emojipickercategories: ["EmojiPicker", "categories"], emojipickercategory: ["EmojiPicker", "category"], emojipickerdisabled: ["EmojiPicker", "disabled"], emojipickerdiversityselector: ["EmojiPicker", "diversitySelector"], emojipickeremojiitem: ["EmojiPicker", "emojiItem"], emojipickerheader: ["EmojiPicker", "header"], emojipickeritem: ["EmojiPicker", "item"], emojipickerpopout: ["EmojiPicker", "popout"], emojipickerpremiumpromo: ["EmojiPicker", "premiumPromo"], emojipickerpremiumpromoclose: ["EmojiPicker", "premiumPromoClose"], emojipickerpremiumpromodescription: ["EmojiPicker", "premiumPromoDescription"], emojipickerpremiumpromoimage: ["EmojiPicker", "premiumPromoImage"], emojipickerpremiumpromotitle: ["EmojiPicker", "premiumPromoTitle"], emojipickerrow: ["EmojiPicker", "row"], emojipickersearchbar: ["EmojiPicker", "searchBar"], emojipickerscroller: ["EmojiPicker", "scroller"], emojipickerscrollerwrap: ["EmojiPicker", "scrollerWrap"], emojipickerselected: ["EmojiPicker", "selected"], emojipickerspriteitem: ["EmojiPicker", "spriteItem"], emojipickerstickyheader: ["EmojiPicker", "stickyHeader"], favbuttoncontainer: ["BDFDB", "favButtonContainer"], fileattachment: ["File", "attachment"], fileattachmentinner: ["File", "attachmentInner"], filecancelbutton: ["File", "cancelButton"], filedownloadbutton: ["File", "downloadButton"], filename: ["File", "filename"], filenamelink: ["File", "fileNameLink"], filenamelinkwrapper: ["File", "filenameLinkWrapper"], filenamewrapper: ["File", "filenameWrapper"], 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"], friendsdiscordtag: ["Friends", "discordTag"], 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"], gamelibrarytable: ["GameLibraryTable", "table"], gamelibrarytableheader: ["GameLibraryTable", "header"], gamelibrarytableheadercell: ["GameLibraryTable", "headerCell"], gamelibrarytableheadercellsorted: ["GameLibraryTable", "headerCellSorted"], gamelibrarytablerow: ["GameLibraryTable", "row"], gamelibrarytablerowwrapper: ["GameLibraryTable", "rowWrapper"], gamelibrarytablestickyheader: ["GameLibraryTable", "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"], goliveactions: ["GoLiveDetails", "actions"], golivebody: ["GoLiveDetails", "body"], goliveclickablegamewrapper: ["GoLiveDetails", "clickableGameWrapper"], golivegameicon: ["GoLiveDetails", "gameIcon"], golivegamename: ["GoLiveDetails", "gameName"], golivegamewrapper: ["GoLiveDetails", "gameWrapper"], goliveinfo: ["GoLiveDetails", "info"], golivepanel: ["GoLiveDetails", "panel"], green: ["TextStyle", "statusGreen"], grey: ["TextStyle", "statusGrey"], guild: ["BDFDB", "guild"], 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"], guildlowerleftbadge: ["BDFDB", "guildLowerLeftBadge"], 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"], guildsettingsemojicard: ["GuildSettingsEmoji", "emojiRow"], 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"], guildupperleftbadge: ["BDFDB", "guildUpperLeftBadge"], 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"], hotkeyresetbutton: ["BDFDB", "hotkeyResetButton"], hotkeyshadowpulse: ["HotKeyRecorder", "shadowPulse"], hotkeytext: ["HotKeyRecorder", "text"], hotkeywrapper: ["BDFDB", "hotkeyWrapper"], hovercard: ["HoverCard", "card"], hovercardbutton: ["NotFound", "hoverCardButton"], hovercardinner: ["BDFDB", "cardInner"], hovercardwrapper: ["BDFDB", "cardWrapper"], 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"], itemlayerdisabledpointerevents: ["ItemLayerContainer", "disabledPointerEvents"], input: ["Input", "input"], inputdefault: ["Input", "inputDefault"], inputdisabled: ["Input", "disabled"], inputeditable: ["Input", "editable"], inputerror: ["Input", "error"], inputerrormessage: ["Input", "errorMessage"], inputfocused: ["Input", "focused"], inputmini: ["Input", "inputMini"], inputprefix: ["Input", "inputPrefix"], inputsuccess: ["Input", "success"], inputwrapper: ["Input", "inputWrapper"], inputnumberbutton: ["BDFDB", "inputNumberButton"], inputnumberbuttondown: ["BDFDB", "inputNumberButtonDown"], inputnumberbuttonup: ["BDFDB", "inputNumberButtonUp"], inputnumberbuttons: ["BDFDB", "inputNumberButtons"], inputnumberwrapper: ["BDFDB", "inputNumberWrapper"], inputnumberwrapperdefault: ["BDFDB", "inputNumberWrapperDefault"], inputnumberwrappermini: ["BDFDB", "inputNumberWrapperMini"], invite: ["GuildInvite", "wrapper"], invitebutton: ["GuildInvite", "button"], invitebuttoncontent: ["GuildInvite", "buttonContent"], invitebuttonicon: ["GuildInvite", "buttonIcon"], invitebuttoninner: ["GuildInvite", "buttonInner"], invitebuttonsize: ["GuildInvite", "buttonSize"], invitechannelname: ["GuildInvite", "channelName"], invitecontent: ["GuildInvite", "content"], invitecursordefault: ["GuildInvite", "cursorDefault"], inviteguilddetail: ["GuildInvite", "guildDetail"], inviteguildicon: ["GuildInvite", "guildIcon"], inviteguildiconexpired: ["GuildInvite", "guildIconExpired"], inviteguildiconimage: ["GuildInvite", "guildIconImage"], inviteguildiconimagejoined: ["GuildInvite", "guildIconImageJoined"], inviteguildiconjoined: ["GuildInvite", "guildIconJoined"], inviteguildinfo: ["GuildInvite", "guildInfo"], inviteguildname: ["GuildInvite", "guildName"], inviteguildnameexpired: ["GuildInvite", "guildNameExpired"], inviteguildnamejoined: ["GuildInvite", "guildNameJoined"], inviteheader: ["GuildInvite", "header"], invitehighbackgroundopacity: ["GuildInvite", "highBackgroundOpacity"], inviteiconsizeoverride: ["GuildInvite", "iconSizeOverride"], invitelowbackgroundopacity: ["GuildInvite", "lowBackgroundOpacity"], invitemediumbackgroundopacity: ["GuildInvite", "mediumBackgroundOpacity"], invitemodal: ["InviteModal", "modal"], invitemodalinviterow: ["InviteModal", "inviteRow"], invitemodalinviterowname: ["InviteModal", "inviteRowName"], invitemodalwrapper: ["InviteModal", "wrapper"], inviteonlinecount: ["GuildInvite", "onlineCount"], inviteresolving: ["GuildInvite", "resolving"], inviteresolvingbackground: ["GuildInvite", "resolvingBackground"], invitestatus: ["GuildInvite", "status"], invitestatusoffline: ["GuildInvite", "statusOffline"], invitestatusonline: ["GuildInvite", "statusOnline"], inviteuserselectnone: ["GuildInvite", "userSelectNone"], 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"], linethrough: ["BDFDB", "lineThrough"], listavatar: ["UserProfile", "listAvatar"], listdiscriminator: ["UserProfile", "listDiscriminator"], listname: ["UserProfile", "listName"], listrow: ["UserProfile", "listRow"], listrowcontent: ["UserProfile", "listRowContent"], listscroller: ["UserProfile", "listScroller"], livetag: ["LiveTag", "live"], livetaggrey: ["LiveTag", "grey"], livetaglarge: ["LiveTag", "liveLarge"], livetagsmall: ["LiveTag", "liveSmall"], loadingicon: ["BDFDB", "loadingIcon"], loadingiconwrapper: ["BDFDB", "loadingIconWrapper"], 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"], memberactivity: ["Member", "activity"], membericon: ["Member", "icon"], memberoffline: ["Member", "offline"], memberownericon: ["Member", "ownerIcon"], memberpremiumicon: ["Member", "premiumIcon"], members: ["MembersWrap", "members"], membersgroup: ["MembersWrap", "membersGroup"], memberswrap: ["MembersWrap", "membersWrap"], memberusername: ["Member", "roleColor"], mention: ["NotFound", "mention"], mentionwrapper: ["NotFound", "mentionWrapper"], message: ["Message", "message"], messageaccessory: ["MessageAccessory", "container"], messageavatar: ["MessageItems", "avatar"], messagebackgroundflash: ["Message", "backgroundFlash"], 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"], messagebeforegroup: ["Message", "beforeGroup"], messagebottag: ["MessageItems", "botTag"], messagebottagcompact: ["MessageItems", "botTagCompact"], messagebottagcozy: ["MessageItems", "botTagCozy"], messagebuttoncontainer: ["MessageItems", "buttonContainer"], messagebuttons: ["Message", "buttons"], messagechanneltextarea: ["Message", "channelTextArea"], messageclickableheader: ["MessageItems", "clickableHeader"], messageclickoverride: ["MessageItems", "clickOverride"], messageclickoverridedisableinteraction: ["MessageItems", "disableInteraction"], messagecompact: ["MessageItems", "compact"], messagecontainer: ["MessageItems", "container"], messagecozy: ["Message", "cozyMessage"], messagedisableinteraction: ["Message", "disableInteraction"], messagedivider: ["Message", "divider"], messagedividerhascontent: ["Message", "hasContent"], messageedited: ["MessageBody", "edited"], messagegroupstart: ["Message", "groupStart"], messagegroupblocked: ["MessageElements", "messageGroupBlocked"], messagegroupblockedbtn: ["MessageElements", "messageGroupBlockedBtn"], messagegroupblockedrevealed: ["MessageElements", "revealed"], messageheadercompact: ["MessageItems", "headerCompact"], messageheadercozy: ["MessageItems", "headerCozy"], messageheadercozymeta: ["MessageItems", "headerCozyMeta"], messagelocalbot: ["Message", "localBot"], messagemarkup: ["MessageMarkup", "markup"], messagemarkupcontainercompact: ["MessageMarkup", "containerCompact"], messagemarkupcontainercozy: ["MessageMarkup", "containerCozy"], messagemarkupcompact: ["MessageMarkup", "compact"], messagemarkupisfailed: ["MessageBody", "isFailed"], messagemarkuprtl: ["MessageBody", "markupRtl"], messagementioned: ["Message", "mentioned"], messageoperations: ["MessageOperations", "operations"], messageselected: ["Message", "selected"], messages: ["MessagesWrap", "messages"], messagesdivider: ["MessagesWrap", "divider"], messageseparator: ["MessageItems", "separator"], messagespopout: ["MessagesPopout", "messagesPopout"], messagespopoutactionbuttons: ["MessagesPopout", "actionButtons"], messagespopoutbody: ["MessagesPopout", "body"], messagespopoutbottom: ["MessagesPopout", "bottom"], messagespopoutchannelname: ["MessagesPopout", "channelName"], messagespopoutchannelseparator: ["MessagesPopout", "channelSeparator"], messagespopoutclosebutton: ["MessagesPopout", "closeIcon"], messagespopoutemptyplaceholder: ["MessagesPopout", "emptyPlaceholder"], messagespopoutfooter: ["MessagesPopout", "footer"], messagespopoutguildname: ["MessagesPopout", "guildName"], messagespopoutgroupcozy: ["MessagesPopout", "messageGroupCozy"], messagespopoutgroupwrapper: ["MessagesPopout", "messageGroupWrapper"], messagespopouthasmore: ["MessagesPopout", "hasMore"], messagespopouthasmorebutton: ["MessagesPopout", "hasMoreButton"], messagespopoutheader: ["MessagesPopout", "header"], messagespopoutimage: ["MessagesPopout", "image"], messagespopoutjumpbutton: ["MessagesPopout", "jumpButton"], messagespopoutloading: ["MessagesPopout", "loading"], messagespopoutloadingmore: ["MessagesPopout", "loadingMore"], messagespopoutloadingplaceholder: ["MessagesPopout", "loadingPlaceholder"], messagespopoutscroller: ["MessagesPopout", "scroller"], messagespopoutscrollingfooterwrap: ["MessagesPopout", "scrollingFooterWrap"], messagespopoutspinner: ["MessagesPopout", "spinner"], messagespopouttitle: ["MessagesPopout", "title"], messagespopoutvisible: ["MessagesPopout", "visible"], messagespopoutwrap: ["MessagesPopout", "messagesPopoutWrap"], messagesscrollerwrapper: ["MessagesWrap", "scrollerWrap"], messageswelcomemessage: ["MessagesWelcome", "welcomeMessage"], messageswelcomemessageheader: ["MessagesWelcome", "h1"], messageswrapper: ["MessagesWrap", "messagesWrapper"], messagesystem: ["MessageSystem", "container"], messagesystemaccessories: ["MessageItems", "systemMessageAccessories"], messagesystemcontent: ["MessageSystem", "content"], messagesystemicon: ["MessageSystem", "icon"], messagesystemmessage: ["Message", "systemMessage"], messagetimedivider: ["MessageElements", "divider"], messagetimedividerred: ["MessageElements", "dividerRed"], messagetimedividercontent: ["MessageElements", "dividerContent"], messagetimestampasiancompact: ["MessageItems", "asianCompactTimeStamp"], messagetimestampbase: ["MessageItems", "timestampBase"], messagetimestampcompact: ["MessageItems", "timestampCompact"], messagetimestampcozy: ["MessageItems", "timestampCozy"], messagetimestampcozyalt: ["MessageItems", "timestampCozyAlt"], messagetimestamplatin12compact: ["MessageItems", "latin12CompactTimeStamp"], messagetimestamplatin24compact: ["MessageItems", "latin24CompactTimeStamp"], messagetimestampsystem: ["MessageSystem", "timestamp"], messagetimestamptooltip: ["MessageItems", "timestampTooltip"], messagetimestampvisibleonhover: ["MessageItems", "timestampVisibleOnHover"], messagetoolbar: ["MessageToolbar", "container"], messagetoolbarbutton: ["MessageToolbarItems", "button"], messagetoolbarbuttondisabled: ["MessageToolbarItems", "disabled"], messagetoolbarbuttonselected: ["MessageToolbarItems", "selected"], messagetoolbaricon: ["MessageToolbar", "icon"], messagetoolbarinner: ["MessageToolbarItems", "wrapper"], messagetoolbarisheader: ["MessageToolbar", "isHeader"], messagetoolbarpublishicon: ["MessageToolbar", "publishIcon"], messagetoolbarseparator: ["MessageToolbarItems", "separator"], messageuploadcancel: ["MessageFile", "cancelButton"], messageusername: ["MessageItems", "username"], modal: ["ModalWrap", "modal"], modalclose: ["Modal", "close"], modalchangelogmodal: ["BDFDB", "changeLogModal"], modalconfirmmodal: ["BDFDB", "confirmModal"], modalcontent: ["Modal", "content"], modalfooter: ["Modal", "footer"], modalguildname: ["ModalItems", "guildName"], modalheader: ["Modal", "header"], modalheaderhassibling: ["BDFDB", "modalHeaderHasSibling"], modalinner: ["ModalWrap", "inner"], modalmini: ["ModalMiniContent", "modal"], modalminicontent: ["ModalMiniContent", "content"], modalminitext: ["HeaderBarTopic", "content"], modalseparator: ["Modal", "separator"], modalsizelarge: ["Modal", "sizeLarge"], modalsizemedium: ["Modal", "sizeMedium"], modalsizesmall: ["Modal", "sizeSmall"], modalsub: ["Modal", "modal"], modalsubinner: ["Modal", "inner"], modalsubinnerscrollerless: ["BDFDB", "modalInnerScrollerLess"], modaltabcontent: ["BDFDB", "modalTabContent"], modaltabcontentopen: ["BDFDB", "modalTabContentOpen"], modalwrapper: ["BDFDB", "modalWrapper"], modedefault: ["FormText", "modeDefault"], modedisabled: ["FormText", "modeDisabled"], modeselectable: ["FormText", "modeSelectable"], namecontainer: ["NameContainer", "container"], namecontaineravatar: ["NameContainer", "avatar"], namecontainerchildren: ["NameContainer", "children"], namecontainerclickable: ["NameContainer", "clickable"], namecontainercontent: ["NameContainer", "content"], namecontainerlayout: ["NameContainer", "layout"], namecontainername: ["NameContainer", "name"], namecontainernamecontainer: ["NotFound", "nameContainerNameContainer"], namecontainernamewrapper: ["NameContainer", "nameAndDecorators"], namecontainerselected: ["NameContainer", "selected"], namecontainersubtext: ["NameContainer", "subText"], 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"], noticepremiumlogo: ["Notice", "premiumLogo"], noticepremiumtext: ["Notice", "premiumText"], noticerichpresence: ["Notice", "noticeRichPresence"], noticespotify: ["Notice", "noticeSpotify"], noticestreamer: ["Notice", "noticeStreamerMode"], noticesuccess: ["Notice", "noticeSuccess"], noticesurvey: ["Notice", "noticeSurvey"], noticewrapper: ["BDFDB", "noticeWrapper"], note: ["SettingsItems", "note"], nowrap: ["Flex", "noWrap"], overflowellipsis: ["BDFDB", "overflowEllipsis"], peoples: ["Peoples", "container"], peoplesbadge: ["Peoples", "badge"], peoplesnowplayingcolumn: ["Peoples", "nowPlayingColumn"], peoplespeoplecolumn: ["Peoples", "peopleColumn"], peoplestabbar: ["Peoples", "tabBar"], pictureinpicture: ["PictureInPicture", "pictureInPicture"], pictureinpicturewindow: ["PictureInPicture", "pictureInPictureWindow"], popout: ["Popout", "popout"], popoutarrowalignmentmiddle: ["Popout", "arrowAlignmentMiddle"], popoutarrowalignmenttop: ["Popout", "arrowAlignmentTop"], popoutbottom: ["Popout", "popoutBottom"], popoutbottomleft: ["Popout", "popoutBottomLeft"], popoutbottomright: ["Popout", "popoutBottomRight"], popoutinvert: ["Popout", "popoutInvert"], popoutleft: ["Popout", "popoutLeft"], popoutnoarrow: ["Popout", "noArrow"], popoutnoshadow: ["Popout", "noShadow"], popoutright: ["Popout", "popoutRight"], popouts: ["Popout", "popouts"], popoutthemedpopout: ["BDFDB", "themedPopout"], popouttop: ["Popout", "popoutTop"], popouttopleft: ["Popout", "popoutTopLeft"], popouttopright: ["Popout", "popoutTopRight"], popoutwrapper: ["BDFDB", "popoutWrapper"], primary: ["TextStyle", "primary"], quickmessage: ["QuickMessage", "quickMessage"], quickmessagepopout: ["UserPopout", "quickMessage"], quickselect: ["QuickSelect", "quickSelect"], quickselectarrow: ["QuickSelect", "quickSelectArrow"], quickselectclick: ["QuickSelect", "quickSelectClick"], quickselectlabel: ["QuickSelect", "quickSelectLabel"], quickselectpopout: ["QuickSelect", "quickSelectPopout"], quickselectpopoutoption: ["QuickSelect", "quickSelectPopoutOption"], quickselectpopoutoptionselected: ["NotFound", "quickSelectPopoutOptionSelected"], quickselectpopoutscroll: ["QuickSelect", "quickSelectPopoutScroll"], quickselectpopoutwrapper: ["BDFDB", "quickSelectPopoutWrapper"], quickselectscroller: ["QuickSelect", "quickSelectScroller"], quickselectselected: ["QuickSelect", "selected"], quickselectvalue: ["QuickSelect", "quickSelectValue"], quickselectwrapper: ["BDFDB", "quickSelectWrapper"], 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"], recentmentionsmentionfilter: ["RecentMentions", "mentionFilter"], recentmentionsmentionfilterlabel: ["RecentMentions", "label"], recentmentionsmentionfiltervalue: ["RecentMentions", "value"], recentmentionspopout: ["RecentMentions", "recentMentionsPopout"], recentmentionstabbar: ["RecentMentions", "tabBar"], recentmentionstabbaritem: ["RecentMentions", "tabBarItem"], recentmentionstabbarwrapper: ["RecentMentions", "headerTabBarWrapper"], red: ["TextStyle", "statusRed"], reset: ["CardStatus", "reset"], scrollbar: ["Scrollbar", "scrollbar"], scrollbardefault: ["Scrollbar", "scrollbarDefault"], scrollbarghost: ["Scrollbar", "scrollbarGhost"], scrollbarghosthairline: ["Scrollbar", "scrollbarGhostHairline"], scroller: ["Scroller", "scroller"], scrollerfade: ["Scroller", "scrollerFade"], scrollersystempad: ["Scroller", "systemPad"], scrollerthemed: ["Scroller", "scrollerThemed"], scrollerthemedwithtrack: ["Scroller", "themedWithTrack"], 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"], searchresultsafter: ["SearchResults", "after"], searchresultsalt: ["SearchResults", "alt"], searchresultsbefore: ["SearchResults", "before"], searchresultschannelname: ["SearchResults", "channelName"], searchresultschannelSeparator: ["SearchResults", "channelSeparator"], searchresultsexpanded: ["SearchResults", "expanded"], searchresultsgroupcozy: ["SearchResults", "messageGroupCozy"], searchresultshit: ["SearchResults", "hit"], searchresultspagination: ["SearchResults", "pagination"], searchresultspaginationbutton: ["SearchResults", "paginationButton"], searchresultspaginationdisabled: ["SearchResults", "disabled"], searchresultspaginationicon: ["SearchResults", "icon"], searchresultssearchheader: ["SearchResults", "searchHeader"], searchresultswrap: ["SearchResults", "searchResultsWrap"], 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"], selectwrapper: ["BDFDB", "selectWrapper"], settingsclosebutton: ["SettingsCloseButton", "closeButton"], settingsclosebuttoncontainer: ["SettingsCloseButton", "container"], settingsheader: ["Item", "header"], settingsitem: ["Item", "item"], settingsitemdragged: ["ItemRole", "dragged"], settingsitemdlock: ["ItemRole", "lock"], settingsitemrole: ["ItemRole", "role"], settingsitemroleinner: ["ItemRole", "roleInner"], settingsitemselected: ["Item", "selected"], settingsitemthemed: ["Item", "themed"], settingspanel: ["BDFDB", "settingsPanel"], settingspanelinner: ["BDFDB", "settingsPanelInner"], settingspanellist: ["BDFDB", "settingsPanelList"], settingspaneltitle: ["BDFDB", "settingsPanelTitle"], settingsseparator: ["Item", "separator"], settingstabbar: ["Friends", "tabBar"], settingstabbarbadge: ["Friends", "badge"], settingstabbartoppill: ["Item", "topPill"], settingstableheader: ["SettingsTable", "header"], settingstableheadername: ["SettingsTable", "headerName"], settingstableheaderoption: ["SettingsTable", "headerOption"], settingstableheaders: ["BDFDB", "settingsTableHeaders"], settingstableheadersize: ["SettingsTable", "headerSize"], settingstableheadervertical: ["BDFDB", "settingsTableHeaderVertical"], settingstablecard: ["BDFDB", "settingsTableCard"], settingstablecardconfigs: ["BDFDB", "settingsTableCardConfigs"], settingstablecardlabel: ["BDFDB", "settingsTableCardLabel"], settingstablelist: ["BDFDB", "settingsTableList"], sidebarregion: ["SettingsWindow", "sidebarRegion"], 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"], stopanimations: ["NotFound", "stopAnimations"], subtext: ["NotFound", "subtext"], svgicon: ["BDFDB", "svgIcon"], 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"], table: ["BDFDB", "table"], tablebodycell: ["BDFDB", "tableBodyCell"], tableheader: ["BDFDB", "tableHeader"], tableheadercell: ["BDFDB", "tableHeaderCellSorted"], tableheadercellsorted: ["BDFDB", "tableHeaderCell"], tableheadersorticon: ["BDFDB", "tableHeaderSortIcon"], tablerow: ["BDFDB", "tableRow"], tablestickyheader: ["BDFDB", "tableStickyHeader"], textarea: ["ChannelTextArea", "textArea"], textareaattachbutton: ["ChannelTextAreaAttachButton", "attachButton"], textareaattachbuttoninner: ["ChannelTextAreaAttachButton", "attachButtonInner"], textareaattachbuttonplus: ["ChannelTextAreaAttachButton", "attachButtonPlus"], textareaattachwrapper: ["ChannelTextAreaAttachButton", "attachWrapper"], textareabutton: ["ChannelTextAreaButton", "button"], textareabuttonactive: ["ChannelTextAreaButton", "active"], textareabuttonpulse: ["ChannelTextAreaButton", "pulseButton"], textareabuttonwrapper: ["ChannelTextAreaButton", "buttonWrapper"], textareacharcounter: ["ChannelTextAreaCharCounter", "characterCount"], textareacharcountererror: ["ChannelTextAreaCharCounter", "error"], textareadisabled: ["ChannelTextArea", "textAreaDisabled"], textareahasautocomplete: ["ChannelTextArea", "hasAutocomplete"], textareaicon: ["ChannelTextAreaButton", "icon"], textareaiconpulse: ["ChannelTextAreaButton", "pulseIcon"], textareainner: ["ChannelTextArea", "inner"], textareainnerdisabled: ["ChannelTextArea", "innerDisabled"], textareapickerbutton: ["ChannelTextArea", "button"], textareapickerbuttoncontainer: ["ChannelTextArea", "buttonContainer"], textareapickerbuttons: ["ChannelTextArea", "buttons"], textareascrollablecontainer: ["ChannelTextArea", "scrollableContainer"], textareaslate: ["ChannelTextAreaSlate", "slateTextArea"], textareaslatecontainer: ["ChannelTextAreaSlate", "slateContainer"], textareaslateplaceholder: ["ChannelTextAreaSlate", "placeholder"], textareauploadinput: ["ChannelTextAreaAttachButton", "uploadInput"], textareawebkit: ["ChannelTextArea", "webkit"], textareawrapall: ["ChannelTextArea", "channelTextArea"], textareawrapchat: ["ChatWindow", "channelTextArea"], textareawrapdisabled: ["ChannelTextArea", "channelTextAreaDisabled"], textlink: ["Notice", "textLink"], textrow: ["PopoutActivity", "textRow"], textscroller: ["BDFDB", "textScroller"], themedark: ["NotFound", "themeDark"], themeghosthairline: ["Scroller", "themeGhostHairline"], themelight: ["NotFound", "themeLight"], themeundefined: ["NotFound", "themeUndefined"], tip: ["Tip", "tip"], tipblock: ["Tip", "block"], tippro: ["Tip", "pro"], tipinline: ["Tip", "inline"], title: ["SettingsItems", "title"], titlebar: ["TitleBar", "titleBar"], titlebarmac: ["TitleBar", "typeMacOS"], titlebarmacbutton: ["TitleBar", "macButton"], titlebarmacbuttonclose: ["TitleBar", "macButtonClose"], titlebarmacbuttonmin: ["TitleBar", "macButtonMinimize"], titlebarmacbuttonmax: ["TitleBar", "macButtonMaximize"], titlebarmacbuttons: ["TitleBar", "macButtons"], titlebarmacwithframe: ["TitleBar", "typeMacOSWithFrame"], titlebarwinbutton: ["TitleBar", "winButton"], titlebarwinbuttonclose: ["TitleBar", "winButtonClose"], titlebarwinbuttonminmax: ["TitleBar", "winButtonMinMax"], titlebarwindows: ["TitleBar", "typeWindows"], titlebarwithframe: ["TitleBar", "withFrame"], titlebarwordmark: ["TitleBar", "wordmark"], titlebarwordmarkmac: ["TitleBar", "wordmarkMacOS"], titlebarwordmarkwindows: ["TitleBar", "wordmarkWindows"], titledefault: ["SettingsItems", "titleDefault"], titlemini: ["SettingsItems", "titleMini"], titlesize10: ["UserPopout", "size10"], titlesize12: ["UserPopout", "size12"], titlesize14: ["UserPopout", "size14"], titlesize16: ["UserPopout", "size16"], size18: ["Title", "size18"], // REMOVE titlesize18: ["Title", "size18"], tooltip: ["Tooltip", "tooltip"], tooltipactivityicon: ["TooltipGuild", "activityIcon"], tooltipblack: ["Tooltip", "tooltipBlack"], tooltipbottom: ["Tooltip", "tooltipBottom"], tooltipbrand: ["Tooltip", "tooltipBrand"], tooltipcustom: ["BDFDB", "tooltipCustom"], tooltipgreen: ["Tooltip", "tooltipGreen"], tooltipgrey: ["Tooltip", "tooltipGrey"], tooltipguildnametext: ["TooltipGuild", "guildNameText"], tooltipguildnametextlimitedsize: ["TooltipGuild", "guildNameTextLimitedSize"], tooltipleft: ["Tooltip", "tooltipLeft"], tooltiplistitem: ["GuildsItems", "listItemTooltip"], tooltippointer: ["Tooltip", "tooltipPointer"], tooltipred: ["Tooltip", "tooltipRed"], tooltipright: ["Tooltip", "tooltipRight"], tooltiprow: ["TooltipGuild", "row"], tooltiprowguildname: ["TooltipGuild", "rowGuildName"], tooltiprowicon: ["TooltipGuild", "rowIcon"], tooltiptop: ["Tooltip", "tooltipTop"], tooltipyellow: ["Tooltip", "tooltipYellow"], typing: ["Typing", "typing"], typingcooldownwrapper: ["Typing", "cooldownWrapper"], typingtext: ["Typing", "text"], underline: ["BDFDB", "underline"], unreadbar: ["UnreadBar", "bar"], unreadbaractive: ["UnreadBar", "active"], unreadbarcontainer: ["UnreadBar", "container"], unreadbaricon: ["UnreadBar", "icon"], unreadbarmention: ["UnreadBar", "mention"], unreadbartext: ["UnreadBar", "text"], unreadbarunread: ["UnreadBar", "unread"], uploadmodal: ["UploadModal", "uploadModal"], userpopout: ["UserPopout", "userPopout"], userpopoutavatarhint: ["UserPopout", "avatarHint"], userpopoutavatarhintinner: ["UserPopout", "avatarHintInner"], userpopoutavatarwrapper: ["UserPopout", "avatarWrapper"], userpopoutavatarwrappernormal: ["UserPopout", "avatarWrapperNormal"], userpopoutbody: ["UserPopout", "body"], userpopoutbodyinner: ["UserPopout", "bodyInner"], userpopoutbodytitle: ["UserPopout", "bodyTitle"], userpopoutcustomstatus: ["UserPopout", "customStatus"], userpopoutcustomstatusemoji: ["UserPopout", "customStatusEmoji"], userpopoutcustomstatussoloemoji: ["UserPopout", "customStatusSoloEmoji"], userpopoutcustomstatustext: ["UserPopout", "customStatusText"], userpopoutendbodysection: ["UserPopout", "endBodySection"], userpopoutfooter: ["UserPopout", "footer"], userpopoutheader: ["UserPopout", "header"], userpopoutheaderbottagwithnickname: ["UserPopout", "headerBotTagWithNickname"], userpopoutheadernamewrapper: ["UserPopout", "headerNameWrapper"], userpopoutheadernickname: ["UserPopout", "headerName"], 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"], userpopoutheadertop: ["UserPopout", "headerTop"], userpopoutprotip: ["UserPopout", "protip"], userpopoutrole: ["Role", "role"], userpopoutrolecircle: ["Role", "roleCircle"], userpopoutrolelist: ["UserPopout", "rolesList"], userpopoutrolename: ["Role", "roleName"], userpopoutroles: ["Role", "root"], 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"], 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"], 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: ["TextStyle", "weightBold"], weightlight: ["TextStyle", "weightLight"], weightmedium: ["TextStyle", "weightMedium"], weightnormal: ["TextStyle", "weightNormal"], weightsemibold: ["TextStyle", "weightSemiBold"], white: ["TextStyle", "white"], whitney: ["TextStyle", "whitney"], wrap: ["Flex", "wrap"], wrapreverse: ["Flex", "wrapReverse"], yellow: ["TextStyle", "statusYellow"] }; BDFDB.DiscordClasses = Object.assign({}, DiscordClasses); InternalBDFDB.getDiscordClass = (item, selector) => { var classname = DiscordClassModules.BDFDB.BDFDBundefined; if (DiscordClasses[item] === undefined) { BDFDB.LogUtils.warn(item + " not found in DiscordClasses"); return classname; } else if (!BDFDB.ArrayUtils.is(DiscordClasses[item]) || DiscordClasses[item].length != 2) { BDFDB.LogUtils.warn(item + " is not an Array of Length 2 in DiscordClasses"); return classname; } else if (DiscordClassModules[DiscordClasses[item][0]] === undefined) { BDFDB.LogUtils.warn(DiscordClasses[item][0] + " not found in DiscordClassModules"); return classname; } else if (DiscordClassModules[DiscordClasses[item][0]][DiscordClasses[item][1]] === undefined) { BDFDB.LogUtils.warn(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; } }; BDFDB.disCN = new Proxy(DiscordClasses, { get: function (list, item) { return InternalBDFDB.getDiscordClass(item, false).replace("#", ""); } }); BDFDB.disCNS = new Proxy(DiscordClasses, { get: function (list, item) { return InternalBDFDB.getDiscordClass(item, false).replace("#", "") + " "; } }); BDFDB.disCNC = new Proxy(DiscordClasses, { get: function (list, item) { return InternalBDFDB.getDiscordClass(item, false).replace("#", "") + ","; } }); BDFDB.dotCN = new Proxy(DiscordClasses, { get: function (list, item) { let classname = InternalBDFDB.getDiscordClass(item, true); return (classname.indexOf("#") == 0 ? "" : ".") + classname; } }); BDFDB.dotCNS = new Proxy(DiscordClasses, { get: function (list, item) { let classname = InternalBDFDB.getDiscordClass(item, true); return (classname.indexOf("#") == 0 ? "" : ".") + classname + " "; } }); BDFDB.dotCNC = new Proxy(DiscordClasses, { get: function (list, item) { let classname = InternalBDFDB.getDiscordClass(item, true); return (classname.indexOf("#") == 0 ? "" : ".") + classname + ","; } }); BDFDB.notCN = new Proxy(DiscordClasses, { get: function (list, item) { return `:not(.${InternalBDFDB.getDiscordClass(item, true).split(".")[0]})`; } }); BDFDB.notCNS = new Proxy(DiscordClasses, { get: function (list, item) { return `:not(.${InternalBDFDB.getDiscordClass(item, true).split(".")[0]}) `; } }); BDFDB.notCNC = new Proxy(DiscordClasses, { get: function (list, item) { return `:not(.${InternalBDFDB.getDiscordClass(item, true).split(".")[0]}),`; } }); var LanguageStrings = LibraryModules.LanguageStore && LibraryModules.LanguageStore._proxyContext ? Object.assign({}, LibraryModules.LanguageStore._proxyContext.defaultMessages) : {}; BDFDB.LanguageUtils = {}; BDFDB.LanguageUtils.languages = { "$discord": {name:"Discord (English))", id:"en", ownlang:"English", integrated:false, dic:false}, "af": {name:"Afrikaans", id:"af", ownlang:"Afrikaans", integrated:false, dic:true}, "sq": {name:"Albanian", id:"sq", ownlang:"Shqiptar", integrated:false, dic:false}, "am": {name:"Amharic", id:"am", ownlang:"አማርኛ", integrated:false, dic:false}, "ar": {name:"Arabic", id:"ar", ownlang:"اللغة العربية", integrated:false, dic:false}, "hy": {name:"Armenian", id:"hy", ownlang:"Հայերեն", integrated:false, dic:false}, "az": {name:"Azerbaijani", id:"az", ownlang:"آذربایجان دیلی", integrated:false, dic:false}, "ba": {name:"Bashkir", id:"ba", ownlang:"Башҡорт", integrated:false, dic:false}, "eu": {name:"Basque", id:"eu", ownlang:"Euskara", integrated:false, dic:false}, "be": {name:"Belarusian", id:"be", ownlang:"Беларуская", integrated:false, dic:false}, "bn": {name:"Bengali", id:"bn", ownlang:"বাংলা", integrated:false, dic:false}, "bs": {name:"Bosnian", id:"bs", ownlang:"Босански", integrated:false, dic:false}, "bg": {name:"Bulgarian", id:"bg", ownlang:"български", integrated:true, dic:false}, "my": {name:"Burmese", id:"my", ownlang:"မြန်မာစာ", integrated:false, dic:false}, "ca": {name:"Catalan", id:"ca", ownlang:"Català", integrated:false, dic:false}, "ceb": {name:"Cebuano", id:"ceb", ownlang:"Bisaya", integrated:false, dic:false}, "ny": {name:"Chichewa", id:"ny", ownlang:"Nyanja", integrated:false, dic:false}, "zh": {name:"Chinese", id:"zh", ownlang:"中文", integrated:false, dic:false}, "zh-HK": {name:"Chinese (Hong Kong)", id:"zh-HK", ownlang:"香港中文", integrated:false, dic:false}, "zh-CN": {name:"Chinese (Simplified)", id:"zh-CN", ownlang:"简体中文", integrated:false, dic:false}, "zh-TW": {name:"Chinese (Traditional)", id:"zh-TW", ownlang:"繁體中文", integrated:true, dic:false}, "co": {name:"Corsican", id:"co", ownlang:"Corsu", integrated:false, dic:false}, "hr": {name:"Croatian", id:"hr", ownlang:"Hrvatski", integrated:true, dic:false}, "cs": {name:"Czech", id:"cs", ownlang:"Čeština", integrated:true, dic:false}, "da": {name:"Danish", id:"da", ownlang:"Dansk", integrated:true, dic:true}, "nl": {name:"Dutch", id:"nl", ownlang:"Nederlands", integrated:true, dic:true}, "en": {name:"English", id:"en", ownlang:"English", integrated:false, dic:true}, "en-GB": {name:"English (UK)", id:"en-GB", ownlang:"English (UK)", integrated:true, dic:true}, "en-US": {name:"English (US)", id:"en-US", ownlang:"English (US)", integrated:true, dic:true}, "eo": {name:"Esperanto", id:"eo", ownlang:"Esperanto", integrated:false, dic:false}, "et": {name:"Estonian", id:"et", ownlang:"Eesti", integrated:false, dic:false}, "fil": {name:"Filipino", id:"fil", ownlang:"Wikang Filipino", integrated:false, dic:false}, "fi": {name:"Finnish", id:"fi", ownlang:"Suomi", integrated:true, dic:false}, "fr": {name:"French", id:"fr", ownlang:"Français", integrated:true, dic:true}, "fr-CA": {name:"French (Canadian)", id:"fr-CA", ownlang:"Français Canadien", integrated:false, dic:false}, "fy": {name:"Frisian", id:"fy", ownlang:"Frysk", integrated:false, dic:false}, "gl": {name:"Galician", id:"gl", ownlang:"Galego", integrated:false, dic:false}, "ka": {name:"Georgian", id:"ka", ownlang:"ქართული", integrated:false, dic:false}, "de": {name:"German", id:"de", ownlang:"Deutsch", integrated:true, dic:true}, "de-AT": {name:"German (Austria)", id:"de-AT", ownlang:"Österreichisch Deutsch", integrated:false, dic:false}, "de-CH": {name:"German (Switzerland)", id:"de-CH", ownlang:"Schweizerdeutsch", integrated:false, dic:false}, "el": {name:"Greek", id:"el", ownlang:"Ελληνικά", integrated:false, dic:false}, "gu": {name:"Gujarati", id:"gu", ownlang:"ગુજરાતી", integrated:false, dic:false}, "ht": {name:"Haitian Creole", id:"ht", ownlang:"Kreyòl Ayisyen", integrated:false, dic:false}, "ha": {name:"Hausa", id:"ha", ownlang:"حَوْسَ", integrated:false, dic:false}, "haw": {name:"Hawaiian", id:"haw", ownlang:"ʻŌlelo Hawaiʻi", integrated:false, dic:false}, "he": {name:"Hebrew", id:"he", ownlang:"עברית", integrated:false, dic:false}, "iw": {name:"Hebrew (Israel)", id:"iw", ownlang:"עברית", integrated:false, dic:false}, "hi": {name:"Hindi", id:"hi", ownlang:"हिन्दी", integrated:false, dic:false}, "hmn": {name:"Hmong", id:"hmn", ownlang:"lol Hmongb", integrated:false, dic:false}, "hu": {name:"Hungarian", id:"hu", ownlang:"Magyar", integrated:false, dic:false}, "is": {name:"Icelandic", id:"is", ownlang:"Íslenska", integrated:false, dic:false}, "ig": {name:"Igbo", id:"ig", ownlang:"Asụsụ Igbo", integrated:false, dic:false}, "id": {name:"Indonesian", id:"id", ownlang:"Bahasa Indonesia", integrated:false, dic:false}, "ga": {name:"Irish", id:"ga", ownlang:"Gaeilge", integrated:false, dic:false}, "it": {name:"Italian", id:"it", ownlang:"Italiano", integrated:true, dic:true}, "ja": {name:"Japanese", id:"ja", ownlang:"日本語", integrated:true, dic:false}, "jv": {name:"Javanese", id:"jv", ownlang:"ꦧꦱꦗꦮ", integrated:false, dic:false}, "jw": {name:"Javanese (Javanese)", id:"jw", ownlang:"ꦧꦱꦗꦮ", integrated:false, dic:false}, "kn": {name:"Kannada", id:"kn", ownlang:"ಕನ್ನಡ", integrated:false, dic:false}, "kk": {name:"Kazakh", id:"kk", ownlang:"Қазақ Tілі", integrated:false, dic:false}, "km": {name:"Khmer", id:"km", ownlang:"ភាសាខ្មែរ", integrated:false, dic:false}, "ko": {name:"Korean", id:"ko", ownlang:"한국어", integrated:true, dic:false}, "ku": {name:"Kurdish", id:"ku", ownlang:"کوردی", integrated:false, dic:false}, "ky": {name:"Kyrgyz", id:"ky", ownlang:"кыргызча", integrated:false, dic:false}, "lo": {name:"Lao", id:"lo", ownlang:"ພາສາລາວ", integrated:false, dic:false}, "la": {name:"Latin", id:"la", ownlang:"Latina", integrated:false, dic:false}, "lv": {name:"Latvian", id:"lv", ownlang:"Latviešu", integrated:false, dic:false}, "lt": {name:"Lithuanian", id:"lt", ownlang:"Lietuvių", integrated:false, dic:false}, "lb": {name:"Luxembourgish", id:"lb", ownlang:"Lëtzebuergesch", integrated:false, dic:false}, "mk": {name:"Macedonian", id:"mk", ownlang:"Mакедонски", integrated:false, dic:false}, "mg": {name:"Malagasy", id:"mg", ownlang:"Malagasy", integrated:false, dic:false}, "ms": {name:"Malay", id:"ms", ownlang:"بهاس ملايو", integrated:false, dic:false}, "ml": {name:"Malayalam", id:"ml", ownlang:"മലയാളം", integrated:false, dic:false}, "mt": {name:"Maltese", id:"mt", ownlang:"Malti", integrated:false, dic:false}, "mi": {name:"Maori", id:"mi", ownlang:"te Reo Māori", integrated:false, dic:false}, "mr": {name:"Marathi", id:"mr", ownlang:"मराठी", integrated:false, dic:false}, "mhr": {name:"Mari", id:"mhr", ownlang:"марий йылме", integrated:false, dic:false}, "mn": {name:"Mongolian", id:"mn", ownlang:"Монгол Хэл", integrated:false, dic:false}, "my": {name:"Myanmar (Burmese)", id:"my", ownlang:"မြန်မာл Хэл", integrated:false, dic:false}, "ne": {name:"Nepali", id:"ne", ownlang:"नेपाली", integrated:false, dic:false}, "no": {name:"Norwegian", id:"no", ownlang:"Norsk", integrated:true, dic:false}, "pap": {name:"Papiamento", id:"pap", ownlang:"Papiamentu", integrated:false, dic:false}, "ps": {name:"Pashto", id:"ps", ownlang:"پښتو", integrated:false, dic:false}, "fa": {name:"Persian", id:"fa", ownlang:"فارسی", integrated:false, dic:false}, "pl": {name:"Polish", id:"pl", ownlang:"Polski", integrated:true, dic:true}, "pt": {name:"Portuguese", id:"pt", ownlang:"Português", integrated:false, dic:true}, "pt-BR": {name:"Portuguese (Brazil)", id:"pt-BR", ownlang:"Português do Brasil", integrated:true, dic:true}, "pt-PT": {name:"Portuguese (Portugal)", id:"pt-PT", ownlang:"Português do Portugal", integrated:false, dic:false}, "pa": {name:"Punjabi", id:"pa", ownlang:"पंजाबी", integrated:false, dic:false}, "ro": {name:"Romanian", id:"ro", ownlang:"Română", integrated:false, dic:false}, "ru": {name:"Russian", id:"ru", ownlang:"Pусский", integrated:true, dic:true}, "sm": {name:"Samoan", id:"sm", ownlang:"Gagana Sāmoa", integrated:false, dic:false}, "gd": {name:"Scottish Gaelic", id:"gd", ownlang:"Gàidhlig", integrated:false, dic:false}, "sr": {name:"Serbian", id:"sr", ownlang:"Српски", integrated:false, dic:false}, "st": {name:"Sesotho", id:"st", ownlang:"Sesotho", integrated:false, dic:false}, "sn": {name:"Shona", id:"sn", ownlang:"Shona", integrated:false, dic:false}, "sd": {name:"Sindhi", id:"sd", ownlang:"سنڌي", integrated:false, dic:false}, "si": {name:"Sinhala", id:"si", ownlang:"සිංහල", integrated:false, dic:false}, "sk": {name:"Slovak", id:"sk", ownlang:"Slovenčina", integrated:false, dic:false}, "sl": {name:"Slovenian", id:"sl", ownlang:"Slovenščina", integrated:false, dic:false}, "so": {name:"Somali", id:"so", ownlang:"Soomaali", integrated:false, dic:false}, "es": {name:"Spanish", id:"es", ownlang:"Español", integrated:true, dic:true}, "es-419": {name:"Spanish (Latin America)", id:"es-419", ownlang:"Español latinoamericano", integrated:false, dic:false}, "su": {name:"Sundanese", id:"su", ownlang:"Basa Sunda", integrated:false, dic:false}, "sw": {name:"Swahili", id:"sw", ownlang:"Kiswahili", integrated:false, dic:false}, "sv": {name:"Swedish", id:"sv", ownlang:"Svenska", integrated:true, dic:true}, "tl": {name:"Tagalog", id:"tl", ownlang:"Wikang Tagalog", integrated:false, dic:false}, "tg": {name:"Tajik", id:"tg", ownlang:"тоҷикӣ", integrated:false, dic:false}, "ta": {name:"Tamil", id:"ta", ownlang:"தமிழ்", integrated:false, dic:false}, "tt": {name:"Tatar", id:"tt", ownlang:"татарча", integrated:false, dic:false}, "te": {name:"Telugu", id:"te", ownlang:"తెలుగు", integrated:false, dic:false}, "th": {name:"Thai", id:"th", ownlang:"ภาษาไทย", integrated:false, dic:false}, "tr": {name:"Turkish", id:"tr", ownlang:"Türkçe", integrated:true, dic:false}, "udm": {name:"Udmurt", id:"udm", ownlang:"удмурт кыл", integrated:false, dic:false}, "uk": {name:"Ukrainian", id:"uk", ownlang:"Yкраїнський", integrated:true, dic:false}, "ur": {name:"Urdu", id:"ur", ownlang:"اُردُو", integrated:false, dic:false}, "uz": {name:"Uzbek", id:"uz", ownlang:"اوزبیک", integrated:false, dic:false}, "vi": {name:"Vietnamese", id:"vi", ownlang:"Tiếng Việt Nam", integrated:false, dic:false}, "cy": {name:"Welsh", id:"cy", ownlang:"Cymraeg", integrated:false, dic:false}, "xh": {name:"Xhosa", id:"xh", ownlang:"Xhosa", integrated:false, dic:false}, "yi": {name:"Yiddish", id:"yi", ownlang:"ייִדיש ייִדיש‬", integrated:false, dic:false}, "yo": {name:"Yoruba", id:"yo", ownlang:"Èdè Yorùbá", integrated:false, dic:false}, "zu": {name:"Zulu", id:"zu", ownlang:"Zulu", integrated:false, dic:false} }; InternalBDFDB.LibraryStrings = { "hr": { toast_plugin_started: "{{var0}} je započeo.", toast_plugin_stopped: "{{var0}} zaustavljen.", toast_plugin_translated: "prijevod na {{var0}}.", file_navigator_text: "Pregledajte datoteku", btn_all_text: "Sve" //REMOVE }, "da": { toast_plugin_started: "{{var0}} er startet.", toast_plugin_stopped: "{{var0}} er stoppet.", toast_plugin_translated: "oversat til {{var0}}.", file_navigator_text: "Gennemse fil", btn_all_text: "Alle" }, "de": { toast_plugin_started: "{{var0}} wurde gestartet.", toast_plugin_stopped: "{{var0}} wurde gestoppt.", toast_plugin_translated: "auf {{var0}} übersetzt.", file_navigator_text: "Datei durchsuchen", btn_all_text: "Alle" }, "es": { toast_plugin_started: "{{var0}} se guilddiv iniciado.", toast_plugin_stopped: "{{var0}} se guilddiv detenido.", toast_plugin_translated: "traducido a {{var0}}.", file_navigator_text: "Buscar archivo", btn_all_text: "Todo" }, "fr": { toast_plugin_started: "{{var0}} a été démarré.", toast_plugin_stopped: "{{var0}} a été arrêté.", toast_plugin_translated: "traduit en {{var0}}.", file_navigator_text: "Parcourir le fichier", btn_all_text: "Tout" }, "it": { toast_plugin_started: "{{var0}} è stato avviato.", toast_plugin_stopped: "{{var0}} è stato interrotto.", toast_plugin_translated: "tradotto in {{var0}}.", file_navigator_text: "Sfoglia file", btn_all_text: "Tutto" }, "nl": { toast_plugin_started: "{{var0}} is gestart.", toast_plugin_stopped: "{{var0}} is gestopt.", toast_plugin_translated: "vertaald naar {{var0}}.", file_navigator_text: "Bestand zoeken", btn_all_text: "Alle" }, "no": { toast_plugin_started: "{{var0}} er startet.", toast_plugin_stopped: "{{var0}} er stoppet.", toast_plugin_translated: "oversatt til {{var0}}.", file_navigator_text: "Bla gjennom fil", btn_all_text: "Alle" }, "pl": { toast_plugin_started: "{{var0}} został uruchomiony.", toast_plugin_stopped: "{{var0}} został zatrzymany.", toast_plugin_translated: "przetłumaczono na {{var0}}.", file_navigator_text: "Przeglądać plik", btn_all_text: "Wszystkie" }, "pt-BR": { toast_plugin_started: "{{var0}} foi iniciado.", toast_plugin_stopped: "{{var0}} foi interrompido.", toast_plugin_translated: "traduzido para {{var0}}.", file_navigator_text: "Procurar arquivo", btn_all_text: "Todo" }, "fi": { toast_plugin_started: "{{var0}} on käynnistetty.", toast_plugin_stopped: "{{var0}} on pysäytetty.", toast_plugin_translated: "käännetty osoitteeseen {{var0}}.", file_navigator_text: "Selaa tiedostoa", btn_all_text: "Kaikki" }, "sv": { toast_plugin_started: "{{var0}} har startats.", toast_plugin_stopped: "{{var0}} har blivit stoppad.", toast_plugin_translated: "översatt till {{var0}}.", file_navigator_text: "Bläddra i fil", btn_all_text: "All" }, "tr": { toast_plugin_started: "{{var0}} başlatıldı.", toast_plugin_stopped: "{{var0}} durduruldu.", toast_plugin_translated: "{{var0}} olarak çevrildi.", file_navigator_text: "Dosyaya gözat", btn_all_text: "Her" }, "cs": { toast_plugin_started: "{{var0}} byl spuštěn.", toast_plugin_stopped: "{{var0}} byl zastaven.", toast_plugin_translated: "přeložen do {{var0}}.", file_navigator_text: "Procházet soubor", btn_all_text: "Vše" }, "bg": { toast_plugin_started: "{{var0}} е стартиран.", toast_plugin_stopped: "{{var0}} е спрян.", toast_plugin_translated: "преведена на {{var0}}.", file_navigator_text: "Прегледайте файла", btn_all_text: "Bсичко" }, "ru": { toast_plugin_started: "{{var0}} запущен.", toast_plugin_stopped: "{{var0}} остановлен.", toast_plugin_translated: "переведен на {{var0}}.", file_navigator_text: "Просмотр файла", btn_all_text: "Все" }, "uk": { toast_plugin_started: "{{var0}} було запущено.", toast_plugin_stopped: "{{var0}} було зупинено.", toast_plugin_translated: "перекладено {{var0}}.", file_navigator_text: "Перегляньте файл", btn_all_text: "Все" }, "ja": { toast_plugin_started: "{{var0}}が開始されました.", toast_plugin_stopped: "{{var0}}が停止しました.", toast_plugin_translated: "は{{var0}}に翻訳されました.", file_navigator_text: "ファイルを参照", btn_all_text: "すべて" }, "zh-TW": { toast_plugin_started: "{{var0}}已經啟動.", toast_plugin_stopped: "{{var0}}已停止.", toast_plugin_translated: "翻譯為{{var0}}.", file_navigator_text: "瀏覽文件", btn_all_text: "所有" }, "ko": { toast_plugin_started: "{{var0}} 시작되었습니다.", toast_plugin_stopped: "{{var0}} 중지되었습니다.", toast_plugin_translated: "{{var0}} 로 번역되었습니다.", file_navigator_text: "파일 찾아보기", btn_all_text: "모든" }, "default": { toast_plugin_started: "{{var0}} has been started.", toast_plugin_stopped: "{{var0}} has been stopped.", toast_plugin_translated: "translated to {{var0}}.", file_navigator_text: "Browse File", btn_all_text: "All" } }; BDFDB.LanguageUtils.getLanguage = function () { var lang = document.querySelector("html").lang || "en"; if (lang == "en-GB" || lang == "en-US") lang = "en"; var langids = lang.split("-"); var langid = langids[0]; var langid2 = langids[1] || ""; lang = langid2 && langid.toUpperCase() !== langid2.toUpperCase() ? langid + "-" + langid2 : langid; return BDFDB.LanguageUtils.languages[lang] || BDFDB.LanguageUtils.languages[langid] || BDFDB.LanguageUtils.languages["en"]; }; BDFDB.LanguageUtils.LanguageStrings = new Proxy(LanguageStrings, { get: function (list, item) { var stringobj = LibraryModules.LanguageStore.Messages[item]; if (!stringobj) BDFDB.LogUtils.warn(item + " not found in BDFDB.LanguageUtils.LanguageStrings"); else { if (stringobj && typeof stringobj == "object" && typeof stringobj.format == "function") return BDFDB.LanguageUtils.LanguageStringsFormat(item); else return stringobj; } return ""; } }); BDFDB.LanguageUtils.LanguageStringsCheck = new Proxy(LanguageStrings, { get: function (list, item) { return !!LibraryModules.LanguageStore.Messages[item]; } }); BDFDB.LanguageUtils.LanguageStringsFormat = function (item, ...values) { if (item) { var stringobj = LibraryModules.LanguageStore.Messages[item]; if (stringobj && typeof stringobj == "object" && typeof stringobj.format == "function") { let i = 0, returnvalue, formatvars = {}; while (!returnvalue && i < 10) { i++; try {returnvalue = stringobj.format(formatvars);} catch (err) { returnvalue = null; formatvars[err.toString().split("for: ")[1]] = values.shift() || "undefined"; } } if (returnvalue) { if (BDFDB.ArrayUtils.is(returnvalue)) { let newstring = ""; for (let ele of returnvalue) { if (typeof ele == "string") newstring += BDFDB.StringUtils.htmlEscape(ele); else if (BDFDB.ObjectUtils.is(ele) && ele.props) newstring += `<${ele.type}>${BDFDB.StringUtils.htmlEscape(ele.props.children[0].toString())}` } return newstring; } return returnvalue; } else { BDFDB.LogUtils.warn(item + " failed to format string in BDFDB.LanguageUtils.LanguageStrings"); return ""; } } else return BDFDB.LanguageUtils.LanguageStrings[item]; } else BDFDB.LogUtils.warn(item + " enter a valid key to format the string in BDFDB.LanguageUtils.LanguageStrings"); return ""; }; BDFDB.LanguageUtils.LibraryStrings = new Proxy(InternalBDFDB.LibraryStrings.default, { get: function (list, item) { let languageid = BDFDB.LanguageUtils.getLanguage().id; if (InternalBDFDB.LibraryStrings[languageid] && InternalBDFDB.LibraryStrings[languageid][item]) return InternalBDFDB.LibraryStrings[languageid][item]; else if (InternalBDFDB.LibraryStrings.default[item]) return InternalBDFDB.LibraryStrings.default[item]; else BDFDB.LogUtils.warn(item + " not found in BDFDB.LanguageUtils.LibraryStrings"); return ""; } }); BDFDB.LanguageUtils.LibraryStringsCheck = new Proxy(LanguageStrings, { get: function (list, item) { return !!InternalBDFDB.LibraryStrings.default[item]; } }); BDFDB.LanguageUtils.LibraryStringsFormat = function (item, ...values) { if (item && values.length) { let languageid = BDFDB.LanguageUtils.getLanguage().id, string = null; if (InternalBDFDB.LibraryStrings[languageid] && InternalBDFDB.LibraryStrings[languageid][item]) string = InternalBDFDB.LibraryStrings[languageid][item]; else if (InternalBDFDB.LibraryStrings.default[item]) string = InternalBDFDB.LibraryStrings.default[item]; if (string) { for (let i = 0; i < values.length; i++) if (typeof values[i] == "string") string = string.replace(new RegExp(`{{var${i}}}`, "g"), values[i]); return string; } else BDFDB.LogUtils.warn(item + " not found in BDFDB.LanguageUtils.LibraryStrings"); } else BDFDB.LogUtils.warn(item + " enter a valid key and at least one value to format the string in BDFDB.LanguageUtils.LibraryStrings"); return ""; }; var initDiscordLanguageInterval = BDFDB.TimeUtils.interval(_ => { if (document.querySelector("html").lang) { BDFDB.TimeUtils.clear(initDiscordLanguageInterval); var language = BDFDB.LanguageUtils.getLanguage(); BDFDB.LanguageUtils.languages.$discord.name = `Discord (${language.name})`; BDFDB.LanguageUtils.languages.$discord.id = language.id; BDFDB.LanguageUtils.languages.$discord.google = language.google; BDFDB.LanguageUtils.languages.$discord.ownlang = language.ownlang; } }, 100); var NativeSubComponents = {}, LibraryComponents = {}, reactInitialized = LibraryModules.React && LibraryModules.React.Component; NativeSubComponents.Button = BDFDB.ModuleUtils.findByProperties("Colors", "Hovers", "Looks"); NativeSubComponents.Checkbox = BDFDB.ModuleUtils.findByName("Checkbox"); NativeSubComponents.ContextMenuSliderItem = BDFDB.ModuleUtils.findByName("SliderMenuItem"); NativeSubComponents.ContextMenuToggleItem = BDFDB.ModuleUtils.findByName("ToggleMenuItem"); NativeSubComponents.FavButton = BDFDB.ModuleUtils.findByName("GIFFavButton"); NativeSubComponents.KeybindRecorder = BDFDB.ModuleUtils.findByName("KeybindRecorder"); NativeSubComponents.PopoutContainer = BDFDB.ModuleUtils.findByName("Popout"); NativeSubComponents.QuickSelect = BDFDB.ModuleUtils.findByName("QuickSelectWrapper"); NativeSubComponents.RadioGroup = BDFDB.ModuleUtils.findByName("RadioGroup"); NativeSubComponents.SearchBar = BDFDB.ModuleUtils.find(m => m && m.displayName == "SearchBar" && m.defaultProps.placeholder == BDFDB.LanguageUtils.LanguageStrings.SEARCH); NativeSubComponents.Select = BDFDB.ModuleUtils.findByName("SelectTempWrapper"); NativeSubComponents.Slider = BDFDB.ModuleUtils.findByName("Slider"); NativeSubComponents.SvgIcon = BDFDB.ModuleUtils.findByProperties("Gradients", "Names"); NativeSubComponents.Switch = BDFDB.ModuleUtils.findByName("Switch"); NativeSubComponents.TabBar = BDFDB.ModuleUtils.findByName("TabBar"); NativeSubComponents.Table = BDFDB.ModuleUtils.findByName("Table"); NativeSubComponents.TextArea = BDFDB.ModuleUtils.findByName("TextArea"); NativeSubComponents.TextInput = BDFDB.ModuleUtils.findByName("TextInput"); NativeSubComponents.TooltipContainer = BDFDB.ModuleUtils.findByName("Tooltip"); LibraryComponents.Anchor = BDFDB.ModuleUtils.findByName("Anchor"); LibraryComponents.Animations = Object.assign({}, BDFDB.ModuleUtils.findByProperties("Controller", "Spring")); LibraryComponents.AutocompleteComponents = Object.assign({}, BDFDB.ModuleUtils.findByName("Autocomplete")); LibraryComponents.AutocompleteComponents.Menu = BDFDB.ModuleUtils.findByName("Autocomplete"); LibraryComponents.Avatar = (BDFDB.ModuleUtils.findByProperties("AnimatedAvatar") || {}).default; LibraryComponents.BadgeComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("IconBadge", "NumberBadge")); LibraryComponents.BadgeComponents.AnimationContainer = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.BadgeComponents.AnimationContainer") || reactInitialized && class BDFDB_BadgeContainer extends LibraryModules.React.Component { componentDidMount() {BDFDB.ReactUtils.forceUpdate(this);} componentWillAppear(e) {if (typeof e == "function") e();} componentWillEnter(e) {if (typeof e == "function") e();} componentWillLeave(e) {if (typeof e == "function") this.timeoutId = setTimeout(e, 300);} componentWillUnmount() {clearTimeout(this.timeoutId)} render() { return BDFDB.ReactUtils.createElement(LibraryComponents.Animations.animated.div, { className: this.props.className, style: this.props.animatedStyle, children: this.props.children }); } }; LibraryComponents.BotTag = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.BotTag") || reactInitialized && class BDFDB_BotTag extends LibraryModules.React.Component { handleClick(e) {if (typeof this.props.onClick == "function") this.props.onClick(e, this);} handleContextMenu(e) {if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this);} render() { return BDFDB.ReactUtils.createElement("span", { className: BDFDB.DOMUtils.formatClassName(this.props.invertColor ? BDFDB.disCN.bottaginvert : BDFDB.disCN.bottagregular, this.props.className), style: this.props.style, onClick: this.handleClick.bind(this), onContextMenu: this.handleContextMenu.bind(this), children: this.props.tag || BDFDB.LanguageUtils.LanguageStrings.BOT_TAG_BOT }); } }; LibraryComponents.Button = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Button") || reactInitialized && class BDFDB_Button extends LibraryModules.React.Component { handleClick(e) {if (typeof this.props.onClick == "function") this.props.onClick(e, this);} handleContextMenu(e) {if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this);} handleMouseDown(e) {if (typeof this.props.onMouseDown == "function") this.props.onMouseDown(e, this);} handleMouseUp(e) {if (typeof this.props.onMouseUp == "function") this.props.onMouseUp(e, this);} handleMouseEnter(e) {if (typeof this.props.onMouseEnter == "function") this.props.onMouseEnter(e, this);} handleMouseLeave(e) {if (typeof this.props.onMouseLeave == "function") this.props.onMouseLeave(e, this);} render() { let processingAndListening = (this.props.disabled || this.props.submitting) && (null != this.props.onMouseEnter || null != this.props.onMouseLeave); let props = BDFDB.ObjectUtils.exclude(this.props, "look", "color", "hover", "size", "fullWidth", "grow", "disabled", "submitting", "type", "style", "wrapperClassName", "className", "innerClassName", "onClick", "onContextMenu", "onMouseDown", "onMouseUp", "onMouseEnter", "onMouseLeave", "children", "rel"); let button = BDFDB.ReactUtils.createElement("button", Object.assign({}, !this.props.disabled && !this.props.submitting && props, { className: BDFDB.DOMUtils.formatClassName(this.props.className, BDFDB.disCN.button, this.props.look != null ? this.props.look : LibraryComponents.Button.Looks.FILLED, this.props.color != null ? this.props.color : LibraryComponents.Button.Colors.BRAND, this.props.hover, this.props.size != null ? this.props.size : LibraryComponents.Button.Sizes.MEDIUM, processingAndListening && this.props.wrapperClassName, this.props.fullWidth && BDFDB.disCN.buttonfullwidth, (this.props.grow === undefined || this.props.grow) && BDFDB.disCN.buttongrow, this.props.hover && this.props.hover !== LibraryComponents.Button.Hovers.DEFAULT && BDFDB.disCN.buttonhashover, this.props.submitting && BDFDB.disCN.buttonsubmitting), onClick: (this.props.disabled || this.props.submitting) ? e => {return e.preventDefault();} : this.handleClick.bind(this), onContextMenu: (this.props.disabled || this.props.submitting) ? e => {return e.preventDefault();} : this.handleContextMenu.bind(this), onMouseUp: !this.props.disabled && this.handleMouseDown.bind(this), onMouseDown: !this.props.disabled && this.handleMouseUp.bind(this), onMouseEnter: this.handleMouseEnter.bind(this), onMouseLeave: this.handleMouseLeave.bind(this), type: this.props.type === "undefined" ? "button" : this.props.type, disabled: this.props.disabled, style: this.props.style, rel: this.props.rel, children: [ this.props.submitting && !this.props.disabled ? BDFDB.ReactUtils.createElement(LibraryComponents.Spinner, { type: LibraryComponents.Spinner.Type.PULSING_ELLIPSIS, className: BDFDB.disCN.buttonspinner, itemClassName: BDFDB.disCN.buttonspinneritem }) : null, BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.buttoncontents, this.props.innerClassName), children: this.props.children }) ] })); return !processingAndListening ? button : BDFDB.ReactUtils.createElement("span", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.buttondisabledwrapper, this.props.wrapperClassName, this.props.size != null ? this.props.size : LibraryComponents.Button.Sizes.MEDIUM, this.props.fullWidth && BDFDB.disCN.buttonfullwidth, (this.props.grow === undefined || this.props.grow) && BDFDB.disCN.buttongrow), children: [ button, BDFDB.ReactUtils.createElement("span", { onMouseEnter: this.handleMouseEnter.bind(this), onMouseLeave: this.handleMouseLeave.bind(this), className: BDFDB.disCN.buttondisabledoverlay }) ] }); } }; LibraryComponents.Card = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Card") || reactInitialized && class BDFDB_Card extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.hovercardwrapper, this.props.backdrop && BDFDB.disCN.hovercard, this.props.className), onMouseEnter: e => {if (typeof this.props.onMouseEnter == "function") this.props.onMouseEnter(e, this);}, onMouseLeave: e => {if (typeof this.props.onMouseLeave == "function") this.props.onMouseLeave(e, this);}, onClick: e => {if (typeof this.props.onClick == "function") this.props.onClick(e, this);}, onContextMenu: e => {if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this);}, children: [ !this.props.noRemove ? BDFDB.ReactUtils.createElement(LibraryComponents.CardRemoveButton, { onClick: e => { if (typeof this.props.onRemove == "function") this.props.onRemove(e, this); BDFDB.ListenerUtils.stopEvent(e); } }) : null, typeof this.props.children == "string" ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextElement, { className: BDFDB.disCN.hovercardinner, color: BDFDB.LibraryComponents.TextElement.Colors.PRIMARY, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextScroller, {children: this.props.children}) }) : this.props.children ].flat(10).filter(n => n) }), "backdrop", "noRemove")); } }; InternalBDFDB.setDefaultProps(LibraryComponents.Card, {backdrop:true, noRemove:false}); LibraryComponents.CardRemoveButton = BDFDB.ModuleUtils.findByName("RemoveButton"); LibraryComponents.ChannelTextAreaButton = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ChannelTextAreaButton") || reactInitialized && class BDFDB_ChannelTextAreaButton extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement(LibraryComponents.Button, { look: LibraryComponents.Button.Looks.BLANK, size: LibraryComponents.Button.Sizes.NONE, "aria-label": this.props.label, tabIndex: this.props.tabIndex, className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.textareabuttonwrapper, this.props.isActive && BDFDB.disCN.textareabuttonactive), innerClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.textareabutton, this.props.className, this.props.pulse && BDFDB.disCN.textareaattachbuttonplus), onClick: this.props.onClick, onContextMenu: this.props.onContextMenu, onMouseEnter: this.props.onMouseEnter, onMouseLeave: this.props.onMouseLeave, children: BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { name: this.props.iconName, iconSVG: this.props.iconSVG, className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.textareaicon, this.props.iconClassName, this.props.pulse && BDFDB.disCN.textareaiconpulse) }) }); } }; LibraryComponents.CharCounter = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.CharCounter") || reactInitialized && class BDFDB_CharCounter extends LibraryModules.React.Component { getCounterString() { let input = this.refElement || {}, string = ""; if (BDFDB.DOMUtils.containsClass(this.refElement, BDFDB.disCN.textarea)) { let instance = BDFDB.ReactUtils.findOwner(input, {name:"ChannelEditorContainer", up:true}); if (instance) string = instance.props.textValue; else string = input.value || input.textContent || ""; } else string = input.value || input.textContent || ""; let start = input.selectionStart || 0, end = input.selectionEnd || 0, selectlength = end - start, selection = BDFDB.DOMUtils.getSelection(); let select = !selectlength && !selection ? 0 : (selectlength || selection.length); select = !select ? 0 : (select > string.length ? (end || start ? string.length - (string.length - end - start) : string.length) : select); let children = [ typeof this.props.renderPrefix == "function" && this.props.renderPrefix(string.length), `${string.length}${!this.props.max ? "" : "/" + this.props.max}${!select ? "" : " (" + select + ")"}`, typeof this.props.renderSuffix == "function" && this.props.renderSuffix(string.length) ].filter(n => n); return children.length == 1 ? children[0] : BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { align: LibraryComponents.Flex.Align.CENTER, children: children }); } updateCounter() { if (!this.refElement) return; BDFDB.TimeUtils.clear(this.updateTimeout); this.updateTimeout = BDFDB.TimeUtils.timeout(this.forceUpdateCounter.bind(this), 100); } forceUpdateCounter() { if (!this.refElement) return; this.props.children = this.getCounterString(); BDFDB.ReactUtils.forceUpdate(this); } handleSelection() { if (!this.refElement) return; let mousemove = _ => { BDFDB.TimeUtils.timeout(this.forceUpdateCounter.bind(this), 10); }; let mouseup = _ => { document.removeEventListener("mousemove", mousemove); document.removeEventListener("mouseup", mouseup); if (this.refElement.selectionEnd - this.refElement.selectionStart) BDFDB.TimeUtils.timeout(_ => { document.addEventListener("click", click); }); }; let click = _ => { var contexttype = BDFDB.ReactUtils.getValue(document.querySelector(BDFDB.dotCN.contextmenu), "return.stateNode.props.type"); if (!contexttype || !contexttype.startsWith("CHANNEL_TEXT_AREA")) this.forceUpdateCounter(); BDFDB.TimeUtils.timeout(this.forceUpdateCounter.bind(this), 100); document.removeEventListener("mousemove", mousemove); document.removeEventListener("mouseup", mouseup); document.removeEventListener("click", click); }; document.addEventListener("mousemove", mousemove); document.addEventListener("mouseup", mouseup); } componentDidMount() { if (this.props.refClass) { let node = BDFDB.ReactUtils.findDOMNode(this); if (node && node.parentElement) { this.refElement = node.parentElement.querySelector(this.props.refClass); if (this.refElement) { if (!this._updateCounter) this._updateCounter = _ => { if (!document.contains(node)) BDFDB.ListenerUtils.multiRemove(this.refElement, "keydown click change", this._updateCounter); else this.updateCounter(); }; if (!this._handleSelection) this._handleSelection = _ => { if (!document.contains(node)) BDFDB.ListenerUtils.multiRemove(this.refElement, "mousedown", this._handleSelection); else this.handleSelection(); }; BDFDB.ListenerUtils.multiRemove(this.refElement, "mousedown", this._handleSelection); BDFDB.ListenerUtils.multiAdd(this.refElement, "mousedown", this._handleSelection); if (this.refElement.tagName == "INPUT" || this.refElement.tagName == "TEXTAREA") { BDFDB.ListenerUtils.multiRemove(this.refElement, "keydown click change", this._updateCounter); BDFDB.ListenerUtils.multiAdd(this.refElement, "keydown click change", this._updateCounter); } else { if (!this._mutationObserver) this._mutationObserver = new MutationObserver(changes => { if (!document.contains(node)) this._mutationObserver.disconnect(); else this.updateCounter(); }); else this._mutationObserver.disconnect(); this._mutationObserver.observe(this.refElement, {childList: true, subtree: true}); } this.updateCounter(); } else BDFDB.LogUtils.warn("could not find referenceElement for BDFDB_CharCounter"); } } else BDFDB.LogUtils.warn("refClass can not be undefined for BDFDB_CharCounter"); } render() { let string = this.getCounterString(); BDFDB.TimeUtils.timeout(_ => {if (string != this.getCounterString()) BDFDB.ReactUtils.forceUpdate(this);}); return BDFDB.ReactUtils.createElement("div", BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.charcounter, this.props.className), children: string }), "parsing", "max", "refClass", "renderPrefix", "renderSuffix")); } }; LibraryComponents.Checkbox = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Checkbox") || reactInitialized && class BDFDB_Checkbox extends LibraryModules.React.Component { handleChange() { this.props.value = !this.props.value; if (typeof this.props.onChange == "function") this.props.onChange(this.props.value, this); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.Checkbox, Object.assign({}, this.props, {onChange: this.handleChange.bind(this)})); } }; LibraryComponents.Clickable = BDFDB.ModuleUtils.findByName("Clickable"); LibraryComponents.CollapseContainer = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.CollapseContainer") || reactInitialized && class BDFDB_CollapseContainer extends LibraryModules.React.Component { render() { if (!BDFDB.ObjectUtils.is(this.props.collapseStates)) this.props.collapseStates = {}; this.props.collapsed = this.props.collapsed && (this.props.collapseStates[this.props.title] || this.props.collapseStates[this.props.title] == undefined); this.props.collapseStates[this.props.title] = this.props.collapsed; return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(this.props.collapsed && BDFDB.disCN.collapsecontainercollapsed, this.props.mini ? BDFDB.disCN.collapsecontainermini : BDFDB.disCN.collapsecontainer, this.props.className), id: this.props.id, children: [ this.props.dividertop ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: this.props.mini ? BDFDB.disCN.marginbottom8 : BDFDB.disCN.marginbottom20 }) : null, BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCNS.collapsecontainerheader + BDFDB.disCN.cursorpointer, align: LibraryComponents.Flex.Align.CENTER, onClick: e => { this.props.collapsed = !this.props.collapsed; this.props.collapseStates[this.props.title] = this.props.collapsed; if (typeof this.props.onClick == "function") this.props.onClick(this.props.collapsed, this); BDFDB.ReactUtils.forceUpdate(this); }, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.collapsecontainerarrow }), BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormTitle, { tag: LibraryComponents.FormComponents.FormTitle.Tags.H2, className: BDFDB.disCNS.collapsecontainertitle + BDFDB.disCN.cursorpointer, children: this.props.title }) ] }), !this.props.collapsed ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.collapsecontainerinner, children: this.props.children }) : null, this.props.dividerbottom ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: this.props.mini ? BDFDB.disCN.margintop8 : BDFDB.disCN.margintop20 }) : null ] }); } }; InternalBDFDB.setDefaultProps(LibraryComponents.CollapseContainer, {collapsed:true, mini:true}); LibraryComponents.ColorSwatches = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ColorSwatches") || reactInitialized && class BDFDB_ColorSwatches extends LibraryModules.React.Component { constructor(props) { super(props); props.selectedColor = BDFDB.ObjectUtils.is(props.color) ? props.color : BDFDB.ColorUtils.convert(props.color, "RGBA"); props.colors = (BDFDB.ArrayUtils.is(props.colors) ? props.colors : [null, 5433630, 3066993, 1752220, 3447003, 3429595, 8789737, 10181046, 15277667, 15286558, 15158332, 15105570, 15844367, 13094093, 7372936, 6513507, 16777215, 3910932, 2067276, 1146986, 2123412, 2111892, 7148717, 7419530, 11342935, 11345940, 10038562, 11027200, 12745742, 9936031, 6121581, 2894892]).map(c => BDFDB.ColorUtils.convert(c, "RGBA")); props.colorRows = props.colors.length ? [props.colors.slice(0, parseInt(props.colors.length/2)), props.colors.slice(parseInt(props.colors.length/2))] : []; props.customColor = props.selectedColor != null ? (props.colors.indexOf(props.selectedColor) > -1 ? null : props.selectedColor) : null; props.customSelected = !!props.customColor; props.pickerConfig = BDFDB.ObjectUtils.is(props.pickerConfig) ? props.pickerConfig : {gradient: true, alpha: true, callback: _ => {}}; this.state = props; var swatches = this; this.ColorSwatch = class ColorSwatch extends LibraryModules.React.Component { render() { let usewhite = !BDFDB.ColorUtils.isBright(this.props.color); let swatch = BDFDB.ReactUtils.createElement("button", { type: "button", className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.colorpickerswatch, this.props.isSingle && BDFDB.disCN.colorpickerswatchsingle, this.props.isDisabled && BDFDB.disCN.colorpickerswatchdisabled, this.props.isSelected && BDFDB.disCN.colorpickerswatchselected, this.props.isCustom && BDFDB.disCN.colorpickerswatchcustom, this.props.color == null && BDFDB.disCN.colorpickerswatchnocolor), number: this.props.number, disabled: this.props.isDisabled, onClick: _ => { if (!this.props.isSelected) { let color = this.props.isCustom && this.props.color == null ? "rgba(0,0,0,1)" : this.props.color; swatches.setState({ selectedColor: color, customColor: this.props.isCustom ? color : swatches.state.customColor, customSelected: this.props.isCustom }); } if (this.props.isCustom || this.props.isSingle) { let swatch = BDFDB.ReactUtils.findDOMNode(this); if (swatch) BDFDB.ColorUtils.openPicker(swatches, swatch, this.props.color, swatches.state.pickerConfig); }; }, style: Object.assign({}, this.props.style, { background: BDFDB.ObjectUtils.is(this.props.color) ? BDFDB.ColorUtils.createGradient(this.props.color) : BDFDB.ColorUtils.convert(this.props.color, "RGBA") }), children: [ this.props.isCustom || this.props.isSingle ? BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { className: BDFDB.disCN.colorpickerswatchdropper, foreground: BDFDB.disCN.colorpickerswatchdropperfg, name: LibraryComponents.SvgIcon.Names.DROPPER, width: this.props.isCustom ? 14 : 10, height: this.props.isCustom ? 14 : 10, color: usewhite ? BDFDB.DiscordConstants.Colors.WHITE : BDFDB.DiscordConstants.Colors.BLACK }) : null, this.props.isSelected && !this.props.isSingle ? BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { name: LibraryComponents.SvgIcon.Names.CHECKMARK, width: this.props.isCustom ? 32 : 16, height: this.props.isCustom ? 24 : 16, color: usewhite ? BDFDB.DiscordConstants.Colors.WHITE : BDFDB.DiscordConstants.Colors.BLACK }) : null ] }); return this.props.isCustom || this.props.isSingle || this.props.color == null ? BDFDB.ReactUtils.createElement(LibraryComponents.TooltipContainer, { text: this.props.isCustom || this.props.isSingle ? BDFDB.LanguageUtils.LanguageStrings.CUSTOM_COLOR : BDFDB.LanguageUtils.LanguageStrings.DEFAULT, tooltipConfig: {type: this.props.isSingle ? "top" : "bottom"}, children: swatch }) : swatch; } } } renderRow(colors) { return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.colorpickerrow, wrap: LibraryComponents.Flex.Wrap.WRAP, children: colors.map(color => { return BDFDB.ReactUtils.createElement(this.ColorSwatch, { color: color, isCustom: false, isSelected: !this.state.customSelected && color === this.state.selectedColor, isDisabled: this.state.disabled }) }) }); } render() { let customSwatch = BDFDB.ReactUtils.createElement(this.ColorSwatch, { number: !this.state.colors.length ? (this.props.number != null ? this.props.number : 0) : null, color: this.state.customColor, isSingle: !this.state.colors.length, isCustom: this.state.colors.length, isSelected: this.state.customSelected, isDisabled: this.state.disabled, style: {margin: 0} }); return !this.state.colors.length ? customSwatch : BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.colorpickerswatches, this.state.disabled && BDFDB.disCN.colorpickerswatchesdisabled), number: this.props.number != null ? this.props.number : 0, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { className: BDFDB.disCN.marginreset, shrink: 0, grow: 0, children: customSwatch }), BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { direction: LibraryComponents.Flex.Direction.VERTICAL, className: BDFDB.disCN.flexmarginreset, grow: 1, children: [ this.renderRow(this.state.colorRows[0]), this.renderRow(this.state.colorRows[1]) ] }) ] }); } }; LibraryComponents.Connectors = Object.assign({}, BDFDB.ModuleUtils.findByProperties("Router", "Link")); LibraryComponents.ContextMenuItems = {}; LibraryComponents.ContextMenuItems.Item = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ContextMenuItems.Item") || reactInitialized && class BDFDB_ContextMenuItem extends LibraryModules.React.Component { render() { let hintIsString = typeof this.props.hint == "string"; return BDFDB.ReactUtils.createElement(LibraryComponents.Clickable, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.contextmenuitem, !this.props.disabled && BDFDB.disCN.contextmenuitemclickable, this.props.danger && BDFDB.disCN.contextmenuitemdanger, this.props.disabled && BDFDB.disCN.contextmenuitemdisabled, this.props.brand && BDFDB.disCN.contextmenuitembrand, this.props.className), style: this.props.style, role: "menuitem", onClick: this.props.disabled || typeof this.props.action != "function" ? null : this.props.action, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.contextmenulabel, children: this.props.label }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.contextmenuhint, style: hintIsString ? { width: 42, maxWidth: 42, marginLeft: 8 } : {}, children: hintIsString ? BDFDB.ReactUtils.createElement(LibraryComponents.TextScroller, { speed: 2, children: this.props.hint }) : (this.props.hint || null) }), this.props.children ] }); } }; LibraryComponents.ContextMenuItems.Group = BDFDB.ModuleUtils.findByString(`"div",{className`, `default.itemGroup}`); LibraryComponents.ContextMenuItems.Slider = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ContextMenuItems.Slider") || reactInitialized && class BDFDB_ContextMenuSliderItem extends LibraryModules.React.Component { handleValueChange(value) { let newvalue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange([0, 100], this.props.edges, value) : value; if (typeof this.props.digits == "number") newvalue = Math.round(newvalue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); this.props.defaultValue = newvalue; if (typeof this.props.onValueChange == "function") this.props.onValueChange(newvalue, this); BDFDB.ReactUtils.forceUpdate(this); } handleValueRender(value) { let newvalue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange([0, 100], this.props.edges, value) : value; if (typeof this.props.digits == "number") newvalue = Math.round(newvalue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); if (typeof this.props.renderLabel == "function") this.props.label = this.props.renderLabel(newvalue); if (typeof this.props.onValueRender == "function") { let tempreturn = this.props.onValueRender(newvalue, this); if (tempreturn != undefined) newvalue = tempreturn; } return newvalue; } render() { let defaultValue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange(this.props.edges, [0, 100], this.props.defaultValue) : this.props.defaultValue; if (typeof this.props.digits == "number") defaultValue = Math.round(defaultValue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); return BDFDB.ReactUtils.createElement(NativeSubComponents.ContextMenuSliderItem, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { defaultValue: defaultValue, label: typeof this.props.renderLabel == "function" ? this.props.renderLabel(this.props.defaultValue) : this.props.label, onValueChange: this.handleValueChange.bind(this), onValueRender: this.handleValueRender.bind(this) }), "digits", "edges", "renderLabel")); } }; LibraryComponents.ContextMenuItems.Sub = BDFDB.ModuleUtils.findByName("FluxContainer(SubMenuItem)"); LibraryComponents.ContextMenuItems.Toggle = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ContextMenuItems.Toggle") || reactInitialized && class BDFDB_ContextMenuToggleItem extends LibraryModules.React.Component { handleToggle() { this.props.active = !this.props.active; if (typeof this.props.action == "function") this.props.action(this.props.active); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.ContextMenuToggleItem, Object.assign({}, this.props, {action: this.handleToggle.bind(this)})); } }; var ComponentTypeData = {}; ComponentTypeData.NormalContextMenus = ["DeveloperContextMenu", "GuildRoleContextMenu", "MessageContextMenu", "NativeContextMenu", "ScreenshareContextMenu", "UserSettingsCogContextMenu"]; ComponentTypeData.FluxContextMenus = ["ApplicationContextMenu", "GroupDMContextMenu"]; ComponentTypeData.NonRenderContextMenus = ["ChannelContextMenu", "GuildContextMenu", "SlateContextMenu", "UserContextMenu"]; ComponentTypeData.ObservedContextMenus = []; ComponentTypeData.ExtraPatchedComponents = ["MessageOptionContextMenu", "MessageOptionToolbar"]; ComponentTypeData.QueuedComponents = [].concat(ComponentTypeData.NonRenderContextMenus, ComponentTypeData.ObservedContextMenus, ComponentTypeData.ExtraPatchedComponents); LibraryComponents.ContextMenus = {}; LibraryComponents.ContextMenus._Exports = {}; LibraryComponents.ContextMenus._Types = Object.entries(BDFDB.DiscordConstants.ContextMenuTypes).map(n => n[1]); LibraryComponents.ContextMenus.ApplicationContextMenu = BDFDB.ModuleUtils.findByName("FluxContainer(ApplicationContextMenu)"); LibraryComponents.ContextMenus.ChannelContextMenu = BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.CHANNEL_LIST_TEXT); LibraryComponents.ContextMenus._Exports.ChannelContextMenu = (BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.CHANNEL_LIST_TEXT, false) || {}).exports; LibraryComponents.ContextMenus.DeveloperContextMenu = BDFDB.ModuleUtils.findByName("DeveloperContextMenu"); LibraryComponents.ContextMenus.GroupDMContextMenu = BDFDB.ModuleUtils.findByName("FluxContainer(GroupDMContextMenu)"); LibraryComponents.ContextMenus.GuildContextMenu = BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.GUILD_CHANNEL_LIST); LibraryComponents.ContextMenus._Exports.GuildContextMenu = (BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.GUILD_CHANNEL_LIST, false) || {}).exports; LibraryComponents.ContextMenus.GuildRoleContextMenu = BDFDB.ModuleUtils.findByName("GuildRoleContextMenu"); LibraryComponents.ContextMenus.MessageContextMenu = BDFDB.ModuleUtils.findByName("MessageContextMenu"); LibraryComponents.ContextMenus.NativeContextMenu = BDFDB.ModuleUtils.findByName("NativeContextMenu"); LibraryComponents.ContextMenus.ScreenshareContextMenu = BDFDB.ModuleUtils.findByName("ScreenshareContextMenu"); LibraryComponents.ContextMenus.SlateContextMenu = BDFDB.ModuleUtils.findByName("SlateContextMenu"); LibraryComponents.ContextMenus._Exports.SlateContextMenu = BDFDB.ModuleUtils.findByName("SlateContextMenu", false); LibraryComponents.ContextMenus.UserContextMenu = BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.USER_CHANNEL_MEMBERS); LibraryComponents.ContextMenus._Exports.UserContextMenu = (BDFDB.ModuleUtils.findByString("Error - no such ctx menu type", BDFDB.DiscordConstants.ContextMenuTypes.USER_CHANNEL_MEMBERS, false) || {}).exports; LibraryComponents.ContextMenus.UserSettingsCogContextMenu = BDFDB.ModuleUtils.findByName("UserSettingsCogContextMenu"); LibraryComponents.DiscordTag = BDFDB.ModuleUtils.findByName("DiscordTag"); LibraryComponents.FavButton = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.FavButton") || reactInitialized && class BDFDB_FavButton extends LibraryModules.React.Component { handleClick() { this.props.isFavorite = !this.props.isFavorite; if (typeof this.props.onClick == "function") this.props.onClick(this.props.isFavorite, this); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.favbuttoncontainer, children: BDFDB.ReactUtils.createElement(NativeSubComponents.FavButton, Object.assign({}, this.props, {onClick: this.handleClick.bind(this)})) }); } }; LibraryComponents.FileButton = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.FileButton") || reactInitialized && class BDFDB_FileButton extends LibraryModules.React.Component { render() { let filter = this.props.filter && [this.props.filter].flat(10).filter(n => typeof n == "string") || []; return BDFDB.ReactUtils.createElement(LibraryComponents.Button, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { onClick: e => {e.currentTarget.querySelector("input").click();}, children: [ BDFDB.LanguageUtils.LibraryStrings.file_navigator_text, BDFDB.ReactUtils.createElement("input", { type: "file", accept: filter.length && (filter.join("/*,") + "/*"), style: {display: "none"}, onChange: e => { let file = e.currentTarget.files[0]; if (this.refInput && file && (!filter.length || filter.some(n => file.type.indexOf(n) == 0))) { this.refInput.props.value = `${this.props.mode == "url" ? "url('" : ""}${this.props.useFilepath ? file.path : `data:${file.type};base64,${BDFDB.LibraryRequires.fs.readFileSync(file.path).toString("base64")}`}${this.props.mode ? "')" : ""}`; BDFDB.ReactUtils.forceUpdate(this.refInput); this.refInput.handleChange(this.refInput.props.value); } } }) ] }), "filter", "mode", "useFilepath")); } }; LibraryComponents.Flex = BDFDB.ModuleUtils.findByProperties("Wrap", "Direction", "Child"); LibraryComponents.FormComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("FormSection", "FormText")); LibraryComponents.FormComponents.FormItem = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.FormComponents.FormItem") || reactInitialized && class BDFDB_FormItem extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement("div", { className: this.props.className, style: this.props.style, children: [ BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { align: LibraryComponents.Flex.Align.BASELINE, children: [ this.props.title != null || this.props.error != null ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { wrap: true, children: BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormTitle, { tag: this.props.tag || LibraryComponents.FormComponents.FormTitle.Tags.H5, disabled: this.props.disabled, required: this.props.required, error: this.props.error, className: this.props.titleClassName, children: this.props.title }) }) : null ].concat([this.props.titlechildren].flat(10)).filter(n => n) }), ].concat(this.props.children) }); } }; LibraryComponents.GuildComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("Separator", "DragPlaceholder")); LibraryComponents.GuildComponents.Badge = BDFDB.ModuleUtils.findByName("GuildBadge"); LibraryComponents.GuildComponents.BlobMask = BDFDB.ModuleUtils.findByName("BlobMask"); LibraryComponents.GuildComponents.Guild = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.GuildComponents.Guild") || reactInitialized && class BDFDB_Guild extends LibraryModules.React.Component { constructor(props) { super(props); this.state = {hovered: false}; } handleMouseEnter(e) { if (!this.props.sorting) this.setState({hovered: true}); if (typeof this.props.onMouseEnter == "function") this.props.onMouseEnter(e, this); } handleMouseLeave(e) { if (!this.props.sorting) this.setState({hovered: false}); if (typeof this.props.onMouseLeave == "function") this.props.onMouseLeave(e, this); } handleMouseDown(e) { if (!this.props.unavailable && this.props.guild && this.props.selectedChannelId) LibraryModules.DirectMessageUtils.preload(this.props.guild.id, this.props.selectedChannelId); if (e.button == 0 && typeof this.props.onMouseDown == "function") this.props.onMouseDown(e, this); } handleMouseUp(e) { if (e.button == 0 && typeof this.props.onMouseUp == "function") this.props.onMouseUp(e, this); } handleClick(e) { if (typeof this.props.onClick == "function") this.props.onClick(e, this); } handleContextMenu(e) { if (this.props.menu) BDFDB.GuildUtils.openMenu(this.props.guild, e); if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this); } setRef(e) { if (typeof this.props.setRef == "function") this.props.setRef(this.props.guild.id, e) } componentDidMount() { let node = BDFDB.ReactUtils.findDOMNode(this); if (node) for (let child of node.querySelectorAll("a")) child.setAttribute("draggable", false); } render() { if (!this.props.guild) return null; this.props.guildId = this.props.guild.id; this.props.selectedChannelId = LibraryModules.LastChannelStore.getChannelId(this.props.guild.id); this.props.selected = this.props.state ? LibraryModules.LastGuildStore.getGuildId() == this.props.guild.id : false; this.props.unread = this.props.state ? LibraryModules.UnreadGuildUtils.hasUnread(this.props.guild.id) : false; this.props.badge = this.props.state ? LibraryModules.UnreadGuildUtils.getMentionCount(this.props.guild.id) : 0; this.props.audio = this.props.state ? (LibraryModules.ChannelStore.getChannel(LibraryModules.LastChannelStore.getVoiceChannelId()) || {}).guild_id == this.props.guild.id : false; this.props.video = this.props.state ? (LibraryModules.StreamUtils.getActiveStream() || {}).guildId == this.props.guild.id : false; this.props.screenshare = this.props.state ? !!LibraryModules.StreamUtils.getAllApplicationStreams().filter(stream => stream.guildId == this.props.guild.id)[0] : false; this.props.isCurrentUserInThisGuildVoice = this.props.state ? !LibraryModules.CurrentVoiceUtils.isDisabled() && LibraryModules.CurrentVoiceUtils.getGuildId() == this.props.guild.id : false; this.props.animatable = this.props.state ? LibraryModules.IconUtils.hasAnimatedGuildIcon(this.props.guild) : false; var isDraggedGuild = this.props.draggingGuildId === this.props.guild.id; var Guild = isDraggedGuild ? BDFDB.ReactUtils.createElement("div", { children: BDFDB.ReactUtils.createElement(LibraryComponents.GuildComponents.DragPlaceholder, {}) }) : BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.guildcontainer, children: BDFDB.ReactUtils.createElement(LibraryComponents.GuildComponents.BlobMask, { selected: this.state.isDropHovering || this.props.selected || this.state.hovered, upperBadge: this.props.unavailable ? LibraryComponents.GuildComponents.renderUnavailableBadge() : LibraryComponents.GuildComponents.renderIconBadge(this.props.audio, this.props.video, this.props.screenshare), lowerBadge: this.props.badge > 0 ? LibraryComponents.GuildComponents.renderMentionBadge(this.props.badge) : null, lowerBadgeWidth: LibraryComponents.BadgeComponents.getBadgeWidthForValue(this.props.badge), children: BDFDB.ReactUtils.createElement(LibraryComponents.NavItem, { to: { pathname: BDFDB.DiscordConstants.Routes.CHANNEL(this.props.guild.id, this.props.selectedChannelId), state: { analyticsSource: { page: BDFDB.DiscordConstants.AnalyticsPages.GUILD_CHANNEL, section: BDFDB.DiscordConstants.AnalyticsSections.CHANNEL_LIST, object: BDFDB.DiscordConstants.AnalyticsObjects.CHANNEL } } }, name: this.props.guild.name, onMouseEnter: this.handleMouseEnter.bind(this), onMouseLeave: this.handleMouseLeave.bind(this), onMouseDown: this.handleMouseDown.bind(this), onMouseUp: this.handleMouseUp.bind(this), onClick: this.handleClick.bind(this), onContextMenu: this.handleContextMenu.bind(this), icon: this.props.guild.getIconURL(this.state.hovered && this.props.animatable ? "gif" : "jpg"), selected: this.props.selected || this.state.hovered }) }) }); if (this.props.draggable && typeof this.props.connectDragSource == "function") Guild = this.props.connectDragSource(Guild); var children = [ this.props.list || this.props.pill ? BDFDB.ReactUtils.createElement(LibraryComponents.GuildComponents.Pill, { hovered: !isDraggedGuild && this.state.hovered, selected: !isDraggedGuild && this.props.selected, unread: !isDraggedGuild && this.props.unread, className: BDFDB.disCN.guildpill }) : null, !this.props.tooltip ? Guild : BDFDB.ReactUtils.createElement(LibraryComponents.TooltipContainer, { tooltipConfig: Object.assign({type: "right"}, this.props.tooltipConfig, {guild: this.props.list && this.props.guild}), children: Guild }) ].filter(n => n); return this.props.list ? LibraryComponents.GuildComponents.renderListItem(BDFDB.ReactUtils.createElement(BDFDB.ReactUtils.Fragment, { children: children }), null != this.props.setRef ? this.setRef : null) : BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.guild, this.props.className), children: children }); } }; InternalBDFDB.setDefaultProps(LibraryComponents.GuildComponents.Guild, {menu:true, tooltip:true, list:false, state:false, draggable:false, sorting:false}); LibraryComponents.GuildComponents.Icon = BDFDB.ModuleUtils.findByName("GuildIconWrapper"); LibraryComponents.GuildComponents.Pill = BDFDB.ModuleUtils.findByString("opacity:1,height:", "20:8", "default.item"); LibraryComponents.HeaderBarComponents = Object.assign({}, BDFDB.ModuleUtils.findByName("HeaderBarContainer")); LibraryComponents.KeybindRecorder = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.KeybindRecorder") || reactInitialized && class BDFDB_KeybindRecorder extends LibraryModules.React.Component { handleChange(arrays) { if (typeof this.props.onChange == "function") this.props.onChange(arrays.map(platformkey => LibraryModules.KeyEvents.codes[BDFDB.LibraryModules.KeyCodeUtils.codeToKey(platformkey)] || platformkey[1]), this); } handleReset() { this.props.defaultValue = []; let recorder = BDFDB.ReactUtils.findOwner(this, {name: "KeybindRecorder"}); if (recorder) recorder.setState({codes: []}); if (typeof this.props.onChange == "function") this.props.onChange([], this); if (typeof this.props.onReset == "function") this.props.onReset(this); } render() { return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.hotkeywrapper, direction: LibraryComponents.Flex.Direction.HORIZONTAL, align: LibraryComponents.Flex.Align.CENTER, children: [ BDFDB.ReactUtils.createElement(NativeSubComponents.KeybindRecorder, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { defaultValue: [this.props.defaultValue].flat(10).filter(n => n).map(keycode => [BDFDB.DiscordConstants.KeyboardDeviceTypes.KEYBOARD_KEY, keycode, BDFDB.DiscordConstants.KeyboardEnvs.BROWSER]), onChange: this.handleChange.bind(this) }), "reset", "onReset")), this.props.reset || this.props.onReset ? BDFDB.ReactUtils.createElement(LibraryComponents.TooltipContainer, { text: BDFDB.LanguageUtils.LanguageStrings.REMOVE_KEYBIND, tooltipConfig: {type: "top"}, children: BDFDB.ReactUtils.createElement(LibraryComponents.Clickable, { className: BDFDB.disCN.hotkeyresetbutton, onClick: this.handleReset.bind(this), children: BDFDB.ReactUtils.createElement(LibraryComponents.SvgIcon, { iconSVG: ``, }) }) }) : null ].filter(n => n) }); } }; LibraryComponents.LazyImage = BDFDB.ModuleUtils.findByName("LazyImage"); LibraryComponents.ListHeader = BDFDB.ModuleUtils.findByName("ListSectionItem"); LibraryComponents.ListItem = BDFDB.ModuleUtils.findByName("ListItem"); LibraryComponents.ListRow = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ListRow") || reactInitialized && class BDFDB_ListRow extends LibraryModules.React.Component { render () { return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.listrow, this.props.className), children: [ this.props.prefix, BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.listrowcontent, style: {flex: "1 1 auto"}, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.listname, this.props.labelClassName), style: {flex: "1 1 auto"}, children: this.props.label }), typeof this.props.note == "string" ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormText, { type: LibraryComponents.FormComponents.FormText.Types.DESCRIPTION, children: this.props.note }) : null ].filter(n => n) }), this.props.suffix ].filter(n => n) }); } }; LibraryComponents.MessageComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("Message", "MessageTimestamp")); LibraryComponents.MessageGroup = BDFDB.ModuleUtils.findByName("FluxContainer(ConnectedMessageGroup)"); LibraryComponents.MessagesPopoutComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("Header", "EmptyStateBottom")); LibraryComponents.MemberRole = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.MemberRole") || reactInitialized && class BDFDB_MemberRole extends LibraryModules.React.Component { handleClick(e) {if (typeof this.props.onClick == "function") this.props.onClick(e, this);} handleContextMenu(e) {if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this);} render() { let color = BDFDB.ColorUtils.convert(this.props.role.colorString || BDFDB.DiscordConstants.Colors.PRIMARY_DARK_300, "RGB"); return BDFDB.ReactUtils.createElement("li", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.userpopoutrole, this.props.className), style: {borderColor: BDFDB.ColorUtils.setAlpha(color, 0.6)}, onClick: this.handleClick.bind(this), onContextMenu: this.handleContextMenu.bind(this), children: [ !this.props.noCircle ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.userpopoutrolecircle, style: {backgroundColor: color} }) : null, BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.userpopoutrolename, children: this.props.role.name }) ].filter(n => n) }); } }; LibraryComponents.ModalComponents = Object.assign({}, BDFDB.ModuleUtils.findByProperties("ModalContent", "ModalFooter")); LibraryComponents.ModalComponents.ModalContent = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ModalComponents.ModalContent") || reactInitialized && class BDFDB_ModalContent extends LibraryModules.React.Component { render() { return this.props.scroller || this.props.scroller === undefined ? BDFDB.ReactUtils.createElement(LibraryComponents.ScrollerVertical, { outerClassName: BDFDB.disCN.modalcontent, className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.modalsubinner, this.props.className), theme: LibraryComponents.ScrollerVertical.Themes.GHOST_HAIRLINE, ref: this.props.scrollerRef, children: this.props.children }) : BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.modalcontent, direction: LibraryComponents.Flex.Direction.VERTICAL, align: LibraryComponents.Flex.Align.STRETCH, children: BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.modalsubinner, BDFDB.disCN.modalsubinnerscrollerless, this.props.className), direction: LibraryComponents.Flex.Direction.VERTICAL, align: LibraryComponents.Flex.Align.STRETCH, children: this.props.children }) }); } }; LibraryComponents.ModalComponents.ModalTabContent = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.ModalComponents.ModalTabContent") || reactInitialized && class BDFDB_ModalTabContent extends LibraryModules.React.Component { render() { let childprops = Object.assign({}, this.props); BDFDB.ObjectUtils.delete(childprops, "open"); return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, Object.assign({tab:"unnamed"}, childprops, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.modaltabcontent, this.props.open && BDFDB.disCN.modaltabcontentopen, this.props.className), direction: LibraryComponents.Flex.Direction.VERTICAL, align: LibraryComponents.Flex.Align.STRETCH, style: Object.assign({}, childprops.style, { display: this.props.open ? null : "none" }) })); } }; LibraryComponents.NavItem = BDFDB.ModuleUtils.findByName("NavItem"); LibraryComponents.Popout = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Popout") || reactInitialized && class BDFDB_Popout extends LibraryModules.React.Component { componentWillUnmount() { delete this.props.containerInstance.popout; if (typeof this.props.onClose == "function") this.props.onClose(this.props.containerInstance, this); } render() { let pos = typeof this.props.position == "string" ? this.props.position.toLowerCase() : null; let position = pos && DiscordClasses["popout" + pos] ? BDFDB.disCN["popout" + pos] : BDFDB.disCN.popouttop; let arrow = !this.props.arrow ? BDFDB.disCN.popoutnoarrow : (pos && pos.indexOf("top") > -1 && pos != "top" ? BDFDB.disCN.popoutarrowalignmenttop : BDFDB.disCN.popoutarrowalignmentmiddle); return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.popoutwrapper, BDFDB.disCN.popout, position, this.props.invert && pos && pos != "bottom" && BDFDB.disCN.popoutinvert, arrow, !this.props.shadow && BDFDB.disCN.popoutnoshadow), id: this.props.id, onClick: e => {e.stopPropagation();}, style: Object.assign({}, this.props.style, { position: this.props.isChild ? "relative" : "absolute" }), children: BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(this.props.className, (this.props.themed || this.props.themed === undefined) && BDFDB.disCN.popoutthemedpopout), style: BDFDB.ObjectUtils.extract(this.props, "padding", "height", "maxHeight", "minHeight", "width", "maxWidth", "minWidth"), children: this.props.children }) }); } }; LibraryComponents.PopoutContainer = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.PopoutContainer") || reactInitialized && class BDFDB_PopoutContainer extends LibraryModules.React.Component { handleRender(e) { return this.popout = BDFDB.ReactUtils.createElement(LibraryComponents.Popout, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { className: this.props.popoutClassName, containerInstance: this, isChild: true, position: e.position, style: this.props.popoutStyle, onClose: typeof this.props.onClose == "function" ? this.props.onClose.bind(this) : _ => {}, children: typeof this.props.renderPopout == "function" ? this.props.renderPopout(this) : null }), "popoutStyle", "popoutClassName")); } componentDidMount() { let basepopout = BDFDB.ReactUtils.findOwner(this, {name:"BasePopout"}); if (!basepopout || !basepopout.handleClick) return; this.handleClick = basepopout.handleClick; this.close = basepopout.close; this.domElementRef = basepopout.domElementRef; } render() { let child = (BDFDB.ArrayUtils.is(this.props.children) ? this.props.children[0] : this.props.children) || BDFDB.ReactUtils.createElement("div", {style: {height: "100%", width: "100%"}}); child.props.className = BDFDB.DOMUtils.formatClassName(child.props.className, this.props.className); let childClick = child.props.onClick, childContextMenu = child.props.onContextMenu; child.props.onClick = (e, childthis) => { if (!this.domElementRef.current || this.domElementRef.current.contains(e.target)) { if ((this.props.openOnClick || this.props.openOnClick === undefined) && typeof this.handleClick == "function") this.handleClick(); if (typeof this.props.onClick == "function") this.props.onClick(e, this); if (typeof childClick == "function") childClick(e, childthis); } else e.stopPropagation(); }; child.props.onContextMenu = (e, childthis) => { if (!this.domElementRef.current || this.domElementRef.current.contains(e.target)) { if (this.props.openOnContextMenu && typeof this.handleClick == "function") this.handleClick(); if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this); if (typeof childContextMenu == "function") childContextMenu(e, childthis); } else e.stopPropagation(); }; return BDFDB.ReactUtils.createElement(LibraryModules.React.Fragment, { children: BDFDB.ReactUtils.createElement(NativeSubComponents.PopoutContainer, Object.assign({}, this.props, { children: _ => {return child;}, renderPopout: this.handleRender.bind(this) })) }); } }; LibraryComponents.QuickSelect = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.QuickSelect") || reactInitialized && class BDFDB_QuickSelect extends LibraryModules.React.Component { handleChange(option) { this.props.value = option; if (typeof this.props.onChange == "function") this.props.onChange(option.value || option.key, this); BDFDB.ReactUtils.forceUpdate(this); } render() { let options = (BDFDB.ArrayUtils.is(this.props.options) ? this.props.options : [{}]).filter(n => n); let selectedOption = BDFDB.ObjectUtils.is(this.props.value) ? this.props.value : (options[0] || {}); return this.props.nativeComponent ? BDFDB.ReactUtils.createElement(NativeSubComponents.QuickSelect, Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName(this.props.className, BDFDB.disCN.quickselectwrapper), popoutClassName: BDFDB.DOMUtils.formatClassName(this.props.popoutClassName, BDFDB.disCN.quickselectpopoutwrapper), popoutProps: {position: "bottom", zIndexBoost: 1000}, value: selectedOption, options: options, renderOption: typeof this.props.renderOption == "function" ? this.props.renderOption : option => option.label, onChange: this.handleChange.bind(this) })) : BDFDB.ReactUtils.createElement(LibraryComponents.PopoutContainer, Object.assign({}, this.props, { children: BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(this.props.className, BDFDB.disCN.quickselectwrapper), children: BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.quickselect, align: LibraryComponents.Flex.Align.CENTER, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.quickselectlabel, children: this.props.label }), BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { align: LibraryComponents.Flex.Align.CENTER, className: BDFDB.disCN.quickselectclick, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.quickselectvalue, children: typeof this.props.renderValue == "function" ? this.props.renderValue(this.props.value) : this.props.value.label }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.quickselectarrow }) ] }) ] }) }), popoutClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.quickselectpopout, this.props.popoutClassName, BDFDB.disCN.contextmenu, BDFDB.disCN.quickselectpopoutwrapper, this.props.scroller && BDFDB.disCN.quickselectpopoutscroll), themed: false, animation: BDFDB.LibraryComponents.PopoutContainer.Animation.TRANSLATE, position: BDFDB.LibraryComponents.PopoutContainer.Positions.BOTTOM, align: BDFDB.LibraryComponents.PopoutContainer.Align.RIGHT, renderPopout: instance => { let items = options.map(option => { let selected = option.value && option.value === selectedOption.value || option.key && option.key === selectedOption.key; return typeof this.props.renderOption == "function" ? this.props.renderOption(option) : BDFDB.ReactUtils.createElement(LibraryComponents.ContextMenuItem, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.quickselectpopoutoption, selected && BDFDB.disCN.quickselectpopoutoptionselected), action: selected ? null : _ => { instance.close(); this.handleChange.bind(this)(option) }, label: option.label }); }); return this.props.scroller ? BDFDB.ReactUtils.createElement(LibraryComponents.ScrollerVertical, { className: BDFDB.disCN.quickselectscroller, children: items }) : items; } })); } }; LibraryComponents.RadioGroup = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.RadioGroup") || reactInitialized && class BDFDB_RadioGroup extends LibraryModules.React.Component { handleChange(value) { this.props.value = value.value; if (typeof this.props.onChange == "function") this.props.onChange(value, this); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.RadioGroup, Object.assign({}, this.props, { onChange: this.handleChange.bind(this) })); } }; LibraryComponents.ScrollerHorizontal = BDFDB.ModuleUtils.findByName("HorizontalScroller"); LibraryComponents.ScrollerVertical = BDFDB.ModuleUtils.findByName("VerticalScroller"); LibraryComponents.SearchBar = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SearchBar") || reactInitialized && class BDFDB_SearchBar extends LibraryModules.React.Component { handleChange(query) { this.props.query = query; if (typeof this.props.onChange == "function") this.props.onChange(query, this); BDFDB.ReactUtils.forceUpdate(this); } handleClear() { this.props.query = ""; if (this.props.changeOnClear && typeof this.props.onChange == "function") this.props.onChange("", this); if (typeof this.props.onClear == "function") this.props.onClear(this); BDFDB.ReactUtils.forceUpdate(this); } render() { let props = Object.assign({}, this.props, { onChange: this.handleChange.bind(this), onClear: this.handleClear.bind(this) }); if (typeof props.query != "string") props.query = ""; return BDFDB.ReactUtils.createElement(NativeSubComponents.SearchBar, props); } }; LibraryComponents.Select = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Select") || reactInitialized && class BDFDB_Select extends LibraryModules.React.Component { handleChange(value) { this.props.value = value; if (typeof this.props.onChange == "function") this.props.onChange(value, this); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.selectwrapper, direction: LibraryComponents.Flex.Direction.HORIZONTAL, align: LibraryComponents.Flex.Align.CENTER, children: BDFDB.ReactUtils.createElement(NativeSubComponents.Select, Object.assign({}, this.props, { onChange: this.handleChange.bind(this) })) }); } }; LibraryComponents.SettingsPanel = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsPanel") || reactInitialized && class BDFDB_SettingsPanel extends LibraryModules.React.Component { render() { return this.props.children ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { direction: LibraryComponents.Flex.Direction.VERTICAL, grow: 1, children: [ typeof this.props.title == "string" ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.settingspaneltitle, tag: LibraryComponents.FormComponents.FormTitle.Tags.H2, children: this.props.title }) : null, typeof this.props.title == "string" ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: BDFDB.disCNS.margintop4 + BDFDB.disCN.marginbottom8 }) : null, BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.settingspanelinner, direction: LibraryComponents.Flex.Direction.VERTICAL, children: this.props.children }) ] }) : null; } }; LibraryComponents.SettingsPanelInner = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsPanelInner") || reactInitialized && class BDFDB_SettingsPanelInner extends LibraryModules.React.Component { render() { return this.props.children ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: this.props.className, direction: LibraryComponents.Flex.Direction.VERTICAL, children: [ !this.props.first ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: BDFDB.disCN.marginbottom8 }) : null, typeof this.props.title == "string" ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.marginbottom4, tag: LibraryComponents.FormComponents.FormTitle.Tags.H3, children: this.props.title }) : null, BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.settingspanellist, direction: LibraryComponents.Flex.Direction.VERTICAL, children: this.props.children }), !this.props.last ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: BDFDB.disCN.marginbottom20 }) : null ] }) : null; } }; LibraryComponents.SettingsItem = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsItem") || reactInitialized && class BDFDB_SettingsItem extends LibraryModules.React.Component { handleChange(value) { if (typeof this.props.onChange == "function") this.props.onChange(value, this); } render() { if (typeof this.props.type != "string" || !["BUTTON", "SELECT", "SWITCH", "TEXTINPUT"].includes(this.props.type.toUpperCase())) return null; let childcomponent = LibraryComponents[this.props.type]; if (!childcomponent) return null; if (this.props.mini && childcomponent.Sizes) this.props.size = childcomponent.Sizes.MINI || childcomponent.Sizes.MIN; return BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.DOMUtils.formatClassName(this.props.className, this.props.disabled && BDFDB.disCN.disabled), id: this.props.id, direction: LibraryComponents.Flex.Direction.VERTICAL, align: LibraryComponents.Flex.Align.STRETCH, grow: this.props.grow, stretch: this.props.stretch, children: [ this.props.dividertop ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: this.props.mini ? BDFDB.disCN.marginbottom4 : BDFDB.disCN.marginbottom8 }) : null, BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { align: LibraryComponents.Flex.Align.CENTER, children: [ this.props.label ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { children: BDFDB.ReactUtils.createElement(LibraryComponents.SettingsLabel, { mini: this.props.mini, label: this.props.label }) }) : null, this.props.labelchildren, BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { grow: 0, shrink: this.props.basis ? 0 : 1, basis: this.props.basis, wrap: true, children: BDFDB.ReactUtils.createElement(childcomponent, BDFDB.ObjectUtils.exclude(Object.assign(BDFDB.ObjectUtils.exclude(this.props, "className", "id", "type"), this.props.childProps, {onChange: this.handleChange.bind(this)}), "grow", "stretch", "basis", "dividerbottom", "dividertop", "label", "labelchildren", "mini", "note", "childProps")) }) ].flat(10).filter(n => n) }), typeof this.props.note == "string" ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { className: BDFDB.disCN.note, children: BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormText, { disabled: this.props.disabled, type: LibraryComponents.FormComponents.FormText.Types.DESCRIPTION, children: BDFDB.ReactUtils.createElement(LibraryComponents.TextScroller, {speed: 2, children: this.props.note}) }) }) : null, this.props.dividerbottom ? BDFDB.ReactUtils.createElement(LibraryComponents.FormComponents.FormDivider, { className: this.props.mini ? BDFDB.disCN.margintop4 : BDFDB.disCN.margintop8 }) : null ] }); } }; LibraryComponents.SettingsLabel = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsLabel") || reactInitialized && class BDFDB_SettingsLabel extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement(LibraryComponents.TextScroller, { className: BDFDB.DOMUtils.formatClassName(this.props.mini ? BDFDB.disCN.titlemini : BDFDB.disCN.titledefault, BDFDB.disCN.cursordefault), speed: 2, children: this.props.label }); } }; LibraryComponents.SettingsList = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsList") || reactInitialized && class BDFDB_SettingsList extends LibraryModules.React.Component { componentDidMount() { let list = BDFDB.ReactUtils.findDOMNode(this); if (list && !this.props.maxWidth) { let headers = Array.from(list.querySelectorAll(BDFDB.dotCN.settingstableheader)); headers.shift(); if (BDFDB.DOMUtils.getRects(headers[0]).width == 0) BDFDB.TimeUtils.timeout(_ => {this.resizeList(list, headers);}); else this.resizeList(list, headers); } } resizeList(list, headers) { let maxWidth = 0, biggestWidth = 0; if (!maxWidth) { for (let header of headers) { header.style = ""; let width = BDFDB.DOMUtils.getRects(header).width; maxWidth = width > maxWidth ? width : maxWidth; } maxWidth += 4; biggestWidth = maxWidth; } if (headers.length * maxWidth > 300) { this.props.vertical = true; maxWidth = parseInt(290 / headers.length); } else if (maxWidth < 36) { maxWidth = 36; biggestWidth = maxWidth; } this.props.maxWidth = maxWidth; this.props.biggestWidth = biggestWidth; this.props.fullWidth = BDFDB.DOMUtils.getRects(list).width; BDFDB.ReactUtils.forceUpdate(this); } render() { this.props.settings = BDFDB.ArrayUtils.is(this.props.settings) ? this.props.settings : []; this.props.renderLabel = typeof this.props.renderLabel == "function" ? this.props.renderLabel : data => data.label; let labelWidth = this.props.maxWidth && this.props.fullWidth && (this.props.fullWidth - 20 - (this.props.maxWidth * this.props.settings.length)); let configWidth = this.props.maxWidth && this.props.maxWidth * this.props.settings.length; let isHeaderClickable = typeof this.props.onHeaderClick == "function" || typeof this.props.onHeaderContextMenu == "function"; return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.settingstablelist, this.props.className), children: [ BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.settingstableheaders, align: LibraryComponents.Flex.Align.STRETCH, style: this.props.vertical && this.props.biggestWidth ? { marginTop: this.props.biggestWidth - 25 || 0 } : {}, children: [].concat(this.props.title || "", this.props.settings).map((setting, i) => BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(i == 0 ? BDFDB.disCN.settingstableheadername : BDFDB.disCN.settingstableheaderoption, i != 0 && this.props.vertical && BDFDB.disCN.settingstableheadervertical, BDFDB.disCN.settingstableheader, BDFDB.disCN.settingstableheadersize, BDFDB.disCN.primary, BDFDB.disCN.weightbold, isHeaderClickable && BDFDB.disCN.cursorpointer), onClick: _ => {if (typeof this.props.onHeaderClick == "function") this.props.onHeaderClick(setting, this);}, onContextMenu: _ => {if (typeof this.props.onHeaderContextMenu == "function") this.props.onHeaderContextMenu(setting, this);}, style: i != 0 && this.props.maxWidth ? { maxWidth: this.props.maxWidth, width: this.props.maxWidth, flex: `0 0 ${this.props.maxWidth}px` } : {}, children: BDFDB.ReactUtils.createElement("span", { children: setting }) })) }), (BDFDB.ArrayUtils.is(this.props.data) ? this.props.data : [{}]).filter(n => n).map(data => BDFDB.ReactUtils.createElement(LibraryComponents.Card, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName([this.props.cardClassName, data.className].filter(n => n).join(" ").indexOf(BDFDB.disCN.card) == -1 && BDFDB.disCN.cardprimaryoutline, BDFDB.disCN.settingstablecard, this.props.cardClassName, data.className), cardId: data.key, backdrop: false, style: Object.assign({}, this.props.cardStyle, data.style), children: [ BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.settingstablecardlabel, align: LibraryComponents.Flex.Align.CENTER, grow: 0, shrink: 0, basis: labelWidth || "auto", style: {maxWidth: labelWidth || null}, children: this.props.renderLabel(data) }), BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { className: BDFDB.disCN.settingstablecardconfigs, justify: LibraryComponents.Flex.Justify.AROUND, align: LibraryComponents.Flex.Align.CENTER, grow: 0, shrink: 0, basis: configWidth || "auto", style: {maxWidth: configWidth || null}, children: this.props.settings.map(setting => BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { className: BDFDB.disCN.checkboxcontainer, grow: 0, shrink: 0, wrap: true, children: BDFDB.ReactUtils.createElement(LibraryComponents.Checkbox, { disabled: data.disabled, cardId: data.key, settingId: setting, shape: LibraryComponents.Checkbox.Shapes.ROUND, type: LibraryComponents.Checkbox.Types.INVERTED, value: data[setting], onChange: this.props.onCheckboxChange }) })).flat(10).filter(n => n) }) ] }), "title", "data", "settings", "renderLabel", "cardClassName", "cardStyle", "onCheckboxChange", "maxWidth", "fullWidth"))) ] }); } }; LibraryComponents.SettingsSaveItem = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsSaveItem") || reactInitialized && class BDFDB_SettingsSaveItem extends LibraryModules.React.Component { saveSettings(value) { if (!BDFDB.ArrayUtils.is(this.props.keys) || !BDFDB.ObjectUtils.is(this.props.plugin)) return; let keys = this.props.keys.filter(n => n); let option = keys.shift(); if (BDFDB.ObjectUtils.is(this.props.plugin) && option) { let data = BDFDB.DataUtils.load(this.props.plugin, option); let newdata = ""; for (let key of keys) newdata += `{"${key}":`; value = value != null && value.value != null ? value.value : value; let marker = typeof value == "string" ? `"` : ``; newdata += (marker + value + marker) + "}".repeat(keys.length); newdata = JSON.parse(newdata); BDFDB.DataUtils.save(BDFDB.ObjectUtils.is(newdata) ? BDFDB.ObjectUtils.deepAssign({}, data, newdata) : newdata, this.props.plugin, option); this.props.plugin.SettingsUpdated = true; } if (typeof this.props.onChange == "function") this.props.onChange(value, this); } render() { if (typeof this.props.type != "string" || !["SELECT", "SWITCH", "TEXTINPUT"].includes(this.props.type.toUpperCase())) return null; return BDFDB.ReactUtils.createElement(LibraryComponents.SettingsItem, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { onChange: this.saveSettings.bind(this) }), "keys", "plugin")); } }; LibraryComponents.SettingsSwitch = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SettingsSwitch") || reactInitialized && class BDFDB_SettingsSwitch extends LibraryModules.React.Component { // REMOVE render() { return BDFDB.ReactUtils.createElement(LibraryComponents.SettingsSaveItem, Object.assign({keys:[]}, this.props, { type: "Switch" })); } }; LibraryComponents.Slider = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Slider") || reactInitialized && class BDFDB_Slider extends LibraryModules.React.Component { handleValueChange(value) { let newvalue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange([0, 100], this.props.edges, value) : value; if (typeof this.props.digits == "number") newvalue = Math.round(newvalue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); this.props.defaultValue = newvalue; if (typeof this.props.onValueChange == "function") this.props.onValueChange(newvalue, this); BDFDB.ReactUtils.forceUpdate(this); } handleValueRender(value) { let newvalue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange([0, 100], this.props.edges, value) : value; if (typeof this.props.digits == "number") newvalue = Math.round(newvalue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); if (typeof this.props.onValueRender == "function") { let tempreturn = this.props.onValueRender(newvalue, this); if (tempreturn != undefined) newvalue = tempreturn; } return newvalue; } render() { let defaultValue = BDFDB.ArrayUtils.is(this.props.edges) && this.props.edges.length == 2 ? BDFDB.NumberUtils.mapRange(this.props.edges, [0, 100], this.props.defaultValue) : this.props.defaultValue; if (typeof this.props.digits == "number") defaultValue = Math.round(defaultValue * Math.pow(10, this.props.digits)) / Math.pow(10, this.props.digits); return BDFDB.ReactUtils.createElement(NativeSubComponents.Slider, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { initialValue: defaultValue, onValueChange: this.handleValueChange.bind(this), onValueRender: this.handleValueRender.bind(this) }), "digits", "edges")); } }; LibraryComponents.Spinner = BDFDB.ModuleUtils.findByName("Spinner"); LibraryComponents.SvgIcon = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.SvgIcon") || reactInitialized && class BDFDB_Icon extends LibraryModules.React.Component { render() { if (this.props.name) return BDFDB.ReactUtils.createElement(NativeSubComponents.SvgIcon, this.props); else if (this.props.iconSVG) { let icon = BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(this.props.iconSVG)); icon.props.className = BDFDB.DOMUtils.formatClassName(!this.props.nativeClass && BDFDB.disCN.svgicon, icon.props.class, this.props.className); icon.props.style = Object.assign({}, icon.props.style, this.props.style); return icon; } return null; } }; LibraryComponents.Switch = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Switch") || reactInitialized && class BDFDB_Switch extends LibraryModules.React.Component { handleChange() { this.props.value = !this.props.value; if (typeof this.props.onChange == "function") this.props.onChange(this.props.value, this); BDFDB.ReactUtils.forceUpdate(this); } render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.Switch, Object.assign({}, this.props, {onChange: this.handleChange.bind(this)})); } }; LibraryComponents.TabBar = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TabBar") || reactInitialized && class BDFDB_TabBar extends LibraryModules.React.Component { handleItemSelect(item) { this.props.selectedItem = item; if (typeof this.props.onItemSelect == "function") this.props.onItemSelect(item, this); BDFDB.ReactUtils.forceUpdate(this); } render() { let items = (BDFDB.ArrayUtils.is(this.props.items) ? this.props.items : [{}]).filter(n => n); return BDFDB.ReactUtils.createElement(NativeSubComponents.TabBar, BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { selectedItem: this.props.selectedItem || (items[0] || {}).value, onItemSelect: this.handleItemSelect.bind(this), children: items.map(data => { return BDFDB.ReactUtils.createElement(LibraryComponents.TabBar.Item, { className: this.props.itemClassName, itemType: this.props.type, id: data.value, children: data.label || data.value, "aria-label": data.label || data.value }) }) }), "itemClassName", "items")); } }; LibraryComponents.Table = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.Table") || reactInitialized && class BDFDB_Table extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.Table, Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.table, this.props.className), headerClassName: BDFDB.DOMUtils.formatClassName(this.props.stickyHeader ? BDFDB.disCN.tablestickyheader : BDFDB.disCN.tableheader, this.props.headerClassName), headerCellClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tableheadercell, this.props.headerCellClassName), sortedHeaderCellClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tableheadercellsorted, this.props.sortedHeaderCellClassName), bodyCellClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tablebodycell, this.props.bodyCellClassName), rowClassName: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.tablerow, this.props.rowClassName), onSort: (sortKey, sortDirection) => { this.props.sortDirection = this.props.sortKey != sortKey && sortDirection == LibraryComponents.Table.SortDirection.ASCENDING && this.props.columns.filter(n => n.key == sortKey)[0].reverse ? LibraryComponents.Table.SortDirection.DESCENDING : sortDirection; this.props.sortKey = sortKey; this.props.data = BDFDB.ArrayUtils.keySort(this.props.data, this.props.sortKey); if (this.props.sortDirection == LibraryComponents.Table.SortDirection.DESCENDING) this.props.data.reverse(); if (typeof this.props.onSort == "function") this.props.onSort(this.props.sortKey, this.props.sortDirection); BDFDB.ReactUtils.forceUpdate(this); } })); } }; LibraryComponents.TextArea = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TextArea") || reactInitialized && class BDFDB_TextArea extends LibraryModules.React.Component { handleChange(e) { this.props.value = e; if (typeof this.props.onChange == "function") this.props.onChange(e, this); BDFDB.ReactUtils.forceUpdate(this); } handleBlur(e) {if (typeof this.props.onBlur == "function") this.props.onBlur(e, this);} handleFocus(e) {if (typeof this.props.onFocus == "function") this.props.onFocus(e, this);} render() { return BDFDB.ReactUtils.createElement(NativeSubComponents.TextArea, Object.assign({}, this.props, { onChange: this.handleChange.bind(this), onBlur: this.handleBlur.bind(this), onFocus: this.handleFocus.bind(this) })); } }; LibraryComponents.TextElement = BDFDB.ModuleUtils.findByName("Text"); LibraryComponents.TextGradientElement = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TextGradientElement") || reactInitialized && class BDFDB_TextGradientElement extends LibraryModules.React.Component { render() { if (this.props.gradient && this.props.children) return BDFDB.ReactUtils.createElement("span", { children: this.props.children, ref: instance => { let ele = BDFDB.ReactUtils.findDOMNode(instance); if (ele) { ele.style.setProperty("background-image", this.props.gradient, "important"); ele.style.setProperty("color", "transparent", "important"); ele.style.setProperty("-webkit-background-clip", "text", "important"); } } }); return this.props.children || null; } }; LibraryComponents.TextInput = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TextInput") || reactInitialized && class BDFDB_TextInput extends LibraryModules.React.Component { handleChange(e) { e = BDFDB.ObjectUtils.is(e) ? e.currentTarget.value : e; this.props.value = e; if (typeof this.props.onChange == "function") this.props.onChange(e, this); BDFDB.ReactUtils.forceUpdate(this); } handleInput(e) {if (typeof this.props.onInput == "function") this.props.onInput(BDFDB.ObjectUtils.is(e) ? e.currentTarget.value : e, this);} handleKeyDown(e) {if (typeof this.props.onKeyDown == "function") this.props.onKeyDown(e, this);} handleBlur(e) {if (typeof this.props.onBlur == "function") this.props.onBlur(e, this);} handleFocus(e) {if (typeof this.props.onFocus == "function") this.props.onFocus(e, this);} handleMouseEnter(e) {if (typeof this.props.onMouseEnter == "function") this.props.onMouseEnter(e, this);} handleMouseLeave(e) {if (typeof this.props.onMouseLeave == "function") this.props.onMouseLeave(e, this);} handleNumberButton(ins, value) { BDFDB.TimeUtils.clear(ins.pressedTimeout); ins.pressedTimeout = BDFDB.TimeUtils.timeout(_ => { delete this.props.focused; BDFDB.ReactUtils.forceUpdate(this); }, 1000); this.props.focused = true; this.handleChange.bind(this)(value); this.handleInput.bind(this)(value); } componentDidMount() { let input = BDFDB.ReactUtils.findDOMNode(this); if (!input) return; input = input.querySelector("input") || input; if (input && !input.patched) { input.addEventListener("keydown", e => { this.handleKeyDown.bind(this)(e); e.stopImmediatePropagation(); }); input.patched = true; } if (this.props.type == "color") { let swatchinstance = BDFDB.ReactUtils.findOwner(this, {name: "BDFDB_ColorSwatches"}); if (swatchinstance) swatchinstance.refInput = this; } else if (this.props.type == "file") { let navigatorinstance = BDFDB.ReactUtils.findOwner(this, {name: "BDFDB_FileButton"}); if (navigatorinstance) navigatorinstance.refInput = this; } } render() { let inputchildren = [ BDFDB.ReactUtils.createElement("input", BDFDB.ObjectUtils.exclude(Object.assign({}, this.props, { className: BDFDB.DOMUtils.formatClassName(this.props.size && LibraryComponents.TextInput.Sizes[this.props.size.toUpperCase()] && BDFDB.disCN["input" + this.props.size.toLowerCase()] || BDFDB.disCN.inputdefault, this.props.inputClassName, this.props.focused && BDFDB.disCN.inputfocused, this.props.error || this.props.errorMessage ? BDFDB.disCN.inputerror : (this.props.success && BDFDB.disCN.inputsuccess), this.props.disabled && BDFDB.disCN.inputdisabled, this.props.editable && BDFDB.disCN.inputeditable), type: this.props.type == "color" || this.props.type == "file" ? "text" : this.props.type, onChange: this.handleChange.bind(this), onInput: this.handleInput.bind(this), onKeyDown: this.handleKeyDown.bind(this), onBlur: this.handleBlur.bind(this), onFocus: this.handleFocus.bind(this), onMouseEnter: this.handleMouseEnter.bind(this), onMouseLeave: this.handleMouseLeave.bind(this), maxLength: this.props.type == "file" ? false : this.props.maxLength, ref: this.props.inputRef }), "errorMessage", "focused", "error", "success", "inputClassName", "inputPrefix", "size", "editable", "inputRef", "style", "mode", "filter", "useFilepath")), this.props.type == "color" ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, { wrap: true, children: BDFDB.ReactUtils.createElement(LibraryComponents.ColorSwatches, { colors: [], compMode: this.props.mode == "comp", color: this.props.value && this.props.mode == "comp" ? BDFDB.ColorUtils.convert(this.props.value.split(","), "RGB") : this.props.value, pickerConfig: {gradient:false, alpha:this.props.mode != "comp"} }) }) : null, this.props.type == "file" ? BDFDB.ReactUtils.createElement(LibraryComponents.FileButton, { filter: this.props.filter, mode: this.props.mode, useFilepath: this.props.useFilepath, }) : null ].filter(n => n); return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.inputwrapper, this.props.type == "number" && (this.props.size && LibraryComponents.TextInput.Sizes[this.props.size.toUpperCase()] && BDFDB.disCN["inputnumberwrapper" + this.props.size.toLowerCase()] || BDFDB.disCN.inputnumberwrapperdefault), this.props.className), style: this.props.style, children: [ this.props.inputPrefix ? BDFDB.ReactUtils.createElement("span", { className: BDFDB.disCN.inputprefix }) : null, this.props.type == "number" ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.inputnumberbuttons, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.inputnumberbuttonup, onClick: e => { let min = parseInt(this.props.min); let max = parseInt(this.props.max); let newv = parseInt(this.props.value) + 1 || min || 0; if (isNaN(max) || !isNaN(max) && newv <= max) this.handleNumberButton.bind(this)(e._targetInst, isNaN(min) || !isNaN(min) && newv >= min ? newv : min); } }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.inputnumberbuttondown, onClick: e => { let min = parseInt(this.props.min); let max = parseInt(this.props.max); let newv = parseInt(this.props.value) - 1 || min || 0; if (isNaN(min) || !isNaN(min) && newv >= min) this.handleNumberButton.bind(this)(e._targetInst, isNaN(max) || !isNaN(max) && newv <= max ? newv : max); } }) ] }) : null, inputchildren.length == 1 ? inputchildren[0] : BDFDB.ReactUtils.createElement(LibraryComponents.Flex, { align: LibraryComponents.Flex.Align.CENTER, children: inputchildren.map((child, i) => i != 0 ? BDFDB.ReactUtils.createElement(LibraryComponents.Flex.Child, {shrink: 0, children: child}) : child) }), this.props.errorMessage ? BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.inputerrormessage, children: this.props.errorMessage }) : null ].filter(n => n) }); } }; LibraryComponents.TextScroller = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TextScroller") || reactInitialized && class BDFDB_TextScroller extends LibraryModules.React.Component { render() { return BDFDB.ReactUtils.createElement("div", { className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.textscroller, this.props.className), style: Object.assign({}, this.props.style, { position: "relative", display: "block", overflow: "hidden" }), ref: instance => { let ele = BDFDB.ReactUtils.findDOMNode(instance); if (ele && ele.parentElement) { let maxwidth = BDFDB.DOMUtils.getInnerWidth(ele.parentElement); if (maxwidth > 50) ele.style.setProperty("max-width", `${maxwidth}px`); let Animation = new LibraryModules.AnimationUtils.Value(0); Animation .interpolate({inputRange:[0, 1], outputRange:[0, (BDFDB.DOMUtils.getRects(ele.firstElementChild).width - BDFDB.DOMUtils.getRects(ele).width) * -1]}) .addListener(v => {ele.firstElementChild.style.setProperty("left", v.value + "px", "important");}); this.scroll = p => { let w = p + parseFloat(ele.firstElementChild.style.getPropertyValue("left")) / (BDFDB.DOMUtils.getRects(ele.firstElementChild).width - BDFDB.DOMUtils.getRects(ele).width); w = isNaN(w) || !isFinite(w) ? p : w; w *= BDFDB.DOMUtils.getRects(ele.firstElementChild).width / (BDFDB.DOMUtils.getRects(ele).width * 2); LibraryModules.AnimationUtils.parallel([LibraryModules.AnimationUtils.timing(Animation, {toValue:p, duration:Math.sqrt(w**2) * 4000 / (parseInt(this.props.speed) || 1)})]).start(); } } }, onClick: e => { if (typeof this.props.onClick == "function") this.props.onClick(e, this); }, onMouseEnter: e => { if (BDFDB.DOMUtils.getRects(e.currentTarget).width < BDFDB.DOMUtils.getRects(e.currentTarget.firstElementChild).width) { this.scrolling = true; e.currentTarget.firstElementChild.style.setProperty("display", "block", "important"); this.scroll(1); } }, onMouseLeave: e => { if (this.scrolling) { delete this.scrolling; e.currentTarget.firstElementChild.style.setProperty("display", "inline", "important"); this.scroll(0); } }, children: BDFDB.ReactUtils.createElement("div", { style: { left: "0", position: "relative", display: "inline", whiteSpace: "nowrap" }, children: this.props.children }) }); } }; LibraryComponents.TooltipContainer = BDFDB.ReactUtils.getValue(window.BDFDB, "LibraryComponents.TooltipContainer") || reactInitialized && class BDFDB_TooltipContainer extends LibraryModules.React.Component { render() { let child = (BDFDB.ArrayUtils.is(this.props.children) ? this.props.children[0] : this.props.children) || BDFDB.ReactUtils.createElement("div", {}); child.props.className = BDFDB.DOMUtils.formatClassName(child.props.className, this.props.className); let childMouseEnter = child.props.onMouseEnter, childMouseLeave = child.props.onMouseLeave, childClick = child.props.onClick, childContextMenu = child.props.onContextMenu; let shown = false; child.props.onMouseEnter = (e, childthis) => { if (!shown) { shown = true; BDFDB.TooltipUtils.create(e.currentTarget, this.props.text, Object.assign({}, this.props.tooltipConfig)); if (typeof this.props.onMouseEnter == "function") this.props.onMouseEnter(e, this); if (typeof childMouseEnter == "function") childMouseEnter(e, childthis); } }; child.props.onMouseLeave = (e, childthis) => { shown = false; if (typeof this.props.onMouseLeave == "function") this.props.onMouseLeave(e, this); if (typeof childMouseLeave == "function") childMouseLeave(e, childthis); }; child.props.onClick = (e, childthis) => { if (typeof this.props.onClick == "function") this.props.onClick(e, this); if (typeof childClick == "function") childClick(e, childthis); }; child.props.onContextMenu = (e, childthis) => { if (typeof this.props.onContextMenu == "function") this.props.onContextMenu(e, this); if (typeof childContextMenu == "function") childContextMenu(e, childthis); }; return BDFDB.ReactUtils.createElement(LibraryModules.React.Fragment, { children: child }); } }; LibraryComponents.UserSummaryItem = BDFDB.ModuleUtils.findByName("UserSummaryItem"); for (let type in NativeSubComponents) if (LibraryComponents[type]) for (let key in NativeSubComponents[type]) if (key != "displayName" && key != "name" && (typeof NativeSubComponents[type][key] != "function" || key.charAt(0) == key.charAt(0).toUpperCase())) LibraryComponents[type][key] = NativeSubComponents[type][key]; BDFDB.LibraryComponents = Object.assign({}, LibraryComponents); BDFDB.DOMUtils.appendLocalStyle("BDFDB", ` @import url(https://mwittrien.github.io/BetterDiscordAddons/Themes/SupporterBadge.css); ${BDFDB.dotCN.changelogicon} { 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.dotCN.loadingiconwrapper} { position: absolute; bottom: 0; right: 0; z-index: 1000; animation: loadingwrapper-fade 3s infinite ease; } ${BDFDB.dotCNS.loadingiconwrapper + BDFDB.dotCN.loadingicon} { margin: 0 5px; } @keyframes loadingwrapper-fade { from {opacity: 0.1;} 50% {opacity: 0.9;} to {opacity: 0.1;} } ${BDFDB.dotCN.settingspanelinner} { padding-left: 15px; padding-right: 5px; } ${BDFDB.dotCN.settingspanellist} { padding-left: 15px; } ${BDFDB.dotCN.collapsecontainer} { margin-bottom: 20px; } ${BDFDB.dotCN.collapsecontainermini} { margin-bottom: 8px; } ${BDFDB.dotCN.collapsecontainerinner} { padding-left: 15px; } ${BDFDB.dotCNS.settingspanelinner + BDFDB.dotCN.collapsecontainerheader} { margin-left: -16px; } ${BDFDB.dotCN.collapsecontainerarrow} { background: url() center/cover no-repeat; height: 16px; width: 16px; transition: transform .3s ease; transform: rotate(0); } ${BDFDB.dotCNS.collapsecontainercollapsed + BDFDB.dotCN.collapsecontainerarrow} { transform: rotate(-90deg); } ${BDFDB.dotCN.overflowellipsis} { overflow: hidden; text-overflow: ellipsis; } ${BDFDB.dotCN.underline} { text-decoration: underline; } ${BDFDB.dotCN.linethrough} { text-decoration: line-through; } ${BDFDB.dotCN.avatarwrapper + BDFDB.dotCN.messageavatar} { overflow: visible; border-radius: 0; } ${BDFDB.dotCN.favbuttoncontainer} { display: flex; position: relative; } ${BDFDB.dotCN.cursordefault} { cursor: default !important; } ${BDFDB.dotCN.cursorpointer} { cursor: pointer !important; } ${BDFDB.dotCNS.selectwrapper + BDFDB.dotCN.selectwrap} { flex: 1 1 auto; } ${BDFDB.dotCN.selectwrapper} [class*="css-"][class*="-container"] > [class*="css-"][class*="-menu"] { z-index: 3; } ${BDFDB.dotCNS.hotkeywrapper + BDFDB.dotCN.hotkeycontainer} { flex: 1 1 auto; } ${BDFDB.dotCN.hotkeyresetbutton} { cursor: pointer; margin-left: 5px; } ${BDFDB.dotCNS.hotkeyresetbutton + BDFDB.dotCN.svgicon}:hover { color: ${BDFDB.DiscordConstants.Colors.STATUS_RED}; } ${BDFDB.dotCNC.hovercardwrapper + BDFDB.dotCN.hovercardinner} { min-height: 28px; } ${BDFDB.dotCN.hovercardinner} { width: 100%; padding-right: 5px; display: flex; align-items: center; z-index: 1; } ${BDFDB.dotCNS.hovercardwrapper + BDFDB.dotCN.hovercardbutton} { position: absolute; top: -6px; right: -6px; opacity: 0; } ${BDFDB.dotCN.hovercardwrapper + BDFDB.dotCNS.hovercard + BDFDB.dotCN.hovercardbutton} { right: -25px; } ${BDFDB.dotCN.hovercardwrapper}:hover ${BDFDB.dotCN.hovercardbutton} { opacity: 1; } ${BDFDB.dotCN.table} { width: 100%; } ${BDFDB.dotCN.tableheader} { padding: 0px 12px 8px 0; margin-bottom: 5px; font-size: 12px; font-weight: 600; box-sizing: border-box; background-color: var(--background-primary); border-bottom: 1px solid var(--background-modifier-accent); } ${BDFDB.dotCN.tablestickyheader}:first-child { position: absolute; width: 100%; } ${BDFDB.dotCNS.modalsubinner + BDFDB.dotCN.tablestickyheader}:first-child { padding-left: 20px; } ${BDFDB.dotCN.tableheadercell} { text-transform: uppercase; color: var(--interactive-normal); } ${BDFDB.dotCN.tableheadercell}, ${BDFDB.dotCN.tablebodycell} { border-left: 1px solid var(--background-modifier-accent); box-sizing: border-box; padding: 0 12px; } ${BDFDB.dotCN.tableheadercell}:first-child, ${BDFDB.dotCN.tablebodycell}:first-child { border-left: none; padding-left: 0; } ${BDFDB.dotCN.tableheadercellsorted}, ${BDFDB.dotCN.tableheadercellsorted}:hover { color: var(--interactive-active); } ${BDFDB.dotCN.tableheadersorticon} { width: 18px; height: 18px; margin-left: 4px; } ${BDFDB.dotCN.tablerow} { position: relative; display: flex; margin-bottom: 5px; align-items: center; color: var(--header-secondary); } ${BDFDB.dotCN.tablebodycell} { font-size: 15px; } ${BDFDB.dotCNS.settingstablelist + BDFDB.dotCN.checkboxcontainer}:before { display: none; } ${BDFDB.dotCNS.settingstablelist + BDFDB.dotCN.settingstableheader} { min-height: 10px; } ${BDFDB.dotCNS.settingstablelist + BDFDB.dotCN.settingstableheaderoption} { width: unset; } ${BDFDB.dotCN.settingstableheadervertical} { position: relative; } ${BDFDB.dotCN.settingstableheadervertical} > span { position: absolute; bottom: 50%; right: calc(50% - 5px); margin-bottom: -5px; writing-mode: vertical-rl; } ${BDFDB.dotCN.settingstablecard} { height: 60px; padding: 0 10px; margin-bottom: 10px; } ${BDFDB.dotCNS.settingstablecard + BDFDB.dotCN.settingstablecardlabel} { padding-right: 10px; } ${BDFDB.dotCNS.settingstablecard + BDFDB.dotCN.settingstablecardlabel}, ${BDFDB.dotCNS.settingstablecard + BDFDB.dotCN.settingstablecardconfigs} { margin: 0; } ${BDFDB.dotCN.settingstableheaders} { margin-right: 10px; } ${BDFDB.dotCNS.themelight + BDFDB.dotCN.quickselectpopoutwrapper}, ${BDFDB.dotCNS.themedark + BDFDB.dotCN.quickselectpopoutwrapper} { border-radius: 4px; padding: 6px 8px; cursor: default; background-color: var(--background-floating); box-sizing: border-box; box-shadow: var(--elevation-high); } ${BDFDB.dotCNS.quickselectpopoutwrapper + BDFDB.dotCN.quickselectpopoutoption} { white-space: nowrap; text-overflow: ellipsis; overflow: hidden; align-items: center; position: relative; font-weight: 500; box-sizing: border-box; margin-top: 2px; margin-bottom: 2px; padding: 0 8px; font-size: 14px; line-height: 18px; min-height: 32px; border-radius: 2px; color: var(--interactive-normal); } ${BDFDB.dotCNS.quickselectpopoutwrapper + BDFDB.dotCN.quickselectpopoutoption}:hover { color: var(--interactive-hover); background-color: var(--background-modifier-hover); } ${BDFDB.dotCNS.quickselectpopoutwrapper + BDFDB.dotCN.quickselectpopoutoption + BDFDB.dotCN.quickselectpopoutoptionselected} { color: var(--interactive-active); background-color: var(--background-modifier-selected); } ${BDFDB.dotCN.charcounter} { color: var(--channels-default); } ${BDFDB.dotCN.inputnumberwrapper} { position: relative; } ${BDFDB.dotCN.inputnumberbuttons}:hover + ${BDFDB.dotCN.input + BDFDB.notCN.inputfocused + BDFDB.notCN.inputerror + BDFDB.notCN.inputsuccess + BDFDB.notCN.inputdisabled}:not(:focus) { border-color: #040405; } ${BDFDB.dotCNS.inputnumberwrapperdefault + BDFDB.dotCN.input} { padding-right: 25px; } ${BDFDB.dotCNS.inputnumberwrappermini + BDFDB.dotCN.input} { padding-left: 6px; padding-right: 17px; } ${BDFDB.dotCNS.inputnumberwrapper + BDFDB.dotCN.input}::-webkit-inner-spin-button, ${BDFDB.dotCNS.inputnumberwrapper + BDFDB.dotCN.input}::-webkit-outer-spin-button{ -webkit-appearance: none !important; } ${BDFDB.dotCN.inputnumberbuttons} { position: absolute; display: flex; flex-direction: column; align-items: center; justify-content: space-around; height: 110%; top: -2%; } ${BDFDB.dotCNS.inputnumberwrapperdefault + BDFDB.dotCN.inputnumberbuttons} { right: 8px; } ${BDFDB.dotCNS.inputnumberwrappermini + BDFDB.dotCN.inputnumberbuttons} { right: 4px; } ${BDFDB.dotCN.inputnumberbutton} { cursor: pointer; border: transparent solid 5px; border-top-width: 2.5px; display: inline-block; } ${BDFDB.dotCNS.themelight + BDFDB.dotCN.inputnumberbutton} { border-bottom-color: #dcddde; } ${BDFDB.dotCNS.themelight + BDFDB.dotCN.inputnumberbutton}:hover { border-bottom-color: #4f545c; } ${BDFDB.dotCNS.themedark + BDFDB.dotCN.inputnumberbutton} { border-bottom-color: #72767d; } ${BDFDB.dotCNS.themedark + BDFDB.dotCN.inputnumberbutton}:hover { border-bottom-color: #f6f6f7; } ${BDFDB.dotCN.inputnumberbuttondown} { transform: rotate(180deg); } ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} { cursor: no-drop; filter: grayscale(70%) brightness(50%); } ${BDFDB.dotCN.colorpickerswatchsingle} { height: 30px; width: 30px; } ${BDFDB.dotCN.guildupperleftbadge} { top: 0; } ${BDFDB.dotCN.guildlowerleftbadge} { bottom: 0; } ${BDFDB.dotCNC.guildlowerleftbadge + BDFDB.dotCN.guildupperleftbadge} { pointer-events: none; position: absolute; left: 0; } ${BDFDB.dotCN.svgicon} { color: var(--interactive-normal); } ${BDFDB.dotCN.svgicon}:hover { color: var(--interactive-hover); } ${BDFDB.dotCN.svgicon}:active { color: var(--interactive-active); } ${BDFDB.dotCN.modalsubinnerscrollerless} { padding-bottom: 10px; overflow: visible; } ${BDFDB.dotCN.modaltabcontent} { margin-top: 10px; } ${BDFDB.dotCNS.listscroller + BDFDB.dotCN.modaltabcontent} { margin-top: 0; } ${BDFDB.dotCNS.modalwrapper + BDFDB.dotCN.modalheader + BDFDB.dotCN.modalheaderhassibling} { padding-bottom: 10px; } ${BDFDB.dotCNS.modalwrapper + BDFDB.dotCN.tabbarcontainer} { background: rgba(0, 0, 0, 0.1); border: none; box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.05); } ${BDFDB.dotCNS.themedark + BDFDB.dotCNS.modalwrapper + BDFDB.dotCN.tabbarcontainer} { background: rgba(0, 0, 0, 0.2); box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.1); } ${BDFDB.dotCN.popoutthemedpopout} { background-color: #fff; border: 1px solid hsla(0,0%,74.9%,.3); -webkit-box-shadow: 0 2px 10px 0 rgba(0,0,0,.1); box-shadow: 0 2px 10px 0 rgba(0,0,0,.1); -webkit-box-sizing: border-box; box-sizing: border-box; border-radius: 5px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; } ${BDFDB.dotCNS.themedark + BDFDB.dotCN.popoutthemedpopout} { background-color: #2f3136; border: 1px solid rgba(28,36,43,.6); -webkit-box-shadow: 0 2px 10px 0 rgba(0,0,0,20%); box-shadow: 0 2px 10px 0 rgba(0,0,0,.2); } #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 ${BDFDB.dotCN._repoupdatebutton}[style] { display: none !important; } #bd-settingspane-container ${BDFDB.dotCNS._repolist + BDFDB.dotCN._repofooter} button + button { margin-left: 10px; } ${BDFDB.dotCN.noticewrapper} { transition: height 0.5s ease !important; border-radius: 0 !important; } ${BDFDB.dotCNS.noticewrapper + BDFDB.dotCN.noticeplatformicon} { margin-top: -7px; } ${BDFDB.dotCNS.noticewrapper + BDFDB.dotCN.noticeplatformicon} svg { max-height: 28px; } ${BDFDB.dotCN.noticesurvey} { background-color: #222; } ${BDFDB.dotCN.tooltip + BDFDB.dotCNS.tooltipcustom + BDFDB.dotCN.tooltippointer} { border-top-color: inherit !important; } ${BDFDB.dotCNC.layermodallarge + BDFDB.dotCN.modalsizelarge} { max-height: 95vh; } @media only screen and (max-height: 900px) { ${BDFDB.dotCNC.layermodalmedium + BDFDB.dotCN.modalsizemedium} { max-height: 75vh; } } /*OLD*/ .BDFDB-modal ${BDFDB.dotCN.modalheader + BDFDB.dotCN.modalheaderhassibling} { padding-bottom: 10px; } .BDFDB-modal ${BDFDB.dotCN.tabbarcontainer} { background: rgba(0, 0, 0, 0.1); border: none !important; 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); } #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; } .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-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 ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled}, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} { cursor: no-drop; filter: grayscale(70%) brightness(50%); } .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault + BDFDB.notCN.colorpickerswatchdisabled}, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault + BDFDB.notCN.colorpickerswatchdisabled} { overflow: hidden; } .BDFDB-colorpicker .gradient-bar .gradient-cursor > div:after, .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault + BDFDB.notCN.colorpickerswatchdisabled}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault + BDFDB.notCN.colorpickerswatchdisabled}: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 + BDFDB.notCN.colorpickerswatchdisabled}:after, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault + BDFDB.notCN.colorpickerswatchdisabled}:after { background: url('data:image/svg+xml; utf8, ') center repeat } .BDFDB-modal ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} ${BDFDB.dotCN.colorpickerswatch}, .BDFDB-settings ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} ${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); } /* REMOVE */ .BDFDB-modal ${BDFDB.dotCN.modaltabcontent + BDFDB.dotCN.modaltabcontentopen} { display: flex; flex-direction: column; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch; } .BDFDB-modal ${BDFDB.dotCN.modaltabcontent + BDFDB.notCN.modaltabcontentopen} { display: none; } /* REMOVE */ .BDFDB-modal *${BDFDB.notCN.modalsubinner} > ${BDFDB.dotCN.modaltabcontent + BDFDB.dotCN.modaltabcontentopen + 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.ListenerUtils.add(BDFDB, document, "click.BDFDBPluginClick", ".bd-settingswrap .bd-refresh-button, .bd-settingswrap .bd-switch-checkbox", _ => { BDFDB.BDUtils.setPluginCache(); BDFDB.BDUtils.setThemeCache(); }); var KeyDownTimeouts = {}; BDFDB.ListenerUtils.add(BDFDB, document, "keydown.BDFDBPressedKeys", e => { if (!BDFDB.InternalData.pressedKeys.includes(e.which)) { BDFDB.TimeUtils.clear(KeyDownTimeouts[e.which]); BDFDB.InternalData.pressedKeys.push(e.which); KeyDownTimeouts[e.which] = BDFDB.TimeUtils.timeout(_ => { BDFDB.ArrayUtils.remove(BDFDB.InternalData.pressedKeys, e.which, true); },60000); } }); BDFDB.ListenerUtils.add(BDFDB, document, "keyup.BDFDBPressedKeys", e => { BDFDB.TimeUtils.clear(KeyDownTimeouts[e.which]); BDFDB.ArrayUtils.remove(BDFDB.InternalData.pressedKeys, e.which, true); }); BDFDB.ListenerUtils.add(BDFDB, document, "mousedown.BDFDBMousePosition", e => { BDFDB.InternalData.mousePosition = e; }); BDFDB.ListenerUtils.add(BDFDB, window, "focus.BDFDBPressedKeysReset", e => { BDFDB.InternalData.pressedKeys = []; }); BDFDB.patchedModules = { after: { V2C_ContentColumn: "render", V2C_PluginCard: "render", V2C_ThemeCard: "render", MessageHeader: "default", MemberListItem: "componentDidMount", UserPopout: "componentDidMount", UserProfile: "componentDidMount", DiscordTag: "default" } }; InternalBDFDB.processV2CContentColumn = function (e) { if (window.PluginUpdates && window.PluginUpdates.plugins && e.instance.props.title == "Plugins") { let [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {key: "folder-button"}); if (index > -1) children.splice(index + 1, 0, BDFDB.ReactUtils.createElement(LibraryComponents.TooltipContainer, { text: "Only checks for updates of plugins, which support the updatecheck. Rightclick for a list of supported plugins. (Listed ≠ Outdated)", tooltipConfig: { selector: "update-button-tooltip", style: "max-width: 420px" }, children: BDFDB.ReactUtils.createElement("button", { className: `${BDFDB.disCN._repofolderbutton} bd-updatebtn`, onClick: _ => {BDFDB.PluginUtils.checkAllUpdates();}, onContextMenu: e => { if (window.PluginUpdates && window.PluginUpdates.plugins && !document.querySelector(".update-list-tooltip")) { var pluginnames = []; for (let url in window.PluginUpdates.plugins) pluginnames.push(window.PluginUpdates.plugins[url].name); BDFDB.TooltipUtils.create(e.currentTarget, pluginnames.sort().join(", "), {type: "bottom", selector: "update-list-tooltip", style: "max-width: 420px"}); } }, children: "Check for Updates" }) })); } }; InternalBDFDB._processCard = function (e, data) { if (e.instance.state && !e.instance.state.settings) { let [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", BDFDB.disCN._repoauthor]]}); if (index > -1) { let author = children[index].props.children; if (author && (author == "DevilBro" || author.indexOf("DevilBro,") == 0)) { let settings = BDFDB.DataUtils.get(BDFDB, "settings"); children.splice(index, 1, BDFDB.ReactUtils.createElement(LibraryComponents.Anchor, { className: BDFDB.disCN._repoauthor, children: "DevilBro", onClick: e => { BDFDB.ListenerUtils.stopEvent(e); if (BDFDB.UserUtils.me.id == "278543574059057154") return; let DMid = LibraryModules.ChannelStore.getDMFromUserId("278543574059057154") if (DMid) LibraryModules.SelectChannelUtils.selectPrivateChannel(DMid); else LibraryModules.DirectMessageUtils.openPrivateChannel(BDFDB.UserUtils.me.id, "278543574059057154"); let close = document.querySelector(BDFDB.dotCNS.settingsclosebuttoncontainer + BDFDB.dotCN.settingsclosebutton); if (close) close.click(); } })); if (author != "DevilBro") children.splice(index + 1, author.split("DevilBro").slice(1).join("DevilBro")); if (data.changelog) { [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", BDFDB.disCN._repoversion]]}); if (index > -1) children[index].props.children = [children[index].props.children, BDFDB.ReactUtils.createElement(LibraryComponents.TooltipContainer, { text: BDFDB.LanguageUtils.LanguageStrings.CHANGE_LOG, children: BDFDB.ReactUtils.createElement("span", { className: BDFDB.disCN.changelogicon, children: " ", style: {whiteSpace: "pre"}, onClick: _ => {BDFDB.PluginUtils.openChangeLog(data);} }) })]; } [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", BDFDB.disCN._repolinks]]}); if (index > -1) { if (children[index].props.children.filter(n => n).length) children[index].props.children.push(" | "); children[index].props.children.push(BDFDB.ReactUtils.createElement("a", { className: `${BDFDB.disCN._repolink}`, target: "_blank", children: "Support Server", onClick: e => { BDFDB.ListenerUtils.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();}); } })); if (settings.addSupportLinks) { children[index].props.children.push(" | "); children[index].props.children.push(BDFDB.ReactUtils.createElement("a", { className: `${BDFDB.disCN._repolink}`, target: "_blank", href: "https://www.paypal.me/MircoWittrien", children: "PayPal" })); children[index].props.children.push(" | "); children[index].props.children.push(BDFDB.ReactUtils.createElement("a", { className: `${BDFDB.disCN._repolink}`, target: "_blank", href: "https://www.patreon.com/MircoWittrien", children: "Patreon" })); } } if (BDFDB.ObjectUtils.toArray(BDFDB.myPlugins).some(n => n == data)) { [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", BDFDB.disCN._repofooter]]}); if (index == -1) { let footer = BDFDB.ReactUtils.createElement("div", {className: BDFDB.disCN._repofooter, children: []}); e.returnvalue.props.children.push(footer); children = footer.props.children; } else { children[index].props.children = [children[index].props.children].flat(); children = children[index].props.children; } children.splice(children.length - 1, 0, BDFDB.ReactUtils.createElement("button", { className: BDFDB.disCNS._reposettingsbutton, children: "Library Settings", onClick: event => { let wrapper = BDFDB.DOMUtils.getParent(BDFDB.dotCN._reposettingsclosed, event.currentTarget); if (wrapper) { let settingsPanel = InternalBDFDB.createLibrarySettings(); if (settingsPanel) { BDFDB.DOMUtils.addClass(wrapper, BDFDB.disCN._reposettingsopen); BDFDB.DOMUtils.removeClass(wrapper, BDFDB.disCN._reposettingsclosed); let children = []; while (wrapper.childElementCount) { children.push(wrapper.firstChild); wrapper.firstChild.remove(); } let closebutton = BDFDB.DOMUtils.create(`
`); wrapper.appendChild(closebutton); closebutton.addEventListener("click", _ => { BDFDB.DOMUtils.removeClass(wrapper, BDFDB.disCN._reposettingsopen); BDFDB.DOMUtils.addClass(wrapper, BDFDB.disCN._reposettingsclosed); while (wrapper.childElementCount) wrapper.firstChild.remove(); while (children.length) wrapper.appendChild(children.shift()); }); wrapper.appendChild(settingsPanel); } } } })); } } } } }; InternalBDFDB.processV2CPluginCard = function (e) {InternalBDFDB._processCard(e, e.instance.props.plugin);}; InternalBDFDB.processV2CThemeCard = function (e) {InternalBDFDB._processCard(e, e.instance.props.theme);}; InternalBDFDB.createLibrarySettings = function () { if (!window.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded) return; let settings = BDFDB.DataUtils.get(BDFDB, "settings"); let settingspanel, settingsitems = []; let bdToastSetting = BDFDB.BDUtils.getSettings("fork-ps-2"); for (let key in settings) settingsitems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, { className: BDFDB.disCN.marginbottom8, type: "Switch", plugin: BDFDB, disabled: key == "showToasts" && bdToastSetting, keys: ["settings", key], label: InternalBDFDB.defaults.settings[key].description, note: key == "showToasts" && bdToastSetting && "Disable BBDs general 'Show Toast' setting before disabling this", dividerbottom: true, value: settings[key] || key == "showToasts" && bdToastSetting })); return settingspanel = BDFDB.PluginUtils.createSettingsPanel(BDFDB, settingsitems); }; const BDFDB_Patrons = [ "363785301195358221" ]; InternalBDFDB._processAvatarRender = function (user, avatar) { if (BDFDB.ReactUtils.isValidElement(avatar) && BDFDB.ObjectUtils.is(user)) { let changed = false; if (avatar.type == "img") avatar = BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Avatar, Object.assign({}, avatar.props, { className: BDFDB.DOMUtils.formatClassName((avatar.props.className || "").replace(BDFDB.disCN.avatar, "")), size: BDFDB.LibraryComponents.Avatar.Sizes.SIZE_40 })); avatar.props["user_by_BDFDB"] = user.id; if (BDFDB_Patrons.includes(user.id) && BDFDB.DataUtils.get(BDFDB, "settings", "showSupportBadges")) { changed = true; avatar.props.className = BDFDB.DOMUtils.formatClassName(avatar.props.className, BDFDB.disCN.bdfdbsupporter); } if (user.id == "278543574059057154") { changed = true; avatar.props.className = BDFDB.DOMUtils.formatClassName(avatar.props.className, BDFDB.disCN.bdfdbdev); } if (changed) return avatar; } }; InternalBDFDB._processAvatarMount = function (user, avatar) { if (Node.prototype.isPrototypeOf(avatar) && BDFDB.ObjectUtils.is(user)) { avatar.setAttribute("user_by_BDFDB", user.id); if (BDFDB_Patrons.includes(user.id) && BDFDB.DataUtils.get(BDFDB, "settings", "showSupportBadges")) BDFDB.DOMUtils.addClass(avatar, BDFDB.disCN.bdfdbsupporter); if (user.id == "278543574059057154") BDFDB.DOMUtils.addClass(avatar, BDFDB.disCN.bdfdbdev); let status = avatar.querySelector(BDFDB.dotCN.avatarpointerevents); if (status) { status.addEventListener("mouseenter", _ => {BDFDB.DOMUtils.addClass(avatar, BDFDB.disCN.avatarstatushovered)}); status.addEventListener("mouseleave", _ => {BDFDB.DOMUtils.removeClass(avatar, BDFDB.disCN.avatarstatushovered)}); } } }; InternalBDFDB.processMessageHeader = function (e) { if (e.instance.props.message && e.instance.props.message.author) { let avatarWrapper = BDFDB.ReactUtils.getValue(e, "returnvalue.props.children.0"); if (avatarWrapper && avatarWrapper.props && typeof avatarWrapper.props.children == "function") { let renderChildren = avatarWrapper.props.children; avatarWrapper.props.children = (...args) => { let renderedChildren = renderChildren(...args); return InternalBDFDB._processAvatarRender(e.instance.props.message.author, renderedChildren) || renderedChildren; }; } } }; InternalBDFDB.processMemberListItem = function (e) { InternalBDFDB._processAvatarMount(e.instance.props.user, e.node.querySelector(BDFDB.dotCN.avatarwrapper)); }; InternalBDFDB.processUserPopout = function (e) { InternalBDFDB._processAvatarMount(e.instance.props.user, e.node.querySelector(BDFDB.dotCN.userpopoutavatarwrapper)); }; InternalBDFDB.processUserProfile = function (e) { InternalBDFDB._processAvatarMount(e.instance.props.user, e.node.querySelector(BDFDB.dotCN.avatarwrapper)); }; InternalBDFDB.processDiscordTag = function (e) { if (e.instance && e.instance.props && e.instance.props.user && e.returnvalue) e.returnvalue.props.user = e.instance.props.user; }; InternalBDFDB.patchPlugin(BDFDB); if (LibraryComponents.GuildComponents.BlobMask) { let newBadges = ["lowerLeftBadge", "upperLeftBadge"]; BDFDB.ModuleUtils.patch(BDFDB, LibraryComponents.GuildComponents.BlobMask.prototype, "render", { before: e => { e.thisObject.props = Object.assign({}, LibraryComponents.GuildComponents.BlobMask.defaultProps, e.thisObject.props); for (let type of newBadges) if (!e.thisObject.state[`${type}Mask`]) e.thisObject.state[`${type}Mask`] = new LibraryComponents.Animations.Controller({spring: 0}); }, after: e => { let [children, index] = BDFDB.ReactUtils.findChildren(e.returnValue, {name: "TransitionGroup"}); if (index > -1) { children[index].props.children.push(!e.thisObject.props.lowerLeftBadge ? null : BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.BadgeComponents.AnimationContainer, { className: BDFDB.disCN.guildlowerleftbadge, key: "lower-left-badge", animatedStyle: e.thisObject.getLowerLeftBadgeStyles(), children: e.thisObject.props.lowerLeftBadge })); children[index].props.children.push(!e.thisObject.props.upperLeftBadge ? null : BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.BadgeComponents.AnimationContainer, { className: BDFDB.disCN.guildupperleftbadge, key: "upper-left-badge", animatedStyle: e.thisObject.getUpperLeftBadgeStyles(), children: e.thisObject.props.upperLeftBadge })); } [children, index] = BDFDB.ReactUtils.findChildren(e.returnValue, {name: "mask"}); if (index > -1) { children[index].props.children.push(BDFDB.ReactUtils.createElement(LibraryComponents.Animations.animated.rect, { x: -4, y: -4, width: e.thisObject.props.upperLeftBadgeWidth + 8, height: 24, rx: 12, ry: 12, transform: e.thisObject.getLeftBadgePositionInterpolation(e.thisObject.state.upperLeftBadgeMask, -1), fill: "black" })); children[index].props.children.push(BDFDB.ReactUtils.createElement(LibraryComponents.Animations.animated.rect, { x: -4, y: 28, width: e.thisObject.props.lowerLeftBadgeWidth + 8, height: 24, rx: 12, ry: 12, transform: e.thisObject.getLeftBadgePositionInterpolation(e.thisObject.state.lowerLeftBadgeMask), fill: "black" })); } } }); BDFDB.ModuleUtils.patch(BDFDB, LibraryComponents.GuildComponents.BlobMask.prototype, "componentDidMount", { after: e => { for (let type of newBadges) e.thisObject.state[`${type}Mask`].update({ spring: e.thisObject.props[type] != null ? 1 : 0, immediate: true }).start(); } }); BDFDB.ModuleUtils.patch(BDFDB, LibraryComponents.GuildComponents.BlobMask.prototype, "componentWillUnmount", { after: e => { for (let type of newBadges) if (e.thisObject.state[`${type}Mask`]) e.thisObject.state[`${type}Mask`].destroy(); } }); BDFDB.ModuleUtils.patch(BDFDB, LibraryComponents.GuildComponents.BlobMask.prototype, "componentDidUpdate", { after: e => { for (let type of newBadges) if (e.thisObject.props[type] != null && e.methodArguments[0][type] == null) { e.thisObject.state[`${type}Mask`].update({ spring: 1, immediate: !document.hasFocus(), config: {friction: 30, tension: 900, mass: 1} }).start(); } else if (e.thisObject.props[type] == null && e.methodArguments[0][type] != null) { e.thisObject.state[`${type}Mask`].update({ spring: 0, immediate: !document.hasFocus(), config: {duration: 150, friction: 10, tension: 100, mass: 1} }).start(); } } }); LibraryComponents.GuildComponents.BlobMask.prototype.getLeftBadgePositionInterpolation = function (e, t) { return void 0 === t && (t = 1), e.animated.spring.to([0, 1], [20, 0]).to(function (e) { return "translate(" + e * -1 + " " + e * t + ")"; }); }; LibraryComponents.GuildComponents.BlobMask.prototype.getLowerLeftBadgeStyles = function () { var e = this.state.lowerLeftBadgeMask.animated.spring; return { opacity: e.to([0, .5, 1], [0, 0, 1]), transform: e.to(function (e) { return "translate(" + -1 * (16 - 16 * e) + "px, " + (16 - 16 * e) + "px)"; }) }; }; LibraryComponents.GuildComponents.BlobMask.prototype.getUpperLeftBadgeStyles = function () { var e = this.state.upperLeftBadgeMask.animated.spring; return { opacity: e.to([0, .5, 1], [0, 0, 1]), transform: e.to(function (e) { return "translate(" + -1 * (16 - 16 * e) + "px, " + -1 * (16 - 16 * e) + "px)"; }) }; }; let extraDefaultProps = {}; for (let type of newBadges) extraDefaultProps[`${type}Width`] = 16; InternalBDFDB.setDefaultProps(LibraryComponents.GuildComponents.BlobMask, extraDefaultProps); } BDFDB.ModuleUtils.patch(BDFDB, LibraryModules.GuildStore, "getGuild", {after: e => { if (e.returnValue && e.methodArguments[0] == "410787888507256842" && !e.returnValue.banner) { e.returnValue.banner = ""; } }}); BDFDB.ModuleUtils.patch(BDFDB, LibraryModules.IconUtils, "getGuildBannerURL", {instead: e => { return e.methodArguments[0].id == "410787888507256842" ? e.methodArguments[0].banner : e.callOriginalMethod(); }}); for (let type of ComponentTypeData.NormalContextMenus) InternalBDFDB.patchContextMenuLib(LibraryComponents.ContextMenus[type], false); for (let type of ComponentTypeData.FluxContextMenus) { if (!BDFDB.InternalData.componentPatchQueries[type]) BDFDB.InternalData.componentPatchQueries[type] = {query:[], module:null}; InternalBDFDB.patchContextMenuLib(LibraryComponents.ContextMenus[type], true); } for (let type of ComponentTypeData.QueuedComponents) if (!BDFDB.InternalData.componentPatchQueries[type]) BDFDB.InternalData.componentPatchQueries[type] = {query:[], module:null}; if (ComponentTypeData.NonRenderContextMenus.length) BDFDB.ModuleUtils.patch(BDFDB, LibraryModules.ContextMenuUtils, "openContextMenu", {before: e => { let menu = e.methodArguments[1](); if (BDFDB.ObjectUtils.is(menu)) { let type = InternalBDFDB.getContextMenuType(menu.type && menu.type.displayName || menu.props && menu.props.type, menu); if (type && ComponentTypeData.NonRenderContextMenus.includes(type)) InternalBDFDB.patchExportedContextMenuLib(menu, type, false); } }}); if (ComponentTypeData.ObservedContextMenus.length) BDFDB.ObserverUtils.connect(BDFDB, BDFDB.dotCN.appmount + " > * > " + BDFDB.dotCN.itemlayercontainer, {name:"contextMenuObserver", instance:(new MutationObserver(changes => {changes.forEach(change => {change.addedNodes.forEach(node => { let menu = node && node.nodeType != Node.TEXT_NODE && (BDFDB.ReactUtils.getInstance(node.querySelector(BDFDB.dotCN.contextmenu)) || {}).return; if (BDFDB.ObjectUtils.is(menu)) { let type = InternalBDFDB.getContextMenuType(menu.type && menu.type.displayName || menu.props && menu.props.type, menu); if (type && ComponentTypeData.ObservedContextMenus.includes(type)) InternalBDFDB.patchExportedContextMenuLib(menu, type, true); } });});}))}, {childList: true}); BDFDB.ModuleUtils.patch(BDFDB, BDFDB.ReactUtils.getValue(BDFDB.ModuleUtils.findByString("renderReactions", "canAddNewReactions", "showMoreUtilities", false), "exports.default"), "type", {after: e => { let [children, index] = BDFDB.ReactUtils.findChildren(e.returnValue, {filter: c => c && c.props && c.props.showMoreUtilities != undefined && c.props.showEmojiPicker != undefined && c.props.setPopout != undefined}); if (index > -1) BDFDB.ModuleUtils.patch(BDFDB, children[index], "type", {after: e2 => { let [children2, index2] = BDFDB.ReactUtils.findChildren(e2.returnValue, {name: "Popout"}); let popoutWrapper = children2[index2]; InternalBDFDB.executeExtraPatchedPatches("MessageOptionToolbar", {instance:{props:Object.assign({}, e2.methodArguments[0], {hasMorePopout: index2 > -1})}, returnvalue:e2.returnValue, methodname:"default"}); if (popoutWrapper && typeof popoutWrapper.props.renderPopout == "function") { let renderPopout = popoutWrapper.props.renderPopout; popoutWrapper.props.renderPopout = (...args) => { let renderedPopout = renderPopout(...args); BDFDB.ModuleUtils.patch(BDFDB, renderedPopout, "type", {after: e3 => {InternalBDFDB.executeExtraPatchedPatches("MessageOptionContextMenu", {instance:{props:e3.methodArguments[0]}, returnvalue:e3.returnValue, methodname:"default"});}}); return renderedPopout; } } }}); }}); BDFDB.ModuleUtils.forceAllUpdates(BDFDB); InternalBDFDB.addContextListeners(BDFDB); if (BDFDB.UserUtils.me.id == "278543574059057154") { for (let module in DiscordClassModules) if (!DiscordClassModules[module]) BDFDB.LogUtils.warn(module + " not initialized in DiscordClassModules"); for (let obj in DiscordObjects) if (!DiscordObjects[obj]) BDFDB.LogUtils.warn(obj + " not initialized in DiscordObjects"); for (let require in LibraryRequires) if (!LibraryRequires[require]) BDFDB.LogUtils.warn(require + " not initialized in LibraryRequires"); for (let module in LibraryModules) if (!LibraryModules[module]) BDFDB.LogUtils.warn(module + " not initialized in LibraryModules"); for (let component in NativeSubComponents) if (!NativeSubComponents[component]) BDFDB.LogUtils.warn(component + " not initialized in NativeSubComponents"); for (let component in LibraryComponents) if (!LibraryComponents[component]) BDFDB.LogUtils.warn(component + " not initialized in LibraryComponents"); BDFDB.ModuleUtils.DevFuncs = {}; BDFDB.ModuleUtils.DevFuncs.generateClassId = function (index) { let chars = "0123456789ABCDEFGHIJKMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_".split(""); let id = ""; while (id.length < 6) id += chars[Math.floor(Math.random() * chars.length)]; return id; }; BDFDB.ModuleUtils.DevFuncs.findByIndex = function (index) { return InternalBDFDB.getWebModuleReq().c[index]; }; BDFDB.ModuleUtils.DevFuncs.findPropAny = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); var req = InternalBDFDB.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.ModuleUtils.DevFuncs.findPropFunc = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); var req = InternalBDFDB.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.ModuleUtils.DevFuncs.findPropStringLib = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); var req = InternalBDFDB.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.ModuleUtils.DevFuncs.findNameAny = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); var req = InternalBDFDB.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.ModuleUtils.DevFuncs.findCodeAny = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); var req = InternalBDFDB.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.ModuleUtils.DevFuncs.getAllModules = function () { var req = InternalBDFDB.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.ModuleUtils.DevFuncs.getAllStringLibs = function () { var req = InternalBDFDB.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" && !BDFDB.ArrayUtils.is(m) && Object.keys(m).length) { 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" && !BDFDB.ArrayUtils.is(m.default) && Object.keys(m.default).length) { 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.ModuleUtils.DevFuncs.listen = function (strings) { strings = BDFDB.ArrayUtils.is(strings) ? strings : Array.from(arguments); BDFDB.ModuleUtils.DevFuncs.listenstop(); BDFDB.ModuleUtils.DevFuncs.listen.p = BDFDB.ModuleUtils.patch("WebpackSearch", BDFDB.ModuleUtils.findByProperties(strings), strings[0], {after: e => { console.log(e); }}); }; BDFDB.ModuleUtils.DevFuncs.listenstop = function () { if (typeof BDFDB.ModuleUtils.DevFuncs.listen.p == "function") BDFDB.ModuleUtils.DevFuncs.listen.p(); }; BDFDB.ModuleUtils.DevFuncs.req = InternalBDFDB.getWebModuleReq(); } for (let obj in DiscordObjects) if (!DiscordObjects[obj]) { DiscordObjects[obj] = function () {}; BDFDB.DiscordObjects[obj] = function () {}; } for (let component in NativeSubComponents) if (!NativeSubComponents[component]) NativeSubComponents[component] = "div"; for (let component in LibraryComponents) if (!LibraryComponents[component]) { LibraryComponents[component] = "div"; BDFDB.LibraryComponents[component] = "div"; } BDFDB.loadMessage = BDFDB.PluginUtils.init; BDFDB.unloadMessage = BDFDB.PluginUtils.clear; BDFDB.createSettingsPanel = BDFDB.PluginUtils.createSettingsPanel; BDFDB.addObserver = BDFDB.ObserverUtils.connect; BDFDB.killObservers = BDFDB.ObserverUtils.disconnect; BDFDB.addEventListener = BDFDB.ListenerUtils.add; BDFDB.removeEventListener = BDFDB.ListenerUtils.remove; BDFDB.addChildEventListener = BDFDB.ListenerUtils.addToChildren; BDFDB.copyEvent = BDFDB.ListenerUtils.copyEvent; BDFDB.stopEvent = BDFDB.ListenerUtils.stopEvent; BDFDB.showToast = BDFDB.NotificationUtils.toast; BDFDB.showDesktopNotification = BDFDB.NotificationUtils.desktop; BDFDB.createNotificationsBar = BDFDB.NotificationUtils.notice; BDFDB.createTooltip = (string, ele, config) => {return BDFDB.TooltipUtils.create(ele, string, config);}; BDFDB.updateTooltipPosition = BDFDB.TooltipUtils.update; BDFDB.isObject = BDFDB.ObjectUtils.is; BDFDB.sortObject = BDFDB.ObjectUtils.sort; BDFDB.reverseObject = BDFDB.ObjectUtils.reverse; BDFDB.filterObject = BDFDB.ObjectUtils.filter; BDFDB.mapObject = BDFDB.ObjectUtils.map; BDFDB.isObjectEmpty = BDFDB.ObjectUtils.isEmpty; BDFDB.sortArrayByKey = BDFDB.ArrayUtils.keySort; BDFDB.numSortArray = BDFDB.ArrayUtils.numSort; BDFDB.removeFromArray = BDFDB.ArrayUtils.remove; BDFDB.getAllIndexes = BDFDB.ArrayUtils.getAllIndexes; BDFDB.removeCopiesFromArray = BDFDB.ArrayUtils.removeCopies; BDFDB.React = Object.assign({}, BDFDB.ReactUtils); BDFDB.getKeyInformation = (config) => {return BDFDB.ReactUtils.findValue(config.node || config.instance, config.key, config);}; BDFDB.getReactInstance = BDFDB.ReactUtils.getInstance; BDFDB.getOwnerInstance = (config) => {return BDFDB.ReactUtils.findOwner(config.node || config.instance, config);}; BDFDB.ReactUtils.getOwner = BDFDB.ReactUtils.findOwner; BDFDB.getContextMenuGroupAndIndex = (startchildren, names) => {return BDFDB.ReactUtils.findChildren(startchildren, {name:names, props:[["label",names]]});}; BDFDB.getReactValue = BDFDB.ReactUtils.getValue; BDFDB.WebModules = Object.assign({}, BDFDB.ModuleUtils); BDFDB.WebModules.patch = (module, modulefunctions, plugin, patchfunctions) => {return BDFDB.ModuleUtils.patch(plugin, module, modulefunctions, patchfunctions)}; BDFDB.ModuleUtils.initiateProcess = InternalBDFDB.initiateProcess; BDFDB.WebModules.initiateProcess = InternalBDFDB.initiateProcess; BDFDB.myData = BDFDB.UserUtils.me; BDFDB.getUserStatus = BDFDB.UserUtils.getStatus; BDFDB.getUserStatusColor = BDFDB.UserUtils.getStatusColor; BDFDB.getUserAvatar = BDFDB.UserUtils.getAvatar; BDFDB.isUserAllowedTo = BDFDB.UserUtils.can; BDFDB.getGuildIcon = BDFDB.GuildUtils.getIcon; BDFDB.getGuildBanner = BDFDB.GuildUtils.getBanner; BDFDB.getServerDiv = BDFDB.GuildUtils.getDiv; BDFDB.getServerData = BDFDB.GuildUtils.getData; BDFDB.readServerList = BDFDB.GuildUtils.getAll; BDFDB.readUnreadServerList = BDFDB.GuildUtils.getUnread; BDFDB.readPingedServerList = BDFDB.GuildUtils.getPinged; BDFDB.readMutedServerList = BDFDB.GuildUtils.getMuted; BDFDB.getSelectedServer = BDFDB.GuildUtils.getSelected; BDFDB.openGuildContextMenu = BDFDB.GuildUtils.openMenu; BDFDB.markGuildAsRead = BDFDB.GuildUtils.markAsRead; BDFDB.getFolderID = BDFDB.FolderUtils.getId; BDFDB.getFolderDiv = BDFDB.FolderUtils.getDiv; BDFDB.getChannelDiv = BDFDB.ChannelUtils.getDiv; BDFDB.getSelectedChannel = BDFDB.ChannelUtils.getSelected; BDFDB.openChannelContextMenu = BDFDB.ChannelUtils.openMenu; BDFDB.markChannelAsRead = BDFDB.ChannelUtils.markAsRead; BDFDB.DmUtils = BDFDB.DMUtils; BDFDB.getDmDiv = BDFDB.DMUtils.getDiv; BDFDB.getChannelIcon = BDFDB.DMUtils.getIcon; BDFDB.readDmList = BDFDB.DMUtils.getAll; BDFDB.saveAllData = (data, plugin, key) => {BDFDB.DataUtils.save(data, plugin, key)}; BDFDB.saveData = (id, data, plugin, key) => {BDFDB.DataUtils.save(data, plugin, key, id)}; BDFDB.loadAllData = (plugin, key) => {return BDFDB.DataUtils.load(plugin, key)}; BDFDB.loadData = (id, plugin, key) => {return BDFDB.DataUtils.load(plugin, key, id)}; BDFDB.removeAllData = (plugin, key) => {BDFDB.DataUtils.remove(plugin, key)}; BDFDB.removeData = (id, plugin, key) => {BDFDB.DataUtils.remove(plugin, key, id)}; BDFDB.getAllData = (plugin, key) => {return BDFDB.DataUtils.get(plugin, key)}; BDFDB.getData = (id, plugin, key) => {return BDFDB.DataUtils.get(plugin, key, id)}; BDFDB.colorCONVERT = BDFDB.ColorUtils.convert; BDFDB.colorSETALPHA = BDFDB.ColorUtils.setAlpha; BDFDB.colorGETALPHA = BDFDB.ColorUtils.getAlpha; BDFDB.colorCHANGE = BDFDB.ColorUtils.change; BDFDB.colorINV = BDFDB.ColorUtils.invert; BDFDB.colorCOMPARE = BDFDB.ColorUtils.compare; BDFDB.colorISBRIGHT = BDFDB.ColorUtils.isBright; BDFDB.colorTYPE = BDFDB.ColorUtils.getType; BDFDB.colorGRADIENT = BDFDB.ColorUtils.createGradient; BDFDB.getSwatchColor = BDFDB.ColorUtils.getSwatchColor; BDFDB.openColorPicker = BDFDB.ColorUtils.openPicker; BDFDB.addClass = BDFDB.DOMUtils.addClass; BDFDB.removeClass = BDFDB.DOMUtils.removeClass; BDFDB.toggleClass = BDFDB.DOMUtils.toggleClass; BDFDB.containsClass = BDFDB.DOMUtils.containsClass; BDFDB.replaceClass = BDFDB.DOMUtils.replaceClass; BDFDB.removeClasses = BDFDB.DOMUtils.removeClassFromDOM; BDFDB.toggleEles = BDFDB.DOMUtils.toggle; BDFDB.isEleHidden = BDFDB.DOMUtils.isHidden; BDFDB.removeEles = BDFDB.DOMUtils.remove; BDFDB.htmlToElement = BDFDB.DOMUtils.create; BDFDB.getParentEle = BDFDB.DOMUtils.getParent; BDFDB.setInnerText = BDFDB.DOMUtils.setText; BDFDB.getInnerText = BDFDB.DOMUtils.getText; BDFDB.getRects = BDFDB.DOMUtils.getRects; BDFDB.getTotalHeight = BDFDB.DOMUtils.getHeight; BDFDB.getTotalWidth = BDFDB.DOMUtils.getWidth; BDFDB.appendLocalStyle = BDFDB.DOMUtils.appendLocalStyle; BDFDB.removeLocalStyle = BDFDB.DOMUtils.removeLocalStyle; BDFDB.encodeToHTML = BDFDB.StringUtils.htmlEscape; BDFDB.regEscape = BDFDB.StringUtils.regEscape; BDFDB.insertNRST = BDFDB.StringUtils.insertNRST; BDFDB.highlightText = BDFDB.StringUtils.highlight; BDFDB.formatBytes = BDFDB.NumberUtils.formatBytes; BDFDB.mapRange = BDFDB.NumberUtils.mapRange; BDFDB.getDiscordTheme = BDFDB.DiscordUtils.getTheme; BDFDB.getDiscordMode = BDFDB.DiscordUtils.getMode; BDFDB.getDiscordZoomFactor = BDFDB.DiscordUtils.getZoomFactor; BDFDB.getDiscordFontScale = BDFDB.DiscordUtils.getFontScale; BDFDB.openModal = BDFDB.ModalUtils.open; BDFDB.openConfirmModal = BDFDB.ModalUtils.confirm; BDFDB.openContextMenu = BDFDB.ContextMenuUtils.open; BDFDB.closeContextMenu = BDFDB.ContextMenuUtils.close; BDFDB.BdUtils = BDFDB.BDUtils; BDFDB.getPluginsFolder = BDFDB.BDUtils.getPluginsFolder; BDFDB.getThemesFolder = BDFDB.BDUtils.getThemesFolder; BDFDB.isPluginEnabled = BDFDB.BDUtils.isPluginEnabled; BDFDB.getPlugin = BDFDB.BDUtils.getPlugin; BDFDB.isThemeEnabled = BDFDB.BDUtils.isThemeEnabled; BDFDB.getTheme = BDFDB.BDUtils.getTheme; BDFDB.isRestartNoMoreEnabled = BDFDB.BDUtils.isAutoLoadEnabled; BDFDB.languages = BDFDB.LanguageUtils.languages; BDFDB.getDiscordLanguage = BDFDB.LanguageUtils.getLanguage; BDFDB.LanguageStrings = BDFDB.LanguageUtils.LanguageStrings; BDFDB.LanguageStringsCheck = BDFDB.LanguageUtils.LanguageStringsCheck; BDFDB.LanguageStringsFormat = BDFDB.LanguageUtils.LanguageStringsFormat; BDFDB.getLibraryStrings = _ => { let languageid = BDFDB.LanguageUtils.getLanguage().id; if (InternalBDFDB.LibraryStrings[languageid]) return InternalBDFDB.LibraryStrings[languageid]; return InternalBDFDB.LibraryStrings.default; }; BDFDB.LibraryComponents.ModalTabContent = LibraryComponents.ModalComponents.ModalTabContent; BDFDB.LibraryComponents.NumberBadge = LibraryComponents.BadgeComponents.NumberBadge; BDFDB.LibraryComponents.ContextMenuItem = LibraryComponents.ContextMenuItems.Item; BDFDB.LibraryComponents.ContextMenuItemGroup = LibraryComponents.ContextMenuItems.Group; BDFDB.LibraryComponents.ContextMenuSliderItem = LibraryComponents.ContextMenuItems.Slider; BDFDB.LibraryComponents.ContextMenuSubItem = LibraryComponents.ContextMenuItems.Sub; BDFDB.LibraryComponents.ContextMenuToggleItem = LibraryComponents.ContextMenuItems.Toggle; BDFDB.loaded = true; window.BDFDB = BDFDB; InternalBDFDB.reloadLib = _ => { 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.min.js"); libraryScript.setAttribute("date", performance.now()); document.head.appendChild(libraryScript); }; var libKeys = Object.keys(BDFDB).length - 10, crashInterval = BDFDB.TimeUtils.interval(_ => { if (!window.BDFDB || typeof BDFDB != "object" || Object.keys(BDFDB).length < libKeys || !BDFDB.InternalData.loadid) { BDFDB.LogUtils.warn("Reloading library due to internal error."); BDFDB.TimeUtils.clear(crashInterval); InternalBDFDB.reloadLib(); } else if (BDFDB.InternalData.loadid != loadid) { BDFDB.TimeUtils.clear(crashInterval); } else if (!BDFDB.InternalData.creationTime || performance.now() - BDFDB.InternalData.creationTime > 18000000) { BDFDB.TimeUtils.clear(crashInterval); InternalBDFDB.reloadLib(); } }, 10000); })();