BetterDiscordApp-v2/js/main.min.js

621 lines
111 KiB
JavaScript

(function(){let __fs=window.require("fs");let __process=window.require("process");let __platform=__process.platform;let __dataPath=(__platform==='win32'?__process.env.APPDATA:__platform==='darwin'?__process.env.HOME+'/Library/Preferences':process.env.HOME+'/.config')+'/BetterDiscord/';let __data={};if(__fs.existsSync(`${__dataPath}localStorage.json`)){try{__data=JSON.parse(__fs.readFileSync(`${__dataPath}localStorage.json`))}catch(err){console.log(err)}}else if(__fs.existsSync("localStorage.json")){try{__data=JSON.parse(__fs.readFileSync("localStorage.json"))}catch(err){console.log(err)}}
var __ls=__data;__ls.setItem=function(i,v){__ls[i]=v;this.save()};__ls.getItem=function(i){return __ls[i]||null};__ls.save=function(){__fs.writeFileSync(`${__dataPath}/localStorage.json`,JSON.stringify(this),null,4)};var __proxy=new Proxy(__ls,{set:function(target,name,val,receiver){__ls[name]=val;__ls.save()},get:function(target,name,receiver){return __ls[name]||null}});window.localStorage=__proxy})();(()=>{let v2Loader=document.createElement('div');v2Loader.className="bd-loaderv2";v2Loader.title="BetterDiscord is loading...";document.body.appendChild(v2Loader)})();window.bdStorage={};window.bdStorage.get=function(i){return betterDiscordIPC.sendSync('synchronous-message',{'arg':'storage','cmd':'get','var':i})};window.bdStorage.set=function(i,v){betterDiscordIPC.sendSync('synchronous-message',{'arg':'storage','cmd':'set','var':i,'data':v})};window.bdPluginStorage={};window.bdPluginStorage.get=function(pn,i){return betterDiscordIPC.sendSync('synchronous-message',{'arg':'pluginstorage','cmd':'get','pn':pn,'var':i})};window.bdPluginStorage.set=function(pn,i,v){betterDiscordIPC.sendSync('synchronous-message',{'arg':'pluginstorage','cmd':'set','pn':pn,'var':i,'data':v})};betterDiscordIPC.on('asynchronous-reply',(event,arg)=>{console.log(event);console.log(arg)});var settingsPanel,emoteModule,utils,quickEmoteMenu,opublicServers,voiceMode,pluginModule,themeModule,customCssEditor,dMode;var jsVersion=1.79;var supportedVersion="0.2.81";var mainObserver;var twitchEmoteUrlStart="https://static-cdn.jtvnw.net/emoticons/v1/";var twitchEmoteUrlEnd="/1.0";var ffzEmoteUrlStart="https://cdn.frankerfacez.com/emoticon/";var ffzEmoteUrlEnd="/1";var bttvEmoteUrlStart="https://cdn.betterttv.net/emote/";var bttvEmoteUrlEnd="/1x";var mainCore;var settings={"Save logs locally":{"id":"bda-gs-0","info":"Saves chat logs locally","implemented":!1,"hidden":!1,"cat":"core"},"Public Servers":{"id":"bda-gs-1","info":"Display public servers button","implemented":!0,"hidden":!1,"cat":"core"},"Minimal Mode":{"id":"bda-gs-2","info":"Hide elements and reduce the size of elements.","implemented":!0,"hidden":!1,"cat":"core"},"Voice Mode":{"id":"bda-gs-4","info":"Only show voice chat","implemented":!0,"hidden":!1,"cat":"core"},"Hide Channels":{"id":"bda-gs-3","info":"Hide channels in minimal mode","implemented":!0,"hidden":!1,"cat":"core"},"Dark Mode":{"id":"bda-gs-5","info":"Make certain elements dark by default(wip)","implemented":!0,"hidden":!1,"cat":"core"},"Override Default Emotes":{"id":"bda-es-5","info":"Override default emotes","implemented":!1,"hidden":!1,"cat":"core"},"Voice Disconnect":{"id":"bda-dc-0","info":"Disconnect from voice server when closing Discord","implemented":!0,"hidden":!1,"cat":"core"},"Custom css live update":{"id":"bda-css-0","info":"","implemented":!0,"hidden":!0,"cat":"core"},"Custom css auto udpate":{"id":"bda-css-1","info":"","implemented":!0,"hidden":!0,"cat":"core"},"24 Hour Timestamps":{"id":"bda-gs-6","info":"Replace 12hr timestamps with proper ones","implemented":!0,"hidden":!1,"cat":"core"},"Coloured Text":{"id":"bda-gs-7","info":"Make text colour the same as role colour","implemented":!0,"hidden":!1,"cat":"core"},"BetterDiscord Blue":{"id":"bda-gs-b","info":"Replace Discord blue with BD Blue","implemented":!0,"hidden":!1,"cat":"core"},"Developer Mode":{"id":"bda-gs-8","info":"Developer Mode","implemented":!0,"hidden":!1,"cat":"core"},"Twitch Emotes":{"id":"bda-es-7","info":"Show Twitch emotes","implemented":!0,"hidden":!1,"cat":"emote"},"FrankerFaceZ Emotes":{"id":"bda-es-1","info":"Show FrankerFaceZ Emotes","implemented":!0,"hidden":!1,"cat":"emote"},"BetterTTV Emotes":{"id":"bda-es-2","info":"Show BetterTTV Emotes","implemented":!0,"hidden":!1,"cat":"emote"},"Emote Menu":{"id":"bda-es-0","info":"Show Twitch/Favourite emotes in emote menu","implemented":!0,"hidden":!1,"cat":"emote"},"Emoji Menu":{"id":"bda-es-9","info":"Show Discord emoji menu","implemented":!0,"hidden":!1,"cat":"emote"},"Emote Autocomplete":{"id":"bda-es-3","info":"Autocomplete emote commands","implemented":!1,"hidden":!1,"cat":"emote"},"Emote Auto Capitalization":{"id":"bda-es-4","info":"Autocapitalize emote commands","implemented":!0,"hidden":!1,"cat":"emote"},"Show Names":{"id":"bda-es-6","info":"Show emote names on hover","implemented":!0,"hidden":!1,"cat":"emote"},"Show emote modifiers":{"id":"bda-es-8","info":"Enable emote mods","implemented":!0,"hidden":!1,"cat":"emote"},};var links={"Jiiks.net":{"text":"Jiiks.net","href":"thtp://jiiks.net","target":"_blank"},"twitter":{"text":"Twitter","href":"http://twitter.com/jiiksi","target":"_blank"},"github":{"text":"Github","href":"http://github.com/jiiks","target":"_blank"}};var defaultCookie={"version":jsVersion,"bda-gs-0":!1,"bda-gs-1":!0,"bda-gs-2":!1,"bda-gs-3":!1,"bda-gs-4":!1,"bda-gs-5":!0,"bda-gs-6":!1,"bda-gs-7":!1,"bda-gs-8":!1,"bda-es-0":!0,"bda-es-1":!0,"bda-es-2":!0,"bda-es-3":!1,"bda-es-4":!1,"bda-es-5":!0,"bda-es-6":!0,"bda-es-7":!0,"bda-gs-b":!0,"bda-es-8":!0,"bda-jd":!0,"bda-es-8":!0,"bda-dc-0":!1,"bda-css-0":!1,"bda-css-1":!1,"bda-es-9":!0};var bdchangelog={"changes":{"0a":{"title":"1.78 : Temp support for new settingspanel","text":"Added temp support for Discord's new settingspanel until v2.","img":""},"0b":{"title":"1.78 : Public Servers","text":"New look and flow for public servers","img":""},"0c":{"title":"1.78 : New loading icon","text":"New loading icon will now display in bottom right when BD is loading.","img":""},"0d":{"title":"1.78 : New CustomCSS editor look","text":"Updated CustomCSS editor with dark theme","img":""},"0e":{"title":"1.78 : BetterDiscord Blue","text":"Replace Discord blue with BetterDiscord blue!","img":""}},"fixes":{"0a":{"title":"1.79 : Settings Saving","text":"Fixed settings not saving with new settings panel","img":""}}};var settingsCookie={};function Core(){}
Core.prototype.init=function(){var self=this;var lVersion=(typeof(version)==="undefined")?bdVersion:version;if(lVersion<supportedVersion){this.alert("Not Supported","BetterDiscord v"+lVersion+"(your version)"+" is not supported by the latest js("+jsVersion+").<br><br> Please download the latest version from <a href='https://betterdiscord.net' target='_blank'>BetterDiscord.net</a>");return}
utils=new Utils();var sock=new BdWSocket();sock.start();utils.getHash();emoteModule=new EmoteModule();quickEmoteMenu=new QuickEmoteMenu();voiceMode=new VoiceMode();dMode=new devMode();emoteModule.init();this.initSettings();this.initObserver();function gwDefer(){console.log(new Date().getTime()+" Defer");if($(".guilds-wrapper .guilds").children().length>0){console.log(new Date().getTime()+" Defer Loaded");var guilds=$(".guilds>li:first-child");var showChannelsButton=$("<button/>",{class:"btn",id:"bd-show-channels",text:"R",css:{"cursor":"pointer"},click:function(){settingsCookie["bda-gs-3"]=!1;$("body").removeClass("bd-minimal-chan");self.saveSettings()}});$(".guilds-wrapper").prepend(showChannelsButton);opublicServers=new PublicServers();customCssEditor=new CustomCssEditor();pluginModule=new PluginModule();pluginModule.loadPlugins();if(typeof(themesupport2)!=="undefined"){themeModule=new ThemeModule();themeModule.loadThemes()}
settingsPanel=new SettingsPanel();settingsPanel.init();quickEmoteMenu.init(!1);$("#tc-settings-button").on("click",function(){settingsPanel.show()});window.addEventListener("beforeunload",function(){if(settingsCookie["bda-dc-0"]){$('.btn.btn-disconnect').click()}});$(document).on("mousedown",function(e){});opublicServers.init();emoteModule.autoCapitalize();if(settingsCookie.version<jsVersion){var cl=self.constructChangelog();$("body").append(cl);settingsCookie.version=jsVersion;self.saveSettings()}
$("head").append("<style>.CodeMirror{ min-width:100%; }</style>");$("head").append('<style id="bdemotemenustyle"></style>');document.getElementsByClassName("bd-loaderv2")[0].remove()}else{setTimeout(gwDefer,100)}}
$(document).ready(function(){setTimeout(gwDefer,1000)})};Core.prototype.initSettings=function(){if($.cookie("better-discord")==undefined){settingsCookie=defaultCookie;this.saveSettings()}else{this.loadSettings();for(var setting in defaultCookie){if(settingsCookie[setting]==undefined){settingsCookie[setting]=defaultCookie[setting];this.saveSettings()}}}};Core.prototype.saveSettings=function(){$.cookie("better-discord",JSON.stringify(settingsCookie),{expires:365,path:'/'})};Core.prototype.loadSettings=function(){settingsCookie=JSON.parse($.cookie("better-discord"))};var botlist=["119598467310944259"];Core.prototype.initObserver=function(){mainObserver=new MutationObserver(function(mutations){mutations.forEach(function(mutation){if(settingsPanel!==undefined)
settingsPanel.inject(mutation);if($(mutation.target).find(".emoji-picker").length){var fc=mutation.target.firstChild;if(fc.classList.contains("popout")){quickEmoteMenu.obsCallback($(fc))}}
if(typeof pluginModule!=="undefined")pluginModule.rawObserver(mutation);if(mutation.target.getAttribute('class')!=null){if(mutation.target.classList.contains('title-wrap')||mutation.target.classList.contains('chat')){voiceMode.obsCallback();if(typeof pluginModule!=="undefined")pluginModule.channelSwitch()}
if(mutation.target.getAttribute('class').indexOf('scroller messages')!=-1){if(typeof pluginModule!=="undefined")pluginModule.newMessage()}
if(settingsCookie["bda-gs-6"]){$(".timestamp").not("[data-24]").each(function(){var t=$(this);t.attr("data-24",!0);var text=t.text();var matches=/(.*)?at\s+(\d{1,2}):(\d{1,2})\s+(.*)/.exec(text);if(matches==null)return!0;if(matches.length<5)return!0;var h=parseInt(matches[2]);if(matches[4]=="AM"){if(h==12)h-=12}else if(matches[4]=="PM"){if(h<12)h+=12}
matches[2]=('0'+h).slice(-2);t.text(matches[1]+" at "+matches[2]+":"+matches[3])})}
if(settingsCookie["bda-gs-7"]){$(".user-name").not("[data-colour]").each(function(){var t=$(this);var color=t.css("color");if(color=="rgb(255, 255, 255)")return!0;t.closest(".message-group").find(".markup").not("[data-colour]").each(function(){$(this).attr("data-colour",!0);$(this).css("color",color)})})}}
emoteModule.obsCallback(mutation)})});mainObserver.observe(document,{childList:!0,subtree:!0})};Core.prototype.constructChangelog=function(){var changeLog=''+'<div id="bd-wn-modal" class="modal" style="opacity:1;">'+' <div class="modal-inner">'+' <div id="bdcl" class="markdown-modal change-log"> '+' <div class="markdown-modal-header">'+' <strong>What\'s new in BetterDiscord JS'+jsVersion+'</strong>'+' <button class="markdown-modal-close" onclick=\'$("#bd-wn-modal").remove();\'></button>'+' </div><!--header-->'+' <div class="scroller-wrap">'+' <div class="scroller">';if(bdchangelog.changes!=null){changeLog+=''+'<h1 class="changelog-added">'+' <span>New Stuff</span>'+'</h1>'+'<ul>';for(var change in bdchangelog.changes){change=bdchangelog.changes[change];changeLog+=''+'<li>'+' <strong>'+change.title+'</strong>'+' <div>'+change.text+'</div>'+'</li>'}
changeLog+='</ul>'}
if(bdchangelog.fixes!=null){changeLog+=''+'<h1 class="changelog-fixed">'+' <span>Fixed</span>'+'</h1>'+'<ul>';for(var fix in bdchangelog.fixes){fix=bdchangelog.fixes[fix];changeLog+=''+'<li>'+' <strong>'+fix.title+'</strong>'+' <div>'+fix.text+'</div>'+'</li>'}
changeLog+='</ul>'}
if(bdchangelog.upcoming!=null){changeLog+=''+'<h1 class="changelog-in-progress">'+' <span>Coming Soon</span>'+'</h1>'+'<ul>';for(var upc in bdchangelog.upcoming){upc=bdchangelog.upcoming[upc];changeLog+=''+'<li>'+' <strong>'+upc.title+'</strong>'+' <div>'+upc.text+'</div>'+'</li>'}
changeLog+='</ul>'}
changeLog+=''+' </div><!--scoller-->'+' </div><!--scroller-wrap-->'+' <div class="footer">'+' </div><!--footer-->'+' </div><!--change-log-->'+' </div><!--modal-inner-->'+'</div><!--modal-->';return changeLog};Core.prototype.alert=function(title,text){var id='';for(var i=0;i<5;i++)
id+="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".charAt(Math.floor(Math.random()*"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".length));var bdAlert='\
<div id="bda-alert-'+id+'" class="modal bda-alert" style="opacity:1" data-bdalert="'+id+'">\
<div class="modal-inner" style="box-shadow:0 0 8px -2px #000;">\
<div class="markdown-modal">\
<div class="markdown-modal-header">\
<strong style="float:left"><span>BetterDiscord - </span><span>'+title+'</span></strong>\
<span></span>\
<button class="markdown-modal-close" onclick=\'document.getElementById("bda-alert-'+id+'").remove(); utils.removeBackdrop("'+id+'");\'></button>\
</div>\
<div class="scroller-wrap fade">\
<div style="font-weight:700" class="scroller">'+text+'</div>\
</div>\
<div class="markdown-modal-footer">\
<span style="float:right"> for support.</span>\
<a style="float:right" href="https://discord.gg/0Tmfo5ZbOR9NxvDd" target="_blank">#support</a>\
<span style="float:right">Join </span>\
</div>\
</div>\
</div>\
</div>\
';$("body").append(bdAlert);utils.addBackdrop(id)};var emotesFfz={};var emotesBTTV={};var emotesTwitch={"emotes":{"emote":{"image_id":0}}};var subEmotesTwitch={};function EmoteModule(){}
EmoteModule.prototype.init=function(){};EmoteModule.prototype.getBlacklist=function(){$.getJSON("https://cdn.rawgit.com/Jiiks/betterDiscordApp/"+_hash+"/data/emotefilter.json",function(data){bemotes=data.blacklist})};EmoteModule.prototype.obsCallback=function(mutation){var self=this;for(var i=0;i<mutation.addedNodes.length;++i){var next=mutation.addedNodes.item(i);if(next){var nodes=self.getNodes(next);for(var node in nodes){if(nodes.hasOwnProperty(node)){var elem=nodes[node].parentElement;if(elem&&elem.classList.contains('edited')){self.injectEmote(elem)}else{self.injectEmote(nodes[node])}}}}}};EmoteModule.prototype.getNodes=function(node){var next;var nodes=[];var treeWalker=document.createTreeWalker(node,NodeFilter.SHOW_TEXT,null,!1);while(next=treeWalker.nextNode()){nodes.push(next)}
return nodes};var bemotes=[];var spoilered=[];EmoteModule.prototype.injectEmote=function(node){var self=this;if(!node.parentElement)return;var parent=$(node).parent();if(!parent.hasClass("markup")&&!parent.hasClass("message-content"))return;function inject(){var contents=parent.contents();contents.each(function(i){if(contents[i]==undefined)return;var nodeValue=contents[i].nodeValue;if(nodeValue==null)return;if(contents[i].nodeType==8)return;contents.splice(i,1);var words=nodeValue.split(/([^\s]+)([\s]|$)/g).filter(function(e){return e});var splice=0;var doInject=!1;var text=null;words.forEach(function(w,index,a){if(w.indexOf("[!s]")>-1){w=w.replace("[!s]","");parent.data("spoilered",!1);parent.addClass("spoiler")}
var allowedClasses=["flip","spin","pulse","spin2","spin3","1spin","2spin","3spin","tr","bl","br","shake","shake2","shake3","flap"];var useEmoteClass=!1;var emoteClass="";var skipffz=!1;var sw=w;if(w.indexOf(":")>-1){var split=w.split(":");if(split[0]!=""&&split[1]!=""){if(allowedClasses.indexOf(split[1])>-1){sw=split[0];emoteClass=settingsCookie["bda-es-8"]?"emote"+split[1]:""}
if(split[1]=="bttv"){sw=split[0];skipffz=!0}}}
if($.inArray(sw,bemotes)==-1){if(typeof emotesTwitch!=='undefind'&&settingsCookie["bda-es-7"]){if(emotesTwitch.emotes.hasOwnProperty(sw)&&sw.length>=4){if(text!=null){contents.splice(i+splice++,0,document.createTextNode(text));text=null}
var url=twitchEmoteUrlStart+emotesTwitch.emotes[sw].image_id+twitchEmoteUrlEnd;contents.splice(i+splice++,0,self.createEmoteElement(sw,url,emoteClass));doInject=!0;return}}
if(typeof subEmotesTwitch!=='undefined'&&settingsCookie["bda-es-7"]){if(subEmotesTwitch.hasOwnProperty(sw)&&sw.length>=4){if(text!=null){contents.splice(i+splice++,0,document.createTextNode(text));text=null}
var url=twitchEmoteUrlStart+subEmotesTwitch[sw]+twitchEmoteUrlEnd;contents.splice(i+splice++,0,self.createEmoteElement(sw,url,emoteClass));doInject=!0;return}}
if(typeof emotesBTTV!=='undefined'&&settingsCookie["bda-es-2"]){if(emotesBTTV.hasOwnProperty(sw)&&sw.length>=4){if(text!=null){contents.splice(i+splice++,0,document.createTextNode(text));text=null}
var url=emotesBTTV[sw];contents.splice(i+splice++,0,self.createEmoteElement(sw,url,emoteClass));doInject=!0;return}}
if((typeof emotesFfz!=='undefined'&&settingsCookie["bda-es-1"])&&(!skipffz||!emotesBTTV2.hasOwnProperty(sw))){if(emotesFfz.hasOwnProperty(sw)&&sw.length>=4){if(text!=null){contents.splice(i+splice++,0,document.createTextNode(text));text=null}
var url=ffzEmoteUrlStart+emotesFfz[sw]+ffzEmoteUrlEnd;contents.splice(i+splice++,0,self.createEmoteElement(sw,url,emoteClass));doInject=!0;return}}
if(typeof emotesBTTV2!=='undefined'&&settingsCookie["bda-es-2"]){if(emotesBTTV2.hasOwnProperty(sw)&&sw.length>=4){if(text!=null){contents.splice(i+splice++,0,document.createTextNode(text));text=null}
var url=bttvEmoteUrlStart+emotesBTTV2[sw]+bttvEmoteUrlEnd;if(skipffz&&emotesFfz.hasOwnProperty(sw))sw=sw+":bttv";contents.splice(i+splice++,0,self.createEmoteElement(sw,url,emoteClass));doInject=!0;return}}}
if(text==null){text=w}else{text+=""+w}
if(index===a.length-1){contents.splice(i+splice,0,document.createTextNode(text))}});if(doInject){var oldHeight=parent.outerHeight();parent.html(contents);var scrollPane=$(".scroller.messages").first();scrollPane.scrollTop(scrollPane.scrollTop()+(parent.outerHeight()-oldHeight))}})}
inject();if(parent.children().hasClass("edited")){setTimeout(inject,250)}};EmoteModule.prototype.createEmoteElement=function(word,url,mod){var len=Math.round(word.length/4);var name=word.substr(0,len)+"\uFDD9"+word.substr(len,len)+"\uFDD9"+word.substr(len*2,len)+"\uFDD9"+word.substr(len*3);var html='<span class="emotewrapper"><img draggable="false" style="max-height:32px;" class="emote '+mod+'" alt="'+name+'" src="'+url+'"/><input onclick=\'quickEmoteMenu.favorite(\"'+name+'\", \"'+url+'\");\' class="fav" title="Favorite!" type="button"></span>';return $.parseHTML(html.replace(new RegExp("\uFDD9","g"),""))[0]};EmoteModule.prototype.autoCapitalize=function(){var self=this;$('body').delegate($(".channel-textarea-inner textarea:first"),'keyup change paste',function(){if(!settingsCookie["bda-es-4"])return;var text=$(".channel-textarea-inner textarea:first").val();if(text==undefined)return;var lastWord=text.split(" ").pop();if(lastWord.length>3){if(lastWord=="danSgame")return;var ret=self.capitalize(lastWord.toLowerCase());if(ret!==null&&ret!==undefined){$(".channel-textarea-inner textarea:first").val(text.replace(lastWord,ret))}}})};EmoteModule.prototype.capitalize=function(value){var res=emotesTwitch.emotes;for(var p in res){if(res.hasOwnProperty(p)&&value==(p+'').toLowerCase()){return p}}};class PublicServers{constructor(){this.v2p=new V2_PublicServers()}
get endPoint(){return 'https://search.discordservers.com'}
get button(){let self=this;let btn=$("<div/>",{class:'guild',id:'bd-pub-li',css:{'height':'20px','display':settingsCookie['bda-gs-1']?"":"none"}}).append($("<div/>",{class:'guild-inner',css:{'height':'20px','border-radius':'4px'}}).append($("<a/>",{}).append($("<div/>",{text:'public',id:'bd-pub-button',css:{'line-height':'20px','font-size':'12px'},click:()=>{self.v2p.render()}}))));return btn}
init(){let self=this;let guilds=$(".guilds>:first-child");guilds.after(self.button)}
get layer(){let self=this;let layer=`<div id="bd-pubs-layer" class="layer bd-layer" tabindex="0">
<div class="ui-standard-sidebar-view">
<div class="sidebar-region">
<div class="scroller-wrap fade dark">
<div class="scroller">
<div class="sidebar">
<div class="ui-tab-bar SIDE">
<div class="ui-tab-bar-header" style="font-size: 16px;">Public Servers</div>
<div class="ui-tab-bar-separator margin-top-8 margin-bottom-8"></div>
<div class="ui-form-item">
<div class="ui-text-input flex-vertical" style="width: 186px; margin-left: 10px;">
<input type="text" class="input default" id="bd-pubs-search" name="bd-pubs-search" value="" placeholder="Search..." maxlength="999">
</div>
</div>
<div class="ui-tab-bar-separator margin-top-8 margin-bottom-8"></div>
<div class="ui-tab-bar-header">Categories</div>
<div class="ui-tab-bar-item selected">All</div>
<div class="ui-tab-bar-item">FPS Games</div>
<div class="ui-tab-bar-item">MMO Games</div>
<div class="ui-tab-bar-item">Strategy Games</div>
<div class="ui-tab-bar-item">Sports Games</div>
<div class="ui-tab-bar-item">Puzzle Games</div>
<div class="ui-tab-bar-item">Retro Games</div>
<div class="ui-tab-bar-item">Party Games</div>
<div class="ui-tab-bar-item">Tabletop Games</div>
<div class="ui-tab-bar-item">Sandbox Games</div>
<div class="ui-tab-bar-item">Simulation Games</div>
<div class="ui-tab-bar-item">Community</div>
<div class="ui-tab-bar-item">Language</div>
<div class="ui-tab-bar-item">Programming</div>
<div class="ui-tab-bar-item">Other</div>
<div class="ui-tab-bar-separator margin-top-8 margin-bottom-8"></div>
<div class="ui-tab-bar-header" style="font-size: 9px;font-weight: 700;">Listing provided by: <a href="https://discordservers.com" target="_blank">Discordservers.com</a></div>
</div>
</div>
</div>
</div>
</div>
<div class="content-region">
<div class="scroller-wrap fade dark">
<div class="scroller">
<div class="content-column" id="bd-pubs-bg-spinner">
<div style="height: 100vh; margin: -60px -40px;">
<span class="spinner" type="wandering-cubes" style="top: 50%;position: relative;left: 50%;transform: translate(-50%, -50%);">
<span class="spinner-inner spinner-wandering-cubes">
<span class="spinner-item"></span>
<span class="spinner-item"></span>
</span>
</span>
</div>
</div>
<div class="content-column" id="bd-pubs-listing-container" style="display:none;">
<span id="bd-pubs-results" style="color: #72767d;font-weight: 700;"></span>
<div id="bd-pubs-listing"></div>
</div>
<div class="tools">
<div class="btn-close">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12 12" style="width: 18px; height: 18px;"><g class="background" fill="none" fill-rule="evenodd"><path d="M0 0h12v12H0"></path><path class="fill" fill="#dcddde" d="M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6"></path></g></svg>
</div>
<div class="esc-text">ESC</div>
</div>
</div>
</div>
</div>
</div>
</div>`;layer=$(layer);layer.on("blur",e=>{if(e.relatedTarget.id==='bd-pubs-search')return;layer.focus();console.log("blur:");console.log(e)});layer.on("keydown",e=>{if(e.which===13&&e.target.id==='bd-pubs-search'){let category=$("#bd-pubs-layer .ui-tab-bar-item.selected").text();if(category==='All')category='';self.search(self.query({'term':e.target.value,'category':category}),!0);return}
if(e.which!==27)return;self.hide()});layer.find('.btn-close').on('click',e=>{self.hide()});layer.find('.ui-tab-bar.SIDE .ui-tab-bar-item').on('click',e=>{let category=e.target.textContent;if(category==='All')category='';self.search(self.query({'term':$("#bd-pubs-search").val(),'category':category}),!0)});return layer}
serverCard(serverInfo){return `<div class="ui-card ui-card-primary bd-server-card" style="margin-top: 5px">
<div class="ui-flex horizontal" style="display: flex; flex-flow: row nowrap; justify-content: flex-start; align-items: stretch; flex: 1 1 auto;">
<div class="ui-flex-child" style="flex: 0 1 auto; padding: 5px;">
<div class="bd-pubs-server-icon" style="width: 100px; height: 100px; background-size: cover; background-image: url(${serverInfo.icon})"></div>
</div>
<div class="ui-flex-child" style="flex: 1 1 auto; padding: 5px;">
<div class="ui-flex horizontal">
<div class="ui-form-item" style="flex: 1 1 auto">
<h5 class="ui-form-title h5 margin-reset">${serverInfo.name}</h5>
</div>
<div class="ui-form-item">
<h5 class="ui-form-title h5 margin-reset">${serverInfo.online}/${serverInfo.members} Members</h5>
</div>
</div>
<div class="ui-flex horizontal">
<div class="scroller-wrap fade dark" style="min-height: 60px; max-height: 60px; border-top: 1px solid #3f4146; border-bottom: 1px solid #3f4146; padding-top: 5px">
<div class="scoller">
<div style="font-size: 13px; color: #b9bbbe">
${serverInfo.description}
</div>
</div>
</div>
</div>
<div class="ui-flex horizontal">
<div class="ui-flex-child bd-server-tags" style="flex: 1 1 auto">${serverInfo.categories.join(" ,")}</div>
<button type="button" class="ui-button filled brand small grow" style="min-height: 12px; margin-top: 4px;">
<div class="ui-button-contents">Join</div>
</button>
</div>
</div>
</div>
</div>`}
get bdServerCard(){let serverInfo={'name':'BetterDiscord','icon':'https://cdn.discordapp.com/icons/86004744966914048/c8d49dc02248e1f55caeb897c3e1a26e.webp','online':'7500+','members':'20000+','description':'Official BetterDiscord support server'};return `<div class="ui-card ui-card-primary bd-server-card" style="margin-top: 5px">
<div class="ui-flex horizontal" style="display: flex; flex-flow: row nowrap; justify-content: flex-start; align-items: stretch; flex: 1 1 auto;">
<div class="ui-flex-child" style="flex: 0 1 auto; padding: 5px;">
<div class="bd-pubs-server-icon" style="width: 100px; height: 100px; background-size: cover; background-image: url(${serverInfo.icon})"></div>
</div>
<div class="ui-flex-child" style="flex: 1 1 auto; padding: 5px;">
<div class="ui-flex horizontal">
<div class="ui-form-item" style="flex: 1 1 auto">
<h5 class="ui-form-title h5 margin-reset">${serverInfo.name}</h5>
</div>
<div class="ui-form-item">
<h5 class="ui-form-title h5 margin-reset">Too many members</h5>
</div>
</div>
<div class="ui-flex horizontal">
<div class="scroller-wrap fade dark" style="min-height: 60px; max-height: 60px; border-top: 1px solid #3f4146; border-bottom: 1px solid #3f4146; padding-top: 5px">
<div class="scoller">
<div style="font-size: 13px; color: #b9bbbe">
${serverInfo.description}
</div>
</div>
</div>
</div>
<div class="ui-flex horizontal">
<div class="ui-flex-child bd-server-tags" style="flex: 1 1 auto"></div>
<button type="button" class="ui-button filled brand small grow" style="min-height: 12px; margin-top: 4px;">
<div class="ui-button-contents">Join</div>
</button>
</div>
</div>
</div>
</div>`}
getPanel(){console.log("pubs get panel");return '<div></div>'}
getPinnedServer(){console.log("pubs get pinned server");return '<div></div>'}
hidePinnedServer(){console.log("pubs hide pinned server")}
showPinnedServer(){console.log("pubs show pinned server")}
show(){let self=this;$(".layers").append(self.layer)}
hide(){$("#bd-pubs-layer").remove()}
loadServers(dataset,search,clear){console.log("pubs load servers")}
search(query,clear){let self=this;let $list=$("#bd-pubs-listing");if(clear){$list.empty();$("#bd-pubs-listing-container").hide();$("#bd-pubs-bg-spinner").show()}
$.ajax({method:'GET',url:`${self.endPoint}?${query}`,success:data=>{$list.append(self.bdServerCard);data.results.map(server=>{$list.append(self.serverCard(server))});$("#bd-pubs-listing-container").show();$("#bd-pubs-bg-spinner").hide();self.setSearchText(1,$(".bd-server-card").size(),data.total,null,$("#bd-pubs-search").val())}})}
setSearchText(start,end,total,category,term){if(!category)category=$("#bd-pubs-layer .ui-tab-bar-item.selected").text();let text=`Showing ${start}-${end} of ${total} results in ${category}`;if(term&&term.length)text+=` for: ${term}`;$("#bd-pubs-results").text(text)}
get next(){let self=this;if(!self.next)return null}
joinServer(code){console.log("pubs join")}
joinServerDirect(code){console.log("pubs join direct")}
escape(unsafe){console.log("pubs escape")}
query(params){return require('querystring').stringify(params)}}
function QuickEmoteMenu(){}
QuickEmoteMenu.prototype.init=function(){$(document).on("mousedown",function(e){if(e.target.id!="rmenu")$("#rmenu").remove()});this.favoriteEmotes={};var fe=bdStorage.get("bdfavemotes");if(fe!==""&&fe!==null){this.favoriteEmotes=JSON.parse(atob(fe))}
var qmeHeader="";qmeHeader+="<div id=\"bda-qem\">";qmeHeader+=" <button class=\"active\" id=\"bda-qem-twitch\" onclick='quickEmoteMenu.switchHandler(this); return false;'>Twitch<\/button>";qmeHeader+=" <button id=\"bda-qem-favourite\" onclick='quickEmoteMenu.switchHandler(this); return false;'>Favourite<\/button>";qmeHeader+=" <button id=\"bda-qem-emojis\" onclick='quickEmoteMenu.switchHandler(this); return false;'>Emojis<\/buttond>";qmeHeader+="<\/div>";this.qmeHeader=qmeHeader;var teContainer="";teContainer+="<div id=\"bda-qem-twitch-container\">";teContainer+=" <div class=\"scroller-wrap fade\">";teContainer+=" <div class=\"scroller\">";teContainer+=" <div class=\"emote-menu-inner\">";for(var emote in emotesTwitch.emotes){if(emotesTwitch.emotes.hasOwnProperty(emote)){var id=emotesTwitch.emotes[emote].image_id;teContainer+="<div class=\"emote-container\">";teContainer+=" <img class=\"emote-icon\" id=\""+emote+"\" alt=\"\" src=\"https://static-cdn.jtvnw.net/emoticons/v1/"+id+"/1.0\" title=\""+emote+"\">";teContainer+=" </img>";teContainer+="</div>"}}
teContainer+=" <\/div>";teContainer+=" <\/div>";teContainer+=" <\/div>";teContainer+="<\/div>";this.teContainer=teContainer;var faContainer="";faContainer+="<div id=\"bda-qem-favourite-container\">";faContainer+=" <div class=\"scroller-wrap fade\">";faContainer+=" <div class=\"scroller\">";faContainer+=" <div class=\"emote-menu-inner\">";for(var emote in this.favoriteEmotes){var url=this.favoriteEmotes[emote];faContainer+="<div class=\"emote-container\">";faContainer+=" <img class=\"emote-icon\" alt=\"\" src=\""+url+"\" title=\""+emote+"\" oncontextmenu='quickEmoteMenu.favContext(event, this);'>";faContainer+=" </img>";faContainer+="</div>"}
faContainer+=" <\/div>";faContainer+=" <\/div>";faContainer+=" <\/div>";faContainer+="<\/div>";this.faContainer=faContainer};QuickEmoteMenu.prototype.favContext=function(e,em){e.stopPropagation();var menu=$('<div/>',{id:"rmenu","data-emoteid":$(em).prop("title"),text:"Remove"});menu.css({top:e.pageY-$("#bda-qem-favourite-container").offset().top,left:e.pageX-$("#bda-qem-favourite-container").offset().left});$(em).parent().append(menu);menu.on("click",function(e){e.preventDefault();e.stopPropagation();$(this).remove();delete quickEmoteMenu.favoriteEmotes[$(this).data("emoteid")];quickEmoteMenu.updateFavorites();return!1});return!1};QuickEmoteMenu.prototype.switchHandler=function(e){this.switchQem($(e).attr("id"))};QuickEmoteMenu.prototype.switchQem=function(id){var twitch=$("#bda-qem-twitch");var fav=$("#bda-qem-favourite");var emojis=$("#bda-qem-emojis");twitch.removeClass("active");fav.removeClass("active");emojis.removeClass("active");$(".emoji-picker").hide();$("#bda-qem-favourite-container").hide();$("#bda-qem-twitch-container").hide();switch(id){case "bda-qem-twitch":twitch.addClass("active");$("#bda-qem-twitch-container").show();break;case "bda-qem-favourite":fav.addClass("active");$("#bda-qem-favourite-container").show();break;case "bda-qem-emojis":emojis.addClass("active");$(".emoji-picker").show();break}
this.lastTab=id;var emoteIcon=$(".emote-icon");emoteIcon.off();emoteIcon.on("click",function(){var emote=$(this).attr("title");var ta=$(".channel-textarea-inner textarea");ta.val(ta.val().slice(-1)==" "?ta.val()+emote:ta.val()+" "+emote)})};QuickEmoteMenu.prototype.obsCallback=function(e){if(!settingsCookie["bda-es-9"]){e.addClass("bda-qme-hidden")}else{e.removeClass("bda-qme-hidden")}
if(!settingsCookie["bda-es-0"])return;var self=this;e.prepend(this.qmeHeader);e.append(this.teContainer);e.append(this.faContainer);if(this.lastTab==undefined){this.lastTab="bda-qem-favourite"}
this.switchQem(this.lastTab)};QuickEmoteMenu.prototype.favorite=function(name,url){if(!this.favoriteEmotes.hasOwnProperty(name)){this.favoriteEmotes[name]=url}
this.updateFavorites()};QuickEmoteMenu.prototype.updateFavorites=function(){var faContainer="";faContainer+="<div id=\"bda-qem-favourite-container\">";faContainer+=" <div class=\"scroller-wrap fade\">";faContainer+=" <div class=\"scroller\">";faContainer+=" <div class=\"emote-menu-inner\">";for(var emote in this.favoriteEmotes){var url=this.favoriteEmotes[emote];faContainer+="<div class=\"emote-container\">";faContainer+=" <img class=\"emote-icon\" alt=\"\" src=\""+url+"\" title=\""+emote+"\" oncontextmenu='quickEmoteMenu.favContext(event, this);'>";faContainer+=" </img>";faContainer+="</div>"}
faContainer+=" <\/div>";faContainer+=" <\/div>";faContainer+=" <\/div>";faContainer+="<\/div>";this.faContainer=faContainer;$("#bda-qem-favourite-container").replaceWith(faContainer);window.bdStorage.set("bdfavemotes",btoa(JSON.stringify(this.favoriteEmotes)))};function CustomCssEditor(){}
CustomCssEditor.prototype.init=function(){var self=this;self.hideBackdrop=!1;self.editor=CodeMirror.fromTextArea(document.getElementById("bd-custom-css-ta"),{lineNumbers:!0,mode:'css',indentUnit:4,theme:'material',scrollbarStyle:'simple'});self.editor.on("change",function(cm){var css=cm.getValue();self.applyCustomCss(css,!1,!1)});var attachEditor="";attachEditor+="<div id=\"bd-customcss-attach-controls\">";attachEditor+=" <ul class=\"checkbox-group\">";attachEditor+=" <li>";attachEditor+=" <div class=\"checkbox\" onclick=\"settingsPanel.updateSetting(this);\">";attachEditor+=" <div class=\"checkbox-inner\"><input id=\"bda-css-0\" type=\"checkbox\" "+(settingsCookie["bda-css-0"]?"checked":"")+"><span><\/span><\/div>";attachEditor+=" <span title=\"Update client css while typing\">Live Update<\/span>";attachEditor+=" <\/div>";attachEditor+=" <\/li>";attachEditor+=" <li>";attachEditor+=" <div class=\"checkbox\" onclick=\"settingsPanel.updateSetting(this);\">";attachEditor+=" <div class=\"checkbox-inner\"><input id=\"bda-css-1\" type=\"checkbox\" "+(settingsCookie["bda-css-1"]?"checked":"")+"><span><\/span><\/div>";attachEditor+=" <span title=\"Autosave css to storage when typing\">TEMPDISABLED<\/span>";attachEditor+=" <\/div>";attachEditor+=" <\/li>";attachEditor+=" <li>";attachEditor+=" <div class=\"checkbox\" onclick=\"settingsPanel.updateSetting(this);\">";attachEditor+=" <div class=\"checkbox-inner\"><input id=\"bda-css-2\" type=\"checkbox\" "+(customCssEditor.hideBackdrop?"checked":"")+"><span><\/span><\/div>";attachEditor+=" <span title=\"Hide the callout backdrop to disable modal close events\">Hide Backdrop<\/span>";attachEditor+=" <\/div>";attachEditor+=" <\/li>";attachEditor+=" <\/ul>";attachEditor+=" <div id=\"bd-customcss-detach-controls-buttons\">";attachEditor+=" <button class=\"btn btn-primary\" id=\"bd-customcss-detached-update\" onclick=\"return false;\">Update<\/button>";attachEditor+=" <button class=\"btn btn-primary\" id=\"bd-customcss-detached-save\" onclick=\"return false;\">Save<\/button>";attachEditor+=" <button class=\"btn btn-primary\" id=\"bd-customcss-detached-detach\" onclick=\"customCssEditor.detach(); return false;\">Detach</button>";attachEditor+=" <\/div>";attachEditor+="<\/div>";this.attachEditor=attachEditor;$("#bd-customcss-innerpane").append(attachEditor);$("#bd-customcss-detached-update").on("click",function(){self.applyCustomCss(self.editor.getValue(),!0,!1);return!1});$("#bd-customcss-detached-save").on("click",function(){self.applyCustomCss(self.editor.getValue(),!1,!0);return!1});var detachEditor="";detachEditor+="<div id=\"bd-customcss-detach-container\">";detachEditor+=" <div id=\"bd-customcss-detach-editor\">";detachEditor+=" <\/div>";detachEditor+="<\/div>";this.detachedEditor=detachEditor};CustomCssEditor.prototype.attach=function(){$("#editor-detached").hide();$("#app-mount").removeClass("bd-detached-editor");$("#bd-customcss-pane").append($("#bd-customcss-innerpane"));$("#bd-customcss-detached-detach").show();$("#bd-customcss-detach-container").remove()};CustomCssEditor.prototype.detach=function(){var self=this;this.attach();$("#editor-detached").show();$("#bd-customcss-detached-detach").hide();$("#app-mount").addClass("bd-detached-editor");$(".app").parent().append(this.detachedEditor);$("#bd-customcss-detach-editor").append($("#bd-customcss-innerpane"))};CustomCssEditor.prototype.applyCustomCss=function(css,forceupdate,forcesave){if($("#customcss").length==0){$("head").append('<style id="customcss"></style>')}
if(forceupdate||settingsCookie["bda-css-0"]){$("#customcss").html(css)}
if(forcesave){window.bdStorage.set("bdcustomcss",btoa(css))}};var settingsButton=null;var panel=null;function SettingsPanel(){utils.injectJs("https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.25.0/codemirror.min.js");utils.injectJs("https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.25.0/mode/css/css.min.js");utils.injectJs("https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.25.0/addon/scroll/simplescrollbars.min.js");utils.injectCss("https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.25.0/addon/scroll/simplescrollbars.min.css");utils.injectCss("https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.25.0/theme/material.min.css");utils.injectJs("https://cdnjs.cloudflare.com/ajax/libs/Sortable/1.4.2/Sortable.min.js")}
SettingsPanel.prototype.init=function(){var self=this;self.v2SettingsPanel=new V2_SettingsPanel();self.construct();var body=$("body");if(settingsCookie["bda-es-0"]){$("#twitchcord-button-container").show()}else{$("#twitchcord-button-container").hide()}
if(settingsCookie["bda-gs-2"]){body.addClass("bd-minimal")}else{body.removeClass("bd-minimal")}
if(settingsCookie["bda-gs-3"]){body.addClass("bd-minimal-chan")}else{body.removeClass("bd-minimal-chan")}
if(settingsCookie["bda-gs-4"]){voiceMode.enable()}
if(settingsCookie["bda-gs-5"]){$("#app-mount").addClass("bda-dark")}
if(settingsCookie["bda-es-6"]){emoteNamePopup=$("<div class='tipsy tipsy-se' style='display: block; top: 82px; left: 1630.5px; visibility: visible; opacity: 0.8;'><div class='tipsy-inner'></div></div>");$(document).on("mouseover",".emote",function(){var x=$(this).offset();var title=$(this).attr("alt");$(emoteNamePopup).find(".tipsy-inner").text(title);$(emoteNamePopup).css('left',x.left-25);$(emoteNamePopup).css('top',x.top-37);$(".app").append($(emoteNamePopup))});$(document).on("mouseleave",".emote",function(){$(".tipsy").remove()})}else{$(document).off('mouseover','.emote')}
if(settingsCookie["bda-gs-8"]){dMode.enable()}else{dMode.disable()}
if(settingsCookie["bda-gs-b"]){$("body").addClass("bd-blue")}else{$("body").removeClass("bd-blue")}};var customCssInitialized=!1;var lastTab="";SettingsPanel.prototype.changeTab=function(tab){var self=this;lastTab=tab;var controlGroups=$("#bd-control-groups");$(".bd-tab").removeClass("selected");$(".bd-pane").hide();$("#"+tab).addClass("selected");$("#"+tab.replace("tab","pane")).show();switch(tab){case "bd-settings-tab":$(".bda-slist-top").show();break;case "bd-emotes-tab":$(".bda-slist-top").show();break;case "bd-customcss-tab":$(".bda-slist-top").show();if(!customCssInitialized){customCssEditor.init();customCssInitialized=!0}
break;case "bd-themes-tab":$(".bda-slist-top:first").hide();break;case "bd-plugins-tab":$(".bda-slist-top:first").hide();break;default:$(".bda-slist-top").show();break}};SettingsPanel.prototype.updateSetting=function(checkbox){var cb=$(checkbox).children().find('input[type="checkbox"]');var enabled=!cb.is(":checked");var id=cb.attr("id");cb.prop("checked",enabled);if(id=="bda-css-2"){$("#app-mount").removeClass("bd-hide-bd");customCssEditor.hideBackdrop=enabled;if(enabled){$("#app-mount").addClass("bd-hide-bd")}}
if(id=="bda-gs-8"&&enabled){mainCore.alert("Developer Mode Enabled","Use F8 to break/resume execution<br>More coming soon")}
settingsCookie[id]=enabled;this.updateSettings()};SettingsPanel.prototype.updateSettings=function(){if(settingsCookie["bda-es-0"]){$("#twitchcord-button-container").show()}else{$("#twitchcord-button-container").hide()}
if(settingsCookie["bda-gs-b"]){$("body").addClass("bd-blue")}else{$("body").removeClass("bd-blue")}
if(settingsCookie["bda-gs-2"]){$("body").addClass("bd-minimal")}else{$("body").removeClass("bd-minimal")}
if(settingsCookie["bda-gs-3"]){$("body").addClass("bd-minimal-chan")}else{$("body").removeClass("bd-minimal-chan")}
if(settingsCookie["bda-gs-1"]){$("#bd-pub-li").show()}else{$("#bd-pub-li").hide()}
if(settingsCookie["bda-gs-4"]){voiceMode.enable()}else{voiceMode.disable()}
$("#app-mount").removeClass("bda-dark");if(settingsCookie["bda-gs-5"]){$("#app-mount").addClass("bda-dark")}
if(settingsCookie["bda-es-6"]){emoteNamePopup=$("<div class='tipsy tipsy-se' style='display: block; top: 82px; left: 1630.5px; visibility: visible; opacity: 0.8;'><div class='tipsy-inner'></div></div>");$(document).on("mouseover",".emote",function(){var x=$(this).offset();var title=$(this).attr("alt");$(emoteNamePopup).find(".tipsy-inner").text(title);$(emoteNamePopup).css('left',x.left-25);$(emoteNamePopup).css('top',x.top-32);$("div[data-reactid='.0.1.1']").append($(emoteNamePopup))});$(document).on("mouseleave",".emote",function(){$(".tipsy").remove()})}else{$(document).off('mouseover','.emote')}
if(settingsCookie["bda-gs-8"]){dMode.enable()}else{dMode.disable()}
mainCore.saveSettings()};SettingsPanel.prototype.construct=function(){var self=this;panel=$("<div/>",{id:"bd-pane",class:"settings-inner",css:{"display":"none"}});var settingsInner='\
<div class="scroller-wrap">\
<div class="scroller settings-wrapper settings-panel">\
<div class="tab-bar TOP">\
<div class="tab-bar-item bd-tab" id="bd-settings-tab" onclick=\'settingsPanel.changeTab("bd-settings-tab");\'>Core\
</div>\
<div class="tab-bar-item bd-tab" id="bd-emotes-tab" onclick=\'settingsPanel.changeTab("bd-emotes-tab");\'>Emotes\
</div>\
<div class="tab-bar-item bd-tab" id="bd-customcss-tab" onclick=\'settingsPanel.changeTab("bd-customcss-tab");\'>Custom CSS\
</div>\
<div class="tab-bar-item bd-tab" id="bd-plugins-tab" onclick=\'settingsPanel.changeTab("bd-plugins-tab");\'>Plugins\
</div>\
<div class="tab-bar-item bd-tab" id="bd-themes-tab" onclick=\'settingsPanel.changeTab("bd-themes-tab");\'>Themes\
</div>\
<div class="bda-slist-top">\
<button class="btn btn-primary" onclick="utils.exportSettings(); return false;">Export</button>\
<button class="btn btn-primary" onclick="utils.importSettings(); return false;">Import</button>\
</div>\
</div>\
<div class="bd-settings">\
<div class="bd-pane control-group" id="bd-settings-pane" style="display:none;">\
<ul class="checkbox-group">\
';for(var setting in settings){var sett=settings[setting];var id=sett.id;if(sett.cat!="core"||!sett.implemented||sett.hidden)continue;settingsInner+='\
<li>\
<div class="checkbox" onclick="settingsPanel.updateSetting(this);">\
<div class="checkbox-inner">\
<input type="checkbox" id="'+id+'" '+(settingsCookie[id]?"checked":"")+'>\
<span></span>\
</div>\
<span>\
'+setting+' - '+sett.info+'\
</span>\
</div>\
</li>\
'}
settingsInner+='\
</ul>\
</div>\
';settingsInner+='\
<div class="bd-pane control-group" id="bd-emotes-pane" style="display:none;">\
<ul class="checkbox-group">\
';for(var setting in settings){var sett=settings[setting];var id=sett.id;if(sett.cat!="emote"||!sett.implemented||sett.hidden)continue;settingsInner+='\
<li>\
<div class="checkbox" onclick="settingsPanel.updateSetting(this);">\
<div class="checkbox-inner">\
<input type="checkbox" id="'+id+'" '+(settingsCookie[id]?"checked":"")+'>\
<span></span>\
</div>\
<span>\
'+setting+' - '+sett.info+'\
</span>\
</div>\
</li>\
'}
settingsInner+='\
</ul>\
</div>\
';var _ccss=window.bdStorage.get("bdcustomcss");var ccss="";if(_ccss!==null&&_ccss!==""){ccss=atob(_ccss)}
customCssEditor.applyCustomCss(ccss,!0,!1);settingsInner+='\
<div class="bd-pane control-group" id="bd-customcss-pane" style="display:none;">\
<div id="editor-detached" style="display:none;">\
<h3>Editor Detached</h3>\
<button class="btn btn-primary" onclick="customCssEditor.attach(); return false;">Attach</button>\
</div>\
<div id="bd-customcss-innerpane">\
<textarea id="bd-custom-css-ta">'+ccss+'</textarea>\
</div>\
</div>\
';settingsInner+='\
<div class="bd-pane control-group" id="bd-plugins-pane" style="display:show;">\
<div class="bda-slist-top">\
<button class="btn btn-primary" onclick=\'betterDiscordIPC.send("asynchronous-message", { "arg": "opendir", "path": "plugindir" }); return false;\'>Open Plugin Folder</button>\
<button class="btn btn-primary" onclick=\'window.open("https://betterdiscord.net/plugins"); return false;\'>Get Plugins</button>\
</div>\
<ul class="bda-slist">\
';$.each(bdplugins,function(){var plugin=this["plugin"];var hasSettings=!1;if(typeof(plugin.getSettingsPanel)=="function"){hasSettings=plugin.getSettingsPanel()!=null&&plugin.getSettingsPanel()!=""}
settingsInner+='\
<li>\
<div class="bda-left">\
<span class="bda-name">'+plugin.getName()+' v'+plugin.getVersion()+' by '+plugin.getAuthor()+'</span>\
<div class="scroller-wrap fade">\
<div class="scroller bda-description">'+plugin.getDescription()+'</div>\
</div>\
</div>\
<div class="bda-right">\
<div class="checkbox" onclick="pluginModule.handlePlugin(this);">\
<div class="checkbox-inner">\
<input id="'+plugin.getName().replace(" ","__")+'" type="checkbox" '+(pluginCookie[plugin.getName()]?"checked":"")+'>\
<span></span>\
</div>\
<span></span>\
</div>\
<button class="btn btn-primary bda-plugin-reload" onclick="return false;" disabled>Reload</button>\
<button class="btn btn-primary bda-plugin-settings" onclick=\'pluginModule.showSettings("'+plugin.getName()+'"); return false;\' '+(hasSettings?"":"disabled")+'>Settings</button>\
</div>\
</li>\
'});settingsInner+='\
</ul>\
</div>\
';settingsInner+='\
<div class="bd-pane control-group" id="bd-themes-pane" style="display:none;">\
<div class="bda-slist-top">\
<button class="btn btn-primary" onclick=\'betterDiscordIPC.send("asynchronous-message", { "arg": "opendir", "path": "themedir" }); return false;\'>Open Theme Folder</button>\
<button class="btn btn-primary" onclick=\'window.open("https://betterdiscord.net/themes"); return false;\'>Get Themes</button>\
</div>\
<ul class="bda-slist">\
';if(typeof(themesupport2)==="undefined"){settingsInner+="Your version does not support themes!"}else{$.each(bdthemes,function(){settingsInner+='\
<li>\
<div class="bda-left">\
<span class="bda-name">'+this["name"].replace(/_/g," ")+' v'+this["version"]+' by '+this["author"]+'</span>\
<div class="scroller-wrap fade">\
<div class="scroller bda-description">'+this["description"]+'</div>\
</div>\
</div>\
<div class="bda-right">\
<div class="checkbox" onclick="themeModule.handleTheme(this);">\
<div class="checkbox-inner">\
<input id="ti'+this["name"]+'" type="checkbox" '+(themeCookie[this["name"]]?"checked":"")+'>\
<span></span>\
</div>\
<span></span>\
</div>\
<button class="btn btn-primary bda-plugin-reload" onclick="return false;" disabled>Reload</button>\
</div>\
</li>\
'})}
settingsInner+='\
</ul>\
</div>\
';settingsInner+='\
<div style="background:#2E3136; color:#ADADAD; height:30px; position:absolute; bottom:0; left:0; right:0;">\
<span style="line-height:30px;margin-left:10px;">BetterDiscord v'+((typeof(version)=="undefined")?bdVersion:version)+'(JSv'+jsVersion+') by Jiiks</span>\
<span style="float:right;line-height:30px;margin-right:10px;"><a href="http://betterdiscord.net" target="_blank">BetterDiscord.net</a></span>\
<span id="bd-changelog" onclick=\'$("body").append(mainCore.constructChangelog());\'>changelog</span>\
</div>\
</div></div>\
';function showSettings(){$(".tab-bar-item").removeClass("selected");settingsButton.addClass("selected");$(".form .settings-right .settings-inner").first().hide();panel.show();if(lastTab==""){self.changeTab("bd-settings-tab")}else{self.changeTab(lastTab)}}
settingsButton=$("<div/>",{class:"tab-bar-item",text:"BetterDiscord",id:"bd-settings-new",click:showSettings});panel.html(settingsInner);this.panel=panel};SettingsPanel.prototype.inject=function(mutation){if(this.injectNew(mutation))return;if(mutation.type!="childList")return;if(mutation.addedNodes.length<=0)return;if($(mutation.addedNodes[0]).find(".user-settings-modal").length<=0)return;var self=this;this.panel.hide();var tabBar=$(".tab-bar.SIDE").first();$(".tab-bar.SIDE .tab-bar-item").click(function(){$(".form .settings-right .settings-inner").first().show();$("#bd-settings-new").removeClass("selected");self.panel.hide()});tabBar.append(settingsButton);$(".form .settings-right .settings-inner").last().after(self.panel);$("#bd-settings-new").removeClass("selected")};SettingsPanel.prototype.injectNew=function(mutation){let self=this;if(!mutation.target.classList.contains("layers"))return;if($(".guild-settings-base-section").length){try{mutation.addedNodes[0].setAttribute('layer-id','server-settings')}catch(err){}}
if(!$(".user-settings-account").length)return;try{mutation.addedNodes[0].setAttribute('layer-id','user-settings')}catch(err){}
if($("#bd-settings-sidebar").length)return;self.v2SettingsPanel.renderSidebar();return!0};SettingsPanel.prototype.versionInfo=function(){let self=this;let element=$("<div/>",{class:'bd-versioninfo-wrapper'}).append($("<span/>",{text:`BetterDiscord v${(typeof(version) === "undefined" ? bdVersion : version)}:${jsVersion} by `})).append($("<a/>",{text:'Jiiks',href:'https://google.com',target:'_blank'}));return element}
SettingsPanel.prototype.tabBarNew=function(){let self=this;let _tabBar=$("<div/>",{class:'tab-bar TOP',style:'border-bottom:none'});let items=[{'id':'bd-core','text':'Core'},{'id':'bd-emotes','text':'Emotes'},{'id':'bd-customcss','text':'Custom CSS'},{'id':'bd-plugins','text':'Plugins'},{'id':'bd-themes','text':'Themes'}];items.map(value=>{_tabBar.append($("<div/>",{class:'tab-bar-item bd-tab',text:value.text,id:value.id,click:()=>self.changeTabNew(value.id)}))});return _tabBar}
SettingsPanel.prototype.changeTabNew=function(id){$(".bd-tab").removeClass("selected");$(`#${id}`).addClass("selected");$(".bd-pane").hide();$(`#${id}-pane`).show();if(id==='bd-customcss'){if(!customCssInitialized){customCssEditor.init();customCssInitialized=!0}}}
SettingsPanel.prototype.updateSettingNew=function(id,checked){if(id=="bda-css-2"){$("#app-mount").removeClass("bd-hide-bd");customCssEditor.hideBackdrop=checked;if(checked){$("#app-mount").addClass("bd-hide-bd")}}
if(id=="bda-gs-8"&&checked){mainCore.alert("Developer Mode Enabled","Use F8 to break/resume execution<br>More coming soon")}
settingsCookie[id]=checked;this.updateSettings()};SettingsPanel.prototype.settingsSwitch=function(key){let self=this;let setting=settings[key];return $("<div/>",{class:'ui-flex flex-vertical flex-justify-start flex-align-stretch flex-nowrap ui-switch-item'}).append($("<div/>",{class:'ui-flex flex-horizontal flex-justify-start flex-align-stretch flex-nowrap'}).append($("<h3/>",{class:'ui-form-title h3 margin-reset margin-reset ui-flex-child',text:key})).append($("<label/>",{class:'ui-switch-wrapper ui-flex-child',style:'flex: 0 0 auto'}).append($("<input/>",{class:'ui-switch-checkbox',type:'checkbox',change:function(){self.updateSettingNew(setting.id,this.checked)},checked:settingsCookie[setting.id]})).append($("<div/>",{class:'ui-switch'})))).append($("<div/>",{class:'ui-form-text style-description margin-top-4',style:'flex: 1 1 auto',text:setting.info}))}
SettingsPanel.prototype.corePaneNew=function(){let self=this;let _pane=$("<div/>",{class:'ui-form-item bd-pane',id:'bd-core-pane',style:'display:none'});Object.keys(settings).map(value=>{let setting=settings[value];if(setting.cat!=='core'||!setting.implemented||setting.hidden)return!1;_pane.append(self.settingsSwitch(value))});return _pane}
SettingsPanel.prototype.emotesPaneNew=function(){let self=this;let _pane=$("<div/>",{class:'ui-form-item bd-pane',id:'bd-emotes-pane',style:'display:none'});Object.keys(settings).map(value=>{let setting=settings[value];if(setting.cat!=='emote'||!setting.implemented||setting.hidden)return!1;_pane.append(self.settingsSwitch(value))});return _pane}
SettingsPanel.prototype.customCssPaneNew=function(){let self=this;let _pane=$("<div/>",{class:'ui-form-item bd-pane',id:'bd-customcss-pane',style:'display:none'});let attachBtn=$("<div/>",{id:'editor-detached',style:'display:none'}).append($("<h3/>",{text:'Editor Detached'})).append($("<button/>",{class:'btn btn-primary',text:'Attach',click:()=>{customCssEditor.attach()}}));_pane.append(attachBtn);let _ccss=window.bdStorage.get("bdcustomcss");let ccss="";if(_ccss!==null&&_ccss!==""){ccss=atob(_ccss)}
let innerPane=$("<div/>",{id:'bd-customcss-innerpane'}).append($("<textarea/>",{id:'bd-custom-css-ta',text:ccss}));_pane.append(innerPane);return _pane}
SettingsPanel.prototype.pluginTemp=function(plugin,cb){let item=$("<li/>",{}).append($("<div/>",{class:'bda-left'}).append($("<span/>",{class:'bda-name',text:`${plugin.getName()} v${plugin.getVersion()} by ${plugin.getAuthor()}`})).append($("<div/>",{class:'scroller-wrap fade'}).append($("<div/>",{class:'scroller bda-description',text:plugin.getDescription()})))).append($("<div/>",{class:'bda-right'}).append($("<label/>",{class:'ui-switch-wrapper ui-flex-child',style:'flex: 0 0 auto'}).append($("<input/>",{class:'ui-switch-checkbox',type:'checkbox',change:function(){pluginModule.handlePluginT(plugin.getName(),this.checked)},checked:pluginCookie[plugin.getName()]})).append($("<div/>",{class:'ui-switch'}))).append($("<button/>",{text:'Reload',disabled:!0,enabled:!1,click:()=>{return!1}})).append($("<button/>",{text:'Settings',click:()=>{pluginModule.showSettingsT(plugin.getName())}})));return item}
SettingsPanel.prototype.pluginsPaneNew=function(){let self=this;let list=$("<ul/>",{class:'bda-slist'});$.each(bdplugins,function(){let plugin=this["plugin"];list.append(self.pluginTemp(plugin))});return $("<div/>",{class:'ui-form-item bd-pane',id:'bd-plugins-pane',style:'display:none'}).append(list)}
SettingsPanel.prototype.themeTemp=function(theme){let item=$("<li/>",{}).append($("<div/>",{class:'bda-left'}).append($("<span/>",{class:'bda-name',text:`${theme["name"].replace(/_/g, " ")} v${theme["version"]} by ${theme["author"]}`})).append($("<div/>",{class:'scroller-wrap fade'}).append($("<div/>",{class:'scroller bda-description',text:theme.description})))).append($("<div/>",{class:'bda-right'}).append($("<label/>",{class:'ui-switch-wrapper ui-flex-child',style:'flex: 0 0 auto'}).append($("<input/>",{class:'ui-switch-checkbox',type:'checkbox',change:function(){themeModule.handleThemeT(theme.name,this.checked)},checked:themeCookie[theme.name]})).append($("<div/>",{class:'ui-switch'}))).append($("<button/>",{text:'Reload',disabled:!0,enabled:!1,click:()=>{return!1}})));return item}
SettingsPanel.prototype.themesPaneNew=function(){let self=this;let list=$("<ul/>",{class:'bda-slist'});$.each(bdthemes,function(){let theme=this;list.append(self.themeTemp(theme))});return $("<div/>",{class:'ui-form-item bd-pane',id:'bd-themes-pane',style:'display:none'}).append(list)}
SettingsPanel.prototype.panesNew=function(){let self=this;let _panes=$("<div/>",{class:'bd-settings-panes'});_panes.append(self.corePaneNew());_panes.append(self.emotesPaneNew());_panes.append(self.customCssPaneNew());_panes.append(self.pluginsPaneNew());_panes.append(self.themesPaneNew());return _panes}
SettingsPanel.prototype.settingsPaneNew=function(){let self=this;if(self.constructed)return self.constructed;let tools=$(".tools").clone();tools.find(".btn-close").on("click",()=>{$(".tools").first().find(".btn-close").click()});self.constructed=$("<div/>",{class:'content-region',id:'bd-settingspane',style:'display:none'}).append($("<div/>",{class:'scroller-wrap fade dark'}).append($("<div/>",{class:'scroller'}).append($("<div/>",{class:'content-column'}).append(self.tabBarNew()).append(self.panesNew())).append(tools)));return self.constructed};SettingsPanel.prototype.showBdSettingsPane=function(){$(".ui-standard-sidebar-view .content-region").first().hide();$("#bd-settingspane").show()};SettingsPanel.prototype.hideBdSettingsPane=function(){$(".ui-standard-sidebar-view .content-region").first().show();$("#bd-settingspane").hide()};var _hash;function Utils(){}
Utils.prototype.getTextArea=function(){return $(".channel-textarea-inner textarea")};Utils.prototype.jqDefer=function(fnc){if(window.jQuery){fnc()}else{setTimeout(function(){this.jqDefer(fnc)},100)}};Utils.prototype.getHash=function(){$.getJSON("https://api.github.com/repos/Jiiks/BetterDiscordApp/commits/master",function(data){_hash=data.sha;emoteModule.getBlacklist()})};Utils.prototype.loadHtml=function(html,callback){var container=$("<div/>",{class:"bd-container"}).appendTo("body");html='//cdn.rawgit.com/Jiiks/BetterDiscordApp/'+_hash+'/html/'+html+'.html';container.load(html,callback())};Utils.prototype.injectJs=function(uri){$("<script/>",{type:"text/javascript",src:uri}).appendTo($("body"))};Utils.prototype.injectCss=function(uri){$("<link/>",{type:"text/css",rel:"stylesheet",href:uri}).appendTo($("head"))};Utils.prototype.log=function(message){console.log('%c[%cBetterDiscord%c] %c'+message+'','color: red;','color: #303030; font-weight:700;','color:red;','')};Utils.prototype.err=function(message){console.log('%c[%cBetterDiscord%c] %c'+message+'','color: red;','color: red; font-weight:700;','color:red;','')};Utils.prototype.importSettings=function(){mainCore.alert("Import Settings",'<div class="form" style="width:100%;"><div class="control-group"><textarea id="bda-import-textarea" style="min-height:150px;"></textarea></div><button id="bda-import-settings" class="btn btn-primary">Import</button></div>');$("#bda-import-settings").off("click").on("click",function(){var obj;try{obj=JSON.parse($("#bda-import-textarea").val())}catch(err){mainCore.alert("Invalid Data",err);return!1}
try{for(key in obj.settings){var val=obj.settings[key];if(settingsCookie.hasOwnProperty(key)){settingsCookie[key]=val;var cb=$("#"+key);cb.prop("checked",val);settingsPanel.updateSettings()}}
window.bdStorage.set("bdcustomcss",obj.customCss);var ccss=window.bdStorage.get("bdcustomcss");if(!customCssInitialized){customCssEditor.init();customCssInitialized=!0}
customCssEditor.applyCustomCss(ccss,settingsCookie["bda-css-0"],!1);customCssEditor.editor.setValue(ccss)}catch(err){mainCore.alert("Invalid Data",err);return!1}
try{$.each(obj.plugins,function(plugin){var enabled=obj.plugins[plugin];if(bdplugins.hasOwnProperty(plugin)){pluginCookie[plugin]=enabled;var cb=$("#"+plugin.replace(" ","__"));if(cb.is(":checked")&&!enabled){bdplugins[plugin].plugin.stop();cb.prop("checked",!1)}
if(!cb.is(":checked")&&enabled){bdplugins[plugin].plugin.start();cb.prop("checked",!0)}}});pluginModule.savePluginData()}catch(err){mainCore.alert("Failed to load plugin data",err);return!1}
try{themeCookie=obj.themes;$.each(themeCookie,function(theme){var enabled=themeCookie[theme];var id="#ti"+theme;if(bdthemes.hasOwnProperty(theme)){if($(id).is(":checked")&&!enabled){$(id).prop("checked",!1);$("#"+theme).remove()}
if(!$(id).is(":checked")&&enabled){$(id).prop("checked",!0);$("head").append('<style id="'+theme+'">'+unescape(bdthemes[theme].css)+'</style>')}}});themeModule.saveThemeData()}catch(err){mainCore.alert("Failed to load theme data",err);return!1}
return!1})};Utils.prototype.exportSettings=function(){var obj={settings:settingsCookie,customCss:window.bdStorage.get("bdcustomcss"),plugins:pluginCookie,themes:themeCookie,favEmotes:window.bdStorage.get("bdfavemotes")};mainCore.alert("Export Settings",'<div class="form" style="width:100%;"><div class="control-group"><textarea style="min-height:150px;">'+JSON.stringify(obj)+'</textarea></div></div>')};Utils.prototype.addBackdrop=function(target){var backDrop=$("<div/>",{class:"bda-backdrop","data-bdbackdrop":target,mouseup:function(){$('[data-bdalert="'+target+'"]').remove();$(this).remove()}});$("#app-mount").append(backDrop)};Utils.prototype.removeBackdrop=function(target){$('[data-bdbackdrop="'+target+'"]').remove()};function VoiceMode(){}
VoiceMode.prototype.obsCallback=function(){var self=this;if(settingsCookie["bda-gs-4"]){self.disable();setTimeout(function(){self.enable()},300)}};VoiceMode.prototype.enable=function(){$(".scroller.guild-channels ul").first().css("display","none");$(".scroller.guild-channels header").first().css("display","none");$(".app.flex-vertical").first().css("overflow","hidden");$(".chat.flex-vertical.flex-spacer").first().css("visibility","hidden").css("min-width","0px");$(".flex-vertical.channels-wrap").first().css("flex-grow","100000");$(".guild-header .btn.btn-hamburger").first().css("visibility","hidden")};VoiceMode.prototype.disable=function(){$(".scroller.guild-channels ul").first().css("display","");$(".scroller.guild-channels header").first().css("display","");$(".app.flex-vertical").first().css("overflow","");$(".chat.flex-vertical.flex-spacer").first().css("visibility","").css("min-width","");$(".flex-vertical.channels-wrap").first().css("flex-grow","");$(".guild-header .btn.btn-hamburger").first().css("visibility","")};var pluginCookie={};function PluginModule(){}
PluginModule.prototype.loadPlugins=function(){this.loadPluginData();$.each(bdplugins,function(){var plugin=this["plugin"];plugin.load();var name=plugin.getName();var enabled=!1;if(pluginCookie.hasOwnProperty(name)){enabled=pluginCookie[name]}else{pluginCookie[name]=!1}
if(enabled){plugin.start()}})};PluginModule.prototype.handlePlugin=function(checkbox){var cb=$(checkbox).children().find('input[type="checkbox"]');var enabled=!cb.is(":checked");var id=cb.attr("id").replace("__"," ");cb.prop("checked",enabled);if(enabled){bdplugins[id].plugin.start();pluginCookie[id]=!0}else{bdplugins[id].plugin.stop();pluginCookie[id]=!1}
this.savePluginData()};PluginModule.prototype.handlePluginT=function(id,enabled){if(enabled){bdplugins[id].plugin.start();pluginCookie[id]=!0}else{bdplugins[id].plugin.stop();pluginCookie[id]=!1}
this.savePluginData()};PluginModule.prototype.showSettings=function(plugin){if(bdplugins[plugin]!=null){if(typeof bdplugins[plugin].plugin.getSettingsPanel==="function"){var panel=bdplugins[plugin].plugin.getSettingsPanel();$(".modal-inner").off("click.bdpsm").on("click.bdpsm",function(e){if($("#bd-psm-id").length){$(".bd-psm").remove()}else{$(".bd-psm").attr("id","bd-psm-id")}});$(".modal").append('<div class="bd-psm"><div class="scroller-wrap" style="height:100%"><div id="bd-psm-s" class="scroller" style="padding:10px;"></div></div></div>');$("#bd-psm-s").append(panel)}}};PluginModule.prototype.showSettingsT=function(plugin){if(bdplugins[plugin]===null)return;if(typeof bdplugins[plugin].plugin.getSettingsPanel!=="function")return;$("#bd-settingspane").off("click.bdpsm").on("click.bdpsm",function(e){if(e.target.id==='bd-psm-s')return;if(e.target.textContent&&e.target.textContent==='Settings')return;$(".bd-psm").remove()});let panel=bdplugins[plugin].plugin.getSettingsPanel();$(".bd-settings-panes").append('<div class="bd-psm"><div class="scroller-wrap" style="height:100%"><div id="bd-psm-s" class="scroller" style="padding:10px;"></div></div></div>');$("#bd-psm-s").append(panel)}
PluginModule.prototype.loadPluginData=function(){var cookie=$.cookie("bd-plugins");if(cookie!=undefined){pluginCookie=JSON.parse($.cookie("bd-plugins"))}};PluginModule.prototype.savePluginData=function(){$.cookie("bd-plugins",JSON.stringify(pluginCookie),{expires:365,path:'/'})};PluginModule.prototype.newMessage=function(){$.each(bdplugins,function(){if(!pluginCookie[this.plugin.getName()])return;if(typeof this.plugin.onMessage==="function"){this.plugin.onMessage()}})};PluginModule.prototype.channelSwitch=function(){$.each(bdplugins,function(){if(!pluginCookie[this.plugin.getName()])return;if(typeof this.plugin.onSwitch==="function"){this.plugin.onSwitch()}})};PluginModule.prototype.socketEvent=function(e,data){$.each(bdplugins,function(){if(!pluginCookie[this.plugin.getName()])return;if(typeof this.plugin.socketEvent==="function"){this.plugin.socketEvent(data)}})};PluginModule.prototype.rawObserver=function(e){$.each(bdplugins,function(){if(!pluginCookie[this.plugin.getName()])return;if(typeof this.plugin.observer==="function"){this.plugin.observer(e)}})};var themeCookie={};function ThemeModule(){}
ThemeModule.prototype.loadThemes=function(){this.loadThemeData();$.each(bdthemes,function(){var name=this["name"];var enabled=!1;if(themeCookie.hasOwnProperty(name)){if(themeCookie[name]){enabled=!0}}else{themeCookie[name]=!1}
if(enabled){$("head").append('<style id="'+name+'">'+unescape(bdthemes[name].css)+'</style>')}})};ThemeModule.prototype.handleTheme=function(checkbox){var cb=$(checkbox).children().find('input[type="checkbox"]');var enabled=!cb.is(":checked");var id=cb.attr("id").substring(2);cb.prop("checked",enabled);if(enabled){$("head").append('<style id="'+id+'">'+unescape(bdthemes[id].css)+'</style>');themeCookie[id]=!0}else{$("#"+id).remove();themeCookie[id]=!1}
this.saveThemeData()};ThemeModule.prototype.handleThemeT=function(id,enabled){if(enabled){$("head").append('<style id="'+id+'">'+unescape(bdthemes[id].css)+'</style>');themeCookie[id]=!0}else{$("#"+id).remove();themeCookie[id]=!1}
this.saveThemeData()};ThemeModule.prototype.loadThemeData=function(){var cookie=$.cookie("bd-themes");if(cookie!=undefined){themeCookie=JSON.parse($.cookie("bd-themes"))}};ThemeModule.prototype.saveThemeData=function(){$.cookie("bd-themes",JSON.stringify(themeCookie),{expires:365,path:'/'})};var bdSocket;var bdws;function BdWSocket(){bdws=this}
BdWSocket.prototype.start=function(){var self=this};BdWSocket.prototype.open=function(host){utils.log("Socket Host: "+host);try{bdSocket=new WebSocket(host);bdSocket.onopen=this.onOpen;bdSocket.onmessage=this.onMessage;bdSocket.onerror=this.onError;bdSocket.onclose=this.onClose}catch(err){utils.log(err)}};BdWSocket.prototype.onOpen=function(){utils.log("Socket Open");var data={op:2,d:{token:JSON.parse(window.bdStorage.get('token')),properties:JSON.parse(window.bdStorage.get('superProperties')),v:3}};bdws.send(data)};BdWSocket.prototype.onMessage=function(e){var packet,data,type;try{packet=JSON.parse(e.data);data=packet.d;type=packet.t}catch(err){utils.err(err);return}
switch(type){case "READY":bdSocket.interval=setInterval(function(){bdws.send({op:1,d:Date.now()})},data.heartbeat_interval);utils.log("Socket Ready");break;case "PRESENCE_UPDATE":pluginModule.socketEvent("PRESENCE_UPDATE",data);break;case "TYPING_START":pluginModule.socketEvent("TYPING_START",data);break;case "MESSAGE_CREATE":pluginModule.socketEvent("MESSAGE_CREATE",data);break;case "MESSAGE_UPDATE":pluginModule.socketEvent("MESSAGE_UPDATE",data);break;default:break}};BdWSocket.prototype.onError=function(e){utils.log("Socket Error - "+e.message)};BdWSocket.prototype.onClose=function(e){utils.log("Socket Closed - "+e.code+" : "+e.reason);clearInterval(bdSocket.interval);bdws.start()};BdWSocket.prototype.send=function(data){if(bdSocket.readyState==1){bdSocket.send(JSON.stringify(data))}};BdWSocket.prototype.getSocket=function(){return bdSocket};function BdApi(){}
BdApi.joinServer=function(code){opublicServers.joinServer(code)};BdApi.injectCSS=function(id,css){$("head").append('<style id="'+id+'"></style>');$("#"+id).html(css)};BdApi.clearCSS=function(id){$("#"+id).remove()};BdApi.getPlugin=function(name){if(bdplugins.hasOwnProperty(name)){return bdplugins[name].plugin}
return null};BdApi.getIpc=function(){return betterDiscordIPC};BdApi.getCore=function(){return mainCore};BdApi.getUserIdByName=function(name){var users=$(".member-username");for(var i=0;i<users.length;i++){var user=$(users[i]);if(user.text()==name){var avatarUrl=user.closest(".member").find(".avatar-small").css("background-image");return avatarUrl.match(/\d+/)}}
return null};var gg;BdApi.getUserNameById=function(id){var users=$(".avatar-small");for(var i=0;i<users.length;i++){var user=$(users[i]);var url=user.css("background-image");if(id==url.match(/\d+/)){return user.parent().find(".member-username").text()}}
return null};BdApi.setPlaying=function(game){bdws.send({"op":3,"d":{"idle_since":null,"game":{"name":game}}})};BdApi.setStatus=function(idle_since,status){bdws.send({"op":3,"d":{"idle_since":idle_since,"game":{"name":status}}})};function devMode(){}
devMode.prototype.enable=function(){var self=this;$(window).on("keydown.bdDevmode",function(e){if(e.which===119){console.log('%c[%cDM%c] %cBreak/Resume','color: red;','color: #303030; font-weight:700;','color:red;','');debugger}})};devMode.prototype.disable=function(){$(window).off("keydown.bdDevmode");$(window).off("mousedown.bdDevmode")};window.bdtemp={'editorDetached':!1};class V2{constructor(){this.internal={'react':require('react'),'react-dom':require('react-dom')}}
get reactComponent(){return this.internal.react.Component}
get react(){return this.internal.react}
get reactDom(){return this.internal['react-dom']}
parseSettings(cat){return Object.keys(settings).reduce((arr,key)=>{let setting=settings[key];if(setting.cat===cat&&setting.implemented&&!setting.hidden){setting.text=key;arr.push(setting)}return arr},[])}}
window.BDV2=new V2();class V2C_SettingsPanel extends BDV2.reactComponent{constructor(props){super(props)}
render(){let{settings}=this.props;return BDV2.react.createElement("div",{className:"content-column default"},BDV2.react.createElement(V2Components.SettingsTitle,{text:this.props.title}),settings.map(setting=>{return BDV2.react.createElement(V2Components.Switch,{id:setting.id,key:setting.id,data:setting,checked:settingsCookie[setting.id],onChange:(id,checked)=>{this.props.onChange(id,checked)}})}))}}
class V2C_Switch extends BDV2.reactComponent{constructor(props){super(props);this.setInitialState();this.onChange=this.onChange.bind(this)}
setInitialState(){this.state={'checked':this.props.checked}}
render(){let{text,info}=this.props.data;let{checked}=this.state;return BDV2.react.createElement("div",{className:"ui-flex flex-vertical flex-justify-start flex-align-stretch flex-nowrap ui-switch-item"},BDV2.react.createElement("div",{className:"ui-flex flex-horizontal flex-justify-start flex-align-stretch flex-nowrap"},BDV2.react.createElement("h3",{className:"ui-form-title h3 margin-reset margin-reset ui-flex-child"},text),BDV2.react.createElement("label",{className:"ui-switch-wrapper ui-flex-child",style:{flex:'0 0 auto'}},BDV2.react.createElement("input",{className:"ui-switch-checkbox",type:"checkbox",checked:checked,onChange:e=>this.onChange(e)}),BDV2.react.createElement("div",{className:"ui-switch"}))),BDV2.react.createElement("div",{className:"ui-form-text style-description margin-top-4",style:{flex:'1 1 auto'}},info))}
onChange(e){this.props.onChange(this.props.id,!this.state.checked);this.setState({'checked':!this.state.checked})}}
class V2C_Scroller extends BDV2.reactComponent{constructor(props){super(props)}
render(){let wrapperClass=`scroller-wrap${this.props.fade ? ' fade' : ''} ${this.props.dark ? ' dark' : ''}`;let{children}=this.props;return BDV2.react.createElement("div",{key:"scrollerwrap",className:wrapperClass},BDV2.react.createElement("div",{key:"scroller",ref:"scroller",className:"scroller"},children))}}
class V2C_TabBarItem extends BDV2.reactComponent{constructor(props){super(props);this.setInitialState();this.onClick=this.onClick.bind(this)}
setInitialState(){this.state={'selected':this.props.selected||!1}}
render(){return BDV2.react.createElement("div",{className:`ui-tab-bar-item${this.props.selected ? ' selected' : ''}`,onClick:this.onClick},this.props.text)}
onClick(){if(this.props.onClick){this.props.onClick(this.props.id)}}}
class V2C_TabBarSeparator extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("div",{className:"ui-tab-bar-separator margin-top-8 margin-bottom-8"})}}
class V2C_TabBarHeader extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("div",{className:"ui-tab-bar-header"},this.props.text)}}
class V2C_SideBar extends BDV2.reactComponent{constructor(props){super(props);let self=this;$('.ui-tab-bar-item').on('click',e=>{self.setState({'selected':null})});self.setInitialState();self.onClick=self.onClick.bind(self)}
setInitialState(){let self=this;self.state={'selected':null,'items':self.props.items};let initialSelection=self.props.items.find(item=>{return item.selected});if(initialSelection){self.state.selected=initialSelection.id}}
render(){let self=this;let{headerText}=self.props;let{items,selected}=self.state;return BDV2.react.createElement("div",null,BDV2.react.createElement(V2Components.TabBar.Separator,null),BDV2.react.createElement(V2Components.TabBar.Header,{text:headerText}),items.map(item=>{let{id,text}=item;return BDV2.react.createElement(V2Components.TabBar.Item,{key:id,selected:selected===id,text:text,id:id,onClick:self.onClick})}))}
onClick(id){let self=this;$('.ui-tab-bar-item').removeClass('selected');self.setState({'selected':id});if(self.props.onClick)self.props.onClick(id)}}
class V2C_XSvg extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 12 12",style:{width:"18px",height:"18px"}},BDV2.react.createElement("g",{className:"background",fill:"none","fill-rule":"evenodd"},BDV2.react.createElement("path",{d:"M0 0h12v12H0"}),BDV2.react.createElement("path",{className:"fill",fill:"#dcddde",d:"M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6"})))}}
class V2C_Tools extends BDV2.reactComponent{constructor(props){super(props);this.onClick=this.onClick.bind(this)}
render(){return BDV2.react.createElement("div",{className:"tools"},BDV2.react.createElement("div",{className:"btn-close",onClick:this.onClick},BDV2.react.createElement(V2Components.XSvg,null)),BDV2.react.createElement("div",{className:"esc-text"},"ESC"))}
onClick(){if(this.props.onClick){this.props.onClick()}
$(".btn-close").first().click()}}
class V2C_SettingsTitle extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("h2",{className:"ui-form-title h2 margin-reset margin-bottom-20"},this.props.text)}}
class V2C_Checkbox extends BDV2.reactComponent{constructor(props){super(props);this.onClick=this.onClick.bind(this);this.setInitialState()}
setInitialState(){this.state={'checked':this.props.checked||!1}}
render(){return BDV2.react.createElement("li",null,BDV2.react.createElement("div",{className:"checkbox",onClick:this.onClick},BDV2.react.createElement("div",{className:"checkbox-inner"},BDV2.react.createElement("input",{checked:this.state.checked,onChange:()=>{},type:"checkbox"}),BDV2.react.createElement("span",null)),BDV2.react.createElement("span",null,this.props.text)))}
onClick(){this.props.onChange(this.props.id,!this.state.checked);this.setState({'checked':!this.state.checked})}}
class V2C_CssEditorDetached extends BDV2.reactComponent{constructor(props){super(props);let self=this;self.onClick=self.onClick.bind(self);self.updateCss=self.updateCss.bind(self);self.saveCss=self.saveCss.bind(self);self.onChange=self.onChange.bind(self)}
componentDidMount(){let self=this;$("#app-mount").addClass('bd-detached-editor');self.editor=CodeMirror.fromTextArea(self.refs.editor,self.options);self.editor.on("change",cm=>{if(!settingsCookie["bda-css-0"])return;self.updateCss()});window.bdtemp.editorDetached=!0}
componentWillUnmount(){$("#app-mount").removeClass('bd-detached-editor');window.bdtemp.editorDetached=!1}
get options(){return{lineNumbers:!0,mode:'css',indentUnit:4,theme:'material',scrollbarStyle:'simple'}}
get css(){let _ccss=window.bdStorage.get("bdcustomcss");let ccss="";if(_ccss&&_ccss!==""){ccss=atob(_ccss)}
return ccss}
get root(){let _root=$("#bd-customcss-detach-container");if(!_root.length){if(!this.injectRoot())return null;return this.detachedRoot}
return _root[0]}
injectRoot(){if(!$(".app").length)return!1;$("<div/>",{id:'bd-customcss-detach-container'}).insertAfter($(".app"));return!0}
render(){let self=this;return BDV2.react.createElement("div",{className:"bd-detached-css-editor",id:"bd-customcss-detach-editor"},BDV2.react.createElement("div",{id:"bd-customcss-innerpane"},BDV2.react.createElement("textarea",{onChange:()=>{},value:self.css,ref:"editor",id:"bd-customcss-ta"}),BDV2.react.createElement("div",{id:"bd-customcss-attach-controls"},BDV2.react.createElement("ul",{className:"checkbox-group"},BDV2.react.createElement(V2Components.Checkbox,{id:"live-update",text:"Live Update",onChange:self.onChange,checked:settingsCookie["bda-css-0"]})),BDV2.react.createElement("div",{id:"bd-customcss-detach-controls-button"},BDV2.react.createElement("button",{style:{borderRadius:"3px 0 0 3px",borderRight:"1px solid #3f4146"},className:"btn btn-primary",onClick:()=>{self.onClick("update")}},"Update"),BDV2.react.createElement("button",{style:{borderRadius:"0",borderLeft:"1px solid #2d2d2d",borderRight:"1px solid #2d2d2d"},className:"btn btn-primary",onClick:()=>{self.onClick("save")}},"Save"),BDV2.react.createElement("button",{style:{borderRadius:"0 3px 3px 0",borderLeft:"1px solid #3f4146"},className:"btn btn-primary",onClick:()=>{self.onClick("attach")}},"Attach"),BDV2.react.createElement("span",{style:{fontSize:"10px",marginLeft:"5px"}},"Unsaved changes are lost on attach")))))}
onChange(id,checked){switch(id){case 'live-update':settingsCookie["bda-css-0"]=checked;mainCore.saveSettings();break}}
onClick(id){let self=this;switch(id){case 'attach':if($("#editor-detached").length)self.props.attach();BDV2.reactDom.unmountComponentAtNode(self.root);break;case 'update':self.updateCss();break;case 'save':self.saveCss();break}}
updateCss(){let self=this;if($("#customcss").length==0){$("head").append('<style id="customcss"></style>')}
$("#customcss").html(self.editor.getValue())}
saveCss(){let self=this;window.bdStorage.set("bdcustomcss",btoa(self.editor.getValue()))}}
class V2C_CssEditor extends BDV2.reactComponent{constructor(props){super(props);let self=this;self.setInitialState();self.attach=self.attach.bind(self);self.detachedEditor=BDV2.react.createElement(V2C_CssEditorDetached,{attach:self.attach});self.onClick=self.onClick.bind(self);self.updateCss=self.updateCss.bind(self);self.saveCss=self.saveCss.bind(self);self.detach=self.detach.bind(self);self.codeMirror=self.codeMirror.bind(self)}
setInitialState(){this.state={'detached':this.props.detached||window.bdtemp.editorDetached}}
componentDidMount(){let self=this;self.codeMirror()}
componentDidUpdate(prevProps,prevState){let self=this;if(prevState.detached&&!self.state.detached){BDV2.reactDom.unmountComponentAtNode(self.detachedRoot);self.codeMirror()}}
codeMirror(){let self=this;if(!self.state.detached){self.editor=CodeMirror.fromTextArea(self.refs.editor,self.options);self.editor.on("change",cm=>{if(!settingsCookie["bda-css-0"])return;self.updateCss()})}}
get options(){return{lineNumbers:!0,mode:'css',indentUnit:4,theme:'material',scrollbarStyle:'simple'}}
get css(){let _ccss=window.bdStorage.get("bdcustomcss");let ccss="";if(_ccss&&_ccss!==""){ccss=atob(_ccss)}
return ccss}
render(){let self=this;let{detached}=self.state;return BDV2.react.createElement("div",{className:"content-column default",style:{padding:'60px 40px 0px'}},detached&&BDV2.react.createElement("div",{id:"editor-detached"},BDV2.react.createElement(V2Components.SettingsTitle,{text:"Custom CSS Editor"}),BDV2.react.createElement("h3",null,"Editor Detached"),BDV2.react.createElement("button",{className:"btn btn-primary",onClick:()=>{self.attach()}},"Attach")),!detached&&BDV2.react.createElement("div",null,BDV2.react.createElement(V2Components.SettingsTitle,{text:"Custom CSS Editor"}),BDV2.react.createElement("textarea",{ref:"editor",value:self.css,onChange:()=>{}}),BDV2.react.createElement("div",{id:"bd-customcss-attach-controls"},BDV2.react.createElement("ul",{className:"checkbox-group"},BDV2.react.createElement(V2Components.Checkbox,{id:"live-update",text:"Live Update",onChange:this.onChange,checked:settingsCookie["bda-css-0"]})),BDV2.react.createElement("div",{id:"bd-customcss-detach-controls-button"},BDV2.react.createElement("button",{style:{borderRadius:"3px 0 0 3px",borderRight:"1px solid #3f4146"},className:"btn btn-primary",onClick:()=>{self.onClick("update")}},"Update"),BDV2.react.createElement("button",{style:{borderRadius:"0",borderLeft:"1px solid #2d2d2d",borderRight:"1px solid #2d2d2d"},className:"btn btn-primary",onClick:()=>{self.onClick("save")}},"Save"),BDV2.react.createElement("button",{style:{borderRadius:"0 3px 3px 0",borderLeft:"1px solid #3f4146"},className:"btn btn-primary",onClick:()=>{self.onClick("detach")}},"Detach"),BDV2.react.createElement("span",{style:{fontSize:"10px",marginLeft:"5px"}},"Unsaved changes are lost on detach")))))}
onClick(arg){let self=this;switch(arg){case 'update':self.updateCss();break;case 'save':self.saveCss();break;case 'detach':self.detach();break}}
onChange(id,checked){switch(id){case 'live-update':settingsCookie["bda-css-0"]=checked;mainCore.saveSettings();break}}
updateCss(){let self=this;if($("#customcss").length==0){$("head").append('<style id="customcss"></style>')}
$("#customcss").html(self.editor.getValue())}
saveCss(){let self=this;window.bdStorage.set("bdcustomcss",btoa(self.editor.getValue()))}
detach(){let self=this;self.setState({'detached':!0});let droot=self.detachedRoot;if(!droot){console.log("FAILED TO INJECT ROOT: .app");return}
BDV2.reactDom.render(self.detachedEditor,droot)}
get detachedRoot(){let _root=$("#bd-customcss-detach-container");if(!_root.length){if(!this.injectDetachedRoot())return null;return this.detachedRoot}
return _root[0]}
injectDetachedRoot(){if(!$(".app").length)return!1;$("<div/>",{id:'bd-customcss-detach-container'}).insertAfter($(".app"));return!0}
attach(){let self=this;self.setState({'detached':!1})}}
class V2C_List extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("ul",{className:this.props.className},this.props.children)}}
class V2C_ContentColumn extends BDV2.reactComponent{constructor(props){super(props)}
render(){return BDV2.react.createElement("div",{className:"content-column default"},BDV2.react.createElement("h2",{className:"ui-form-title h2 margin-reset margin-bottom-20"},this.props.title),this.props.children)}}
class V2C_PluginCard extends BDV2.reactComponent{constructor(props){super(props);let self=this;if(typeof self.props.plugin.getSettingsPanel==="function"){self.settingsPanel=self.props.plugin.getSettingsPanel()}
self.onChange=self.onChange.bind(self);self.showSettings=self.showSettings.bind(self);self.setInitialState()}
setInitialState(){this.state={'checked':pluginCookie[this.props.plugin.getName()],'settings':!1}}
componentDidUpdate(){if(this.state.settings){if(typeof this.settingsPanel==="object"){this.refs.settingspanel.appendChild(this.settingsPanel)}}}
render(){let self=this;let{plugin}=this.props;let name=plugin.getName();let author=plugin.getAuthor();let description=plugin.getDescription();let version=plugin.getVersion();let{settingsPanel}=this;if(this.state.settings){return BDV2.react.createElement("li",{style:{maxHeight:"500px",overflow:"auto"}},BDV2.react.createElement("div",{style:{float:"right",cursor:"pointer"},onClick:()=>{this.refs.settingspanel.innerHTML="";self.setState({'settings':!1})}},BDV2.react.createElement(V2Components.XSvg,null)),typeof settingsPanel==='object'&&BDV2.react.createElement("div",{ref:"settingspanel"}),typeof settingsPanel!=='object'&&BDV2.react.createElement("div",{ref:"settingspanel",dangerouslySetInnerHTML:{__html:plugin.getSettingsPanel()}}))}
return BDV2.react.createElement("li",null,BDV2.react.createElement("div",{className:"bda-left"},BDV2.react.createElement("span",{className:"bda-name"},name," v",version," by ",author),BDV2.react.createElement("div",{className:"scroller-wrap fade"},BDV2.react.createElement("div",{className:"scroller bda-description"},description))),BDV2.react.createElement("div",{className:"bda-right"},BDV2.react.createElement("label",{className:"ui-switch-wrapper ui-flex-child",style:{flex:'0 0 auto'}},BDV2.react.createElement("input",{checked:this.state.checked,onChange:this.onChange,className:"ui-switch-checkbox",type:"checkbox"}),BDV2.react.createElement("div",{className:"ui-switch"})),this.settingsPanel&&BDV2.react.createElement("button",{onClick:this.showSettings},"Settings")))}
onChange(){let self=this;self.setState({'checked':!self.state.checked});pluginCookie[self.props.plugin.getName()]=!self.state.checked;if(!self.state.checked){self.props.plugin.start()}else{self.props.plugin.stop()}
$.cookie("bd-plugins",JSON.stringify(pluginCookie),{expires:365,path:'/'})}
showSettings(){if(!this.settingsPanel)return;this.setState({'settings':!0})}}
class V2C_ThemeCard extends BDV2.reactComponent{constructor(props){super(props);this.setInitialState();this.onChange=this.onChange.bind(this)}
setInitialState(){this.state={'checked':themeCookie[this.props.theme.name]}}
render(){let{theme}=this.props;let name=theme.name.replace('_',' ');let description=theme.description;let version=theme.version;let author=theme.author;return BDV2.react.createElement("li",null,BDV2.react.createElement("div",{className:"bda-left"},BDV2.react.createElement("span",{className:"bda-name"},name," v",version," by ",author),BDV2.react.createElement("div",{className:"scroller-wrap fade"},BDV2.react.createElement("div",{className:"scroller bda-description"},description))),BDV2.react.createElement("div",{className:"bda-right"},BDV2.react.createElement("label",{className:"ui-switch-wrapper ui-flex-child",style:{flex:'0 0 auto'}},BDV2.react.createElement("input",{checked:this.state.checked,onChange:this.onChange,className:"ui-switch-checkbox",type:"checkbox"}),BDV2.react.createElement("div",{className:"ui-switch"}))))}
onChange(){let self=this;self.setState({'checked':!self.state.checked});themeCookie[self.props.theme.name]=!self.state.checked;if(!self.state.checked){$("head").append(`<style id="${self.props.theme.name}">${unescape(self.props.theme.css)}</style>`)}else{$(`#${self.props.theme.name}`).remove()}
$.cookie("bd-themes",JSON.stringify(themeCookie),{expires:365,path:'/'})}}
class V2Cs_TabBar{static get Item(){return V2C_TabBarItem}
static get Header(){return V2C_TabBarHeader}
static get Separator(){return V2C_TabBarSeparator}}
class V2C_Layer extends BDV2.reactComponent{constructor(props){super(props)}
componentDidMount(){$(window).on(`keyup.${this.props.id}`,e=>{if(e.which===27){BDV2.reactDom.unmountComponentAtNode(this.refs.root.parentNode)}})}
componentWillUnmount(){$(window).off(`keyup.${this.props.id}`);$(`#${this.props.rootId}`).remove()}
render(){return BDV2.react.createElement("div",{className:"layer",id:this.props.id,ref:"root"},this.props.children)}}
class V2C_SidebarView extends BDV2.reactComponent{constructor(props){super(props)}
render(){let{sidebar,content}=this.props.children;return BDV2.react.createElement("div",{className:"ui-standard-sidebar-view"},BDV2.react.createElement("div",{className:"sidebar-region"},BDV2.react.createElement(V2Components.Scroller,{key:"sidebarScroller",ref:"sidebarScroller",fade:sidebar.fade||!0,dark:sidebar.dark||!0,children:sidebar.component})),BDV2.react.createElement("div",{className:"content-region"},BDV2.react.createElement(V2Components.Scroller,{key:"contentScroller",ref:"contentScroller",fade:content.fade||!0,dark:content.dark||!0,children:content.component})))}}
class V2C_ServerCard extends BDV2.reactComponent{constructor(props){super(props)}
render(){let{server}=this.props;return BDV2.react.createElement("div",{className:`ui-card ui-card-primary bd-server-card${server.pinned ? ' bd-server-card-pinned' : ''}`,style:{marginTop:"5px"}},BDV2.react.createElement("div",{className:"ui-flex horizontal",style:{display:"flex",flexFlow:"row nowrap",justifyContent:"flex-start",alignItems:"stretch",flex:"1 1 auto"}},BDV2.react.createElement("div",{className:"ui-flex-child",style:{flex:"0 1 auto",padding:"5px"}},BDV2.react.createElement("div",{className:"bd-pubs-server-icon",style:{width:"100px",height:"100px",backgroundSize:"cover",backgroundImage:`url(${server.icon})`}})),BDV2.react.createElement("div",{className:"ui-flex-child",style:{flex:"1 1 auto",padding:"5px"}},BDV2.react.createElement("div",{className:"ui-flex horizontal"},BDV2.react.createElement("div",{className:"ui-form-item",style:{flex:"1 1 auto"}},BDV2.react.createElement("h5",{className:"ui-form-title h5 margin-reset"},server.name)),BDV2.react.createElement("div",{className:"ui-form-item"},BDV2.react.createElement("h5",{className:"ui-form-title h5 margin-reset"},server.online,"/",server.members," Members"))),BDV2.react.createElement("div",{className:"ui-flex horizontal"},BDV2.react.createElement("div",{className:"scroller-wrap fade dark",style:{minHeight:"60px",maxHeight:"60px",borderTop:"1px solid #3f4146",borderBottom:"1px solid #3f4146",paddingTop:"5px"}},BDV2.react.createElement("div",{className:"scroller"},BDV2.react.createElement("div",{style:{fontSize:"13px",color:"#b9bbbe"}},server.description)))),BDV2.react.createElement("div",{className:"ui-flex horizontal"},BDV2.react.createElement("div",{className:"ui-flex-child bd-server-tags",style:{flex:"1 1 auto"}},server.categories.join(', ')),server.joined&&BDV2.react.createElement("button",{type:"button",className:"ui-button filled brand small grow disabled",style:{minHeight:"12px",marginTop:"4px",backgroundColor:"#3ac15c"}},BDV2.react.createElement("div",{className:"ui-button-contents"},"Joined")),server.error&&BDV2.react.createElement("button",{type:"button",className:"ui-button filled brand small grow disabled",style:{minHeight:"12px",marginTop:"4px",backgroundColor:"#c13a3a"}},BDV2.react.createElement("div",{className:"ui-button-contents"},"Error")),!server.error&&!server.joined&&BDV2.react.createElement("button",{type:"button",className:"ui-button filled brand small grow",style:{minHeight:"12px",marginTop:"4px"},onClick:()=>{this.join(server.identifier)}},BDV2.react.createElement("div",{className:"ui-button-contents"},"Join"))))))}
join(id){let self=this;self.props.join(self.props.server)}}
class V2C_PublicServers extends BDV2.reactComponent{constructor(props){super(props);this.setInitialState();this.close=this.close.bind(this);this.changeCategory=this.changeCategory.bind(this);this.search=this.search.bind(this);this.searchKeyDown=this.searchKeyDown.bind(this);this.checkConnection=this.checkConnection.bind(this);this.join=this.join.bind(this);this.connect=this.connect.bind(this)}
componentDidMount(){this.checkConnection()}
setInitialState(){this.state={'selectedCategory':-1,'title':'Loading...','loading':!0,'servers':[],'next':null,'connection':{'state':0,'user':null}}}
close(){BDV2.reactDom.unmountComponentAtNode(document.getElementById(this.props.rootId))}
search(query,clear){let self=this;$.ajax({method:'GET',url:`${self.endPoint}${query}`,success:data=>{let servers=data.results.reduce((arr,server)=>{server.joined=!1;arr.push(server);return arr},[]);if(!clear){servers=self.state.servers.concat(servers)}else{}
let end=data.size+data.from;if(end>=data.total){end=data.total;data.next=null}
let title=`Showing 1-${end} of ${data.total} results in ${self.categoryButtons[self.state.selectedCategory]}`;if(self.state.term)title+=` for ${self.state.term}`;self.setState({'loading':!1,'title':title,'servers':servers,'next':data.next});if(clear){self.refs.sbv.refs.contentScroller.refs.scroller.scrollTop=0}},error:(jqXHR,textStatus,errorThrow)=>{self.setState({'loading':!1,'title':'Failed to load servers. Check console for details'});console.log(jqXHR)}})}
join(server){let self=this;if(self.state.loading)return;self.setState({'loading':!0});if(server.nativejoin){self.setState({'loading':!1});$(".guilds-add").click();$(".join .btn-primary").click();$(".join-server input").val(server.invitecode);return}
$.ajax({method:'GET',url:`${self.joinEndPoint}/${server.identifier}`,crossDomain:!0,xhrFields:{withCredentials:!0},success:data=>{let servers=self.state.servers;servers.map(s=>{if(s.identifier===server.identifier)server.joined=!0});self.setState({'loading':!1,'servers':servers})},error:jqXHR=>{console.log(`[BetterDiscord] Failed to join server ${server.name}. Reason: `);console.log(jqXHR);let servers=self.state.servers;servers.map(s=>{if(s.identifier===server.identifier)server.error=!0});self.setState({'loading':!1,'servers':servers})}})}
get bdServer(){let server={"name":"BetterDiscord","online":"7500+","members":"20000+","categories":["community","programming","support"],"description":"Official BetterDiscord server for support etc","identifier":"86004744966914048","icon":"https://cdn.discordapp.com/icons/86004744966914048/c8d49dc02248e1f55caeb897c3e1a26e.png","nativejoin":!0,"invitecode":"0Tmfo5ZbORCRqbAd","pinned":!0};return BDV2.react.createElement(V2Components.ServerCard,{server:server,pinned:!0,join:this.join})}
get endPoint(){return 'https://search.discordservers.com'}
get joinEndPoint(){return 'https://join.discordservers.com'}
get connectEndPoint(){return 'https://join.discordservers.com/connect'}
checkConnection(){let self=this;$.ajax({method:'GET',url:`${self.joinEndPoint}/session`,crossDomain:!0,xhrFields:{withCredentials:!0},success:data=>{self.setState({'selectedCategory':0,'connection':{'state':2,'user':data}});self.search("",!0)},error:jqXHR=>{if(jqXHR.status===403){self.setState({'title':'Not connected to discordservers.com!','loading':!0,'selectedCategory':-1,'connection':{'state':1,'user':null}});return}
console.log(jqXHR)}})}
get windowOptions(){return{width:520,height:710,backgroundColor:'#282b30',show:!0,resizable:!1,maximizable:!1,minimizable:!1,alwaysOnTop:!0,frame:!1,center:!1}}
connect(){let self=this;let options=self.windowOptions;options.x=Math.round(window.screenX+window.innerWidth/2-options.width/2);options.y=Math.round(window.screenY+window.innerHeight/2-options.height/2);self.joinWindow=new(window.require('electron').remote.BrowserWindow)(options);let sub=window.location.hostname.split('.')[0];let url=self.connectEndPoint+(sub==='canary'||sub==='ptb'?`/${sub}`:'');self.joinWindow.on('close',e=>{self.checkConnection()});self.joinWindow.webContents.on('did-navigate',(event,url)=>{if(!url.includes("connect/callback"))return;self.joinWindow.close()});self.joinWindow.loadURL(url)}
render(){return BDV2.react.createElement(V2Components.SidebarView,{ref:"sbv",children:this.component})}
get component(){return{'sidebar':{'component':this.sidebar},'content':{'component':this.content}}}
get sidebar(){return BDV2.react.createElement("div",{className:"sidebar",key:"ps"},BDV2.react.createElement("div",{className:"ui-tab-bar SIDE"},BDV2.react.createElement("div",{className:"ui-tab-bar-header",style:{fontSize:"16px"}},"Public Servers"),BDV2.react.createElement(V2Components.TabBar.Separator,null),this.searchInput,BDV2.react.createElement(V2Components.TabBar.Separator,null),BDV2.react.createElement(V2Components.TabBar.Header,{text:"Categories"}),this.categoryButtons.map((value,index)=>{return BDV2.react.createElement(V2Components.TabBar.Item,{id:index,onClick:this.changeCategory,key:index,text:value,selected:this.state.selectedCategory===index})}),BDV2.react.createElement(V2Components.TabBar.Separator,null),this.footer,this.connection))}
get searchInput(){return BDV2.react.createElement("div",{className:"ui-form-item"},BDV2.react.createElement("div",{className:"ui-text-input flex-vertical",style:{width:"172px",marginLeft:"10px"}},BDV2.react.createElement("input",{ref:"searchinput",onKeyDown:this.searchKeyDown,onChange:()=>{},type:"text",className:"input default",placeholder:"Search...",maxLength:"50"})))}
searchKeyDown(e){let self=this;if(self.state.loading||e.which!==13)return;self.setState({'loading':!0,'title':'Loading...','term':e.target.value});let query=`?term=${e.target.value}`;if(self.state.selectedCategory!==0){query+=`&category=${self.categoryButtons[self.state.selectedCategory]}`}
self.search(query,!0)}
get categoryButtons(){return["All","FPS Games","MMO Games","Strategy Games","Sports Games","Puzzle Games","Retro Games","Party Games","Tabletop Games","Sandbox Games","Simulation Games","Community","Language","Programming","Other"]}
changeCategory(id){let self=this;if(self.state.loading)return;self.refs.searchinput.value="";self.setState({'loading':!0,'selectedCategory':id,'title':'Loading...','term':null});if(id===0){self.search("",!0);return}
self.search(`?category=${self.categoryButtons[id]}`,!0)}
get content(){let self=this;if(self.state.connection.state===1)return self.notConnected;return[BDV2.react.createElement("div",{ref:"content",key:"pc",className:"content-column default"},BDV2.react.createElement(V2Components.SettingsTitle,{text:self.state.title}),self.bdServer,self.state.servers.map((server,index)=>{return BDV2.react.createElement(V2Components.ServerCard,{key:index,server:server,join:self.join})}),self.state.next&&BDV2.react.createElement("button",{type:"button",onClick:()=>{if(self.state.loading)return;self.setState({'loading':!0});self.search(self.state.next,!1)},className:"ui-button filled brand small grow",style:{width:"100%",marginTop:"10px",marginBottom:"10px"}},BDV2.react.createElement("div",{className:"ui-button-contents"},self.state.loading?'Loading':'Load More')),self.state.servers.length>0&&BDV2.react.createElement(V2Components.SettingsTitle,{text:self.state.title})),BDV2.react.createElement(V2Components.Tools,{key:"pt",ref:"tools",onClick:self.close})]}
get notConnected(){let self=this;return[BDV2.react.createElement("div",{key:"ncc",ref:"content",className:"content-column default"},BDV2.react.createElement("h2",{className:"ui-form-title h2 margin-reset margin-bottom-20"},"Not connected to discordservers.com!",BDV2.react.createElement("button",{onClick:self.connect,type:"button",className:"ui-button filled brand small grow",style:{display:"inline-block",minHeight:"18px",marginLeft:"10px",lineHeight:"14px"}},BDV2.react.createElement("div",{className:"ui-button-contents"},"Connect"))),self.bdServer),BDV2.react.createElement(V2Components.Tools,{key:"nct",ref:"tools",onClick:self.close})]}
get footer(){return BDV2.react.createElement("div",{className:"ui-tab-bar-header"},BDV2.react.createElement("a",{href:"https://discordservers.com",target:"_blank"},"Discordservers.com"))}
get connection(){let self=this;let{connection}=self.state;if(connection.state!==2)return BDV2.react.createElement("span",null);return BDV2.react.createElement("span",null,BDV2.react.createElement(V2Components.TabBar.Separator,null),BDV2.react.createElement("span",{style:{color:"#b9bbbe",fontSize:"10px",marginLeft:"10px"}},"Connected as: ",`${connection.user.username}#${connection.user.discriminator}`),BDV2.react.createElement("div",{style:{padding:"5px 10px 0 10px"}},BDV2.react.createElement("button",{style:{width:"100%",minHeight:"20px"},type:"button",className:"ui-button filled brand small grow"},BDV2.react.createElement("div",{className:"ui-button-contents",onClick:self.connect},"Reconnect"))))}}
class V2Components{static get SettingsPanel(){return V2C_SettingsPanel}
static get Switch(){return V2C_Switch}
static get Scroller(){return V2C_Scroller}
static get TabBar(){return V2Cs_TabBar}
static get SideBar(){return V2C_SideBar}
static get Tools(){return V2C_Tools}
static get SettingsTitle(){return V2C_SettingsTitle}
static get CssEditor(){return V2C_CssEditor}
static get Checkbox(){return V2C_Checkbox}
static get List(){return V2C_List}
static get PluginCard(){return V2C_PluginCard}
static get ThemeCard(){return V2C_ThemeCard}
static get ContentColumn(){return V2C_ContentColumn}
static get XSvg(){return V2C_XSvg}
static get Layer(){return V2C_Layer}
static get SidebarView(){return V2C_SidebarView}
static get ServerCard(){return V2C_ServerCard}}
class V2_PublicServers{constructor(){}
get component(){return BDV2.react.createElement(V2Components.Layer,{rootId:"pubslayerroot",id:"pubslayer",children:BDV2.react.createElement(V2C_PublicServers,{rootId:"pubslayerroot"})})}
get root(){let _root=$("#pubslayerroot");if(!_root.length){if(!this.injectRoot())return null;return this.root}
return _root[0]}
injectRoot(){if(!$(".layers").length)return!1;$(".layers").append($("<span/>",{id:'pubslayerroot'}));return!0}
render(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layers");return}
BDV2.reactDom.render(this.component,root)}}
class V2_SettingsPanel_Sidebar{constructor(onClick){this.onClick=onClick}
get items(){return[{'text':'Core','id':'core'},{'text':'Emotes','id':'emotes'},{'text':'Custom CSS','id':'customcss'},{'text':'Plugins','id':'plugins'},{'text':'Themes','id':'themes'}]}
get component(){return BDV2.react.createElement("span",null,BDV2.react.createElement(V2Components.SideBar,{onClick:this.onClick,headerText:"BetterDiscord",items:this.items}),BDV2.react.createElement("span",{style:{fontSize:"12px",fontWeight:"600",color:"#72767d",padding:"6px 10px"}},`v${bdVersion}:${jsVersion} by `,BDV2.react.createElement("a",{href:"https://github.com/Jiiks/",target:"_blank"},"Jiiks")))}
get root(){let _root=$("#bd-settings-sidebar");if(!_root.length){if(!this.injectRoot())return null;return this.root}
return _root[0]}
injectRoot(){let changeLog=$(".ui-tab-bar-item:not(.danger)").last();if(!changeLog.length)return!1;$("<span/>",{'id':'bd-settings-sidebar'}).insertBefore(changeLog.prev());return!0}
render(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .ui-tab-bar-item:not(.danger)");return}
BDV2.reactDom.render(this.component,root)}}
class V2_SettingsPanel{constructor(){let self=this;self.sideBarOnClick=self.sideBarOnClick.bind(self);self.onChange=self.onChange.bind(self);self.updateSettings=this.updateSettings.bind(self);self.sidebar=new V2_SettingsPanel_Sidebar(self.sideBarOnClick)}
get root(){let _root=$("#bd-settingspane-container");if(!_root.length){if(!this.injectRoot())return null;return this.root}
return _root[0]}
injectRoot(){if(!$(".layer .ui-standard-sidebar-view").length)return!1;$(".layer .ui-standard-sidebar-view").append($("<div/>",{class:'content-region',id:'bd-settingspane-container'}));return!0}
get coreSettings(){return this.getSettings("core")}
get emoteSettings(){return this.getSettings("emote")}
getSettings(category){return Object.keys(settings).reduce((arr,key)=>{let setting=settings[key];if(setting.cat===category&&setting.implemented&&!setting.hidden){setting.text=key;arr.push(setting)}
return arr},[])}
sideBarOnClick(id){let self=this;$(".content-region").first().hide();$(self.root).show();switch(id){case 'core':self.renderCoreSettings();break;case 'emotes':self.renderEmoteSettings();break;case 'customcss':self.renderCustomCssEditor();break;case 'plugins':self.renderPluginPane();break;case 'themes':self.renderThemePane();break}}
onClick(id){}
onChange(id,checked){settingsCookie[id]=checked;this.updateSettings()}
updateSettings(){let _c=settingsCookie;if(_c["bda-es-0"]){$("#twitchcord-button-container").show()}else{$("#twitchcord-button-container").hide()}
if(_c["bda-gs-b"]){$("body").addClass("bd-blue")}else{$("body").removeClass("bd-blue")}
if(_c["bda-gs-2"]){$("body").addClass("bd-minimal")}else{$("body").removeClass("bd-minimal")}
if(_c["bda-gs-3"]){$("body").addClass("bd-minimal-chan")}else{$("body").removeClass("bd-minimal-chan")}
if(_c["bda-gs-1"]){$("#bd-pub-li").show()}else{$("#bd-pub-li").hide()}
if(_c["bda-gs-4"]){voiceMode.enable()}else{voiceMode.disable()}
if(_c["bda-gs-5"]){$("#app-mount").addClass("bda-dark")}else{$("#app-mount").removeClass("bda-dark")}
if(_c["bda-es-6"]){emoteNamePopup=$("<div class='tipsy tipsy-se' style='display: block; top: 82px; left: 1630.5px; visibility: visible; opacity: 0.8;'><div class='tipsy-inner'></div></div>");$(document).on("mouseover",".emote",function(){var x=$(this).offset();var title=$(this).attr("alt");$(emoteNamePopup).find(".tipsy-inner").text(title);$(emoteNamePopup).css('left',x.left-25);$(emoteNamePopup).css('top',x.top-32);$("div[data-reactid='.0.1.1']").append($(emoteNamePopup))});$(document).on("mouseleave",".emote",function(){$(".tipsy").remove()})}else{$(document).off('mouseover','.emote')}
if(_c["bda-gs-8"]){dMode.enable()}else{dMode.disable()}
mainCore.saveSettings()}
renderSidebar(){let self=this;$(".ui-tab-bar-item").off('click.v2settingspanel').on('click.v2settingspanel',e=>{BDV2.reactDom.unmountComponentAtNode(self.root);$(self.root).hide();$(".content-region").first().show()});self.sidebar.render()}
get coreComponent(){return BDV2.react.createElement(V2Components.Scroller,{fade:!0,dark:!0,children:[BDV2.react.createElement(V2Components.SettingsPanel,{key:"cspanel",title:"Core Settings",onChange:this.onChange,settings:this.coreSettings}),BDV2.react.createElement(V2Components.Tools,{key:"tools"})]})}
get emoteComponent(){return BDV2.react.createElement(V2Components.Scroller,{fade:!0,dark:!0,children:[BDV2.react.createElement(V2Components.SettingsPanel,{key:"espanel",title:"Emote Settings",onChange:this.onChange,settings:this.emoteSettings}),BDV2.react.createElement(V2Components.Tools,{key:"tools"})]})}
get customCssComponent(){return BDV2.react.createElement(V2Components.Scroller,{fade:!0,dark:!0,children:[BDV2.react.createElement(V2Components.CssEditor,{key:"csseditor"}),BDV2.react.createElement(V2Components.Tools,{key:"tools"})]})}
get pluginsComponent(){let plugins=Object.keys(bdplugins).reduce((arr,key)=>{arr.push(BDV2.react.createElement(V2Components.PluginCard,{key:key,plugin:bdplugins[key].plugin}));return arr},[]);let list=BDV2.react.createElement(V2Components.List,{key:"plugin-list",className:"bda-slist",children:plugins});let contentColumn=BDV2.react.createElement(V2Components.ContentColumn,{key:"pcolumn",title:"Plugins",children:list});return BDV2.react.createElement(V2Components.Scroller,{fade:!0,dark:!0,children:[contentColumn,BDV2.react.createElement(V2Components.Tools,{key:"tools"})]})}
get themesComponent(){let themes=Object.keys(bdthemes).reduce((arr,key)=>{arr.push(BDV2.react.createElement(V2Components.ThemeCard,{key:key,theme:bdthemes[key]}));return arr},[]);let list=BDV2.react.createElement(V2Components.List,{key:"theme-list",className:"bda-slist",children:themes});let contentColumn=BDV2.react.createElement(V2Components.ContentColumn,{key:"tcolumn",title:"Themes",children:list});return BDV2.react.createElement(V2Components.Scroller,{fade:!0,dark:!0,children:[contentColumn,BDV2.react.createElement(V2Components.Tools,{key:"tools"})]})}
renderCoreSettings(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layer .ui-standard-sidebar-view");return}
BDV2.reactDom.render(this.coreComponent,root)}
renderEmoteSettings(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layer .ui-standard-sidebar-view");return}
BDV2.reactDom.render(this.emoteComponent,root)}
renderCustomCssEditor(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layer .ui-standard-sidebar-view");return}
BDV2.reactDom.render(this.customCssComponent,root)}
renderPluginPane(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layer .ui-standard-sidebar-view");return}
BDV2.reactDom.render(this.pluginsComponent,root)}
renderThemePane(){let root=this.root;if(!root){console.log("FAILED TO LOCATE ROOT: .layer .ui-standard-sidebar-view");return}
BDV2.reactDom.render(this.themesComponent,root)}}