X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=webapp%2Fsrc%2Fapp%2F%40core-xds%2Fservices%2Fconfig.service.ts;h=beeeea817e6f591344f88d0f4064a36d9ad1ad88;hb=48739a930ceb0c6a4b843471750da70db2052890;hp=cc4d2375e6fd453accfc4dbb54d5c2e91d4805b4;hpb=a2cc38902ff7528870822110c4f04329a3918564;p=src%2Fxds%2Fxds-agent.git diff --git a/webapp/src/app/@core-xds/services/config.service.ts b/webapp/src/app/@core-xds/services/config.service.ts index cc4d237..beeeea8 100644 --- a/webapp/src/app/@core-xds/services/config.service.ts +++ b/webapp/src/app/@core-xds/services/config.service.ts @@ -18,62 +18,78 @@ import { Injectable } from '@angular/core'; import { CookieService } from 'ngx-cookie'; +import { NbThemeService } from '@nebular/theme'; + import { Observable } from 'rxjs/Observable'; import { BehaviorSubject } from 'rxjs/BehaviorSubject'; -import { AlertService, IAlert } from '../services/alert.service'; - export interface IConfig { - language: string; - projectsRootDir: string; + language: string; + theme: string; + grafanaDashboardUrl: string; } @Injectable() export class ConfigService { - public Conf$: Observable; + public Conf$: Observable; - private confSubject: BehaviorSubject; - private confStore: IConfig; + private confSubject: BehaviorSubject; + private confStore: IConfig; - constructor( - private cookie: CookieService, - private alert: AlertService, - ) { - this.load(); - this.confSubject = >new BehaviorSubject(this.confStore); - this.Conf$ = this.confSubject.asObservable(); - } + private confDefault: IConfig = { + language: 'ENG', + theme: 'default', + grafanaDashboardUrl: 'http://localhost:3000', + }; - // Load config - load() { - // Try to retrieve previous config from cookie - const cookConf = this.cookie.getObject('xds-config'); - if (cookConf != null) { - this.confStore = cookConf; - } else { - // Set default config - this.confStore = { - language: 'ENG', - projectsRootDir: '', - // projects: [] - }; - } - } + constructor( + private cookie: CookieService, + private themeService: NbThemeService, + ) { + this.confSubject = >new BehaviorSubject(this.confStore); + this.Conf$ = this.confSubject.asObservable(); - // Save config into cookie - save() { - // Notify subscribers - this.confSubject.next(Object.assign({}, this.confStore)); + // Save selected theme in cookie + this.themeService.onThemeChange().subscribe(tm => { + if (typeof this.confStore === 'undefined') { + return; + } + if (tm.name !== this.confStore.theme) { + this.confStore.theme = tm.name; + this.save(); + } + }); - // Don't save projects in cookies (too big!) - const cfg = Object.assign({}, this.confStore); - this.cookie.putObject('xds-config', cfg); + // Load initial config and apply it + this.load(); + this.themeService.changeTheme(this.confStore.theme); + } + + // Load config + load() { + // Try to retrieve previous config from cookie + const cookConf = this.cookie.getObject('xds-config'); + if (cookConf != null) { + this.confStore = cookConf; + this.confSubject.next(Object.assign({}, this.confStore)); + } else { + // Set default config + this.confStore = this.confDefault; + this.save(); } + } - set projectsRootDir(p: string) { - this.confStore.projectsRootDir = p; - this.save(); + // Save config into cookie + save(cfg?: IConfig) { + if (typeof cfg !== 'undefined') { + this.confStore = this.confDefault; } + // Notify subscribers + this.confSubject.next(Object.assign({}, this.confStore)); + + this.cookie.putObject('xds-config', this.confStore); + } + }