1 import { Component, OnInit } from '@angular/core';
3 import { PrometheusService } from '../../../shared/api/prometheus.service';
4 import { Permissions } from '../../../shared/models/permissions';
5 import { AuthStorageService } from '../../../shared/services/auth-storage.service';
9 } from '../../../shared/services/feature-toggles.service';
10 import { SummaryService } from '../../../shared/services/summary.service';
13 selector: 'cd-navigation',
14 templateUrl: './navigation.component.html',
15 styleUrls: ['./navigation.component.scss']
17 export class NavigationComponent implements OnInit {
18 permissions: Permissions;
22 prometheusConfigured = false;
23 enabledFeature$: FeatureTogglesMap$;
26 private authStorageService: AuthStorageService,
27 private prometheusService: PrometheusService,
28 private summaryService: SummaryService,
29 private featureToggles: FeatureTogglesService
31 this.permissions = this.authStorageService.getPermissions();
32 this.enabledFeature$ = this.featureToggles.get();
36 this.summaryService.subscribe((data: any) => {
40 this.summaryData = data;
42 if (this.permissions.configOpt.read) {
43 this.prometheusService.ifAlertmanagerConfigured(() => (this.prometheusConfigured = true));
48 if (this.summaryData && this.summaryData.rbd_mirroring) {
49 if (this.summaryData.rbd_mirroring.errors > 0) {
50 return { color: '#d9534f' };
51 } else if (this.summaryData.rbd_mirroring.warnings > 0) {
52 return { color: '#f0ad4e' };