2020-02-27 08:44:03 +01:00
//META{"name":"TimedLightDarkMode","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/TimedLightDarkMode","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/TimedLightDarkMode/TimedLightDarkMode.plugin.js"}*//
2019-03-07 23:15:46 +01:00
class TimedLightDarkMode {
getName ( ) { return "TimedLightDarkMode" ; }
2020-02-12 15:05:53 +01:00
getVersion ( ) { return "1.0.6" ; }
2019-03-07 23:15:46 +01:00
getAuthor ( ) { return "DevilBro" ; }
2019-04-17 10:56:54 +02:00
getDescription ( ) { return "Allows you to automatically change light/dark mode depending on the time of day. Slider is added to the 'Appearance' settings." ; }
2019-03-07 23:15:46 +01:00
2019-09-04 12:34:02 +02:00
constructor ( ) {
2019-04-17 10:56:54 +02:00
this . changelog = {
2019-11-10 19:27:14 +01:00
"improved" : [ [ "New Library Structure & React" , "Restructured my Library and switched to React rendering instead of DOM manipulation" ] ]
2019-04-17 10:56:54 +02:00
} ;
2019-09-04 12:34:02 +02:00
2019-11-14 17:56:26 +01:00
this . patchedModules = {
after : {
RadioGroup : "componentDidMount"
}
2019-03-07 23:15:46 +01:00
} ;
2019-09-04 12:34:02 +02:00
}
initConstructor ( ) {
2019-03-07 23:15:46 +01:00
this . defaults = {
2019-03-07 23:52:24 +01:00
settings : {
running : { value : true }
} ,
2019-03-07 23:15:46 +01:00
values : {
timer1 : { value : 25 } ,
timer2 : { value : 75 }
}
} ;
}
2020-04-11 19:32:58 +02:00
// Legacy
2019-03-07 23:15:46 +01:00
load ( ) { }
start ( ) {
2020-01-17 19:50:31 +01:00
if ( ! window . BDFDB ) window . BDFDB = { myPlugins : { } } ;
if ( window . BDFDB && window . BDFDB . myPlugins && typeof window . BDFDB . myPlugins == "object" ) window . BDFDB . myPlugins [ this . getName ( ) ] = this ;
2019-11-10 19:27:14 +01:00
let libraryScript = document . querySelector ( 'head script#BDFDBLibraryScript' ) ;
2019-05-26 13:55:26 +02:00
if ( ! libraryScript || ( performance . now ( ) - libraryScript . getAttribute ( "date" ) ) > 600000 ) {
2019-03-07 23:15:46 +01:00
if ( libraryScript ) libraryScript . remove ( ) ;
libraryScript = document . createElement ( "script" ) ;
2019-05-26 13:55:26 +02:00
libraryScript . setAttribute ( "id" , "BDFDBLibraryScript" ) ;
2019-03-07 23:15:46 +01:00
libraryScript . setAttribute ( "type" , "text/javascript" ) ;
2019-10-18 10:56:41 +02:00
libraryScript . setAttribute ( "src" , "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js" ) ;
2019-03-07 23:15:46 +01:00
libraryScript . setAttribute ( "date" , performance . now ( ) ) ;
2020-01-14 00:06:07 +01:00
libraryScript . addEventListener ( "load" , _ => { this . initialize ( ) ; } ) ;
2019-03-07 23:15:46 +01:00
document . head . appendChild ( libraryScript ) ;
2019-05-26 13:55:26 +02:00
}
2020-01-17 19:50:31 +01:00
else if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) this . initialize ( ) ;
2020-01-14 00:06:07 +01:00
this . startTimeout = setTimeout ( _ => {
2019-11-01 10:27:07 +01:00
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-03-07 23:15:46 +01:00
}
initialize ( ) {
2020-01-17 19:50:31 +01:00
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
2019-03-07 23:15:46 +01:00
if ( this . started ) return ;
2019-10-22 18:55:25 +02:00
BDFDB . PluginUtils . init ( this ) ;
2019-09-04 12:34:02 +02:00
2019-10-22 18:55:25 +02:00
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
this . startInterval ( ) ;
}
2019-11-01 10:14:50 +01:00
else console . error ( ` %c[ ${ this . getName ( ) } ]%c ` , "color: #3a71c1; font-weight: 700;" , "" , "Fatal Error: Could not load BD functions!" ) ;
2019-03-07 23:15:46 +01:00
}
stop ( ) {
2020-01-17 19:50:31 +01:00
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
2019-10-22 11:37:23 +02:00
this . stopping = true ;
2019-11-01 11:09:32 +01:00
BDFDB . TimeUtils . clear ( this . checkInterval ) ;
2019-09-04 12:34:02 +02:00
2020-02-12 15:05:53 +01:00
BDFDB . DOMUtils . remove ( BDFDB . dotCN . _timedlightdarkmodetimersettings ) ;
2019-09-04 12:34:02 +02:00
2019-10-22 18:55:25 +02:00
BDFDB . PluginUtils . clear ( this ) ;
2019-03-07 23:15:46 +01:00
}
}
2019-09-04 12:34:02 +02:00
2020-04-11 19:32:58 +02:00
// Begin of own functions
2019-09-04 12:34:02 +02:00
2019-11-10 19:27:14 +01:00
processRadioGroup ( e ) {
if ( e . instance . props && Array . isArray ( e . instance . props . options ) && e . instance . props . options [ 0 ] && ( e . instance . props . options [ 0 ] . value == "light" || e . instance . props . options [ 0 ] . value == "dark" ) && e . instance . props . options [ 1 ] && ( e . instance . props . options [ 1 ] . value == "light" || e . instance . props . options [ 1 ] . value == "dark" ) && e . node . parentElement . firstElementChild . innerText && e . node . parentElement . firstElementChild . innerText . toUpperCase ( ) == BDFDB . LanguageUtils . LanguageStrings . THEME . toUpperCase ( ) ) {
2019-10-22 23:04:35 +02:00
let settings = BDFDB . DataUtils . get ( this , "settings" ) ;
2019-11-10 19:27:14 +01:00
let values = BDFDB . DataUtils . get ( this , "values" ) ;
2020-02-12 15:07:26 +01:00
let slider , settingsbox = BDFDB . DOMUtils . create ( ` <div class=" ${ BDFDB . disCNS . _timedlightdarkmodetimersettings + BDFDB . disCN . margintop8 } "></div> ` ) ;
2020-02-12 15:05:53 +01:00
BDFDB . ReactUtils . render ( BDFDB . ReactUtils . createElement ( BDFDB . ReactUtils . Fragment , {
children : [
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
type : "Switch" ,
plugin : this ,
keys : [ "settings" , "running" ] ,
value : settings . running ,
label : ` ${ BDFDB . LanguageUtils . LanguageStrings . THEME } Timer ` ,
tag : BDFDB . LibraryComponents . FormComponents . FormTitle . Tags . H5 ,
onChange : ( value , instance ) => {
this . startInterval ( ) ;
2020-02-12 15:07:26 +01:00
if ( slider ) BDFDB . DOMUtils . toggleClass ( slider , BDFDB . disCN . sliderdisabled , ! value ) ;
2020-02-12 15:05:53 +01:00
}
} ) ,
BDFDB . ReactUtils . elementToReact ( BDFDB . DOMUtils . create ( ` <div class=" ${ BDFDB . disCNS . slider + BDFDB . disCN . margintop20 } ${ ! settings . running ? ( " " + BDFDB . disCN . sliderdisabled ) : "" } "><input type="number" timer="timer1" class=" ${ BDFDB . disCN . sliderinput } " value=" ${ values . timer1 } " readonly=""><input type="number" timer="timer2" class=" ${ BDFDB . disCN . sliderinput } " value=" ${ values . timer2 } " readonly=""><div class=" ${ BDFDB . disCN . slidertrack } "><div class=" ${ BDFDB . disCN . slidermark } " style="left: 0%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">00:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 12.5%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">03:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 25%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">06:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 37.5%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">09:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 50%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">12:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 62.5%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">15:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 75%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">18:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 87.5%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">21:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div><div class=" ${ BDFDB . disCN . slidermark } " style="left: 100%;"><div class=" ${ BDFDB . disCN . slidermarkvalue } ">24:00</div><div class=" ${ BDFDB . disCN . slidermarkdash } "></div></div></div><div class=" ${ BDFDB . disCN . sliderbar } "><div class=" ${ BDFDB . disCN . sliderbarfill } "></div></div><div class=" ${ BDFDB . disCN . slidertrack } "><div class=" ${ BDFDB . disCNS . slidergrabber + BDFDB . disCN . _timedlightdarkmodetimergrabber } " timer="timer1" style="left: ${ values . timer1 } %;"></div><div class=" ${ BDFDB . disCNS . slidergrabber + BDFDB . disCN . _timedlightdarkmodetimergrabber } " timer="timer2" style="left: ${ values . timer2 } %;"></div><div class=" ${ BDFDB . disCNS . slidergrabber + BDFDB . disCN . _timedlightdarkmodedategrabber } " timer="current" style="left: ${ this . getPercent ( new Date ( ) ) } %; cursor: help !important; height: 12px; margin-top: -7px;"></div></div></div> ` ) , node => {
if ( Node . prototype . isPrototypeOf ( node ) ) {
2020-02-12 15:07:26 +01:00
slider = node ;
this . updateSlider ( slider , values ) ;
BDFDB . ListenerUtils . addToChildren ( slider , "mousedown" , BDFDB . dotCN . _timedlightdarkmodetimergrabber , event => { this . dragSlider ( event . currentTarget ) ; } ) ;
BDFDB . ListenerUtils . addToChildren ( slider , "mouseenter" , BDFDB . dotCN . _timedlightdarkmodedategrabber , event => { this . showCurrentTime ( event . currentTarget ) ; } ) ;
2020-02-12 15:05:53 +01:00
}
} )
]
} ) , settingsbox ) ;
2019-11-10 19:27:14 +01:00
e . node . parentElement . appendChild ( settingsbox ) ;
2019-03-07 23:15:46 +01:00
}
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
startInterval ( ) {
2019-11-01 11:09:32 +01:00
BDFDB . TimeUtils . clear ( this . checkInterval ) ;
2019-10-22 20:16:05 +02:00
if ( BDFDB . DataUtils . get ( this , "settings" , "running" ) ) {
2019-11-10 19:27:14 +01:00
let values = BDFDB . DataUtils . get ( this , "values" ) ;
let inverted = values . timer1 > values . timer2 ;
let timer1LOW = this . getTime ( values . timer1 ) , timer2LOW = this . getTime ( values . timer2 ) ;
let timer1HIGH = this . getHighTime ( timer2LOW ) , timer2HIGH = this . getHighTime ( timer1LOW ) ;
2020-01-14 00:06:07 +01:00
let check = _ => {
2019-11-10 19:27:14 +01:00
let currenttime = new Date ( ) ;
let currenthours = currenttime . getHours ( ) ;
let currentminutes = currenttime . getMinutes ( ) ;
2019-03-07 23:52:24 +01:00
if ( inverted ) this . changeTheme ( ! ( this . checkTime ( timer1LOW , timer1HIGH , [ currenthours , currentminutes ] ) ) ) ;
else this . changeTheme ( this . checkTime ( timer2LOW , timer2HIGH , [ currenthours , currentminutes ] ) ) ;
2019-04-17 10:56:54 +02:00
} ;
check ( ) ;
2019-11-01 11:09:32 +01:00
this . checkInterval = BDFDB . TimeUtils . interval ( check , 60000 ) ;
2019-03-07 23:52:24 +01:00
}
2019-03-07 23:15:46 +01:00
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
checkTime ( timerLOW , timerHIGH , time ) {
return timerHIGH [ 0 ] > time [ 0 ] || timerHIGH [ 0 ] == time [ 0 ] && timerHIGH [ 1 ] >= time [ 1 ] || time [ 0 ] > timerLOW [ 0 ] || time [ 0 ] == timerLOW [ 0 ] && time [ 1 ] >= timerLOW [ 1 ] ;
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
changeTheme ( dark ) {
2019-11-10 19:27:14 +01:00
let theme = BDFDB . DiscordUtils . getTheme ( ) ;
2019-11-01 10:50:15 +01:00
if ( dark && theme == BDFDB . disCN . themelight ) BDFDB . LibraryModules . SettingsUtils . updateLocalSettings ( { theme : "dark" } ) ;
else if ( ! dark && theme == BDFDB . disCN . themedark ) BDFDB . LibraryModules . SettingsUtils . updateLocalSettings ( { theme : "light" } ) ;
2019-03-07 23:15:46 +01:00
}
2019-09-04 12:34:02 +02:00
2019-04-17 10:56:54 +02:00
showCurrentTime ( grabber ) {
2019-11-10 19:27:14 +01:00
let currenttime = new Date ( ) ;
let currenthours = currenttime . getHours ( ) ;
let currentminutes = currenttime . getMinutes ( ) ;
let bubble = BDFDB . DOMUtils . create ( ` <span class=" ${ BDFDB . disCN . sliderbubble } "> ${ ( currenthours > 9 ? currenthours : ( "0" + currenthours ) ) + ":" + ( currentminutes > 9 ? currentminutes : ( "0" + currentminutes ) ) } </span> ` ) ;
2019-04-17 10:56:54 +02:00
grabber . appendChild ( bubble ) ;
grabber . style . setProperty ( "left" , ` ${ this . getPercent ( currenttime ) } % ` ) ;
2020-01-14 00:06:07 +01:00
let mouseleave = _ => {
2019-10-23 11:10:01 +02:00
BDFDB . DOMUtils . remove ( bubble ) ;
2019-04-17 10:56:54 +02:00
grabber . removeEventListener ( "mouseleave" , mouseleave ) ;
} ;
grabber . addEventListener ( "mouseleave" , mouseleave ) ;
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
dragSlider ( grabber ) {
2019-11-10 19:27:14 +01:00
let track = grabber . parentNode ;
2019-10-23 11:10:01 +02:00
if ( BDFDB . DOMUtils . containsClass ( track . parentNode , BDFDB . disCN . sliderdisabled ) ) return ;
2020-02-12 15:05:53 +01:00
let timer = grabber . getAttribute ( "timer" ) ;
let input = track . parentNode . querySelector ( ` ${ BDFDB . dotCN . sliderinput } [timer=" ${ timer } "] ` ) ;
2019-11-10 19:27:14 +01:00
let values = BDFDB . DataUtils . get ( this , "values" ) ;
2019-03-07 23:15:46 +01:00
2019-10-23 11:10:01 +02:00
BDFDB . DOMUtils . appendLocalStyle ( "disableTextSelection" , ` *{user-select: none !important;} ` ) ;
2019-03-07 23:15:46 +01:00
2020-02-12 15:05:53 +01:00
let value = values [ timer ] ;
let othervalue = timer == "timer1" ? values . timer2 : values . timer1 ;
2019-11-10 19:27:14 +01:00
let sY = 0 ;
let sHalfW = BDFDB . DOMUtils . getRects ( grabber ) . width / 2 ;
let sMinX = BDFDB . DOMUtils . getRects ( track ) . left ;
let sMaxX = sMinX + BDFDB . DOMUtils . getRects ( track ) . width ;
let bubble = BDFDB . DOMUtils . create ( ` <span class=" ${ BDFDB . disCN . sliderbubble } "> ${ this . getTime ( value , true ) } </span> ` ) ;
2019-03-07 23:15:46 +01:00
grabber . appendChild ( bubble ) ;
2020-01-14 00:06:07 +01:00
let mouseup = _ => {
2019-03-07 23:15:46 +01:00
document . removeEventListener ( "mouseup" , mouseup ) ;
document . removeEventListener ( "mousemove" , mousemove ) ;
2019-10-23 11:10:01 +02:00
BDFDB . DOMUtils . remove ( bubble ) ;
BDFDB . DOMUtils . removeLocalStyle ( "disableTextSelection" ) ;
2020-02-12 15:05:53 +01:00
BDFDB . DataUtils . save ( value , this , "values" , timer ) ;
2019-03-07 23:15:46 +01:00
this . startInterval ( ) ;
} ;
2019-11-10 19:27:14 +01:00
let mousemove = e => {
2019-03-07 23:15:46 +01:00
sY = e . clientX > sMaxX ? sMaxX - sHalfW : ( e . clientX < sMinX ? sMinX - sHalfW : e . clientX - sHalfW ) ;
2019-10-23 11:10:01 +02:00
value = BDFDB . NumberUtils . mapRange ( [ sMinX - sHalfW , sMaxX - sHalfW ] , [ 0 , 100 ] , sY ) ;
2019-03-07 23:15:46 +01:00
input . value = value ;
grabber . style . setProperty ( "left" , value + "%" ) ;
bubble . innerText = this . getTime ( value , true ) ;
2020-02-12 15:05:53 +01:00
values [ timer ] = value ;
2019-03-07 23:15:46 +01:00
this . updateSlider ( track . parentNode , values ) ;
} ;
document . addEventListener ( "mouseup" , mouseup ) ;
document . addEventListener ( "mousemove" , mousemove ) ;
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
updateSlider ( slider , values ) {
2019-11-10 19:27:14 +01:00
let bar = slider . querySelector ( BDFDB . dotCN . sliderbar ) ;
let fill = slider . querySelector ( BDFDB . dotCN . sliderbarfill ) ;
let inverted = values . timer1 > values . timer2 ;
2019-03-07 23:15:46 +01:00
fill . style . setProperty ( "width" , ( inverted ? ( values . timer1 - values . timer2 ) : ( values . timer2 - values . timer1 ) ) + "%" ) ;
fill . style . setProperty ( "margin-left" , ( inverted ? values . timer2 : values . timer1 ) + "%" ) ;
fill . style . setProperty ( "background-color" , inverted ? "#66757F" : "#E0C460" , "important" ) ;
bar . style . setProperty ( "background-color" , inverted ? "#E0C460" : "#66757F" , "important" ) ;
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
getTime ( percent , stringify ) {
2019-11-10 19:27:14 +01:00
let time = BDFDB . NumberUtils . mapRange ( [ 0 , 100 ] , [ 0 , 1440 ] , percent ) / 60 ;
let hours = Math . floor ( time ) ;
let minutes = Math . floor ( ( time - hours ) * 60 ) ;
2019-03-07 23:15:46 +01:00
return stringify ? ( hours > 9 ? hours : ( "0" + hours ) ) + ":" + ( minutes > 9 ? minutes : ( "0" + minutes ) ) : [ hours , minutes ] ;
}
2019-09-04 12:34:02 +02:00
2019-04-17 10:56:54 +02:00
getPercent ( time ) {
if ( ! time ) return 0 ;
2019-11-10 19:27:14 +01:00
let hours = Array . isArray ( time ) ? time [ 0 ] : ( typeof time == "object" && typeof time . getHours == "function" ? time . getHours ( ) : 0 ) ;
let minutes = Array . isArray ( time ) ? time [ 1 ] : ( typeof time == "object" && typeof time . getMinutes == "function" ? time . getMinutes ( ) : 0 ) ;
2019-10-23 11:10:01 +02:00
return BDFDB . NumberUtils . mapRange ( [ 0 , 1440 ] , [ 0 , 100 ] , ( hours * 60 ) + minutes ) ;
2019-04-17 10:56:54 +02:00
}
2019-09-04 12:34:02 +02:00
2019-03-07 23:15:46 +01:00
getHighTime ( timer ) {
2019-11-10 19:27:14 +01:00
let hours = timer [ 0 ] ;
let minutes = timer [ 1 ] - 1 ;
2019-03-07 23:15:46 +01:00
if ( minutes < 0 ) {
minutes = 59 ;
hours -= 1 ;
}
if ( hours < 0 ) hours = 0 ;
return [ hours , minutes ] ;
}
}