]>
Commit | Line | Data |
---|---|---|
3b20bdd6 RK |
1 | import { fromEvent } from 'rxjs' |
2 | import { debounceTime } from 'rxjs/operators' | |
67ed6552 C |
3 | import { Injectable } from '@angular/core' |
4 | import { ScreenService } from '../wrappers' | |
3b20bdd6 RK |
5 | |
6 | @Injectable() | |
7 | export class MenuService { | |
8 | isMenuDisplayed = true | |
9 | isMenuChangedByUser = false | |
8544d8f5 | 10 | menuWidth = 240 // should be kept equal to $menu-width |
3b20bdd6 | 11 | |
ac940348 | 12 | constructor ( |
3b20bdd6 RK |
13 | private screenService: ScreenService |
14 | ) { | |
245b9d27 K |
15 | // Do not display menu on small or touch screens |
16 | if (this.screenService.isInSmallView() || this.screenService.isInTouchScreen()) { | |
17 | this.setMenuDisplay(false) | |
3b20bdd6 RK |
18 | } |
19 | ||
245b9d27 | 20 | this.handleWindowResize() |
3b20bdd6 RK |
21 | } |
22 | ||
23 | toggleMenu () { | |
245b9d27 | 24 | this.setMenuDisplay(!this.isMenuDisplayed) |
3b20bdd6 RK |
25 | this.isMenuChangedByUser = true |
26 | } | |
27 | ||
d95bc702 C |
28 | isDisplayed () { |
29 | return this.isMenuDisplayed | |
30 | } | |
31 | ||
245b9d27 K |
32 | setMenuDisplay (display: boolean) { |
33 | this.isMenuDisplayed = display | |
34 | ||
1bfc7b73 C |
35 | if (!this.screenService.isInTouchScreen()) return |
36 | ||
245b9d27 | 37 | // On touch screens, lock body scroll and display content overlay when memu is opened |
1bfc7b73 C |
38 | if (this.isMenuDisplayed) { |
39 | document.body.classList.add('menu-open') | |
40 | this.screenService.onFingerSwipe('left', () => { this.setMenuDisplay(false) }) | |
41 | return | |
245b9d27 | 42 | } |
1bfc7b73 C |
43 | |
44 | document.body.classList.remove('menu-open') | |
245b9d27 K |
45 | } |
46 | ||
3b20bdd6 RK |
47 | onResize () { |
48 | this.isMenuDisplayed = window.innerWidth >= 800 && !this.isMenuChangedByUser | |
49 | } | |
245b9d27 K |
50 | |
51 | private handleWindowResize () { | |
52 | // On touch screens, do not handle window resize event since opened menu is handled with a content overlay | |
1bfc7b73 | 53 | if (this.screenService.isInTouchScreen()) return |
245b9d27 K |
54 | |
55 | fromEvent(window, 'resize') | |
56 | .pipe(debounceTime(200)) | |
57 | .subscribe(() => this.onResize()) | |
58 | } | |
3b20bdd6 | 59 | } |