2020-02-27 08:44:03 +01:00
//META{"name":"ServerHider","authorId":"278543574059057154","invite":"Jx3TjNS","donate":"https://www.paypal.me/MircoWittrien","patreon":"https://www.patreon.com/MircoWittrien","website":"https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ServerHider","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ServerHider/ServerHider.plugin.js"}*//
2018-10-11 10:21:26 +02:00
2020-02-11 17:05:06 +01:00
var ServerHider = ( _ => {
return class ServerHider {
getName ( ) { return "ServerHider" ; }
2019-01-16 00:14:18 +01:00
2020-02-11 17:05:06 +01:00
getVersion ( ) { return "6.1.3" ; }
2019-01-16 00:14:18 +01:00
2020-02-11 17:05:06 +01:00
getAuthor ( ) { return "DevilBro" ; }
2019-01-16 00:14:18 +01:00
2020-02-11 17:05:06 +01:00
getDescription ( ) { return "Hide Servers in your Serverlist" ; }
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
constructor ( ) {
this . changelog = {
"fixed" : [ [ "No Folders" , "Plugin now works properly even if you got no server folders" ] ] ,
"improved" : [ [ "New Library Structure & React" , "Restructured my Library and switched to React rendering instead of DOM manipulation" ] , [ "Folder Support" , "You can now also hide folders with the plugin" ] ]
} ;
2019-09-04 12:34:02 +02:00
2020-02-11 17:05:06 +01:00
this . patchedModules = {
after : {
Guilds : "render"
}
} ;
}
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
getSettingsPanel ( ) {
if ( ! window . BDFDB || typeof BDFDB != "object" || ! BDFDB . loaded || ! this . started ) return ;
let settingspanel , settingsitems = [ ] ;
settingsitems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsItem , {
type : "Button" ,
className : BDFDB . disCN . marginbottom8 ,
color : BDFDB . LibraryComponents . Button . Colors . RED ,
label : "Unhide all Servers/Folders" ,
onClick : _ => {
BDFDB . ModalUtils . confirm ( this , "Are you sure you want to unhide all servers and folders?" , _ => {
BDFDB . DataUtils . save ( [ ] , this , "hidden" ) ;
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
} ) ;
} ,
children : BDFDB . LanguageUtils . LanguageStrings . RESET
} ) ) ;
return settingspanel = BDFDB . PluginUtils . createSettingsPanel ( this , settingsitems ) ;
}
2018-10-11 10:21:26 +02:00
2020-02-11 17:05:06 +01:00
//legacy
load ( ) { }
2018-10-11 10:21:26 +02:00
2020-02-11 17:05:06 +01:00
start ( ) {
if ( ! window . BDFDB ) window . BDFDB = { myPlugins : { } } ;
if ( window . BDFDB && window . BDFDB . myPlugins && typeof window . BDFDB . myPlugins == "object" ) window . BDFDB . myPlugins [ this . getName ( ) ] = this ;
let libraryScript = document . querySelector ( "head script#BDFDBLibraryScript" ) ;
if ( ! libraryScript || ( performance . now ( ) - libraryScript . getAttribute ( "date" ) ) > 600000 ) {
if ( libraryScript ) libraryScript . remove ( ) ;
libraryScript = document . createElement ( "script" ) ;
libraryScript . setAttribute ( "id" , "BDFDBLibraryScript" ) ;
libraryScript . setAttribute ( "type" , "text/javascript" ) ;
libraryScript . setAttribute ( "src" , "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js" ) ;
libraryScript . setAttribute ( "date" , performance . now ( ) ) ;
libraryScript . addEventListener ( "load" , _ => { this . initialize ( ) ; } ) ;
document . head . appendChild ( libraryScript ) ;
}
else if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) this . initialize ( ) ;
this . startTimeout = setTimeout ( _ => {
try { return this . initialize ( ) ; }
catch ( err ) { console . error ( ` %c[ ${ this . getName ( ) } ]%c ` , "color: #3a71c1; font-weight: 700;" , "" , "Fatal Error: Could not initiate plugin! " + err ) ; }
} , 30000 ) ;
2019-05-26 13:55:26 +02:00
}
2018-10-11 10:21:26 +02:00
2020-02-11 17:05:06 +01:00
initialize ( ) {
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
if ( this . started ) return ;
BDFDB . PluginUtils . init ( this ) ;
BDFDB . ModuleUtils . patch ( this , BDFDB . LibraryModules . FolderStore , "getGuildFolderById" , { after : e => {
let hiddenGuildIds = BDFDB . DataUtils . load ( this , "hidden" , "servers" ) || [ ] ;
if ( e . returnValue && hiddenGuildIds . length ) {
let folder = Object . assign ( { } , e . returnValue ) ;
folder . guildIds = [ ] . concat ( folder . guildIds ) . filter ( n => ! hiddenGuildIds . includes ( n ) ) ;
folder . hiddenGuildIds = [ ] . concat ( folder . guildIds ) . filter ( n => hiddenGuildIds . includes ( n ) ) ;
return folder ;
}
} } ) ;
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
}
else console . error ( ` %c[ ${ this . getName ( ) } ]%c ` , "color: #3a71c1; font-weight: 700;" , "" , "Fatal Error: Could not load BD functions!" ) ;
2018-10-11 10:21:26 +02:00
}
2020-02-11 17:05:06 +01:00
stop ( ) {
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
this . stopping = true ;
2019-10-22 11:37:23 +02:00
2020-02-11 17:05:06 +01:00
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
BDFDB . PluginUtils . clear ( this ) ;
}
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
// begin of own functions
2018-10-11 10:21:26 +02:00
2020-02-11 17:05:06 +01:00
onGuildContextMenu ( e ) {
if ( document . querySelector ( BDFDB . dotCN . modalwrapper ) ) return ;
if ( e . instance . props . target && e . instance . props . type . startsWith ( "GUILD_ICON_" ) ) {
let [ children , index ] = BDFDB . ReactUtils . findChildren ( e . returnvalue , { name : [ "FluxContainer(MessageDeveloperModeGroup)" , "DeveloperModeGroup" ] } ) ;
children . splice ( index > - 1 ? index : children . length , 0 , BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Group , {
children : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Sub , {
label : this . labels . context _serverhider _text ,
render : [ BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Group , {
children : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Item , {
label : this . labels . submenu _openhidemenu _text ,
action : _ => {
BDFDB . ContextMenuUtils . close ( e . instance ) ;
this . showHideModal ( ) ;
}
} ) ,
! e . instance . props . guild && ! e . instance . props . folderId ? null : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Item , {
label : e . instance . props . guild ? this . labels . submenu _hideserver _text : this . labels . submenu _hidefolder _text ,
action : _ => {
BDFDB . ContextMenuUtils . close ( e . instance ) ;
if ( e . instance . props . guild ) this . toggleItem ( BDFDB . DataUtils . load ( this , "hidden" , "servers" ) || [ ] , e . instance . props . guild . id , "servers" ) ;
else this . toggleItem ( BDFDB . DataUtils . load ( this , "hidden" , "folders" ) || [ ] , e . instance . props . folderId , "folders" ) ;
}
} )
] . filter ( n => n )
} ) ]
} )
]
} ) ) ;
}
2019-01-16 00:14:18 +01:00
}
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
processGuilds ( e ) {
let hiddenGuildIds = BDFDB . DataUtils . load ( this , "hidden" , "servers" ) || [ ] ;
let hiddenFolderIds = BDFDB . DataUtils . load ( this , "hidden" , "folders" ) || [ ] ;
if ( hiddenGuildIds . length || hiddenFolderIds . length ) {
let guildChildren ;
let [ children , index ] = BDFDB . ReactUtils . findChildren ( e . returnvalue , { name : [ "DragSource(ForwardRef(FluxContainer(GuildFolder)))" , "DragSource(ForwardRef(FluxContainer(Guild)))" ] } ) ;
if ( index > - 1 ) guildChildren = children ;
else {
[ children , index ] = BDFDB . ReactUtils . findChildren ( e . returnvalue , { name : "ConnectedUnreadDMs" } ) ;
if ( index > - 1 ) for ( let sub of children ) if ( BDFDB . ArrayUtils . is ( sub ) && sub [ 0 ] && sub [ 0 ] . type && sub [ 0 ] . type . displayName == "DragSource(ConnectedGuild)" ) {
guildChildren = sub ;
break ;
}
2019-12-20 14:44:57 +01:00
}
2020-02-11 17:05:06 +01:00
if ( guildChildren ) for ( let i in guildChildren ) {
let child = guildChildren [ i ] ;
if ( child . props . folderId ) {
if ( hiddenFolderIds . includes ( child . props . folderId ) ) guildChildren [ i ] = null ;
else {
let guildIds = [ ] . concat ( child . props . guildIds . filter ( guildId => ! hiddenGuildIds . includes ( guildId ) ) ) ;
if ( guildIds . length ) {
child . props . hiddenGuildIds = [ ] . concat ( child . props . guildIds . filter ( guildId => hiddenGuildIds . includes ( guildId ) ) ) ;
child . props . guildIds = guildIds ;
}
else guildChildren [ i ] = null ;
2019-11-22 14:38:30 +01:00
}
2019-11-22 14:26:12 +01:00
}
2020-02-11 17:05:06 +01:00
else if ( child . props . guildId && hiddenGuildIds . includes ( child . props . guildId ) ) guildChildren [ i ] = null ;
2019-11-22 14:26:12 +01:00
}
}
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-02-11 17:05:06 +01:00
showHideModal ( ) {
let hiddenGuildIds = BDFDB . DataUtils . load ( this , "hidden" , "servers" ) || [ ] ;
let hiddenFolderIds = BDFDB . DataUtils . load ( this , "hidden" , "folders" ) || [ ] ;
let guilds = BDFDB . LibraryModules . FolderStore . guildFolders . map ( n => n . guildIds ) . flat ( 10 ) . map ( guildId => BDFDB . LibraryModules . GuildStore . getGuild ( guildId ) ) . filter ( n => n ) ;
let folders = BDFDB . LibraryModules . FolderStore . guildFolders . filter ( n => n . folderId ) ;
let foldersAdded = [ ] ;
BDFDB . ModalUtils . open ( this , {
size : "MEDIUM" ,
header : this . labels . modal _header _text ,
subheader : "" ,
contentClassName : BDFDB . disCN . listscroller ,
children : guilds . map ( ( guild , i ) => {
let folder = folders . find ( folder => folder . guildIds . includes ( guild . id ) && ! foldersAdded . includes ( folder . folderId ) ) ;
if ( folder ) foldersAdded . push ( folder . folderId ) ;
return [
folder ? [
folders . indexOf ( folder ) == 0 ? null : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormDivider , {
className : BDFDB . disCNS . margintop4 + BDFDB . disCN . marginbottom4
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormDivider , {
className : BDFDB . disCNS . margintop8 + BDFDB . disCN . marginbottom4
} )
] ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ListRow , {
prefix : BDFDB . ReactUtils . createElement ( "div" , {
className : BDFDB . disCN . listavatar ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . GuildComponents . BlobMask , {
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Clickable , {
className : BDFDB . disCN . guildfolder ,
2019-11-22 14:26:12 +01:00
children : BDFDB . ReactUtils . createElement ( "div" , {
2020-02-11 17:05:06 +01:00
className : BDFDB . disCN . guildfoldericonwrapper ,
children : BDFDB . ReactUtils . createElement ( "div" , {
className : BDFDB . disCN . guildfoldericonwrapperexpanded ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SvgIcon , {
name : BDFDB . LibraryComponents . SvgIcon . Names . FOLDER ,
style : { color : BDFDB . ColorUtils . convert ( folder . folderColor , "RGB" ) }
} )
2019-11-22 14:26:12 +01:00
} )
} )
} )
} )
2020-02-11 17:05:06 +01:00
} ) ,
label : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TextScroller , {
children : folder . folderName || ` ${ BDFDB . LanguageUtils . LanguageStrings . SERVER _FOLDER _PLACEHOLDER } # ${ folders . indexOf ( folder ) + 1 } `
} ) ,
suffix : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Switch , {
value : ! hiddenFolderIds . includes ( folder . folderId ) ,
onChange : value => { this . toggleItem ( hiddenFolderIds , folder . folderId , "folders" , value ) ; }
2019-11-22 14:26:12 +01:00
} )
2020-02-11 17:05:06 +01:00
} )
] : null ,
i == 0 && ! folder ? null : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormDivider , {
className : BDFDB . disCNS . margintop4 + BDFDB . disCN . marginbottom4
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ListRow , {
prefix : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . GuildComponents . Guild , {
className : BDFDB . disCN . listavatar ,
guild : guild ,
menu : false ,
tooltip : false
2019-11-22 14:26:12 +01:00
} ) ,
label : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TextScroller , {
2020-02-11 17:05:06 +01:00
children : guild . name
2019-11-22 14:26:12 +01:00
} ) ,
suffix : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Switch , {
2020-02-11 17:05:06 +01:00
value : ! hiddenGuildIds . includes ( guild . id ) ,
onChange : value => { this . toggleItem ( hiddenGuildIds , guild . id , "servers" , value ) ; }
2019-11-22 14:26:12 +01:00
} )
} )
2020-02-11 17:05:06 +01:00
] ;
} ) . flat ( 10 ) . filter ( n => n ) ,
buttons : [ {
contents : BDFDB . LanguageUtils . LanguageStrings . OKAY ,
color : "BRAND" ,
close : true
} , {
contents : BDFDB . LanguageUtils . LanguageStrings . FORM _LABEL _ALL ,
color : "TRANSPARENT" ,
look : "LINK" ,
click : ( modal , instance ) => {
let enabled = hiddenGuildIds . includes ( guilds [ 0 ] . id ) ;
hiddenGuildIds = [ ] . concat ( enabled ? [ ] : guilds . map ( n => n . id ) ) ;
BDFDB . DataUtils . save ( hiddenGuildIds , this , "hidden" , "servers" ) ;
hiddenFolderIds = [ ] . concat ( enabled ? [ ] : folders . map ( n => n . folderId ) ) ;
BDFDB . DataUtils . save ( hiddenFolderIds , this , "hidden" , "folders" ) ;
let switchInstances = BDFDB . ReactUtils . findOwner ( instance , { name : "BDFDB_Switch" , all : true , unlimited : true } ) ;
for ( let switchIns of switchInstances ) switchIns . props . value = enabled ;
BDFDB . ReactUtils . forceUpdate ( switchInstances ) ;
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
}
} ]
} ) ;
}
toggleItem ( array , id , type , force ) {
if ( ! id ) return ;
if ( force || ( force === undefined && array . includes ( id ) ) ) BDFDB . ArrayUtils . remove ( array , id , true ) ;
else array . push ( id ) ;
BDFDB . DataUtils . save ( array , this , "hidden" , type ) ;
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
}
2019-09-04 12:34:02 +02:00
2020-02-11 17:05:06 +01:00
setLabelsByLanguage ( ) {
switch ( BDFDB . LanguageUtils . getLanguage ( ) . id ) {
case "hr" : //croatian
return {
modal _header _text : "Upravljanje popisom poslužitelja" ,
context _serverhider _text : "Vidljivost poslužitelj" ,
submenu _hideserver _text : "Sakrij poslužitelj" ,
submenu _hidefolder _text : "Sakrij mapu" ,
submenu _openhidemenu _text : "Upravljanje popisom poslužitelja"
} ;
case "da" : //danish
return {
modal _header _text : "Styring af serverliste" ,
context _serverhider _text : "Server synlighed" ,
submenu _hideserver _text : "Skjul server" ,
submenu _hidefolder _text : "Skjul mappe" ,
submenu _openhidemenu _text : "Styre serverliste"
} ;
case "de" : //german
return {
modal _header _text : "Verwaltung der Serverliste" ,
context _serverhider _text : "Serversichtbarkeit" ,
submenu _hideserver _text : "Server verstecken" ,
submenu _hidefolder _text : "Ordner verstecken" ,
submenu _openhidemenu _text : "Serverliste verwalten"
} ;
case "es" : //spanish
return {
modal _header _text : "Administración de lista de servidores" ,
context _serverhider _text : "Visibilidad del servidor" ,
submenu _hideserver _text : "Ocultar servidor" ,
submenu _hidefolder _text : "Ocultar carpeta" ,
submenu _openhidemenu _text : "Administrar lista de servidores"
} ;
case "fr" : //french
return {
modal _header _text : "Gestion de la liste des serveurs" ,
context _serverhider _text : "Visibilité du serveur" ,
submenu _hideserver _text : "Cacher le serveur" ,
submenu _hidefolder _text : "Cacher le dossier" ,
submenu _openhidemenu _text : "Gérer la liste des serveurs"
} ;
case "it" : //italian
return {
modal _header _text : "Gestione dell'elenco dei server" ,
context _serverhider _text : "Visibilità del server" ,
submenu _hideserver _text : "Nascondi il server" ,
submenu _hidefolder _text : "Nascondi la cartella" ,
submenu _openhidemenu _text : "Gestione elenco dei server"
} ;
case "nl" : //dutch
return {
modal _header _text : "Beheer van de Serverlijst" ,
context _serverhider _text : "Server zichtbaarheid" ,
submenu _hideserver _text : "Verberg server" ,
submenu _hidefolder _text : "Verberg map" ,
submenu _openhidemenu _text : "Beheer serverlijst"
} ;
case "no" : //norwegian
return {
modal _header _text : "Administrasjon av serverlisten" ,
context _serverhider _text : "Server synlighet" ,
submenu _hideserver _text : "Skjul server" ,
submenu _hidefolder _text : "Skjul mappe" ,
submenu _openhidemenu _text : "Administrer serverliste"
} ;
case "pl" : //polish
return {
modal _header _text : "Zarządzanie listą serwerów" ,
context _serverhider _text : "Widoczność serwera" ,
submenu _hideserver _text : "Ukryj serwer" ,
submenu _hidefolder _text : "Ukryj folder" ,
submenu _openhidemenu _text : "Zarządzaj listą serwerów"
} ;
case "pt-BR" : //portuguese (brazil)
return {
modal _header _text : "Gerenciamento da lista de servidores" ,
context _serverhider _text : "Visibilidade do servidor" ,
submenu _hideserver _text : "Ocultar servidor" ,
submenu _hidefolder _text : "Ocultar pasta" ,
submenu _openhidemenu _text : "Gerenciar lista de servidores"
} ;
case "fi" : //finnish
return {
modal _header _text : "Palvelinluettelon hallinta" ,
context _serverhider _text : "Palvelimen näkyvyys" ,
submenu _hideserver _text : "Piilota palvelin" ,
submenu _hidefolder _text : "Piilota kansio" ,
submenu _openhidemenu _text : "Hallinnoi palvelinluetteloa"
} ;
case "sv" : //swedish
return {
modal _header _text : "Hantering av serverlistan" ,
context _serverhider _text : "Server sikt" ,
submenu _hideserver _text : "Dölj server" ,
submenu _hidefolder _text : "Dölj mapp" ,
submenu _openhidemenu _text : "Hantera serverlistan"
} ;
case "tr" : //turkish
return {
modal _header _text : "Sunucu Listesinin Yönetimi" ,
context _serverhider _text : "Sunucu görünürlüğü" ,
submenu _hideserver _text : "Sunucuyu Gizle" ,
submenu _hidefolder _text : "Klasörü Gizle" ,
submenu _openhidemenu _text : "Sunucu Listesini Yönet"
} ;
case "cs" : //czech
return {
modal _header _text : "Správa seznamu serverů" ,
context _serverhider _text : "Viditelnost serveru" ,
submenu _hideserver _text : "Skrýt server" ,
submenu _hidefolder _text : "Skrýt složky" ,
submenu _openhidemenu _text : "Správa seznamu serverů"
} ;
case "bg" : //bulgarian
return {
modal _header _text : "Управление на списъка със сървъри" ,
context _serverhider _text : "Видимост на сървъра" ,
submenu _hideserver _text : "Скриване на сървър" ,
submenu _hidefolder _text : "Скриване на папка" ,
submenu _openhidemenu _text : "Управление на списъка със сървъри"
} ;
case "ru" : //russian
return {
modal _header _text : "Управление списком серверов" ,
context _serverhider _text : "Видимость сервера" ,
submenu _hideserver _text : "Скрыть сервер" ,
submenu _hidefolder _text : "Скрыть папки" ,
submenu _openhidemenu _text : "Управление списком серверов"
} ;
case "uk" : //ukrainian
return {
modal _header _text : "Управління списком серверів" ,
context _serverhider _text : "Видимість сервера" ,
submenu _hideserver _text : "Сховати сервер" ,
submenu _hidefolder _text : "Сховати папки" ,
submenu _openhidemenu _text : "Управління списком серверів"
} ;
case "ja" : //japanese
return {
modal _header _text : "サーバリストの管理" ,
context _serverhider _text : "サーバーの可視性" ,
submenu _hideserver _text : "サーバーを隠す" ,
submenu _hidefolder _text : "フォルダーを非表示" ,
submenu _openhidemenu _text : "サーバーリストを管理する"
} ;
case "zh-TW" : //chinese (traditional)
return {
modal _header _text : "管理服务器列表" ,
context _serverhider _text : "服務器可見性" ,
submenu _hideserver _text : "隐藏服务器" ,
submenu _hidefolder _text : "隱藏資料夾" ,
submenu _openhidemenu _text : "管理服务器列表"
} ;
case "ko" : //korean
return {
modal _header _text : "서버 목록 관리" ,
context _serverhider _text : "서버 가시성" ,
submenu _hideserver _text : "서버 숨기기" ,
submenu _hidefolder _text : "폴더 숨기기" ,
submenu _openhidemenu _text : "서버 목록 관리"
} ;
default : //default: english
return {
modal _header _text : "Managing Serverlist" ,
context _serverhider _text : "Server Visibility" ,
submenu _hideserver _text : "Hide Server" ,
submenu _hidefolder _text : "Hide Folder" ,
submenu _openhidemenu _text : "Manage Serverlist"
} ;
}
2018-10-11 10:21:26 +02:00
}
}
2020-02-11 17:05:06 +01:00
} ) ( ) ;