UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

422 lines 55.7 kB
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: