import {ChangeDetectorRef, Component, OnDestroy, OnInit} from '@angular/core'; import {ActivatedRoute, NavigationEnd, Router} from '@angular/router'; import {EnvProperties} from './openaireLibrary/utils/properties/env-properties'; import {EnvironmentSpecificService} from './openaireLibrary/utils/properties/environment-specific.service'; import {User} from './openaireLibrary/login/utils/helper.class'; import {UserManagementService} from "./openaireLibrary/services/user-management.service"; import {SideBarService} from "./library/sharedComponents/sidebar/sideBar.service"; import {StakeholderService} from "./services/stakeholder.service"; import {Subscriber} from "rxjs"; @Component({ selector: 'app-root', templateUrl: './app.component.html' }) export class AppComponent implements OnInit, OnDestroy { properties: EnvProperties; user: User; loginCheck: boolean = false; hasSidebar: boolean = false; public subscriptions: any[] = []; constructor(private route: ActivatedRoute, private propertiesService: EnvironmentSpecificService, private router: Router, private userManagementService: UserManagementService, private sidebarService: SideBarService, private stakeholderService: StakeholderService, private cdr: ChangeDetectorRef) { } ngOnInit() { this.propertiesService.loadEnvironment() .then(properties => { this.properties = properties; this.router.events.forEach((event) => { if (event instanceof NavigationEnd) { let r = this.route; while (r.firstChild) { r = r.firstChild; } r.params.subscribe(params => { if (params['stakeholder']) { if (!this.stakeholderService.stakeholder || this.stakeholderService.stakeholder.alias !== params['stakeholder']) { this.stakeholderService.getStakeholder(this.properties.monitorServiceAPIURL, params['stakeholder']).subscribe(stakeholder => { this.stakeholderService.setStakeholder(stakeholder); console.log(stakeholder); this.sidebarService.setOpen(true); }); } } else { this.stakeholderService.setStakeholder(null); } }); } }); this.userManagementService.getUserInfo(this.properties.userInfoUrl).subscribe(user => { this.user = user; this.loginCheck = true; }, error => { console.log("App couldn't fetch properties"); console.log(error); }); }); this.subscriptions.push(this.sidebarService.hasSidebar.subscribe(hasSidebar => { this.hasSidebar = hasSidebar; this.cdr.detectChanges(); })); } public ngOnDestroy() { this.subscriptions.forEach(value => { if (value instanceof Subscriber) { value.unsubscribe(); } }); } public get open() { return this.sidebarService.open; } public toggleOpen(event = null) { if (!event) { this.sidebarService.setOpen(!this.open); } else if (event && event['value'] === true) { this.sidebarService.setOpen(false); } } }