if (isOpen === false) {
this.helpVisible = false
} else {
- this.toggleCheatSheet()
+ this.toggleHelpVisible()
}
})
}
}
public toggleCheatSheet (): void {
+ this.hotkeysService.cheatSheetToggle.next(!this.helpVisible)
+ }
+
+ public toggleHelpVisible (): void {
this.helpVisible = !this.helpVisible
}
}
<span class="language">
<span tabindex="0" (keyup.enter)="openLanguageChooser()" (click)="openLanguageChooser()" i18n-title title="Change the language" class="icon icon-language"></span>
</span>
+ <span class="shortcuts">
+ <span tabindex="0" (keyup.enter)="openHotkeysCheatSheet()" (click)="openHotkeysCheatSheet()" i18n-title title="Show keyboard shortcuts" class="icon icon-shortcuts"></span>
+ </span>
<span class="color-palette">
<span tabindex="0" (keyup.enter)="toggleDarkTheme()" (click)="toggleDarkTheme()" i18n-title title="Toggle dark interface" class="icon icon-moonsun"></span>
</span>
padding-right: $menu-lateral-padding;
width: $menu-width;
- .language, .color-palette {
+ .language, .shortcuts, .color-palette {
display: inline-block;
color: $menu-bottom-color;
cursor: pointer;
background-image: url('../../assets/images/menu/language.png');
}
+ &.icon-shortcuts {
+ position: relative;
+ top: -1px;
+ width: 24px;
+ height: 24px;
+
+ background-image: url('../../assets/images/menu/keyboard.png');
+ background-color: #fff;
+ filter: invert(100%);
+ }
+
&.icon-moonsun {
margin-left: 10px;
position: relative;
import { AuthService, AuthStatus, RedirectService, ServerService, ThemeService } from '../core'
import { User } from '../shared/users/user.model'
import { LanguageChooserComponent } from '@app/menu/language-chooser.component'
+import { HotkeysService } from 'angular2-hotkeys'
@Component({
selector: 'my-menu',
user: User
isLoggedIn: boolean
userHasAdminAccess = false
+ helpVisible = false
private routesPerRight = {
[UserRight.MANAGE_USERS]: '/admin/users',
private authService: AuthService,
private serverService: ServerService,
private redirectService: RedirectService,
- private themeService: ThemeService
+ private themeService: ThemeService,
+ private hotkeysService: HotkeysService
) {}
ngOnInit () {
}
}
)
+
+ this.hotkeysService.cheatSheetToggle.subscribe(isOpen => {
+ this.helpVisible = isOpen
+ })
}
isRegistrationAllowed () {
this.languageChooserModal.show()
}
+ openHotkeysCheatSheet () {
+ this.hotkeysService.cheatSheetToggle.next(!this.helpVisible)
+ }
+
toggleDarkTheme () {
this.themeService.toggleDarkTheme()
}