2020-04-11 17:11:08 +02:00
( _ => {
let DiscordClassModules , DiscordClasses , userId ;
window . global = window ;
2020-04-11 17:20:54 +02:00
window . respondToParent = function ( data = { } ) {
if ( window . parent && typeof window . parent . postMessage == "function" ) window . parent . postMessage ( data , "*" ) ;
2020-04-11 22:03:14 +02:00
if ( data . hostId != null && data . hostName != null ) {
2020-04-11 17:20:54 +02:00
let ipcRenderer = ( require ( "electron" ) || { } ) . ipcRenderer ;
2020-04-11 21:36:14 +02:00
if ( ipcRenderer && typeof ipcRenderer . sendTo == "function" ) ipcRenderer . sendTo ( data . hostId , data . hostName , data ) ;
2020-04-11 17:20:54 +02:00
}
} ;
2020-04-10 21:51:48 +02:00
2020-04-11 17:11:08 +02:00
window . onload = function ( ) {
2020-04-11 17:20:54 +02:00
window . respondToParent ( {
2020-04-11 17:11:08 +02:00
origin : "DiscordPreview" ,
reason : "OnLoad"
2020-04-11 17:20:54 +02:00
} ) ;
2020-04-11 17:11:08 +02:00
} ;
window . onkeyup = function ( e ) {
2020-04-11 17:20:54 +02:00
window . respondToParent ( {
2020-04-11 17:11:08 +02:00
origin : "DiscordPreview" ,
reason : "KeyUp" ,
which : e . which
2020-04-11 17:20:54 +02:00
} ) ;
2020-04-11 17:11:08 +02:00
} ;
window . onmessage = function ( e ) {
2020-04-11 17:37:10 +02:00
let data = e . data || e ;
if ( typeof data === "object" && ( data . origin == "PluginRepo" || data . origin == "ThemeRepo" ) ) {
switch ( data . reason ) {
2020-04-11 17:11:08 +02:00
case "OnLoad" :
document . body . innerHTML = document . body . innerHTML . replace ( /\t|\n|\r/g , "" ) ;
2020-04-11 17:37:10 +02:00
if ( data . username ) {
document . body . innerHTML = document . body . innerHTML . replace ( /REPLACE_USERNAMESMALL/gi , data . username . toLowerCase ( ) ) ;
document . body . innerHTML = document . body . innerHTML . replace ( /REPLACE_USERNAME/gi , data . username ) ;
2019-10-09 14:45:23 +02:00
}
2020-04-11 17:37:10 +02:00
if ( data . id ) {
userId = data . id ;
document . body . innerHTML = document . body . innerHTML . replace ( /REPLACE_USERID/gi , data . id ) ;
2020-04-11 17:11:08 +02:00
}
2020-04-11 17:37:10 +02:00
if ( data . avatar ) document . body . innerHTML = document . body . innerHTML . replace ( /REPLACE_AVATAR/gi , data . avatar . split ( '"' ) . join ( '' ) + "?size=" ) ;
if ( data . discriminator ) document . body . innerHTML = document . body . innerHTML . replace ( /REPLACE_DISCRIMINATOR/gi , data . discriminator ) ;
if ( data . classes ) DiscordClasses = JSON . parse ( data . classes ) ;
2020-04-11 19:29:23 +02:00
if ( data . classmodules || data . classModules ) DiscordClassModules = JSON . parse ( data . classmodules || data . classModules ) ;
2020-04-11 17:11:08 +02:00
if ( disCN != undefined && DiscordClasses != undefined && DiscordClassModules != undefined ) {
2020-04-11 17:12:22 +02:00
let oldHTML = document . body . innerHTML . split ( "REPLACE_CLASS_" ) ;
let newHTML = oldHTML . shift ( ) ;
2020-04-11 17:11:08 +02:00
for ( let html of oldHTML ) {
let reg = /([A-z0-9_]+)(.+)/ . exec ( html ) ;
newHTML += disCN [ reg [ 1 ] ] + reg [ 2 ] ;
}
document . body . innerHTML = newHTML ;
}
2020-04-11 19:29:23 +02:00
if ( data . nativecss || data . nativeCSS ) {
2020-04-11 17:12:22 +02:00
let theme = document . createElement ( "link" ) ;
2020-04-11 17:37:10 +02:00
theme . classList . add ( data . reason ) ;
2020-04-11 17:11:08 +02:00
theme . rel = "stylesheet" ;
2020-04-11 19:29:23 +02:00
theme . href = data . nativecss || data . nativeCSS ;
2020-04-11 17:11:08 +02:00
document . head . appendChild ( theme ) ;
}
2020-04-11 20:10:50 +02:00
if ( data . html || data . htmlClassName ) document . documentElement . className = data . html || data . htmlClassName ;
2020-04-11 17:11:08 +02:00
document . documentElement . classList . add ( "mouse-mode" ) ;
document . documentElement . classList . add ( "full-motion" ) ;
2020-04-11 19:29:23 +02:00
if ( data . titlebar || data . titleBar ) document . querySelector ( ".preview-titlebar" ) . outerHTML = data . titlebar || data . titleBar ;
2020-04-11 17:11:08 +02:00
document . body . firstElementChild . style . removeProperty ( "display" ) ;
2020-04-11 18:43:30 +02:00
let electron = require ( "electron" ) ;
2020-04-11 20:11:56 +02:00
if ( electron && electron . remote ) {
2020-04-11 18:43:30 +02:00
let browserWindow = electron . remote . getCurrentWindow ( ) ;
2020-04-11 20:01:36 +02:00
if ( browserWindow ) document . addEventListener ( "click" , event => {
let button = getParent ( dotCNC . titlebarmacbutton + dotCN . titlebarwinbutton , event . target ) ;
if ( button ) {
2020-04-11 21:06:51 +02:00
if ( button . className . indexOf ( disCN . titlebarmacbuttonclose ) > - 1 || button . className . indexOf ( disCN . titlebarwinbuttonclose ) > - 1 ) browserWindow . close ( ) ;
2020-04-11 20:25:14 +02:00
else if ( button . className . indexOf ( disCN . titlebarmacbuttonmax ) > - 1 || ( button . className . indexOf ( disCN . titlebarwinbuttonminmax ) > - 1 && button . parentElement . lastElementChild != button ) ) {
2020-04-11 20:01:36 +02:00
if ( browserWindow . isMaximized ( ) ) browserWindow . unmaximize ( ) ;
else browserWindow . maximize ( ) ;
}
2020-04-11 20:51:42 +02:00
else if ( button . className . indexOf ( disCN . titlebarmacbuttonmin ) > - 1 || ( button . className . indexOf ( disCN . titlebarwinbuttonminmax ) > - 1 && button . parentElement . lastElementChild == button ) ) browserWindow . minimize ( ) ;
2020-04-11 20:01:36 +02:00
}
} ) ;
2020-04-11 18:43:30 +02:00
}
2020-04-11 17:11:08 +02:00
break ;
case "NewTheme" :
case "CustomCSS" :
case "ThemeFixer" :
2020-04-11 17:37:10 +02:00
document . querySelectorAll ( "style." + data . reason ) . forEach ( theme => theme . remove ( ) ) ;
if ( data . checked ) {
2020-04-11 17:12:22 +02:00
let theme = document . createElement ( "style" ) ;
2020-04-11 17:37:10 +02:00
theme . classList . add ( data . reason ) ;
theme . innerText = data . css ;
2020-04-11 17:11:08 +02:00
document . head . appendChild ( theme ) ;
}
break ;
case "DarkLight" :
2020-04-11 20:06:14 +02:00
if ( data . checked ) {
document . documentElement . className = document . documentElement . className . replace ( new RegExp ( disCN . themedark , "g" ) , disCN . themelight ) ;
document . body . innerHTML = document . body . innerHTML . replace ( new RegExp ( disCN . themedark , "g" ) , disCN . themelight ) ;
}
else {
document . documentElement . className = document . documentElement . className . replace ( new RegExp ( disCN . themelight , "g" ) , disCN . themedark ) ;
document . body . innerHTML = document . body . innerHTML . replace ( new RegExp ( disCN . themelight , "g" ) , disCN . themedark ) ;
}
2020-04-11 17:11:08 +02:00
break ;
case "Normalize" :
2020-04-11 17:12:22 +02:00
let oldHTML2 = document . body . innerHTML . split ( 'class="' ) ;
let newHTML2 = oldHTML2 . shift ( ) ;
for ( let html of oldHTML2 ) {
2020-04-11 17:11:08 +02:00
html = html . split ( '"' ) ;
2020-04-11 17:37:10 +02:00
newHTML2 += 'class="' + ( data . checked ? html [ 0 ] . split ( " " ) . map ( n => n . replace ( /([A-z0-9]+?)-([A-z0-9_-]{6})/g , "$1-$2 da-$1" ) ) . join ( " " ) : html [ 0 ] . split ( " " ) . filter ( n => n . indexOf ( "da-" ) != 0 ) . join ( " " ) ) + '"' + html . slice ( 1 ) . join ( '"' ) ;
2020-04-11 17:11:08 +02:00
}
2020-04-11 17:12:22 +02:00
document . body . innerHTML = newHTML2 ;
2020-04-11 17:11:08 +02:00
break ;
}
2018-10-11 10:21:26 +02:00
}
2020-04-11 17:11:08 +02:00
} ;
2020-04-11 19:09:12 +02:00
let disCN = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
return getDiscordClass ( item , false ) . replace ( "#" , "" ) ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let disCNS = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
return getDiscordClass ( item , false ) . replace ( "#" , "" ) + " " ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let disCNC = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
return getDiscordClass ( item , false ) . replace ( "#" , "" ) + "," ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let dotCN = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
let className = getDiscordClass ( item , true ) ;
return ( className . indexOf ( "#" ) == 0 ? "" : "." ) + className ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let dotCNS = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
let className = getDiscordClass ( item , true ) ;
return ( className . indexOf ( "#" ) == 0 ? "" : "." ) + className + " " ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let dotCNC = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
let className = getDiscordClass ( item , true ) ;
return ( className . indexOf ( "#" ) == 0 ? "" : "." ) + className + "," ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let notCN = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
return ` :not(. ${ getDiscordClass ( item , true ) . split ( "." ) [ 0 ] } ) ` ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let notCNS = new Proxy ( { } , {
2020-04-11 19:02:19 +02:00
get : function ( list , item ) {
return ` :not(. ${ getDiscordClass ( item , true ) . split ( "." ) [ 0 ] } ) ` ;
}
} ) ;
2020-04-11 19:09:12 +02:00
let notCNC = new Proxy ( { } , {
2020-04-11 17:11:08 +02:00
get : function ( list , item ) {
2020-04-11 19:02:19 +02:00
return ` :not(. ${ getDiscordClass ( item , true ) . split ( "." ) [ 0 ] } ), ` ;
2019-04-07 19:07:10 +02:00
}
2020-04-11 17:11:08 +02:00
} ) ;
2020-04-11 19:02:19 +02:00
let getDiscordClass = function ( item , selector ) {
2020-04-11 17:11:08 +02:00
let className = "Preview_undefined" ;
2020-04-11 19:02:19 +02:00
if ( DiscordClasses [ item ] === undefined ) {
2020-04-11 17:11:08 +02:00
if ( userId == "278543574059057154" ) console . warn ( ` %c[Preview]%c ` , 'color:#3a71c1; font-weight:700;' , '' , item + ' not found in DiscordClasses' ) ;
return className ;
}
2020-04-11 19:35:22 +02:00
else if ( ! Array . isArray ( DiscordClasses [ item ] ) || DiscordClasses [ item ] . length != 2 ) {
2020-04-11 17:11:08 +02:00
if ( userId == "278543574059057154" ) console . warn ( ` %c[Preview]%c ` , 'color:#3a71c1; font-weight:700;' , '' , item + ' is not an Array of Length 2 in DiscordClasses' ) ;
return className ;
}
else if ( DiscordClassModules [ DiscordClasses [ item ] [ 0 ] ] === undefined ) {
if ( userId == "278543574059057154" ) console . warn ( ` %c[Preview]%c ` , 'color:#3a71c1; font-weight:700;' , '' , DiscordClasses [ item ] [ 0 ] + ' not found in DiscordClassModules' ) ;
return className ;
}
else if ( DiscordClassModules [ DiscordClasses [ item ] [ 0 ] ] [ DiscordClasses [ item ] [ 1 ] ] === undefined ) {
if ( userId == "278543574059057154" ) console . warn ( ` %c[Preview]%c ` , 'color:#3a71c1; font-weight:700;' , '' , DiscordClasses [ item ] [ 1 ] + ' not found in ' + DiscordClasses [ item ] [ 0 ] + ' in DiscordClassModules' ) ;
return className ;
}
2020-04-11 19:02:19 +02:00
else {
className = DiscordClassModules [ DiscordClasses [ item ] [ 0 ] ] [ DiscordClasses [ item ] [ 1 ] ] ;
if ( selector ) {
className = className . split ( " " ) . filter ( n => n . indexOf ( "da-" ) != 0 ) . join ( selector ? "." : " " ) ;
className = className || "Preview_undefined" ;
}
return className ;
}
2020-04-11 17:11:08 +02:00
} ;
2020-04-11 20:01:36 +02:00
let getParent = function ( listOrSelector , node ) {
let parent = null ;
if ( Node . prototype . isPrototypeOf ( node ) && listOrSelector ) {
let list = NodeList . prototype . isPrototypeOf ( listOrSelector ) ? listOrSelector : typeof listOrSelector == "string" ? document . querySelectorAll ( listOrSelector ) : null ;
if ( list ) for ( let listNode of list ) if ( listNode . contains ( node ) ) {
parent = listNode ;
break ;
}
}
return parent ;
} ;
2020-04-11 18:46:55 +02:00
if ( typeof window . require != "function" ) window . require = function ( ) {
2020-04-11 17:11:08 +02:00
return _ => { } ;
} ;
2020-04-11 18:46:55 +02:00
if ( typeof window . getString != "function" ) window . getString = function ( obj ) {
2020-04-11 17:11:08 +02:00
let string = "" ;
if ( typeof obj == "string" ) string = obj ;
else if ( obj && obj . props ) {
if ( typeof obj . props . children == "string" ) string = obj . props . children ;
else if ( Array . isArray ( obj . props . children ) ) for ( let c of obj . props . children ) string += typeof c == "string" ? c : getString ( c ) ;
}
return string ;
} ;
2020-04-11 18:46:55 +02:00
if ( typeof window . webpackJsonp != "function" ) window . webpackJsonp = function ( ) {
2020-04-11 17:11:08 +02:00
return {
default : {
m : { } ,
c : { }
}
} ;
} ;
2020-04-11 17:20:54 +02:00
2020-04-11 17:11:08 +02:00
let WebModulesFind = function ( filter ) {
const id = "PluginRepo-WebModules" ;
const req = typeof ( window . webpackJsonp ) == "function" ? window . webpackJsonp ( [ ] , { [ id ] : ( module , exports , req ) => exports . default = req } , [ id ] ) . default : window . webpackJsonp . push ( [ [ ] , { [ id ] : ( module , exports , req ) => module . exports = req } , [ [ id ] ] ] ) ;
delete req . m [ id ] ;
delete req . c [ id ] ;
for ( let m in req . c ) {
if ( req . c . hasOwnProperty ( m ) ) {
var module = req . c [ m ] . exports ;
if ( module && module . _ _esModule && module . default && filter ( module . default ) ) return module . default ;
if ( module && filter ( module ) ) return module ;
}
}
} ;
let WebModulesFindByProperties = function ( properties ) {
properties = Array . isArray ( properties ) ? properties : Array . from ( arguments ) ;
let module = WebModulesFind ( module => properties . every ( prop => module [ prop ] !== undefined ) ) ;
if ( ! module ) {
module = { } ;
for ( let property of properties ) module [ property ] = property ;
}
return module ;
} ;
let WebModulesFindByName = function ( name ) {
return WebModulesFind ( module => module . displayName === name ) || "" ;
} ;
if ( ! window . BDV2 ) {
window . BDV2 = { } ;
window . BDV2 . react = window . React ;
window . BDV2 . reactDom = window . ReactDOM ;
window . BDV2 . WebpackModules = { } ;
window . BDV2 . WebpackModules . find = WebModulesFind ;
window . BDV2 . WebpackModules . findByUniqueProperties = WebModulesFindByProperties ;
window . BDV2 . WebpackModules . findByDisplayName = WebModulesFindByName ;
2020-04-11 00:23:38 +02:00
}
2020-04-11 17:11:08 +02:00
if ( ! window . BdApi ) {
window . BdApi = { } ;
window . BdApi . getData = _ => { return { } ; } ;
window . BdApi . loadData = _ => { return { } ; } ;
window . BdApi . saveData = _ => { } ;
window . BdApi . React = window . React ;
window . BdApi . ReactDOM = window . ReactDOM ;
window . BdApi . findModule = WebModulesFind ;
window . BdApi . findModuleByProps = WebModulesFindByProperties ;
window . BdApi . findModuleByDisplayName = WebModulesFindByName ;
2020-04-11 00:23:38 +02:00
}
2020-04-11 17:11:08 +02:00
} ) ( ) ;