@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
422 lines • 55.7 kB
JavaScript
import { Breakpoints } from '@angular/cdk/layout';
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { filter, take } from 'rxjs/operators';
import { NAE_ROUTING_CONFIGURATION_PATH } from '../../routing/routing-builder/routing-builder.service';
import { PathService } from '../service/path.service';
import { LEFT_DRAWER_DEFAULT_WIDTH, RIGHT_DRAWER_DEFAULT_MIN_WIDTH, RIGHT_DRAWER_DEFAULT_WIDTH, RIGHT_DRAWER_MAX_WIDTH, } from '../model/navigation-configs';
import { GroupNavigationConstants } from "../model/group-navigation-constants";
import { extractFieldValueFromData } from "../utility/navigation-item-task-utility-methods";
import { LoadingEmitter } from "../../utility/loading-emitter";
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "@angular/cdk/layout";
import * as i3 from "../../translate/language.service";
import * as i4 from "@ngx-translate/core";
import * as i5 from "../../user/services/user.service";
import * as i6 from "../../logger/services/logger.service";
import * as i7 from "../../configuration/configuration.service";
import * as i8 from "../service/path.service";
import * as i9 from "../../resources/engine-endpoint/case-resource.service";
import * as i10 from "../../impersonation/services/impersonation-user-select.service";
import * as i11 from "../../impersonation/services/impersonation.service";
import * as i12 from "./service/double-drawer-navigation.service";
export class AbstractNavigationDoubleDrawerComponent {
_router;
_activatedRoute;
_breakpoint;
_languageService;
_translateService;
_userService;
_log;
_config;
_pathService;
_caseResourceService;
_impersonationUserSelect;
_impersonation;
_navigationService;
portalLeftMenu;
portalRightMenu;
imageRouterLink = '/';
imageAlt = 'Logo';
image;
profileRouterLink = '/profile';
includeUser = true;
includeLanguage = true;
includeMoreMenu = true;
includeImpersonation = true;
allClosable = true;
folderIcon = 'folder';
openedFolderIcon = 'folder_open';
filterIcon = 'filter_alt';
foldersCategoryName = 'toolbar.menu.folders';
viewsCategoryName = 'toolbar.menu.views';
loggedOut = new EventEmitter(true); // on logout
stateChanged = new EventEmitter(); // on menu state change
itemClicked = new EventEmitter(); // on item click
resized = new EventEmitter(true); // on menu resize
itemLoaded = new EventEmitter(true); // on item loaded
hideMoreMenu;
_breakpointSubscription;
_currentNodeSubscription;
_currentPathSubscription;
_loggedUserSubscription;
/**
* Currently display Path
* Siblings of the node are on the left, children are on the right
*/
_currentPath;
_pathResolverLoading$;
_configLeftMenu = {
mode: 'side',
opened: true,
disableClose: false,
width: LEFT_DRAWER_DEFAULT_WIDTH,
};
_configRightMenu = {
mode: 'side',
opened: true,
disableClose: false,
width: RIGHT_DRAWER_DEFAULT_WIDTH,
};
configUrl;
constructor(_router, _activatedRoute, _breakpoint, _languageService, _translateService, _userService, _log, _config, _pathService, _caseResourceService, _impersonationUserSelect, _impersonation, _navigationService) {
this._router = _router;
this._activatedRoute = _activatedRoute;
this._breakpoint = _breakpoint;
this._languageService = _languageService;
this._translateService = _translateService;
this._userService = _userService;
this._log = _log;
this._config = _config;
this._pathService = _pathService;
this._caseResourceService = _caseResourceService;
this._impersonationUserSelect = _impersonationUserSelect;
this._impersonation = _impersonation;
this._navigationService = _navigationService;
let configUrl = this._config.getServicesConfiguration()?.doubleDrawer?.url;
if (configUrl !== undefined && !configUrl.startsWith('/')) {
configUrl = '/' + configUrl;
}
this.configUrl = configUrl;
this.hideMoreMenu = true;
this._navigationService.itemClicked$.subscribe((itemClickEvent) => {
this.itemClicked.emit(itemClickEvent);
});
this._navigationService.itemLoaded$.subscribe((itemLoadedEvent) => {
this.itemLoaded.emit(itemLoadedEvent);
});
this._pathResolverLoading$ = new LoadingEmitter();
}
ngOnInit() {
this._breakpointSubscription = this._breakpoint.observe([Breakpoints.HandsetLandscape]).subscribe(() => {
if (this._breakpoint.isMatched('(max-width: 959.99px)')) {
this.resolveLayout(false);
}
else {
this.resolveLayout(true);
}
});
this._userService.user$.pipe(filter(u => !!u && u.id !== ''), take(1)).subscribe(() => {
this.resolveInitialValueOfPath();
this._currentPathSubscription = this._pathService.activePath$.subscribe(path => {
if (path !== this.currentPath && !this._pathResolverLoading$.isActive) {
this.currentPath = path;
}
else if (!this._pathResolverLoading$.isActive) {
this.openAvailableView();
}
});
if (this.canApplyAutoSelect()) {
this.rightItems$.pipe(filter(rightItems => rightItems.length > 0), take(1)).subscribe(() => {
this.openAvailableView();
});
}
const viewConfigurationPath = this._activatedRoute.snapshot.data[NAE_ROUTING_CONFIGURATION_PATH];
if (!!viewConfigurationPath) {
const viewConfiguration = this._config.getViewByPath(viewConfigurationPath);
this._navigationService.initializeCustomViewsOfView(viewConfiguration, viewConfigurationPath);
}
this.hiddenCustomItems$.subscribe(hiddenCustomItems => {
this.hideMoreMenu = !hiddenCustomItems?.length;
});
});
}
ngOnDestroy() {
this._breakpointSubscription?.unsubscribe();
this.loggedOut.complete();
this.stateChanged.complete();
this.itemClicked.complete();
this.resized.complete();
this.itemLoaded.complete();
this._currentNodeSubscription?.unsubscribe();
this._currentPathSubscription?.unsubscribe();
this._loggedUserSubscription?.unsubscribe();
}
get currentPath() {
return this._navigationService.currentPath;
}
set currentPath(node) {
this._navigationService.currentPath = node;
}
get configLeftMenu() {
return this._configLeftMenu;
}
get configRightMenu() {
return this._configRightMenu;
}
get leftItems$() {
return this._navigationService.leftItems$;
}
get leftItems() {
return this._navigationService.leftItems;
}
get rightItems$() {
return this._navigationService.rightItems$;
}
get rightItems() {
return this._navigationService.rightItems;
}
get moreItems$() {
return this._navigationService.moreItems$;
}
get moreItems() {
return this._navigationService.moreItems;
}
get hiddenCustomItems$() {
return this._navigationService.hiddenCustomItems$;
}
get hiddenCustomItems() {
return this._navigationService.hiddenCustomItems;
}
get leftLoading$() {
return this._navigationService.leftLoading$;
}
get rightLoading$() {
return this._navigationService.rightLoading$;
}
get pathResolverLoading$() {
return this._pathResolverLoading$;
}
toggleMenu() {
this.toggleRightMenu();
if (this.allClosable) {
this.toggleLeftMenu();
}
}
toggleLeftMenu() {
this._configLeftMenu.opened = !this._configLeftMenu.opened;
this.stateChanged.emit({ menu: 'left', isOpened: this._configLeftMenu.opened });
}
toggleRightMenu() {
this._configRightMenu.opened = !this._configRightMenu.opened;
this.stateChanged.emit({ menu: 'right', isOpened: this._configRightMenu.opened });
}
getLang() {
return this._languageService.getLanguage();
}
logout() {
this._userService.logout().subscribe(response => {
this._log.debug('User is logged out');
this.loggedOut.emit(response);
if (this._config.get().services && this._config.get().services.auth && this._config.getOnLogoutPath()) {
const redirectPath = this._config.getOnLogoutPath();
this._log.info('Redirecting to ' + redirectPath);
this._router.navigate([redirectPath]);
}
});
}
impersonate() {
this._impersonationUserSelect.selectImpersonate();
}
stopImpersonating() {
this._impersonation.cease();
}
get user() {
return this._userService.user;
}
get canGoBackLoading$() {
return this._navigationService.canGoBackLoading$;
}
/**
* On home click, the current level is set to 0, and current parent is
* set to root node.
* */
onHomeClick() {
this._navigationService.onHomeClick();
}
/**
* On back click, the parent is set to parent of left nodes, that will solve
* the right side menu (elements that were in left side, after backward
* navigation will be on the right side).
* Current level is set to a lower number in order to set the left side menu.
* */
onBackClick() {
this._navigationService.onBackClick();
}
onItemClick(item) {
this._navigationService.onItemClick(item);
}
loadMoreItems() {
this._navigationService.loadMoreItems();
}
isAscending() {
return this._navigationService.isAscending();
}
switchOrder() {
this._navigationService.switchOrder();
}
/**
* Function to check whether the back button should be displayed
* @returns boolean if the back button should be displayed
* */
isOnZeroLevel() {
return this.currentPath === PathService.SEPARATOR;
}
isItemAndPathEqual(item, path) {
return item.resource?.immediateData.find(f => f.stringId === GroupNavigationConstants.ITEM_FIELD_ID_NODE_PATH)?.value === path;
}
isLeftItemsEmpty() {
return this._navigationService.leftItems === undefined || this._navigationService.leftItems.length === 0;
}
isRightItemsEmpty() {
return this._navigationService.rightItems === undefined || this._navigationService.rightItems.length === 0;
}
itemsTrackBy(index, item) {
return item.id;
}
onResizeEvent(event) {
if (event.rectangle.width > RIGHT_DRAWER_MAX_WIDTH) {
this._configRightMenu.width = RIGHT_DRAWER_MAX_WIDTH;
}
else if (event.rectangle.width < RIGHT_DRAWER_DEFAULT_MIN_WIDTH) {
this._configRightMenu.width = RIGHT_DRAWER_DEFAULT_MIN_WIDTH;
}
else {
this._configRightMenu.width = event.rectangle.width;
}
this.resized.emit({ width: this._configRightMenu.width });
// TODO implement saving drawer width to user preferences
// this.userPreferenceService._drawerWidthChanged$.next(this.width);
// this.contentWidth.next(this.width);
}
resolveLayout(isLargeScreen) {
this._configLeftMenu = isLargeScreen ? {
mode: 'side',
opened: true,
disableClose: true,
width: this._configLeftMenu.width,
} : {
mode: 'over',
opened: false,
disableClose: false,
width: this._configLeftMenu.width,
};
this._configRightMenu = isLargeScreen ? {
mode: 'side',
opened: true,
disableClose: true,
width: this._configRightMenu.width,
} : {
mode: 'over',
opened: false,
disableClose: false,
width: this._configRightMenu.width,
};
}
canApplyAutoSelect() {
return this.configUrl === this._router.url;
}
openAvailableView() {
this._navigationService.openAvailableView();
}
resolveInitialValueOfPath() {
if (this.currentPath === undefined) {
const groupNavigationRoute = this._config.getServicesConfiguration()?.groupNavigation?.groupNavigationRoute;
if (this._router.url.includes(groupNavigationRoute)) {
this._pathResolverLoading$.on();
this._pathService.datafieldsForMenuResolver.pipe(take(1)).subscribe(data => {
this._pathResolverLoading$.off();
let nodePath;
let hasChildren;
try {
nodePath = extractFieldValueFromData(data, GroupNavigationConstants.ITEM_FIELD_ID_NODE_PATH);
hasChildren = extractFieldValueFromData(data, GroupNavigationConstants.ITEM_FIELD_ID_HAS_CHILDREN);
}
catch (e) {
this._log.info("Couldn't resolve menu, skipping...");
}
if (hasChildren && nodePath) {
this._navigationService.fromResolver = true;
this._pathService.activePath = nodePath;
}
else if (nodePath) {
this._navigationService.fromResolver = true;
this._pathService.activePath = this._navigationService.extractParentPath(nodePath);
}
}, error => {
this._pathResolverLoading$.off();
this.currentPath = this._pathService.activePath;
});
}
else {
const viewConfiguration = this._config.getViewByUrl(this._router.url);
if (viewConfiguration?.processUri) {
this._navigationService.fromResolver = true;
this._pathService.activePath = viewConfiguration.processUri;
}
}
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractNavigationDoubleDrawerComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.BreakpointObserver }, { token: i3.LanguageService }, { token: i4.TranslateService }, { token: i5.UserService }, { token: i6.LoggerService }, { token: i7.ConfigurationService }, { token: i8.PathService }, { token: i9.CaseResourceService }, { token: i10.ImpersonationUserSelectService }, { token: i11.ImpersonationService }, { token: i12.DoubleDrawerNavigationService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractNavigationDoubleDrawerComponent, selector: "ncc-abstract-navigation-double-drawer", inputs: { portalLeftMenu: "portalLeftMenu", portalRightMenu: "portalRightMenu", imageRouterLink: "imageRouterLink", imageAlt: "imageAlt", image: "image", profileRouterLink: "profileRouterLink", includeUser: "includeUser", includeLanguage: "includeLanguage", includeMoreMenu: "includeMoreMenu", includeImpersonation: "includeImpersonation", allClosable: "allClosable", folderIcon: "folderIcon", openedFolderIcon: "openedFolderIcon", filterIcon: "filterIcon", foldersCategoryName: "foldersCategoryName", viewsCategoryName: "viewsCategoryName" }, outputs: { loggedOut: "loggedOut", stateChanged: "stateChanged", itemClicked: "itemClicked", resized: "resized", itemLoaded: "itemLoaded" }, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractNavigationDoubleDrawerComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-navigation-double-drawer',
template: '',
}]
}], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.BreakpointObserver }, { type: i3.LanguageService }, { type: i4.TranslateService }, { type: i5.UserService }, { type: i6.LoggerService }, { type: i7.ConfigurationService }, { type: i8.PathService }, { type: i9.CaseResourceService }, { type: i10.ImpersonationUserSelectService }, { type: i11.ImpersonationService }, { type: i12.DoubleDrawerNavigationService }], propDecorators: { portalLeftMenu: [{
type: Input
}], portalRightMenu: [{
type: Input
}], imageRouterLink: [{
type: Input
}], imageAlt: [{
type: Input
}], image: [{
type: Input
}], profileRouterLink: [{
type: Input
}], includeUser: [{
type: Input
}], includeLanguage: [{
type: Input
}], includeMoreMenu: [{
type: Input
}], includeImpersonation: [{
type: Input
}], allClosable: [{
type: Input
}], folderIcon: [{
type: Input
}], openedFolderIcon: [{
type: Input
}], filterIcon: [{
type: Input
}], foldersCategoryName: [{
type: Input
}], viewsCategoryName: [{
type: Input
}], loggedOut: [{
type: Output
}], stateChanged: [{
type: Output
}], itemClicked: [{
type: Output
}], resized: [{
type: Output
}], itemLoaded: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-navigation-double-drawer.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/navigation/navigation-double-drawer/abstract-navigation-double-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {BreakpointObserver, Breakpoints} from '@angular/cdk/layout';\nimport {Component, EventEmitter, Input, OnDestroy, OnInit, Output, TemplateRef} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ResizeEvent} from 'angular-resizable-element';\nimport {Observable, Subscription} from 'rxjs';\nimport {filter, take} from 'rxjs/operators';\nimport {ConfigurationService} from '../../configuration/configuration.service';\nimport {ImpersonationUserSelectService} from '../../impersonation/services/impersonation-user-select.service';\nimport {ImpersonationService} from '../../impersonation/services/impersonation.service';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {CaseResourceService} from '../../resources/engine-endpoint/case-resource.service';\nimport {NAE_ROUTING_CONFIGURATION_PATH} from '../../routing/routing-builder/routing-builder.service';\nimport {LanguageService} from '../../translate/language.service';\nimport {User} from '../../user/models/user';\nimport {UserService} from '../../user/services/user.service';\nimport {PathService} from '../service/path.service';\nimport {\n    ConfigDoubleMenu,\n    LEFT_DRAWER_DEFAULT_WIDTH,\n    NavigationItem,\n    RIGHT_DRAWER_DEFAULT_MIN_WIDTH,\n    RIGHT_DRAWER_DEFAULT_WIDTH,\n    RIGHT_DRAWER_MAX_WIDTH,\n} from '../model/navigation-configs';\nimport {\n    MenuItemClickEvent,\n    MenuItemLoadedEvent,\n    MenuResizeEvent,\n    MenuStateChangeEvent,\n} from '../model/navigation-menu-events';\nimport {DoubleDrawerNavigationService} from \"./service/double-drawer-navigation.service\";\nimport {GroupNavigationConstants} from \"../model/group-navigation-constants\";\nimport {extractFieldValueFromData} from \"../utility/navigation-item-task-utility-methods\";\nimport {LoadingEmitter} from \"../../utility/loading-emitter\";\n\n@Component({\n    selector: 'ncc-abstract-navigation-double-drawer',\n    template: '',\n})\nexport abstract class AbstractNavigationDoubleDrawerComponent implements OnInit, OnDestroy {\n\n    @Input() portalLeftMenu: TemplateRef<any>;\n    @Input() portalRightMenu: TemplateRef<any>;\n    @Input() imageRouterLink: string = '/';\n    @Input() imageAlt: string = 'Logo';\n    @Input() image: string;\n    @Input() profileRouterLink: string = '/profile';\n    @Input() includeUser: boolean = true;\n    @Input() includeLanguage: boolean = true;\n    @Input() includeMoreMenu: boolean = true;\n    @Input() includeImpersonation: boolean = true;\n    @Input() allClosable: boolean = true;\n    @Input() folderIcon: string = 'folder';\n    @Input() openedFolderIcon: string = 'folder_open';\n    @Input() filterIcon: string = 'filter_alt';\n    @Input() foldersCategoryName: string = 'toolbar.menu.folders';\n    @Input() viewsCategoryName: string = 'toolbar.menu.views';\n\n    @Output() loggedOut = new EventEmitter<any>(true); // on logout\n    @Output() stateChanged = new EventEmitter<MenuStateChangeEvent>(); // on menu state change\n    @Output() itemClicked = new EventEmitter<MenuItemClickEvent>(); // on item click\n    @Output() resized = new EventEmitter<MenuResizeEvent>(true); // on menu resize\n    @Output() itemLoaded = new EventEmitter<MenuItemLoadedEvent>(true); // on item loaded\n\n    public hideMoreMenu: boolean;\n    protected _breakpointSubscription: Subscription;\n    protected _currentNodeSubscription: Subscription;\n    protected _currentPathSubscription: Subscription;\n    protected _loggedUserSubscription: Subscription;\n    /**\n     * Currently display Path\n     * Siblings of the node are on the left, children are on the right\n     */\n    protected _currentPath: string;\n    protected _pathResolverLoading$: LoadingEmitter;\n\n    protected _configLeftMenu: ConfigDoubleMenu = {\n        mode: 'side',\n        opened: true,\n        disableClose: false,\n        width: LEFT_DRAWER_DEFAULT_WIDTH,\n    };\n    protected _configRightMenu: ConfigDoubleMenu = {\n        mode: 'side',\n        opened: true,\n        disableClose: false,\n        width: RIGHT_DRAWER_DEFAULT_WIDTH,\n    };\n\n    protected configUrl: string;\n\n    protected constructor(protected _router: Router,\n                          protected _activatedRoute: ActivatedRoute,\n                          protected _breakpoint: BreakpointObserver,\n                          protected _languageService: LanguageService,\n                          protected _translateService: TranslateService,\n                          protected _userService: UserService,\n                          protected _log: LoggerService,\n                          protected _config: ConfigurationService,\n                          protected _pathService: PathService,\n                          protected _caseResourceService: CaseResourceService,\n                          protected _impersonationUserSelect: ImpersonationUserSelectService,\n                          protected _impersonation: ImpersonationService,\n                          protected _navigationService: DoubleDrawerNavigationService) {\n        let configUrl: string = this._config.getServicesConfiguration()?.doubleDrawer?.url;\n        if (configUrl !== undefined && !configUrl.startsWith('/')) {\n            configUrl = '/' + configUrl;\n        }\n        this.configUrl = configUrl;\n        this.hideMoreMenu = true;\n        this._navigationService.itemClicked$.subscribe((itemClickEvent: MenuItemClickEvent) => {\n            this.itemClicked.emit(itemClickEvent);\n        })\n        this._navigationService.itemLoaded$.subscribe((itemLoadedEvent: MenuItemLoadedEvent) => {\n            this.itemLoaded.emit(itemLoadedEvent);\n        })\n        this._pathResolverLoading$ = new LoadingEmitter();\n    }\n\n    public ngOnInit(): void {\n        this._breakpointSubscription = this._breakpoint.observe([Breakpoints.HandsetLandscape]).subscribe(() => {\n            if (this._breakpoint.isMatched('(max-width: 959.99px)')) {\n                this.resolveLayout(false);\n            } else {\n                this.resolveLayout(true);\n            }\n        });\n\n        this._userService.user$.pipe(filter(u => !!u && u.id !== ''), take(1)).subscribe(() => {\n            this.resolveInitialValueOfPath();\n\n            this._currentPathSubscription = this._pathService.activePath$.subscribe(path => {\n                if (path !== this.currentPath && !this._pathResolverLoading$.isActive) {\n                    this.currentPath = path;\n                } else if (!this._pathResolverLoading$.isActive) {\n                    this.openAvailableView();\n                }\n            });\n\n            if (this.canApplyAutoSelect()) {\n                this.rightItems$.pipe(\n                    filter(rightItems => rightItems.length > 0),\n                    take(1)\n                ).subscribe(() => {\n                    this.openAvailableView();\n                })\n            }\n\n            const viewConfigurationPath = this._activatedRoute.snapshot.data[NAE_ROUTING_CONFIGURATION_PATH];\n            if (!!viewConfigurationPath) {\n                const viewConfiguration = this._config.getViewByPath(viewConfigurationPath);\n                this._navigationService.initializeCustomViewsOfView(viewConfiguration, viewConfigurationPath);\n            }\n            this.hiddenCustomItems$.subscribe(hiddenCustomItems => {\n                this.hideMoreMenu = !hiddenCustomItems?.length;\n            })\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this._breakpointSubscription?.unsubscribe();\n        this.loggedOut.complete();\n        this.stateChanged.complete();\n        this.itemClicked.complete();\n        this.resized.complete();\n        this.itemLoaded.complete();\n        this._currentNodeSubscription?.unsubscribe();\n        this._currentPathSubscription?.unsubscribe();\n        this._loggedUserSubscription?.unsubscribe();\n    }\n\n    public get currentPath(): string {\n        return this._navigationService.currentPath;\n    }\n\n    public set currentPath(node: string) {\n        this._navigationService.currentPath = node;\n    }\n\n    public get configLeftMenu() {\n        return this._configLeftMenu;\n    }\n\n    public get configRightMenu() {\n        return this._configRightMenu;\n    }\n\n    public get leftItems$() {\n        return this._navigationService.leftItems$;\n    }\n\n    public get leftItems() {\n        return this._navigationService.leftItems;\n    }\n\n    public get rightItems$() {\n        return this._navigationService.rightItems$;\n    }\n\n    public get rightItems() {\n        return this._navigationService.rightItems;\n    }\n\n    public get moreItems$() {\n        return this._navigationService.moreItems$;\n    }\n\n    public get moreItems() {\n        return this._navigationService.moreItems;\n    }\n\n    public get hiddenCustomItems$() {\n        return this._navigationService.hiddenCustomItems$;\n    }\n\n    public get hiddenCustomItems() {\n        return this._navigationService.hiddenCustomItems;\n    }\n\n    public get leftLoading$() {\n        return this._navigationService.leftLoading$;\n    }\n\n    public get rightLoading$() {\n        return this._navigationService.rightLoading$;\n    }\n\n    public get pathResolverLoading$() {\n        return this._pathResolverLoading$;\n    }\n\n    public toggleMenu() {\n        this.toggleRightMenu();\n        if (this.allClosable) {\n            this.toggleLeftMenu();\n        }\n    }\n\n    public toggleLeftMenu() {\n        this._configLeftMenu.opened = !this._configLeftMenu.opened;\n        this.stateChanged.emit({menu: 'left', isOpened: this._configLeftMenu.opened});\n    }\n\n    public toggleRightMenu() {\n        this._configRightMenu.opened = !this._configRightMenu.opened;\n        this.stateChanged.emit({menu: 'right', isOpened: this._configRightMenu.opened});\n    }\n\n    public getLang() {\n        return this._languageService.getLanguage();\n    }\n\n    public logout(): void {\n        this._userService.logout().subscribe(response => {\n            this._log.debug('User is logged out');\n            this.loggedOut.emit(response);\n            if (this._config.get().services && this._config.get().services.auth && this._config.getOnLogoutPath()) {\n                const redirectPath = this._config.getOnLogoutPath();\n                this._log.info('Redirecting to ' + redirectPath);\n                this._router.navigate([redirectPath]);\n            }\n        });\n    }\n\n    public impersonate(): void {\n        this._impersonationUserSelect.selectImpersonate();\n    }\n\n    public stopImpersonating(): void {\n        this._impersonation.cease();\n    }\n\n    public get user(): User {\n        return this._userService.user;\n    }\n\n    public get canGoBackLoading$(): Observable<boolean> {\n        return this._navigationService.canGoBackLoading$;\n    }\n\n    /**\n     * On home click, the current level is set to 0, and current parent is\n     * set to root node.\n     * */\n    public onHomeClick(): void {\n        this._navigationService.onHomeClick();\n    }\n\n    /**\n     * On back click, the parent is set to parent of left nodes, that will solve\n     * the right side menu (elements that were in left side, after backward\n     * navigation will be on the right side).\n     * Current level is set to a lower number in order to set the left side menu.\n     * */\n    public onBackClick(): void {\n        this._navigationService.onBackClick()\n    }\n\n    public onItemClick(item: NavigationItem): void {\n        this._navigationService.onItemClick(item);\n    }\n\n    public loadMoreItems() {\n        this._navigationService.loadMoreItems();\n    }\n\n    public isAscending() {\n        return this._navigationService.isAscending();\n    }\n\n    public switchOrder() {\n        this._navigationService.switchOrder();\n    }\n\n    /**\n     * Function to check whether the back button should be displayed\n     * @returns boolean if the back button should be displayed\n     * */\n    public isOnZeroLevel(): boolean {\n        return this.currentPath === PathService.SEPARATOR;\n    }\n\n    isItemAndPathEqual(item: NavigationItem, path: