Adding aliases for imports
[portal/nonrtric-controlpanel.git] / webapp-frontend / src / app / app.component.ts
1 /*-
2  * ========================LICENSE_START=================================
3  * O-RAN-SC
4  * %%
5  * Copyright (C) 2019 AT&T Intellectual Property
6  * %%
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ========================LICENSE_END===================================
19  */
20 import { Component, OnInit } from '@angular/core';
21 import { UiService } from '@services/ui/ui.service';
22 import { CookieService } from 'ngx-cookie-service';
23
24 @Component({
25   selector: 'nrcp-root',
26   templateUrl: './app.component.html',
27   styleUrls: ['./app.component.scss']
28 })
29 export class AppComponent implements OnInit {
30   darkMode: boolean;
31   private 'DARK_MODE_COOKIE' = 'darkMode';
32
33   constructor(private cookieService: CookieService, private ui: UiService) {
34   }
35
36   ngOnInit() {
37     const dark = this.cookieService.get(this.DARK_MODE_COOKIE);
38     if (dark) {
39       this.ui.darkModeState.next(dark === 'yes');
40     }
41
42     this.ui.darkModeState.subscribe((value) => {
43       this.darkMode = value;
44     });
45   }
46
47   modeToggleSwitch() {
48     this.ui.darkModeState.next(!this.darkMode);
49     this.cookieService.set(this.DARK_MODE_COOKIE, this.darkMode ? 'yes' : 'no');
50   }
51 }