refactor theme toggle into a service

pull/1026/head
Rigel Kent 2018-09-06 12:00:53 +02:00
parent 1c66c35c55
commit 1a00c5619f
No known key found for this signature in database
GPG Key ID: EA12971B0E438F36
6 changed files with 46 additions and 36 deletions

View File

@ -1,7 +1,7 @@
import { Component, OnInit } from '@angular/core' import { Component, OnInit } from '@angular/core'
import { DomSanitizer, SafeHtml } from '@angular/platform-browser' import { DomSanitizer, SafeHtml } from '@angular/platform-browser'
import { GuardsCheckStart, NavigationEnd, Router } from '@angular/router' import { GuardsCheckStart, NavigationEnd, Router } from '@angular/router'
import { AuthService, RedirectService, ServerService } from '@app/core' import { AuthService, RedirectService, ServerService, ThemeService } from '@app/core'
import { is18nPath } from '../../../shared/models/i18n' import { is18nPath } from '../../../shared/models/i18n'
import { ScreenService } from '@app/shared/misc/screen.service' import { ScreenService } from '@app/shared/misc/screen.service'
import { skip } from 'rxjs/operators' import { skip } from 'rxjs/operators'
@ -37,7 +37,8 @@ export class AppComponent implements OnInit {
private domSanitizer: DomSanitizer, private domSanitizer: DomSanitizer,
private redirectService: RedirectService, private redirectService: RedirectService,
private screenService: ScreenService, private screenService: ScreenService,
private hotkeysService: HotkeysService private hotkeysService: HotkeysService,
private themeService: ThemeService
) { } ) { }
get serverVersion () { get serverVersion () {
@ -155,7 +156,11 @@ export class AppComponent implements OnInit {
new Hotkey('g u', (event: KeyboardEvent): boolean => { new Hotkey('g u', (event: KeyboardEvent): boolean => {
this.router.navigate([ '/videos/upload' ]) this.router.navigate([ '/videos/upload' ])
return false return false
}, undefined, 'Go to the videos upload page') }, undefined, 'Go to the videos upload page'),
new Hotkey('T', (event: KeyboardEvent): boolean => {
this.themeService.toggleDarkTheme()
return false
}, undefined, 'Toggle Dark theme')
]) ])
} }

View File

@ -14,6 +14,7 @@ import { ConfirmComponent, ConfirmService } from './confirm'
import { throwIfAlreadyLoaded } from './module-import-guard' import { throwIfAlreadyLoaded } from './module-import-guard'
import { LoginGuard, RedirectService, UserRightGuard } from './routing' import { LoginGuard, RedirectService, UserRightGuard } from './routing'
import { ServerService } from './server' import { ServerService } from './server'
import { ThemeService } from './theme'
@NgModule({ @NgModule({
imports: [ imports: [
@ -45,6 +46,7 @@ import { ServerService } from './server'
AuthService, AuthService,
ConfirmService, ConfirmService,
ServerService, ServerService,
ThemeService,
LoginGuard, LoginGuard,
UserRightGuard, UserRightGuard,
RedirectService RedirectService

View File

@ -2,4 +2,5 @@ export * from './auth'
export * from './server' export * from './server'
export * from './confirm' export * from './confirm'
export * from './routing' export * from './routing'
export * from './theme'
export * from './core.module' export * from './core.module'

View File

@ -0,0 +1 @@
export * from './theme.service'

View File

@ -0,0 +1,31 @@
import { Injectable } from '@angular/core'
@Injectable()
export class ThemeService {
private theme = document.querySelector('body')
private previousTheme = {}
constructor () {
// initialise the alternative theme with dark theme colors
this.previousTheme['mainBackgroundColor'] = '#111111'
this.previousTheme['mainForegroundColor'] = '#fff'
this.previousTheme['submenuColor'] = 'rgb(32,32,32)'
this.previousTheme['inputColor'] = 'gray'
this.previousTheme['inputPlaceholderColor'] = '#fff'
}
toggleDarkTheme () {
// switch properties
this.switchProperty('mainBackgroundColor')
this.switchProperty('mainForegroundColor')
this.switchProperty('submenuColor')
this.switchProperty('inputColor')
this.switchProperty('inputPlaceholderColor')
}
private switchProperty (property, newValue?) {
const propertyOldvalue = window.getComputedStyle(this.theme).getPropertyValue('--' + property)
this.theme.style.setProperty('--' + property, (newValue) ? newValue : this.previousTheme[property])
this.previousTheme[property] = propertyOldvalue
}
}

View File

@ -1,9 +1,8 @@
import { Component, OnInit, ViewChild } from '@angular/core' import { Component, OnInit, ViewChild } from '@angular/core'
import { UserRight } from '../../../../shared/models/users/user-right.enum' import { UserRight } from '../../../../shared/models/users/user-right.enum'
import { AuthService, AuthStatus, RedirectService, ServerService } from '../core' import { AuthService, AuthStatus, RedirectService, ServerService, ThemeService } from '../core'
import { User } from '../shared/users/user.model' import { User } from '../shared/users/user.model'
import { LanguageChooserComponent } from '@app/menu/language-chooser.component' import { LanguageChooserComponent } from '@app/menu/language-chooser.component'
import { Hotkey, HotkeysService } from 'angular2-hotkeys'
@Component({ @Component({
selector: 'my-menu', selector: 'my-menu',
@ -16,7 +15,6 @@ export class MenuComponent implements OnInit {
user: User user: User
isLoggedIn: boolean isLoggedIn: boolean
userHasAdminAccess = false userHasAdminAccess = false
hotkeys: Hotkey[]
private routesPerRight = { private routesPerRight = {
[UserRight.MANAGE_USERS]: '/admin/users', [UserRight.MANAGE_USERS]: '/admin/users',
@ -24,14 +22,12 @@ export class MenuComponent implements OnInit {
[UserRight.MANAGE_VIDEO_ABUSES]: '/admin/video-abuses', [UserRight.MANAGE_VIDEO_ABUSES]: '/admin/video-abuses',
[UserRight.MANAGE_VIDEO_BLACKLIST]: '/admin/video-blacklist' [UserRight.MANAGE_VIDEO_BLACKLIST]: '/admin/video-blacklist'
} }
private theme = document.querySelector('body')
private previousTheme = { }
constructor ( constructor (
private authService: AuthService, private authService: AuthService,
private serverService: ServerService, private serverService: ServerService,
private redirectService: RedirectService, private redirectService: RedirectService,
private hotkeysService: HotkeysService private themeService: ThemeService
) {} ) {}
ngOnInit () { ngOnInit () {
@ -56,21 +52,6 @@ export class MenuComponent implements OnInit {
} }
} }
) )
// initialise the alternative theme with dark theme colors
this.previousTheme['mainBackgroundColor'] = '#111111'
this.previousTheme['mainForegroundColor'] = '#fff'
this.previousTheme['submenuColor'] = 'rgb(32,32,32)'
this.previousTheme['inputColor'] = 'gray'
this.previousTheme['inputPlaceholderColor'] = '#fff'
this.hotkeys = [
new Hotkey('T', (event: KeyboardEvent): boolean => {
this.toggleDarkTheme()
return false
}, undefined, 'Toggle Dark theme')
]
this.hotkeysService.add(this.hotkeys)
} }
isRegistrationAllowed () { isRegistrationAllowed () {
@ -117,18 +98,7 @@ export class MenuComponent implements OnInit {
} }
toggleDarkTheme () { toggleDarkTheme () {
// switch properties this.themeService.toggleDarkTheme()
this.switchProperty('mainBackgroundColor')
this.switchProperty('mainForegroundColor')
this.switchProperty('submenuColor')
this.switchProperty('inputColor')
this.switchProperty('inputPlaceholderColor')
}
private switchProperty (property, newValue?) {
const propertyOldvalue = window.getComputedStyle(this.theme).getPropertyValue('--' + property)
this.theme.style.setProperty('--' + property, (newValue) ? newValue : this.previousTheme[property])
this.previousTheme[property] = propertyOldvalue
} }
private computeIsUserHasAdminAccess () { private computeIsUserHasAdminAccess () {