[Library | Trunk]: Add isDashboad subject on laypout service

git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@60118 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
k.triantafyllou 2020-12-11 18:33:54 +00:00
parent 5f458d8fde
commit a130f208a8
1 changed files with 59 additions and 34 deletions

View File

@ -6,17 +6,17 @@ import {ActivationStart, Router} from "@angular/router";
providedIn: 'root'
})
export class LayoutService {
/**
* Set this to true when sidebar items are ready.
*/
private openSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add hasSidebar: false on data of route config, if sidebar is not needed.
*/
private hasSidebarSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add hasHeader: false on data of route config, if header is not needed.
*/
@ -25,28 +25,37 @@ export class LayoutService {
/**
* Add hasAdminMenu: true on data of route config, if global sidebar should be used.
*/
private _hasAdminMenuSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
private hasAdminMenuSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add hasMiniMenu: true on data of route config, if sidebar should be closed to mini should be used.
*/
private _hasMiniMenuSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
private hasMiniMenuSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add isFrontPage: true on data of route config, if current route is for front page.
*/
private _isFrontPageSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
private _isSmallScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
sub:any;
private isFrontPageSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add isSmallScreen: true on data of route config, if screen is small.
*/
private isSmallScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
/**
* Add isDashboard: false on data of route config, if page is for a stakeholder but not for dashboard.
*/
private isDashboardSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(true);
sub: any;
ngOnDestroy() {
this.clearSubscriptions();
}
clearSubscriptions(){
clearSubscriptions() {
if (this.sub instanceof Subscriber) {
this.sub.unsubscribe();
}
}
constructor(private router: Router) {
this.sub = this.router.events.subscribe(event => {
if (event instanceof ActivationStart) {
@ -87,62 +96,78 @@ export class LayoutService {
} else {
this.setSmallScreen(false);
}
if (data['isDashboard'] !== undefined &&
data['isDashboard'] === false) {
this.setDashboard(false);
} else {
this.setDashboard(true);
}
}
});
}
get open(): boolean {
return this.openSubject.getValue();
}
setOpen(value: boolean) {
this.openSubject.next(value);
}
get hasSidebar(): Observable<boolean> {
return this.hasSidebarSubject.asObservable();
}
setHasSidebar(value: boolean) {
this.hasSidebarSubject.next(value);
}
get hasHeader(): Observable<boolean> {
return this.hasHeaderSubject.asObservable();
}
setHasHeader(value: boolean) {
this.hasHeaderSubject.next(value);
}
get hasAdminMenu(): Observable<boolean> {
return this._hasAdminMenuSubject.asObservable();
return this.hasAdminMenuSubject.asObservable();
}
setHasAdminMenu(value: boolean) {
this._hasAdminMenuSubject.next(value);
this.hasAdminMenuSubject.next(value);
}
get hasMiniMenu(): Observable<boolean> {
return this._hasMiniMenuSubject.asObservable();
return this.hasMiniMenuSubject.asObservable();
}
setHasMiniMenu(value: boolean) {
this._hasMiniMenuSubject.next(value);
this.hasMiniMenuSubject.next(value);
}
get isFrontPage(): Observable<boolean> {
return this._isFrontPageSubject.asObservable();
return this.isFrontPageSubject.asObservable();
}
setFrontPage(value: boolean) {
this._isFrontPageSubject.next(value);
this.isFrontPageSubject.next(value);
}
get isSmallScreen(): boolean{
return this._isSmallScreenSubject.getValue();
get isDashboard(): Observable<boolean> {
return this.isDashboardSubject.asObservable();
}
setDashboard(value: boolean) {
this.isDashboardSubject.next(value);
}
get isSmallScreen(): boolean {
return this.isSmallScreenSubject.getValue();
}
setSmallScreen(value: boolean) {
this._isSmallScreenSubject.next(value);
this.isSmallScreenSubject.next(value);
}
}