2020-02-27 08:44:03 +01:00
//META{"name":"ShowHiddenChannels","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/ShowHiddenChannels","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ShowHiddenChannels/ShowHiddenChannels.plugin.js"}*//
2018-10-11 10:21:26 +02:00
2020-09-19 20:49:33 +02:00
module . exports = ( _ => {
2020-10-09 21:09:35 +02:00
const config = {
2020-09-19 20:49:33 +02:00
"info" : {
"name" : "ShowHiddenChannels" ,
"author" : "DevilBro" ,
2020-10-17 15:39:40 +02:00
"version" : "2.8.3" ,
2020-10-16 10:25:30 +02:00
"description" : "Display channels that are hidden from you by role restrictions"
2020-10-17 15:39:40 +02:00
} ,
"changeLog" : {
"added" : {
"Voice Bit-Rate" : "Now shows the bit rate for voice channels in the access modal"
}
2020-09-19 20:49:33 +02:00
}
2020-04-09 21:00:35 +02:00
} ;
2020-10-09 21:09:35 +02:00
return ! window . BDFDB _Global || ( ! window . BDFDB _Global . loaded && ! window . BDFDB _Global . started ) ? class {
2020-09-19 20:49:33 +02:00
getName ( ) { return config . info . name ; }
getAuthor ( ) { return config . info . author ; }
getVersion ( ) { return config . info . version ; }
getDescription ( ) { return config . info . description ; }
2020-10-09 21:09:35 +02:00
load ( ) {
2020-09-19 20:49:33 +02:00
if ( ! window . BDFDB _Global || ! Array . isArray ( window . BDFDB _Global . pluginQueue ) ) window . BDFDB _Global = Object . assign ( { } , window . BDFDB _Global , { pluginQueue : [ ] } ) ;
if ( ! window . BDFDB _Global . downloadModal ) {
window . BDFDB _Global . downloadModal = true ;
BdApi . showConfirmationModal ( "Library Missing" , ` The library plugin needed for ${ config . info . name } is missing. Please click "Download Now" to install it. ` , {
confirmText : "Download Now" ,
cancelText : "Cancel" ,
onCancel : _ => { delete window . BDFDB _Global . downloadModal ; } ,
2020-09-20 08:15:13 +02:00
onConfirm : _ => {
delete window . BDFDB _Global . downloadModal ;
require ( "request" ) . get ( "https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js" , ( e , r , b ) => {
if ( ! e && b && b . indexOf ( ` //META{"name":" ` ) > - 1 ) require ( "fs" ) . writeFile ( require ( "path" ) . join ( BdApi . Plugins . folder , "0BDFDB.plugin.js" ) , b , _ => { } ) ;
else BdApi . alert ( "Error" , "Could not download BDFDB library plugin, try again some time later." ) ;
} ) ;
}
2020-06-09 21:51:14 +02:00
} ) ;
}
2020-09-19 20:49:33 +02:00
if ( ! window . BDFDB _Global . pluginQueue . includes ( config . info . name ) ) window . BDFDB _Global . pluginQueue . push ( config . info . name ) ;
2020-10-09 21:09:35 +02:00
}
start ( ) { this . load ( ) ; }
stop ( ) { }
} : ( ( [ Plugin , BDFDB ] ) => {
2020-09-28 18:07:09 +02:00
var blacklist = [ ] , collapselist = [ ] , hiddenCategory , overrideTypes = [ ] ;
var hiddenChannelCache = { } ;
2020-09-19 20:49:33 +02:00
var settings = { } ;
const settingsMap = {
GUILD _TEXT : "showText" ,
GUILD _VOICE : "showVoice" ,
GUILD _ANNOUNCEMENT : "showAnnouncement" ,
GUILD _STORE : "showStore"
} ;
2019-09-04 12:34:02 +02:00
2020-09-19 20:49:33 +02:00
const typeNameMap = {
GUILD _TEXT : "TEXT_CHANNEL" ,
GUILD _VOICE : "VOICE_CHANNEL" ,
GUILD _ANNOUNCEMENT : "NEWS_CHANNEL" ,
GUILD _STORE : "STORE_CHANNEL" ,
GUILD _CATEGORY : "CATEGORY"
} ;
2019-09-04 12:34:02 +02:00
2020-09-19 20:49:33 +02:00
const channelIcons = {
GUILD _TEXT : ` M 5.88657 21 C 5.57547 21 5.3399 20.7189 5.39427 20.4126 L 6.00001 17 H 2.59511 C 2.28449 17 2.04905 16.7198 2.10259 16.4138 L 2.27759 15.4138 C 2.31946 15.1746 2.52722 15 2.77011 15 H 6.35001 L 7.41001 9 H 4.00511 C 3.69449 9 3.45905 8.71977 3.51259 8.41381 L 3.68759 7.41381 C 3.72946 7.17456 3.93722 7 4.18011 7 H 7.76001 L 8.39677 3.41262 C 8.43914 3.17391 8.64664 3 8.88907 3 H 9.87344 C 10.1845 3 10.4201 3.28107 10.3657 3.58738 L 9.76001 7 H 15.76 L 16.3968 3.41262 C 16.4391 3.17391 16.6466 3 16.8891 3 H 17.8734 C 18.1845 3 18.4201 3.28107 18.3657 3.58738 L 17.76 7 H 21.1649 C 21.4755 7 21.711 7.28023 21.6574 7.58619 L 21.4824 8.58619 C 21.4406 8.82544 21.2328 9 20.9899 9 H 17.41 L 16.35 15 H 19.7549 C 20.0655 15 20.301 15.2802 20.2474 15.5862 L 20.0724 16.5862 C 20.0306 16.8254 19.8228 17 19.5799 17 H 16 L 15.3632 20.5874 C 15.3209 20.8261 15.1134 21 14.8709 21 H 13.8866 C 13.5755 21 13.3399 20.7189 13.3943 20.4126 L 14 17 H 8.00001 L 7.36325 20.5874 C 7.32088 20.8261 7.11337 21 6.87094 21 H 5.88657Z M 9.41045 9 L 8.35045 15 H 14.3504 L 15.4104 9 H 9.41045 Z ` ,
GUILD _VOICE : ` M 11.383 3.07904 C 11.009 2.92504 10.579 3.01004 10.293 3.29604 L 6 8.00204 H 3 C 2.45 8.00204 2 8.45304 2 9.00204 V 15.002 C 2 15.552 2.45 16.002 3 16.002 H 6 L 10.293 20.71 C 10.579 20.996 11.009 21.082 11.383 20.927 C 11.757 20.772 12 20.407 12 20.002 V 4.00204 C 12 3.59904 11.757 3.23204 11.383 3.07904Z M 14 5.00195 V 7.00195 C 16.757 7.00195 19 9.24595 19 12.002 C 19 14.759 16.757 17.002 14 17.002 V 19.002 C 17.86 19.002 21 15.863 21 12.002 C 21 8.14295 17.86 5.00195 14 5.00195Z M 14 9.00195 C 15.654 9.00195 17 10.349 17 12.002 C 17 13.657 15.654 15.002 14 15.002 V 13.002 C 14.551 13.002 15 12.553 15 12.002 C 15 11.451 14.551 11.002 14 11.002 V 9.00195 Z ` ,
GUILD _ANNOUNCEMENT : ` M 3.9 8.26 H 2 V 15.2941 H 3.9 V 8.26 Z M 19.1 4 V 5.12659 L 4.85 8.26447 V 18.1176 C 4.85 18.5496 5.1464 18.9252 5.5701 19.0315 L 9.3701 19.9727 C 9.4461 19.9906 9.524 20 9.6 20 C 9.89545 20 10.1776 19.8635 10.36 19.6235 L 12.7065 16.5242 L 19.1 17.9304 V 19.0588 H 21 V 4 H 19.1 Z M 9.2181 17.9944 L 6.75 17.3826 V 15.2113 L 10.6706 16.0753 L 9.2181 17.9944 Z ` ,
GUILD _STORE : ` M 21.707 13.293l -11 -11 C 10.519 2.105 10.266 2 10 2 H 3c -0.553 0 -1 0.447 -1 1 v 7 c 0 0.266 0.105 0.519 0.293 0.707l11 11 c 0.195 0.195 0.451 0.293 0.707 0.293 s 0.512 -0.098 0.707 -0.293l7 -7 c 0.391 -0.391 0.391 -1.023 0 -1.414 z M 7 9c -1.106 0 -2 -0.896 -2 -2 0 -1.106 0.894 -2 2 -2 1.104 0 2 0.894 2 2 0 1.104 -0.896 2 -2 2 z ` ,
DEFAULT : ` M 11.44 0 c 4.07 0 8.07 1.87 8.07 6.35 c 0 4.13 -4.74 5.72 -5.75 7.21 c -0.76 1.11 -0.51 2.67 -2.61 2.67 c -1.37 0 -2.03 -1.11 -2.03 -2.13 c 0 -3.78 5.56 -4.64 5.56 -7.76 c 0 -1.72 -1.14 -2.73 -3.05 -2.73 c -4.07 0 -2.48 4.19 -5.56 4.19 c -1.11 0 -2.07 -0.67 -2.07 -1.94 C 4 2.76 7.56 0 11.44 0 z M 11.28 18.3 c 1.43 0 2.61 1.17 2.61 2.61 c 0 1.43 -1.18 2.61 -2.61 2.61 c -1.43 0 -2.61 -1.17 -2.61 -2.61 C 8.68 19.48 9.85 18.3 11.28 18.3 z `
2020-05-11 15:59:06 +02:00
} ;
2020-09-19 20:49:33 +02:00
const userRowComponent = class UserRow extends BdApi . React . Component {
componentDidMount ( ) {
if ( this . props . user . fetchable ) {
this . props . user . fetchable = false ;
BDFDB . LibraryModules . UserFetchUtils . getUser ( this . props . user . id ) . then ( fetchedUser => {
this . props . user = Object . assign ( { } , fetchedUser , BDFDB . LibraryModules . MemberStore . getMember ( this . props . guildId , this . props . user . id ) || { } ) ;
BDFDB . ReactUtils . forceUpdate ( this ) ;
} ) ;
}
}
render ( ) {
return BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ListRow , {
prefix : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . AvatarComponents . default , {
className : BDFDB . disCN . listavatar ,
src : BDFDB . UserUtils . getAvatar ( this . props . user . id ) ,
status : BDFDB . UserUtils . getStatus ( this . props . user . id ) ,
size : BDFDB . LibraryComponents . AvatarComponents . Sizes . SIZE _40
} ) ,
label : [
BDFDB . ReactUtils . createElement ( "span" , {
className : BDFDB . disCN . username ,
children : this . props . user . username ,
style : { color : this . props . user . colorString }
} ) ,
! this . props . user . discriminator ? null : BDFDB . ReactUtils . createElement ( "span" , {
className : BDFDB . disCN . listdiscriminator ,
children : ` # ${ this . props . user . discriminator } `
} )
]
} ) ;
2020-03-13 12:28:36 +01:00
}
} ;
2020-08-14 00:36:42 +02:00
2020-09-19 20:49:33 +02:00
const roleRowComponent = class RoleRow extends BdApi . React . Component {
render ( ) {
return BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ListRow , {
prefix : BDFDB . ReactUtils . createElement ( "div" , {
className : BDFDB . disCNS . avataricon + BDFDB . disCNS . listavatar + BDFDB . disCNS . avatariconsizemedium + BDFDB . disCN . avatariconinactive ,
style : {
boxSizing : "border-box" ,
padding : 10
} ,
children : BDFDB . ReactUtils . createElement ( "div" , {
style : {
borderRadius : "50%" ,
height : "100%" ,
width : "100%" ,
backgroundColor : BDFDB . ColorUtils . convert ( this . props . role . colorString || BDFDB . DiscordConstants . Colors . PRIMARY _DARK _300 , "RGB" )
}
} )
} ) ,
labelClassName : this . props . role . overwritten && BDFDB . disCN . strikethrough ,
label : BDFDB . ReactUtils . createElement ( "span" , {
children : this . props . role . name ,
style : { color : this . props . role . colorString }
} )
} ) ;
2020-03-13 12:28:36 +01:00
}
} ;
2020-09-19 20:49:33 +02:00
2020-10-09 21:09:35 +02:00
return class ShowHiddenChannels extends Plugin {
2020-09-19 20:49:33 +02:00
onLoad ( ) {
overrideTypes = Object . keys ( BDFDB . DiscordConstants . PermissionOverrideType ) ;
this . defaults = {
settings : {
sortNative : { value : false , description : "Sort hidden Channels in the native Order" } ,
showText : { value : true , description : "Show hidden Text Channels" } ,
showVoice : { value : true , description : "Show hidden Voice Channels" } ,
showAnnouncement : { value : true , description : "Show hidden Announcement Channels" } ,
showStore : { value : true , description : "Show hidden Store Channels" } ,
showForNormal : { value : false , description : "Add Access-Overview ContextMenu Entry for non-hidden Channels" } ,
}
} ;
2019-11-14 14:17:57 +01:00
2020-09-19 20:49:33 +02:00
this . patchedModules = {
before : {
Channels : "render" ,
ChannelCategoryItem : "render"
} ,
after : {
ChannelItem : [ "render" , "componentDidMount" , "componentDidUpdate" ]
}
} ;
2020-10-17 15:39:40 +02:00
this . css = `
$ { BDFDB . dotCNS . _showhiddenchannelsaccessmodal + BDFDB . dotCN . messagespopoutemptyplaceholder } {
position : absolute ;
bottom : 0 ;
width : 100 % ;
}
` ;
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
onStart ( ) {
2020-03-13 12:28:36 +01:00
let loadedBlacklist = BDFDB . DataUtils . load ( this , "blacklist" ) ;
this . saveBlacklist ( ! BDFDB . ArrayUtils . is ( loadedBlacklist ) ? [ ] : loadedBlacklist ) ;
2020-08-14 00:43:19 +02:00
let loadedCollapselist = BDFDB . DataUtils . load ( this , "categorydata" ) ;
this . saveCollapselist ( ! BDFDB . ArrayUtils . is ( loadedCollapselist ) ? [ ] : loadedCollapselist ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . UnreadChannelUtils , "hasUnread" , { after : e => {
2020-03-13 12:28:36 +01:00
return e . returnValue && ! this . isChannelHidden ( e . methodArguments [ 0 ] ) ;
} } ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . UnreadChannelUtils , "getMentionCount" , { after : e => {
2020-03-13 12:28:36 +01:00
return this . isChannelHidden ( e . methodArguments [ 0 ] ) ? 0 : e . returnValue ;
} } ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . CategoryCollapseStore , "isCollapsed" , { after : e => {
2020-08-14 00:43:19 +02:00
if ( e . methodArguments [ 0 ] && e . methodArguments [ 0 ] . endsWith ( "hidden" ) ) return collapselist . includes ( e . methodArguments [ 0 ] ) ;
2020-03-13 12:28:36 +01:00
} } ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . CategoryCollapseUtils , "categoryCollapse" , { before : e => {
2020-03-13 12:28:36 +01:00
if ( e . methodArguments [ 0 ] && e . methodArguments [ 0 ] . endsWith ( "hidden" ) ) {
2020-08-14 00:43:19 +02:00
if ( ! collapselist . includes ( e . methodArguments [ 0 ] ) ) {
collapselist . push ( e . methodArguments [ 0 ] ) ;
this . saveCollapselist ( BDFDB . ArrayUtils . removeCopies ( collapselist ) ) ;
2020-03-13 12:28:36 +01:00
}
2019-11-14 14:17:57 +01:00
}
2020-03-13 12:28:36 +01:00
} } ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . CategoryCollapseUtils , "categoryExpand" , { before : e => {
2020-03-13 12:28:36 +01:00
if ( e . methodArguments [ 0 ] && e . methodArguments [ 0 ] . endsWith ( "hidden" ) ) {
2020-08-14 00:43:19 +02:00
if ( collapselist . includes ( e . methodArguments [ 0 ] ) ) {
BDFDB . ArrayUtils . remove ( collapselist , e . methodArguments [ 0 ] , true ) ;
this . saveCollapselist ( BDFDB . ArrayUtils . removeCopies ( collapselist ) ) ;
2020-03-13 12:28:36 +01:00
}
2019-11-14 14:17:57 +01:00
}
2020-03-13 12:28:36 +01:00
} } ) ;
2020-09-11 19:31:36 +02:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . GuildChannelStore , "getTextChannelNameDisambiguations" , { after : e => {
2020-03-13 12:28:36 +01:00
let all = BDFDB . LibraryModules . ChannelStore . getChannels ( ) ;
for ( let channel _id in all ) if ( all [ channel _id ] . guild _id == e . methodArguments [ 0 ] && ! e . returnValue [ channel _id ] && ( all [ channel _id ] . type != BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY && all [ channel _id ] . type != BDFDB . DiscordConstants . ChannelTypes . GUILD _VOICE ) ) e . returnValue [ channel _id ] = { id : channel _id , name : all [ channel _id ] . name } ;
} } ) ;
2019-01-26 22:45:19 +01:00
2020-08-29 09:02:00 +02:00
this . forceUpdateAll ( ) ;
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
onStop ( ) {
2020-08-29 09:02:00 +02:00
this . forceUpdateAll ( ) ;
2020-03-13 12:28:36 +01:00
}
2019-01-26 22:45:19 +01:00
2020-09-19 20:49:33 +02:00
getSettingsPanel ( collapseStates = { } ) {
let settingsPanel , settingsItems = [ ] ;
settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . CollapseContainer , {
title : "Settings" ,
collapseStates : collapseStates ,
children : Object . keys ( settings ) . map ( key => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
type : "Switch" ,
plugin : this ,
keys : [ "settings" , key ] ,
label : this . defaults . settings [ key ] . description ,
value : settings [ key ]
} ) )
} ) ) ;
settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . CollapseContainer , {
title : "Server Black List" ,
collapseStates : collapseStates ,
children : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsGuildList , {
className : BDFDB . disCN . marginbottom20 ,
disabled : blacklist ,
onClick : disabledGuilds => {
this . saveBlacklist ( disabledGuilds ) ;
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsItem , {
type : "Button" ,
color : BDFDB . LibraryComponents . Button . Colors . GREEN ,
label : "Enable for all Servers" ,
onClick : _ => {
this . batchSetGuilds ( settingsPanel , collapseStates , true ) ;
} ,
children : BDFDB . LanguageUtils . LanguageStrings . ENABLE
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsItem , {
type : "Button" ,
color : BDFDB . LibraryComponents . Button . Colors . PRIMARY ,
label : "Disable for all Servers" ,
onClick : _ => {
this . batchSetGuilds ( settingsPanel , collapseStates , false ) ;
} ,
children : BDFDB . LanguageUtils . LanguageStrings . DISABLE
2020-03-13 12:28:36 +01:00
} )
2020-09-19 20:49:33 +02:00
]
} ) ) ;
return settingsPanel = BDFDB . PluginUtils . createSettingsPanel ( this , settingsItems ) ;
}
onSettingsClosed ( ) {
if ( this . SettingsUpdated ) {
delete this . SettingsUpdated ;
this . forceUpdateAll ( ) ;
2019-11-13 08:48:45 +01:00
}
2019-11-12 23:52:22 +01:00
}
2020-05-06 11:20:03 +02:00
2020-09-28 18:07:09 +02:00
forceUpdateAll ( ) {
2020-09-19 20:49:33 +02:00
settings = BDFDB . DataUtils . get ( this , "settings" ) ;
2020-09-28 18:07:09 +02:00
hiddenChannelCache = { } ;
2020-08-14 00:36:42 +02:00
2020-09-19 20:49:33 +02:00
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
2020-08-14 00:36:42 +02:00
}
2020-09-19 20:49:33 +02:00
onChannelContextMenu ( e ) {
if ( e . instance . props . channel ) {
if ( e . instance . props . channel . id . endsWith ( "hidden" ) && e . instance . props . channel . type == BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ) {
let [ children , index ] = BDFDB . ReactUtils . findParent ( e . returnvalue , { name : "ChannelMuteItem" } ) ;
if ( index > - 1 ) children . splice ( index , 1 ) ;
}
let isHidden = this . isChannelHidden ( e . instance . props . channel . id ) ;
if ( isHidden || BDFDB . DataUtils . get ( this , "settings" , "showForNormal" ) ) {
let [ children , index ] = BDFDB . ContextMenuUtils . findItem ( e . returnvalue , { id : "mark-channel-read" , group : true } ) ;
children . splice ( index > - 1 ? index + 1 : 0 , 0 , BDFDB . ContextMenuUtils . createItem ( BDFDB . LibraryComponents . MenuItems . MenuGroup , {
children : BDFDB . ContextMenuUtils . createItem ( BDFDB . LibraryComponents . MenuItems . MenuItem , {
label : BDFDB . LanguageUtils . LanguageStrings . CHANNEL + " " + BDFDB . LanguageUtils . LanguageStrings . ACCESSIBILITY ,
id : BDFDB . ContextMenuUtils . createItemId ( this . name , "permissions" ) ,
action : _ => {
2020-10-17 15:39:40 +02:00
this . openAccessModal ( e . instance . props . channel , ! isHidden ) ;
2020-09-19 20:49:33 +02:00
}
} )
} ) ) ;
}
2020-05-11 15:59:06 +02:00
}
2020-09-19 20:49:33 +02:00
}
onGuildContextMenu ( e ) {
if ( e . instance . props . guild ) {
let [ children , index ] = BDFDB . ContextMenuUtils . findItem ( e . returnvalue , { id : "hide-muted-channels" } ) ;
if ( index > - 1 ) children . splice ( index + 1 , 0 , BDFDB . ContextMenuUtils . createItem ( BDFDB . LibraryComponents . MenuItems . MenuCheckboxItem , {
label : this . labels . context _hidehidden _text ,
id : BDFDB . ContextMenuUtils . createItemId ( this . name , "hide-locked-channels" ) ,
checked : blacklist . includes ( e . instance . props . guild . id ) ,
action : value => {
if ( value ) blacklist . push ( e . instance . props . guild . id ) ;
else BDFDB . ArrayUtils . remove ( blacklist , e . instance . props . guild . id , true ) ;
this . saveBlacklist ( BDFDB . ArrayUtils . removeCopies ( blacklist ) ) ;
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
}
} ) ) ;
2019-11-12 23:52:22 +01:00
}
2020-09-19 20:49:33 +02:00
}
onGuildHeaderContextMenu ( e ) {
this . onGuildContextMenu ( e ) ;
}
processChannels ( e ) {
if ( ! e . instance . props . guild || blacklist . includes ( e . instance . props . guild . id ) ) return ;
let [ hiddenChannels , amount ] = this . getHiddenChannels ( e . instance . props . guild ) ;
if ( amount ) {
e . instance . props . categories = Object . assign ( { } , e . instance . props . categories ) ;
for ( let catId in e . instance . props . categories ) e . instance . props . categories [ catId ] = [ ] . concat ( e . instance . props . categories [ catId ] ) ;
e . instance . props . channels = Object . assign ( { } , e . instance . props . channels ) ;
for ( let type in e . instance . props . channels ) e . instance . props . channels [ type ] = [ ] . concat ( e . instance . props . channels [ type ] ) ;
let hiddenId = e . instance . props . guild . id + "_hidden" ;
2020-03-13 12:28:36 +01:00
2020-09-19 20:49:33 +02:00
delete e . instance . props . categories [ hiddenId ] ;
e . instance . props . categories . _categories = e . instance . props . categories . _categories . filter ( n => n . channel . id != hiddenId ) ;
e . instance . props . channels [ BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ] = e . instance . props . channels [ BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ] . filter ( n => n . channel . id != hiddenId ) ;
let index = - 1 ;
for ( let catId in e . instance . props . categories ) {
if ( catId != "_categories" ) e . instance . props . categories [ catId ] = e . instance . props . categories [ catId ] . filter ( n => ! this . isChannelHidden ( n . channel . id ) ) ;
for ( let channelObj of e . instance . props . categories [ catId ] ) if ( channelObj . index > index ) index = parseInt ( channelObj . index ) ;
}
if ( ! settings . sortNative ) {
hiddenCategory = new BDFDB . DiscordObjects . Channel ( {
guild _id : e . instance . props . guild . id ,
id : hiddenId ,
"name" : "hidden" ,
type : BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY
} ) ;
e . instance . props . categories [ hiddenId ] = [ ] ;
e . instance . props . categories . _categories . push ( {
channel : hiddenCategory ,
index : ++ index
2020-05-11 15:59:06 +02:00
} ) ;
2020-09-19 20:49:33 +02:00
e . instance . props . channels [ BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ] . push ( {
comparator : ( e . instance . props . channels [ BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ] [ e . instance . props . channels [ BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ] . length - 1 ] || { comparator : 0 } ) . comparator + 1 ,
channel : hiddenCategory
2020-05-11 15:59:06 +02:00
} ) ;
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
else hiddenCategory = null ;
for ( let type in hiddenChannels ) {
let channelType = type == BDFDB . DiscordConstants . ChannelTypes . GUILD _TEXT && e . instance . props . channels . SELECTABLE ? "SELECTABLE" : type ;
if ( ! BDFDB . ArrayUtils . is ( e . instance . props . channels [ channelType ] ) ) e . instance . props . channels [ channelType ] = [ ] ;
for ( let channel of hiddenChannels [ type ] ) {
let hiddenChannel = new BDFDB . DiscordObjects . Channel ( Object . assign ( { } , channel , {
parent _id : hiddenCategory ? hiddenId : channel . parent _id
} ) ) ;
let parent _id = hiddenChannel . parent _id || "null" ;
e . instance . props . categories [ parent _id ] . push ( {
channel : hiddenChannel ,
index : hiddenChannel . position
} ) ;
e . instance . props . channels [ channelType ] . push ( {
comparator : hiddenChannel . position ,
channel : hiddenChannel
} ) ;
}
}
for ( let parent _id in e . instance . props . categories ) BDFDB . ArrayUtils . keySort ( e . instance . props . categories [ parent _id ] , "index" ) ;
for ( let channelType in e . instance . props . channels ) BDFDB . ArrayUtils . keySort ( e . instance . props . channels [ channelType ] , "comparator" ) ;
2020-03-13 12:28:36 +01:00
}
2019-11-12 22:28:33 +01:00
}
2020-09-19 20:49:33 +02:00
processChannelCategoryItem ( e ) {
if ( hiddenCategory && e . instance . props . channel && ! e . instance . props . channel . id && e . instance . props . channel . type != BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY ) e . instance . props . channel = hiddenCategory ;
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
processChannelItem ( e ) {
if ( e . node ) {
if ( e . instance . props . className . indexOf ( BDFDB . disCN . channelmodelocked ) == - 1 ) BDFDB . DOMUtils . removeClass ( e . node , BDFDB . disCN . channelmodelocked ) ;
e . node . removeEventListener ( "click" , BDFDB . ListenerUtils . stopEvent ) ;
e . node . removeEventListener ( "mousedown" , BDFDB . ListenerUtils . stopEvent ) ;
e . node . removeEventListener ( "mouseup" , BDFDB . ListenerUtils . stopEvent ) ;
}
if ( e . instance . props . channel && this . isChannelHidden ( e . instance . props . channel . id ) ) {
if ( e . returnvalue ) {
let [ children , index ] = BDFDB . ReactUtils . findParent ( e . returnvalue , { name : "Icon" } ) ;
if ( index > - 1 ) children [ index ] = BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SvgIcon , {
nativeClass : true ,
iconSVG : ` <svg class=" ${ BDFDB . disCN . channelicon } " width="24" height="24" viewBox="0 0 24 24"><mask id=" ${ this . name + e . instance . props . channel . id } " fill="black"><path d="M 0 0 H 24 V 24 H 0 Z" fill="white"></path><path d="M24 0 H 13 V 12 H 24 Z" fill="black"></path></mask><path mask="url(# ${ this . name + e . instance . props . channel . id } )" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd" d=" ${ this . channelIcons [ BDFDB . DiscordConstants . ChannelTypes [ e . instance . props . channel . type ] ] || this . channelIcons . DEFAULT } "></path><path fill="currentColor" d="M 21.025 5 V 4 C 21.025 2.88 20.05 2 19 2 C 17.95 2 17 2.88 17 4 V 5 C 16.4477 5 16 5.44772 16 6 V 9 C 16 9.55228 16.4477 10 17 10 H 19 H 21 C 21.5523 10 22 9.55228 22 9 V 5.975C22 5.43652 21.5635 5 21.025 5 Z M 20 5 H 18 V 4 C 18 3.42857 18.4667 3 19 3 C 19.5333 3 20 3.42857 20 4 V 5 Z"></path></svg> `
} ) ;
[ children , index ] = BDFDB . ReactUtils . findParent ( e . returnvalue , { props : [ [ "className" , BDFDB . disCN . channelchildren ] ] } ) ;
if ( index > - 1 && children [ index ] . props && children [ index ] . props . children ) {
children [ index ] . props . children = [ BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TooltipContainer , {
text : BDFDB . LanguageUtils . LanguageStrings . CHANNEL _LOCKED _SHORT ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Clickable , {
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SvgIcon , {
className : BDFDB . disCN . channelactionicon ,
name : BDFDB . LibraryComponents . SvgIcon . Names . LOCK _CLOSED
} )
2020-03-13 12:28:36 +01:00
} )
2020-09-19 20:49:33 +02:00
} ) ] ;
}
}
if ( e . node ) {
BDFDB . DOMUtils . addClass ( e . node , BDFDB . disCN . channelmodelocked ) ;
e . node . addEventListener ( "click" , BDFDB . ListenerUtils . stopEvent ) ;
e . node . addEventListener ( "mousedown" , BDFDB . ListenerUtils . stopEvent ) ;
e . node . addEventListener ( "mouseup" , BDFDB . ListenerUtils . stopEvent ) ;
2020-03-13 12:28:36 +01:00
}
2019-11-12 22:28:33 +01:00
}
}
2020-09-19 20:49:33 +02:00
isChannelHidden ( channelId ) {
2020-09-28 18:07:09 +02:00
let channel = BDFDB . LibraryModules . ChannelStore . getChannel ( channelId ) ;
return channel && hiddenChannelCache [ channel . guild _id ] && hiddenChannelCache [ channel . guild _id ] . hidden [ channel . type ] && hiddenChannelCache [ channel . guild _id ] . hidden [ channel . type ] . find ( c => c . id == channel . id ) ;
2020-09-19 20:49:33 +02:00
}
getHiddenChannels ( guild ) {
if ( ! guild ) return [ { } , 0 ] ;
let roles = ( BDFDB . LibraryModules . MemberStore . getMember ( guild . id , BDFDB . UserUtils . me . id ) || { roles : [ ] } ) . roles . length ;
2020-09-28 18:07:09 +02:00
if ( hiddenChannelCache [ guild . id ] && hiddenChannelCache [ guild . id ] . roles == roles ) return [ hiddenChannelCache [ guild . id ] . hidden , hiddenChannelCache [ guild . id ] . amount ] ;
2020-09-19 20:49:33 +02:00
else {
let all = BDFDB . LibraryModules . ChannelStore . getChannels ( ) , hidden = { } , amount = 0 ;
for ( let type in BDFDB . DiscordConstants . ChannelTypes ) hidden [ BDFDB . DiscordConstants . ChannelTypes [ type ] ] = [ ] ;
for ( let channel _id in all ) {
let channel = all [ channel _id ] ;
2020-09-28 18:07:09 +02:00
if ( channel . guild _id == guild . id && channel . type != BDFDB . DiscordConstants . ChannelTypes . GUILD _CATEGORY && ( settings [ settingsMap [ BDFDB . DiscordConstants . ChannelTypes [ channel . type ] ] ] || settings [ settingsMap [ BDFDB . DiscordConstants . ChannelTypes [ channel . type ] ] ] === undefined ) && ! BDFDB . DMUtils . isDMChannel ( channel . id ) && ! BDFDB . UserUtils . can ( "VIEW_CHANNEL" , BDFDB . UserUtils . me . id , channel . id ) ) {
2020-09-19 20:49:33 +02:00
amount ++ ;
hidden [ channel . type ] . push ( channel ) ;
}
2020-08-29 09:02:00 +02:00
}
2020-09-28 18:07:09 +02:00
hiddenChannelCache [ guild . id ] = { hidden , amount , roles } ;
2020-09-19 20:49:33 +02:00
return [ hidden , amount ] ;
2020-03-13 12:28:36 +01:00
}
2019-11-12 22:28:33 +01:00
}
2020-09-19 20:49:33 +02:00
batchSetGuilds ( settingsPanel , collapseStates , value ) {
if ( ! value ) {
for ( let id of BDFDB . LibraryModules . FolderStore . getFlattenedGuildIds ( ) ) blacklist . push ( id ) ;
this . saveBlacklist ( BDFDB . ArrayUtils . removeCopies ( blacklist ) ) ;
}
else this . saveBlacklist ( [ ] ) ;
BDFDB . PluginUtils . refreshSettingsPanel ( this , settingsPanel , collapseStates ) ;
2019-01-17 23:48:29 +01:00
}
2020-09-19 20:49:33 +02:00
saveBlacklist ( savedBlacklist ) {
blacklist = savedBlacklist ;
BDFDB . DataUtils . save ( savedBlacklist , this , "blacklist" ) ;
}
saveCollapselist ( savedCollapselist ) {
collapselist = savedCollapselist ;
BDFDB . DataUtils . save ( savedCollapselist , this , "categorydata" ) ;
}
2020-10-17 15:39:40 +02:00
openAccessModal ( channel , allowed ) {
2020-09-19 20:49:33 +02:00
let guild = BDFDB . LibraryModules . GuildStore . getGuild ( channel . guild _id ) ;
let myMember = guild && BDFDB . LibraryModules . MemberStore . getMember ( guild . id , BDFDB . UserUtils . me . id ) ;
if ( myMember ) {
let category = BDFDB . LibraryModules . ChannelStore . getChannel ( BDFDB . LibraryModules . ChannelStore . getChannel ( channel . id ) . parent _id ) ;
let lightTheme = BDFDB . DiscordUtils . getTheme ( ) == BDFDB . disCN . themelight ;
let allowedRoles = [ ] , allowedUsers = [ ] , deniedRoles = [ ] , deniedUsers = [ ] , everyoneDenied = false ;
for ( let id in channel . permissionOverwrites ) {
if ( ( channel . permissionOverwrites [ id ] . type == BDFDB . DiscordConstants . PermissionOverrideType . ROLE || overrideTypes [ channel . permissionOverwrites [ id ] . type ] == BDFDB . DiscordConstants . PermissionOverrideType . ROLE ) && ( guild . roles [ id ] && guild . roles [ id ] . name != "@everyone" ) && ( ( channel . permissionOverwrites [ id ] . allow | BDFDB . DiscordConstants . Permissions . VIEW _CHANNEL ) == channel . permissionOverwrites [ id ] . allow || ( channel . permissionOverwrites [ id ] . allow | BDFDB . DiscordConstants . Permissions . CONNECT ) == channel . permissionOverwrites [ id ] . allow ) ) {
allowedRoles . push ( Object . assign ( { overwritten : myMember . roles . includes ( id ) && ! allowed } , guild . roles [ id ] ) ) ;
}
else if ( ( channel . permissionOverwrites [ id ] . type == BDFDB . DiscordConstants . PermissionOverrideType . MEMBER || overrideTypes [ channel . permissionOverwrites [ id ] . type ] == BDFDB . DiscordConstants . PermissionOverrideType . MEMBER ) && ( ( channel . permissionOverwrites [ id ] . allow | BDFDB . DiscordConstants . Permissions . VIEW _CHANNEL ) == channel . permissionOverwrites [ id ] . allow || ( channel . permissionOverwrites [ id ] . allow | BDFDB . DiscordConstants . Permissions . CONNECT ) == channel . permissionOverwrites [ id ] . allow ) ) {
let user = BDFDB . LibraryModules . UserStore . getUser ( id ) ;
if ( user ) allowedUsers . push ( Object . assign ( { } , user , BDFDB . LibraryModules . MemberStore . getMember ( guild . id , id ) || { } ) ) ;
else allowedUsers . push ( { id : id , username : ` UserId: ${ id } ` , fetchable : true } ) ;
}
if ( ( channel . permissionOverwrites [ id ] . type == BDFDB . DiscordConstants . PermissionOverrideType . ROLE || overrideTypes [ channel . permissionOverwrites [ id ] . type ] == BDFDB . DiscordConstants . PermissionOverrideType . ROLE ) && ( ( channel . permissionOverwrites [ id ] . deny | BDFDB . DiscordConstants . Permissions . VIEW _CHANNEL ) == channel . permissionOverwrites [ id ] . deny || ( channel . permissionOverwrites [ id ] . deny | BDFDB . DiscordConstants . Permissions . CONNECT ) == channel . permissionOverwrites [ id ] . deny ) ) {
deniedRoles . push ( guild . roles [ id ] ) ;
if ( guild . roles [ id ] && guild . roles [ id ] . name == "@everyone" ) everyoneDenied = true ;
}
else if ( ( channel . permissionOverwrites [ id ] . type == BDFDB . DiscordConstants . PermissionOverrideType . MEMBER || overrideTypes [ channel . permissionOverwrites [ id ] . type ] == BDFDB . DiscordConstants . PermissionOverrideType . MEMBER ) && ( ( channel . permissionOverwrites [ id ] . deny | BDFDB . DiscordConstants . Permissions . VIEW _CHANNEL ) == channel . permissionOverwrites [ id ] . deny || ( channel . permissionOverwrites [ id ] . deny | BDFDB . DiscordConstants . Permissions . CONNECT ) == channel . permissionOverwrites [ id ] . deny ) ) {
let user = BDFDB . LibraryModules . UserStore . getUser ( id ) ;
if ( user ) deniedUsers . push ( Object . assign ( { } , user , BDFDB . LibraryModules . MemberStore . getMember ( guild . id , id ) || { } ) ) ;
else deniedUsers . push ( { id : id , username : ` UserId: ${ id } ` , fetchable : true } ) ;
}
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
if ( allowed && ! everyoneDenied ) allowedRoles . push ( { name : "@everyone" } ) ;
let allowedElements = [ ] , deniedElements = [ ] ;
for ( let role of allowedRoles ) allowedElements . push ( BDFDB . ReactUtils . createElement ( roleRowComponent , { role : role , guildId : guild . id , channelId : channel . id } ) ) ;
for ( let user of allowedUsers ) allowedElements . push ( BDFDB . ReactUtils . createElement ( userRowComponent , { user : user , guildId : guild . id , channelId : channel . id } ) ) ;
for ( let role of deniedRoles ) deniedElements . push ( BDFDB . ReactUtils . createElement ( roleRowComponent , { role : role , guildId : guild . id , channelId : channel . id } ) ) ;
for ( let user of deniedUsers ) deniedElements . push ( BDFDB . ReactUtils . createElement ( userRowComponent , { user : user , guildId : guild . id , channelId : channel . id } ) ) ;
2020-10-17 15:39:40 +02:00
2020-09-19 20:49:33 +02:00
BDFDB . ModalUtils . open ( this , {
size : "MEDIUM" ,
header : BDFDB . LanguageUtils . LanguageStrings . CHANNEL + " " + BDFDB . LanguageUtils . LanguageStrings . ACCESSIBILITY ,
subheader : "#" + channel . name ,
2020-10-17 15:39:40 +02:00
className : BDFDB . disCN . _showhiddenchannelsaccessmodal ,
2020-09-19 20:49:33 +02:00
contentClassName : BDFDB . disCN . listscroller ,
children : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ModalComponents . ModalTabContent , {
className : BDFDB . disCN . modalsubinner ,
tab : BDFDB . LanguageUtils . LanguageStrings . OVERLAY _SETTINGS _GENERAL _TAB ,
children : [ {
title : BDFDB . LanguageUtils . LanguageStrings . FORM _LABEL _CHANNEL _NAME ,
text : channel . name
2020-10-17 18:26:32 +02:00
} , channel . type == BDFDB . DiscordConstants . ChannelTypes . GUILD _VOICE ? {
2020-10-17 15:39:40 +02:00
title : BDFDB . LanguageUtils . LanguageStrings . FORM _LABEL _BITRATE ,
text : channel . bitrate || "---"
2020-10-17 18:26:32 +02:00
} : {
title : BDFDB . LanguageUtils . LanguageStrings . FORM _LABEL _CHANNEL _TOPIC ,
text : channel . topic || "---"
2020-09-19 20:49:33 +02:00
} , {
title : BDFDB . LanguageUtils . LanguageStrings . CHANNEL _TYPE ,
text : BDFDB . LanguageUtils . LanguageStrings [ typeNameMap [ BDFDB . DiscordConstants . ChannelTypes [ channel . type ] ] ]
} , {
title : BDFDB . LanguageUtils . LanguageStrings . CATEGORY _NAME ,
text : category && category . name || BDFDB . LanguageUtils . LanguageStrings . NO _CATEGORY
2020-10-17 15:39:40 +02:00
} ] . map ( ( formLabel , i ) => formLabel && [
2020-09-19 20:49:33 +02:00
i == 0 ? null : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormDivider , {
className : BDFDB . disCN . marginbottom20
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormItem , {
2020-10-17 15:39:40 +02:00
title : ` ${ formLabel . title } : ` ,
2020-09-19 20:49:33 +02:00
className : BDFDB . DOMUtils . formatClassName ( BDFDB . disCN . marginbottom20 , i == 0 && BDFDB . disCN . margintop8 ) ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormText , {
className : BDFDB . disCN . marginleft8 ,
2020-10-17 15:39:40 +02:00
children : formLabel . text
2020-09-19 20:49:33 +02:00
} )
2020-03-13 12:28:36 +01:00
} )
2020-09-19 20:49:33 +02:00
] ) . flat ( 10 ) . filter ( n => n )
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ModalComponents . ModalTabContent , {
tab : this . labels . modal _allowed _text ,
children : allowedElements . length ? allowedElements :
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . MessagesPopoutComponents . EmptyStateBottom , {
msg : BDFDB . LanguageUtils . LanguageStrings . AUTOCOMPLETE _NO _RESULTS _HEADER ,
image : lightTheme ? "/assets/9b0d90147f7fab54f00dd193fe7f85cd.svg" : "/assets/308e587f3a68412f137f7317206e92c2.svg"
2019-11-12 23:05:47 +01:00
} )
2020-09-19 20:49:33 +02:00
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ModalComponents . ModalTabContent , {
tab : this . labels . modal _denied _text ,
children : deniedElements . length ? deniedElements :
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . MessagesPopoutComponents . EmptyStateBottom , {
msg : BDFDB . LanguageUtils . LanguageStrings . AUTOCOMPLETE _NO _RESULTS _HEADER ,
image : lightTheme ? "/assets/9b0d90147f7fab54f00dd193fe7f85cd.svg" : "/assets/308e587f3a68412f137f7317206e92c2.svg"
} )
} )
]
} ) ;
}
2020-03-13 12:28:36 +01:00
}
2019-01-26 22:45:19 +01:00
2020-09-19 20:49:33 +02:00
setLabelsByLanguage ( ) {
switch ( BDFDB . LanguageUtils . getLanguage ( ) . id ) {
case "hr" : //croatian
return {
context _hidehidden _text : "Sakrij skrivene kanale" ,
modal _allowed _text : "Dopušteno" ,
modal _denied _text : "Odbijen"
} ;
case "da" : //danish
return {
context _hidehidden _text : "Skjul låste kanaler" ,
modal _allowed _text : "Odbijen" ,
modal _denied _text : "Nægtet"
} ;
case "de" : //german
return {
context _hidehidden _text : "Versteckte Kanäle ausblenden" ,
modal _allowed _text : "Erlaubt" ,
modal _denied _text : "Verweigert"
} ;
case "es" : //spanish
return {
context _hidehidden _text : "Ocultar canales bloqueados" ,
modal _allowed _text : "Permitido" ,
modal _denied _text : "Negado"
} ;
case "fr" : //french
return {
context _hidehidden _text : "Masquer les salons verrouillées" ,
modal _allowed _text : "Permis" ,
modal _denied _text : "Nié"
} ;
case "it" : //italian
return {
context _hidehidden _text : "Nascondi canali bloccati" ,
modal _allowed _text : "Permesso" ,
modal _denied _text : "Negato"
} ;
case "nl" : //dutch
return {
context _hidehidden _text : "Vergrendelde kanalen verbergen" ,
modal _allowed _text : "Toegestaan" ,
modal _denied _text : "Ontkend"
} ;
case "no" : //norwegian
return {
context _hidehidden _text : "Skjul låste kanaler" ,
modal _allowed _text : "Tillatt" ,
modal _denied _text : "Benektet"
} ;
case "pl" : //polish
return {
context _hidehidden _text : "Ukryj zablokowane kanały" ,
modal _allowed _text : "Dozwolony" ,
modal _denied _text : "Odmówiono"
} ;
case "pt-BR" : //portuguese (brazil)
return {
context _hidehidden _text : "Ocultar canais bloqueados" ,
modal _allowed _text : "Permitido" ,
modal _denied _text : "Negado"
} ;
case "fi" : //finnish
return {
context _hidehidden _text : "Piilota lukitut kanavat" ,
modal _allowed _text : "Sallittu" ,
modal _denied _text : "Evätty"
} ;
case "sv" : //swedish
return {
context _hidehidden _text : "Dölj låsta kanaler" ,
modal _allowed _text : "Tillåten" ,
modal _denied _text : "Nekas"
} ;
case "tr" : //turkish
return {
context _hidehidden _text : "Kilitli Kanalları Gizle" ,
modal _allowed _text : "Izin" ,
modal _denied _text : "Inkar"
} ;
case "cs" : //czech
return {
context _hidehidden _text : "Skrýt uzamčené kanály" ,
modal _allowed _text : "Povoleno" ,
modal _denied _text : "Odepřeno"
} ;
case "bg" : //bulgarian
return {
context _hidehidden _text : "Скриване на заключени канали" ,
modal _allowed _text : "Позволен" ,
modal _denied _text : "Отказан"
} ;
case "ru" : //russian
return {
context _hidehidden _text : "Скрыть заблокированные каналы" ,
modal _allowed _text : "Разрешается" ,
modal _denied _text : "Отказано"
} ;
case "uk" : //ukrainian
return {
context _hidehidden _text : "Сховати заблоковані канали" ,
modal _allowed _text : "Дозволено" ,
modal _denied _text : "Заперечували"
} ;
case "ja" : //japanese
return {
context _hidehidden _text : "ロックされたチャンネルを隠す" ,
modal _allowed _text : "許可された" ,
modal _denied _text : "拒否されました"
} ;
case "zh-TW" : //chinese (traditional)
return {
context _hidehidden _text : "隱藏鎖定的頻道" ,
modal _allowed _text : "允許的" ,
modal _denied _text : "被拒絕"
} ;
case "ko" : //korean
return {
context _hidehidden _text : "잠긴 채널 숨기기" ,
modal _allowed _text : "허용됨" ,
modal _denied _text : "거부"
} ;
default : //default: english
return {
context _hidehidden _text : "Hide Locked Channels" ,
modal _allowed _text : "Permitted" ,
modal _denied _text : "Denied"
} ;
}
2020-03-13 12:28:36 +01:00
}
2020-09-19 20:49:33 +02:00
} ;
2020-10-09 21:09:35 +02:00
} ) ( window . BDFDB _Global . PluginUtils . buildPlugin ( config ) ) ;
2020-09-19 20:49:33 +02:00
} ) ( ) ;