import { Component, OnInit, ViewChild } from '@angular/core'
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 { LanguageChooserComponent } from '@app/menu/language-chooser.component'
-import { Hotkey, HotkeysService } from 'angular2-hotkeys'
+import { HotkeysService } from 'angular2-hotkeys'
@Component({
selector: 'my-menu',
styleUrls: [ './menu.component.scss' ]
})
export class MenuComponent implements OnInit {
- @ViewChild('languageChooserModal') languageChooserModal: LanguageChooserComponent
+ @ViewChild('languageChooserModal', { static: true }) languageChooserModal: LanguageChooserComponent
user: User
isLoggedIn: boolean
userHasAdminAccess = false
- hotkeys: Hotkey[]
+ helpVisible = false
- private routesPerRight = {
+ private routesPerRight: { [ role in UserRight ]?: string } = {
[UserRight.MANAGE_USERS]: '/admin/users',
[UserRight.MANAGE_SERVER_FOLLOW]: '/admin/friends',
- [UserRight.MANAGE_VIDEO_ABUSES]: '/admin/video-abuses',
- [UserRight.MANAGE_VIDEO_BLACKLIST]: '/admin/video-blacklist'
+ [UserRight.MANAGE_VIDEO_ABUSES]: '/admin/moderation/video-abuses',
+ [UserRight.MANAGE_VIDEO_BLACKLIST]: '/admin/moderation/video-blacklist',
+ [UserRight.MANAGE_JOBS]: '/admin/jobs',
+ [UserRight.MANAGE_CONFIGURATION]: '/admin/config'
}
- private theme = document.querySelector('body')
- private previousTheme = { }
constructor (
private authService: AuthService,
private serverService: ServerService,
private redirectService: RedirectService,
+ private themeService: ThemeService,
private hotkeysService: HotkeysService
) {}
}
)
- // 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)
+ this.hotkeysService.cheatSheetToggle.subscribe(isOpen => {
+ this.helpVisible = isOpen
+ })
}
isRegistrationAllowed () {
UserRight.MANAGE_USERS,
UserRight.MANAGE_SERVER_FOLLOW,
UserRight.MANAGE_VIDEO_ABUSES,
- UserRight.MANAGE_VIDEO_BLACKLIST
+ UserRight.MANAGE_VIDEO_BLACKLIST,
+ UserRight.MANAGE_JOBS,
+ UserRight.MANAGE_CONFIGURATION
]
for (const adminRight of adminRights) {
this.languageChooserModal.show()
}
- 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
+ openHotkeysCheatSheet () {
+ this.hotkeysService.cheatSheetToggle.next(!this.helpVisible)
}
private computeIsUserHasAdminAccess () {