diff --git a/Plugins/BDFDB.js b/Plugins/BDFDB.js index 68789745f8..875b4d9222 100644 --- a/Plugins/BDFDB.js +++ b/Plugins/BDFDB.js @@ -1272,10 +1272,10 @@ 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); + const bdSettings = document.querySelector("#bd-settingspane-container > *"); if (app) { selectedTypes = [selectedTypes].flat(10).filter(n => n).map(type => type && WebModulesData.PatchMap[type] ? WebModulesData.PatchMap[type] + " _ _ " + type : type); - let filteredModules = [], specialModules = {}, patchtypes = {}; + let filteredModules = [], specialModules = [], 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 (BDFDB.ArrayUtils.includes(methodnames, "componentDidMount", "componentDidUpdate", "render", false) && (!selectedTypes.length || selectedTypes.includes(type))) { @@ -1286,7 +1286,7 @@ for (let ele of document.querySelectorAll(BDFDB.dotCN[className])) { let constro = filter(BDFDB.ReactUtils.getInstance(ele)); if (constro) { - specialModules[type] = constro; + specialModules.push([type, constro]); break; } } @@ -1297,16 +1297,20 @@ patchtypes[name].push(patchType); } } - if (filteredModules.length || !BDFDB.ObjectUtils.isEmpty(specialModules)) { + if (filteredModules.length || specialModules.length) { filteredModules = BDFDB.ArrayUtils.removeCopies(filteredModules); + specialModules = BDFDB.ArrayUtils.removeCopies(specialModules); try { const appInsDown = BDFDB.ReactUtils.findOwner(app, {name:filteredModules, type:specialModules, all:true, group:true, unlimited:true}); const appInsUp = BDFDB.ReactUtils.findOwner(app, {name:filteredModules, type:specialModules, 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, type:specialModules, all:true, group:true, unlimited:true}); - for (let type in bdSettingsIns) for (let ins of bdSettingsIns[type]) InternalBDFDB.forceInitiateProcess(plugin, ins, type, patchtypes[type]); + const bdSettingsIns = BDFDB.ReactUtils.findOwner(bdSettings, {name:filteredModules, type:specialModules, all:true, unlimited:true}); + if (bdSettingsIns.length) { + const bdSettingsChange = BDFDB.ReactUtils.findValue(BDFDB.ReactUtils.getInstance(bdSettings), "onChange", {up:true}) + if (typeof bdSettingsChange == "function") bdSettingsChange(); + } } } catch (err) {BDFDB.LogUtils.error("Could not force update components! " + err, plugin.name);} @@ -1838,7 +1842,7 @@ foundInstances[group].push(instance.stateNode); } if (config.type && instance.type) { - let group = config.type.find(t => BDFDB.ArrayUtils.is(t) && instance.type === t) || "Default"; + let group = [config.type.find(t => BDFDB.ArrayUtils.is(t) && instance.type === t[1])].flat(10)[0] || "Default"; if (!BDFDB.ArrayUtils.is(foundInstances[group])) foundInstances[group] = []; foundInstances[group].push(instance.stateNode); } diff --git a/Plugins/BDFDB.min.js b/Plugins/BDFDB.min.js index a1350e13f6..022acf8742 100644 --- a/Plugins/BDFDB.min.js +++ b/Plugins/BDFDB.min.js @@ -1 +1 @@ -(a=>{if(window['BDFDB']&&window['BDFDB']['ListenerUtils']&&typeof window['BDFDB']['ListenerUtils']['remove']=='function')window['BDFDB']['ListenerUtils']['remove'](window['BDFDB']);if(window['BDFDB']&&window['BDFDB']['StoreChangeUtils']&&typeof window['BDFDB']['StoreChangeUtils']['remove']=='function')window['BDFDB']['StoreChangeUtils']['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 b={'myPlugins':Object['assign']({},window['BDFDB']&&window['BDFDB']['myPlugins']),'InternalData':Object['assign']({'pressedKeys':[],'mousePosition':{'pageX':0x0,'pageY':0x0},'componentPatchQueries':{}},window['BDFDB']&&window['BDFDB']['InternalData'],{'creationTime':performance['now']()}),'BDv2Api':window['BDFDB']&&window['BDFDB']['BDv2Api']||undefined,'name':'BDFDB'};var c=Math['round'](Math['random']()*0x2386f26fc10000),d={};b['InternalData']['loadid']=c;if(typeof Array['prototype']['flat']!='function')Array['prototype']['flat']=function(){return this;};d['defaults']={'settings':{'showToasts':{'value':!![],'description':'Show\x20Plugin\x20start\x20and\x20stop\x20Toasts'},'showSupportBadges':{'value':!![],'description':'Show\x20little\x20Badges\x20for\x20Users\x20who\x20support\x20my\x20Patreon'}}};b['LogUtils']={};b['LogUtils']['log']=function(y,z){console['log']('%c['+(typeof z=='string'&&z||'BDFDB')+']','color:\x20#3a71c1;\x20font-weight:\x20700;',(typeof y=='string'&&y||'')['trim']());};b['LogUtils']['warn']=function(y,z){console['warn']('%c['+(typeof z=='string'&&z||'BDFDB')+']','color:\x20#3a71c1;\x20font-weight:\x20700;',(typeof y=='string'&&y||'')['trim']());};b['LogUtils']['error']=function(y,z){console['error']('%c['+(typeof z=='string'&&z||'BDFDB')+']','color:\x20#3a71c1;\x20font-weight:\x20700;','Fatal\x20Error:\x20'+(typeof y=='string'&&y||'')['trim']());};b['LogUtils']['log']('Loading\x20library.');b['PluginUtils']={};b['PluginUtils']['init']=function(y){y['name']=y['name']||(typeof y['getName']=='function'?y['getName']():null);y['version']=y['version']||(typeof y['getVersion']=='function'?y['getVersion']():null);y['author']=y['author']||(typeof y['getAuthor']=='function'?y['getAuthor']():null);y['description']=y['description']||(typeof y['getDescription']=='function'?y['getDescription']():null);d['clearStartTimeout'](y);let z=b['LanguageUtils']['LibraryStringsFormat']('toast_plugin_started','v'+y['version']);b['LogUtils']['log'](z,y['name']);if(!b['BDUtils']['getSettings']('fork-ps-2')&&b['DataUtils']['get'](b,'settings','showToasts'))b['NotificationUtils']['toast'](y['name']+'\x20'+z,{'nopointer':!![],'selector':'plugin-started-toast'});let A=typeof y['getRawUrl']=='function'&&typeof y['getRawUrl']()=='string'?y['getRawUrl']():'https://mwittrien.github.io/BetterDiscordAddons/Plugins/'+y['name']+'/'+y['name']+'.plugin.js';b['PluginUtils']['checkUpdate'](y['name'],A);if(b['ObjectUtils']['is'](y['classes']))d['addPluginClasses'](y);if(typeof y['initConstructor']==='function')b['TimeUtils']['suppress'](y['initConstructor']['bind'](y),'Could\x20not\x20initiate\x20constructor!',y['name'])();if(typeof y['css']==='string')b['DOMUtils']['appendLocalStyle'](y['name'],y['css']);d['patchPlugin'](y);d['addSpecialListeners'](y);b['PluginUtils']['translate'](y);b['PluginUtils']['checkChangeLog'](y);if(!window['PluginUpdates']||typeof window['PluginUpdates']!=='object')window['PluginUpdates']={'plugins':{}};window['PluginUpdates']['plugins'][A]={'name':y['name'],'raw':A,'version':y['version']};if(typeof window['PluginUpdates']['interval']==='undefined')window['PluginUpdates']['interval']=b['TimeUtils']['interval'](B=>{b['PluginUtils']['checkAllUpdates']();},0x3e8*0x3c*0x3c*0x2);y['started']=!![];delete y['stopping'];for(let B in b['myPlugins'])if(!b['myPlugins'][B]['started']&&typeof b['myPlugins'][B]['initialize']=='function')setImmediate(C=>{b['TimeUtils']['suppress'](b['myPlugins'][B]['initialize']['bind'](b['myPlugins'][B]),'Could\x20not\x20initiate\x20plugin!',B)();});};b['PluginUtils']['clear']=function(y){d['clearStartTimeout'](y);delete b['myPlugins'][y['name']];let z=b['LanguageUtils']['LibraryStringsFormat']('toast_plugin_stopped','v'+y['version']);b['LogUtils']['log'](z,y['name']);if(!b['BDUtils']['getSettings']('fork-ps-2')&&b['DataUtils']['get'](b,'settings','showToasts'))b['NotificationUtils']['toast'](y['name']+'\x20'+z,{'nopointer':!![],'selector':'plugin-stopped-toast'});let A=typeof y['getRawUrl']=='function'&&typeof y['getRawUrl']()=='string'?y['getRawUrl']():'https://mwittrien.github.io/BetterDiscordAddons/Plugins/'+y['name']+'/'+y['name']+'.plugin.js';if(b['ObjectUtils']['is'](y['classes']))d['removePluginClasses'](y);if(typeof y['css']==='string')b['DOMUtils']['removeLocalStyle'](y['name']);b['ModuleUtils']['unpatch'](y);b['ListenerUtils']['remove'](y);b['StoreChangeUtils']['remove'](y);b['ObserverUtils']['disconnect'](y);b['WindowUtils']['closeAll'](y);b['WindowUtils']['removeListener'](y);for(let B in b['InternalData']['componentPatchQueries'])b['ArrayUtils']['remove'](b['InternalData']['componentPatchQueries'][B]['query'],y,!![]);for(let C of document['querySelectorAll']('.'+y['name']+'-modal,\x20.'+y['name']['toLowerCase']()+'-modal,\x20.'+y['name']+'-settingsmodal,\x20.'+y['name']['toLowerCase']()+'-settingsmodal')){let D=C['querySelector'](b['dotCN']['modalclose']);if(D)D['click']();}delete b['DataUtils']['cached'][y['name']];delete window['PluginUpdates']['plugins'][A];delete y['started'];b['TimeUtils']['timeout'](E=>{delete y['stopping'];});};b['PluginUtils']['translate']=function(y){y['labels']={};if(typeof y['setLabelsByLanguage']==='function'||typeof y['changeLanguageStrings']==='function'){if(document['querySelector']('html')['lang'])A();else{var z=b['TimeUtils']['interval'](B=>{if(document['querySelector']('html')['lang']){b['TimeUtils']['clear'](z);A();}},0x64);}function A(){var B=b['LanguageUtils']['getLanguage']();if(typeof y['setLabelsByLanguage']==='function')y['labels']=y['setLabelsByLanguage'](B['id']);if(typeof y['changeLanguageStrings']==='function')y['changeLanguageStrings']();b['LogUtils']['log'](b['LanguageUtils']['LibraryStringsFormat']('toast_plugin_translated',B['ownlang']),y['name']);}}};b['PluginUtils']['checkUpdate']=function(y,z){if(!y||!z)return;j['request'](z,(A,B,C)=>{if(A)return;var D=C['match'](/['"][0-9]+\.[0-9]+\.[0-9]+['"]/i);if(!D)return;if(b['NumberUtils']['getVersionDifference'](D[0x0],window['PluginUpdates']['plugins'][z]['version'])>0.2){b['NotificationUtils']['toast'](y+'\x20will\x20be\x20force\x20updated,\x20because\x20your\x20version\x20is\x20heavily\x20outdated.',{'type':'warn','nopointer':!![],'selector':'plugin-forceupdate-toast'});b['PluginUtils']['downloadUpdate'](y,z);}else if(b['NumberUtils']['compareVersions'](D[0x0],window['PluginUpdates']['plugins'][z]['version']))b['PluginUtils']['showUpdateNotice'](y,z);else b['PluginUtils']['removeUpdateNotice'](y);});};b['PluginUtils']['checkAllUpdates']=function(){for(let z in window['PluginUpdates']['plugins']){var y=window['PluginUpdates']['plugins'][z];b['PluginUtils']['checkUpdate'](y['name'],y['raw']);}};b['PluginUtils']['showUpdateNotice']=function(y,z){if(!y||!z)return;var A=document['querySelector']('#pluginNotice');if(!A){A=b['NotificationUtils']['notice']('The\x20following\x20plugins\x20need\x20to\x20be\x20updated: ',{'html':!![],'id':'pluginNotice','type':'info','btn':!b['BDUtils']['isAutoLoadEnabled']()?'Reload':'','customicon':''});A['style']['setProperty']('display','block','important');A['style']['setProperty']('visibility','visible','important');A['style']['setProperty']('opacity','1','important');A['querySelector'](b['dotCN']['noticedismiss'])['addEventListener']('click',E=>{b['DOMUtils']['remove']('.update-clickme-tooltip');});let D=A['querySelector'](b['dotCN']['noticebutton']);if(D){b['DOMUtils']['toggle'](D,!![]);D['addEventListener']('click',E=>{j['electron']['remote']['getCurrentWindow']()['reload']();});D['addEventListener']('mouseenter',E=>{if(window['PluginUpdates']['downloaded'])b['TooltipUtils']['create'](D,window['PluginUpdates']['downloaded']['join'](',\x20'),{'type':'bottom','selector':'update-notice-tooltip','style':'max-width:\x20420px'});});}}if(A){var B=A['querySelector']('#outdatedPlugins');if(B&&!B['querySelector']('#'+y+'-notice')){if(B['querySelector']('span'))B['appendChild'](b['DOMUtils']['create'](',\x20'));var C=b['DOMUtils']['create'](''+y+'');C['addEventListener']('click',E=>{b['PluginUtils']['downloadUpdate'](y,z);});B['appendChild'](C);if(!document['querySelector']('.update-clickme-tooltip'))b['TooltipUtils']['create'](B,'Click\x20us!',{'type':'bottom','selector':'update-clickme-tooltip','delay':0x1f4});}}};b['PluginUtils']['removeUpdateNotice']=function(y,z=document['querySelector']('#pluginNotice')){if(!y||!z)return;var A=z['querySelector']('#outdatedPlugins');if(A){var B=A['querySelector']('#'+y+'-notice');if(B){var C=B['nextSibling'];var D=B['prevSibling'];if(C&&b['DOMUtils']['containsClass'](C,'separator'))C['remove']();else if(D&&b['DOMUtils']['containsClass'](D,'separator'))D['remove']();B['remove']();}if(!A['querySelector']('span')){var E=z['querySelector'](b['dotCN']['noticebutton']);if(E){z['querySelector']('.notice-message')['innerText']='To\x20finish\x20updating\x20you\x20need\x20to\x20reload.';b['DOMUtils']['toggle'](E,![]);}else z['querySelector'](b['dotCN']['noticedismiss'])['click']();}}};b['PluginUtils']['downloadUpdate']=function(y,z){if(!y||!z)return;j['request'](z,(A,B,C)=>{if(A)return b['LogUtils']['warn']('Unable\x20to\x20get\x20update\x20for\x20'+y);b['InternalData']['creationTime']=0x0;var D=C['match'](/['"][0-9]+\.[0-9]+\.[0-9]+['"]/i);D=D['toString']()['replace'](/['"]/g,'');j['fs']['writeFileSync'](j['path']['join'](b['BDUtils']['getPluginsFolder'](),z['split']('/')['slice'](-0x1)[0x0]),C);b['NotificationUtils']['toast'](y+'\x20v'+window['PluginUpdates']['plugins'][z]['version']+'\x20has\x20been\x20replaced\x20by\x20'+y+'\x20v'+D+'.',{'nopointer':!![],'selector':'plugin-updated-toast'});var E=document['querySelector']('#pluginNotice');if(E){if(E['querySelector'](b['dotCN']['noticebutton'])){window['PluginUpdates']['plugins'][z]['version']=D;if(!window['PluginUpdates']['downloaded'])window['PluginUpdates']['downloaded']=[];if(!window['PluginUpdates']['downloaded']['includes'](y))window['PluginUpdates']['downloaded']['push'](y);}b['PluginUtils']['removeUpdateNotice'](y,E);}});};b['PluginUtils']['checkChangeLog']=function(y){if(!b['ObjectUtils']['is'](y)||!y['changelog'])return;var z=b['DataUtils']['load'](y,'changelog');if(!z['currentversion']||b['NumberUtils']['compareVersions'](y['version'],z['currentversion'])){z['currentversion']=y['version'];b['DataUtils']['save'](z,y,'changelog');b['PluginUtils']['openChangeLog'](y);}};b['PluginUtils']['openChangeLog']=function(y){if(!b['ObjectUtils']['is'](y)||!y['changelog'])return;var z='',A={'added':'New\x20Features','fixed':'Bug\x20Fixes','improved':'Improvements','progress':'Progress'};for(let C in y['changelog']){C=C['toLowerCase']();var B=b['disCN']['changelog'+C];if(B){z+='