]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/app.component.ts
Client: add ability to hide left menu
[github/Chocobozzz/PeerTube.git] / client / src / app / app.component.ts
CommitLineData
e2a2d6c8 1import { Component, OnInit, ViewContainerRef } from '@angular/core';
ab32b0fc 2import { Router } from '@angular/router';
dc8bc31b 3
92fb909c 4import { AuthService, ConfigService } from './core';
6e07c3de 5import { VideoService } from './videos';
e2a2d6c8
C
6import { UserService } from './shared';
7
dc8bc31b 8@Component({
3154f382
C
9 selector: 'my-app',
10 templateUrl: './app.component.html',
11 styleUrls: [ './app.component.scss' ]
dc8bc31b 12})
e2a2d6c8 13export class AppComponent implements OnInit {
7ddd02c9
C
14 notificationOptions = {
15 timeOut: 3000,
16 lastOnBottom: true,
17 clickToClose: true,
18 maxLength: 0,
19 maxStack: 7,
20 showProgressBar: false,
21 pauseOnHover: false,
22 preventDuplicates: false,
23 preventLastDuplicates: 'visible',
24 rtl: false
25 };
26
67167390
C
27 isMenuDisplayed = true;
28
3154f382
C
29 constructor(
30 private router: Router,
e2a2d6c8 31 private authService: AuthService,
92fb909c 32 private configService: ConfigService,
e2a2d6c8 33 private userService: UserService,
6e07c3de 34 private videoService: VideoService,
3154f382
C
35 viewContainerRef: ViewContainerRef
36 ) {}
a99593ed 37
e2a2d6c8
C
38 ngOnInit() {
39 if (this.authService.isLoggedIn()) {
40 // The service will automatically redirect to the login page if the token is not valid anymore
41 this.userService.checkTokenValidity();
42 }
6e07c3de 43
92fb909c 44 this.configService.loadConfig();
6e07c3de 45 this.videoService.loadVideoCategories();
d07137b9 46 this.videoService.loadVideoLicences();
db216afd 47 this.videoService.loadVideoLanguages();
e2a2d6c8
C
48 }
49
beacf699
C
50 isInAdmin() {
51 return this.router.url.indexOf('/admin/') !== -1;
dc8bc31b 52 }
67167390
C
53
54 toggleMenu() {
55 this.isMenuDisplayed = !this.isMenuDisplayed;
56 }
57
58 getMainColClasses() {
59 const colSizes = {
60 md: 10,
61 sm: 9,
62 xs: 9
63 }
64
65 // Take all width is the menu is not displayed
66 if (this.isMenuDisplayed === false) {
67 Object.keys(colSizes).forEach(col => colSizes[col] = 12);
68 }
69
70 const classes = [ "main-col" ];
71 Object.keys(colSizes).forEach(col => classes.push(`col-${col}-${colSizes[col]}`));
72
73 return classes;
74 }
dc8bc31b 75}