@ -25,7 +25,7 @@ import { canonicalizeMatch } from "@utils/patches";
import definePlugin , { OptionType } from "@utils/types" ;
import definePlugin , { OptionType } from "@utils/types" ;
import { findByPropsLazy } from "@webpack" ;
import { findByPropsLazy } from "@webpack" ;
import { ChannelStore , PermissionStore , Tooltip } from "@webpack/common" ;
import { ChannelStore , PermissionStore , Tooltip } from "@webpack/common" ;
import { Channel } from "discord-types/general" ;
import type { Channel , Role } from "discord-types/general" ;
import HiddenChannelLockScreen , { setChannelBeginHeaderComponent } from "./components/HiddenChannelLockScreen" ;
import HiddenChannelLockScreen , { setChannelBeginHeaderComponent } from "./components/HiddenChannelLockScreen" ;
@ -252,12 +252,24 @@ export default definePlugin({
match : /permissionOverwrites\[.+?\i=(?<=context:(\i)}.+?)(?=(.+?)VIEW_CHANNEL)/ ,
match : /permissionOverwrites\[.+?\i=(?<=context:(\i)}.+?)(?=(.+?)VIEW_CHANNEL)/ ,
replace : ( m , channel , permCheck ) = > ` ${ m } !Vencord.Webpack.Common.PermissionStore.can( ${ CONNECT } n, ${ channel } )? ${ permCheck } CONNECT): `
replace : ( m , channel , permCheck ) = > ` ${ m } !Vencord.Webpack.Common.PermissionStore.can( ${ CONNECT } n, ${ channel } )? ${ permCheck } CONNECT): `
} ,
} ,
{
// Include the @everyone role in the allowed roles list for Hidden Channels
match : /sortBy.{0,100}?return (?<=var (\i)=\i\.channel.+?)(?=\i\.id)/ ,
replace : ( m , channel ) = > ` ${ m } $ self.isHiddenChannel( ${ channel } )?true: `
} ,
{
// If the @everyone role has the required permissions, make the array only contain it
match : /computePermissionsForRoles.+?.value\(\)(?<=var (\i)=\i\.channel.+?)/ ,
replace : ( m , channel ) = > ` ${ m } .reduce(... $ self.makeAllowedRolesReduce( ${ channel } .guild_id)) `
} ,
{
{
// Patch the header to only return allowed users and roles if it's a hidden channel or locked channel (Like when it's used on the HiddenChannelLockScreen)
// Patch the header to only return allowed users and roles if it's a hidden channel or locked channel (Like when it's used on the HiddenChannelLockScreen)
match : /MANAGE_ROLES.{0,60}?return(?=\(.+?(\(0,\i\.jsxs\)\("div",{className:\i\(\)\.members.+?guildId:(\i)\.guild_id.+?roleColor.+?]}\)))/ ,
match : /MANAGE_ROLES.{0,60}?return(?=\(.+?(\(0,\i\.jsxs\)\("div",{className:\i\(\)\.members.+?guildId:(\i)\.guild_id.+?roleColor.+?]}\)))/ ,
replace : ( m , component , channel ) = > {
replace : ( m , component , channel ) = > {
// Export the channel for the users allowed component patch
// Export the channel for the users allowed component patch
component = component . replace ( canonicalizeMatch ( /(?<=users:\i)/ ) , ` ,channel: ${ channel } ` ) ;
component = component . replace ( canonicalizeMatch ( /(?<=users:\i)/ ) , ` ,channel: ${ channel } ` ) ;
// Always render the component for multiple allowed users
component = component . replace ( canonicalizeMatch ( /1!==\i\.length/ ) , "true" ) ;
return ` ${ m } $ self.isHiddenChannel( ${ channel } ,true)? ${ component } : ` ;
return ` ${ m } $ self.isHiddenChannel( ${ channel } ,true)? ${ component } : ` ;
}
}
@ -311,6 +323,11 @@ export default definePlugin({
// Disable useless components for the HiddenChannelLockScreen of voice channels
// Disable useless components for the HiddenChannelLockScreen of voice channels
match : /(?:{|,)render(?!Header|ExternalHeader).{0,30}?:(?<=renderContent=function.+?)(?!void)/g ,
match : /(?:{|,)render(?!Header|ExternalHeader).{0,30}?:(?<=renderContent=function.+?)(?!void)/g ,
replace : "$&!this.props.inCall&&$self.isHiddenChannel(this.props.channel,true)?null:"
replace : "$&!this.props.inCall&&$self.isHiddenChannel(this.props.channel,true)?null:"
} ,
{
// Disable bad CSS class which mess up hidden voice channels styling
match : /callContainer,(?<=(\i)=\i\.channel.+?\(\)\.callContainer,)/ ,
replace : ( m , channel ) = > ` ${ m } $ self.isHiddenChannel( ${ channel } ,true)?"": `
}
}
]
]
} ,
} ,
@ -426,6 +443,20 @@ export default definePlugin({
return res ;
return res ;
} ,
} ,
makeAllowedRolesReduce ( guildId : string ) {
return [
( prev : Array < Role > , _ : Role , index : number , originalArray : Array < Role > ) = > {
if ( index !== 0 ) return prev ;
const everyoneRole = originalArray . find ( role = > role . id === guildId ) ;
if ( everyoneRole ) return [ everyoneRole ] ;
return originalArray ;
} ,
[ ] as Array < Role >
] ;
} ,
HiddenChannelLockScreen : ( channel : any ) = > < HiddenChannelLockScreen channel = { channel } / > ,
HiddenChannelLockScreen : ( channel : any ) = > < HiddenChannelLockScreen channel = { channel } / > ,
LockIcon : ( ) = > (
LockIcon : ( ) = > (