UNPKG

ad-custom-lib

Version:

This is an UI custom library based on Adminlte library with purpose for personal use, if you need a full template of Primeng please visit https://github.com/mledour/angular-admin-lte

687 lines 63 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, NgZone, QueryList, Renderer2, ViewChild, ViewChildren } from '@angular/core'; import { NavigationEnd, PRIMARY_OUTLET, Router, ActivatedRoute } from '@angular/router'; import { removeListeners, removeSubscriptions } from '../../helpers'; import { RoutingService } from '../../services/routing.service'; import { HeaderService } from '../header/header.service'; import { LayoutStore } from '../layout.store'; import { WrapperService } from '../wrapper/wrapper.service'; import { SidebarLeftToggleDirective } from './sidebar-left.directive'; /** * @record */ export function Item() { } if (false) { /** @type {?} */ Item.prototype.id; /** @type {?} */ Item.prototype.parentId; /** @type {?} */ Item.prototype.label; /** @type {?|undefined} */ Item.prototype.route; /** @type {?|undefined} */ Item.prototype.iconClasses; /** @type {?|undefined} */ Item.prototype.children; /** @type {?|undefined} */ Item.prototype.isActive; /** @type {?|undefined} */ Item.prototype.isCollapsed; /** @type {?|undefined} */ Item.prototype.disableCollapse; } export class SidebarLeftComponent { /** * \@method constructor * @param {?} changeDetectorRef [description] * @param {?} layoutStore [description] * @param {?} ngZone [description] * @param {?} renderer2 [description] * @param {?} router [description] * @param {?} routingService [description] * @param {?} wrapperService [description] * @param {?} headerService [description] * @param {?} activatedRoute */ constructor(changeDetectorRef, layoutStore, ngZone, renderer2, router, routingService, wrapperService, headerService, activatedRoute) { this.changeDetectorRef = changeDetectorRef; this.layoutStore = layoutStore; this.ngZone = ngZone; this.renderer2 = renderer2; this.router = router; this.routingService = routingService; this.wrapperService = wrapperService; this.headerService = headerService; this.activatedRoute = activatedRoute; this.collapsedItems = []; this.activatedItems = []; this.toggleListeners = []; this.listeners = []; this.itemsByIds = {}; this.runningAnimations = 0; this.subscriptions = []; } /** * \@method ngOnInit * @return {?} */ ngOnInit() { this.subscriptions.push(this.layoutStore.sidebarLeftMenu.subscribe((/** * @param {?} value * @return {?} */ value => { this.menu = value; this.monkeyPatchMenu(this.menu); if (this.initialized) { this.setMenuListeners(this.activeUrl); this.setSidebarListeners(); this.setMenuTogglesListeners(); } this.initialized = true; }))); this.subscriptions.push(this.layoutStore.sidebarLeftMenuActiveUrl.subscribe((/** * @param {?} value * @return {?} */ value => { this.activeUrl = value; this.setMenuListeners(value); }))); this.subscriptions.push(this.routingService.events.subscribe((/** * @param {?} event * @return {?} */ (event) => { /** @type {?} */ let url; if (event instanceof NavigationEnd) { url = event.url; } else { url = this.router.url; } this.activeUrl = url; this.setMenuListeners(url); // console.log(url) }))); this.setSidebarListeners(); } /** * \@method ngAfterViewInit * @return {?} */ ngAfterViewInit() { this.setMenuTogglesListeners(); this.checkMenuWithoutChildren(); } /** * \@method ngOnDestroy * @return {?} */ ngOnDestroy() { this.subscriptions = removeSubscriptions(this.subscriptions); this.listeners = removeListeners(this.listeners); this.toggleListeners = removeListeners(this.toggleListeners); } /** * [setSidebarListeners description] * \@method setSidebarListeners * @return {?} */ setSidebarListeners() { this.subscriptions.push(this.layoutStore.layout.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.layout = value; this.setSidebarHeight(); }))); this.subscriptions.push(this.layoutStore.windowInnerHeight.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.windowInnerHeight = value; this.setSidebarHeight(); }))); this.subscriptions.push(this.layoutStore.sidebarLeftMenu.subscribe((/** * @return {?} */ () => { this.changeDetectorRef.detectChanges(); }))); this.ngZone.runOutsideAngular((/** * @return {?} */ () => { this.listeners.push(this.renderer2.listen(this.sidebarElement.nativeElement, 'mouseenter', (/** * @return {?} */ () => { this.layoutStore.sidebarLeftMouseOver(true); }))); this.listeners.push(this.renderer2.listen(this.sidebarElement.nativeElement, 'mouseleave', (/** * @return {?} */ () => { this.layoutStore.sidebarLeftMouseOver(false); }))); })); this.subscriptions.push(this.layoutStore.windowInnerWidth.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.windowInnerWidth = value; if (!this.isSidebarLeftCollapsed && this.windowInnerWidth <= 767) { this.layoutStore.sidebarLeftCollapsed(true); } else if (this.windowInnerWidth > 767 && this.isSidebarLeftCollapsed && !this.isSidebarLeftExpandOnOver) { this.layoutStore.sidebarLeftCollapsed(false); } }))); this.subscriptions.push(this.layoutStore.isSidebarLeftMouseOver.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.isSidebarLeftMouseOver = value; if (this.isSidebarLeftExpandOnOver) { this.layoutStore.sidebarLeftCollapsed(!value); } }))); this.subscriptions.push(this.layoutStore.isSidebarLeftExpandOnOver.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.isSidebarLeftExpandOnOver = value; if (this.windowInnerWidth > 767 && this.isSidebarLeftCollapsed !== undefined) { this.layoutStore.sidebarLeftCollapsed(value); } }))); this.subscriptions.push(this.layoutStore.isSidebarLeftCollapsed.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.isSidebarLeftCollapsed = value; if (this.windowInnerWidth <= 767) { if (value) { this.renderer2.removeClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-open'); } else { this.renderer2.addClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-open'); } } else { if (this.isSidebarLeftExpandOnOver && !this.isSidebarLeftMouseOver && !value) { this.layoutStore.sidebarLeftExpandOnOver(false); } if (value) { this.renderer2.addClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-collapse'); if (this.isSidebarLeftExpandOnOver) { this.renderer2.removeClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-expanded-on-hover'); } } else { this.renderer2.removeClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-collapse'); if (this.isSidebarLeftExpandOnOver) { this.renderer2.addClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-expanded-on-hover'); } } } }))); this.subscriptions.push(this.layoutStore.isSidebarLeftMini.subscribe((/** * @param {?} value * @return {?} */ (value) => { if (value) { this.renderer2.addClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-mini'); } else { this.renderer2.removeClass(this.wrapperService.wrapperElementRef.nativeElement, 'sidebar-mini'); } }))); } /** * [setMenuListeners description] * \@method setMenuListeners * @param {?} url * @return {?} */ setMenuListeners(url) { if (url === '/') { this.activeItems(url); this.changeDetectorRef.detectChanges(); } else { /** @type {?} */ const primaryOutlet = this.router.parseUrl(url).root.children[PRIMARY_OUTLET]; if (primaryOutlet) { // console.log(primaryOutlet) // this.activeItems('/' + primaryOutlet.toString()); this.activeItems(primaryOutlet.toString()); this.changeDetectorRef.detectChanges(); } } if (this.windowInnerWidth <= 767 || this.isSidebarLeftExpandOnOver) { this.layoutStore.sidebarLeftCollapsed(true); } } /** * [getIconClasses description] * \@method getIconClasses * @param {?} item [description] * @return {?} [description] */ getIconClasses(item) { if (item.iconClasses || item.iconClasses === '') { return item.iconClasses; } else { return 'fa fa-dot-circle-o'; } } /** * [visibilityStateStart description] * \@method visibilityStateStart * @param {?} event [description] * @return {?} */ visibilityStateStart(event) { this.runningAnimations++; this.ngZone.runOutsideAngular((/** * @return {?} */ () => { setTimeout((/** * @return {?} */ () => { this.runningAnimations--; if (!this.runningAnimations) { this.layoutStore.setSidebarLeftElementHeight(this.sidebarElement.nativeElement.offsetHeight); } }), event.totalTime); })); } /** * [uncollapseItemParents description] * \@method uncollapseItemParents * @private * @param {?} item [description] * @param {?=} isActive [description] * @return {?} */ uncollapseItemParents(item, isActive = false) { if (isActive) { item.isActive = true; this.activatedItems.push(item); } // console.log(item) // console.log(isActive) item.isCollapsed = false; this.collapsedItems.push(item); if (item.parentId) { this.uncollapseItemParents(this.itemsByIds[item.parentId], isActive); } } /** * [findItemsByUrl description] * \@method findItemsByUrl * @private * @param {?} url [description] * @param {?} items [description] * @param {?=} returnItems [description] * @return {?} [description] */ findItemsByUrl(url, items, returnItems = []) { items.forEach((/** * @param {?} item * @return {?} */ (item) => { if (item.route === url) { returnItems.push(item); } else if (item.children) { this.findItemsByUrl(url, item.children, returnItems); } else if (url.includes(item.route) && item.route != '/') { returnItems.push(item); } })); return returnItems; } /** * [activeItems description] * \@method activeItems * @private * @param {?} url [description] * @return {?} */ activeItems(url) { this.activatedItems.forEach((/** * @param {?} item * @return {?} */ (item) => { item.isActive = false; })); this.activatedItems = []; this.collapsedItems.forEach((/** * @param {?} item * @return {?} */ (item) => { item.isActive = false; item.isCollapsed = true; })); this.collapsedItems = []; // console.log(url) /** @type {?} */ const items = this.findItemsByUrl(url, this.menu); items.forEach((/** * @param {?} item * @return {?} */ item => { item.isActive = true; this.uncollapseItemParents(item, true); this.activatedItems.push(item); })); } /** * [monkeyPatchMenu description] * \@method monkeyPatchMenu * @private * @param {?} items [description] * @param {?=} parentId [description] * @return {?} */ monkeyPatchMenu(items, parentId) { items.forEach((/** * @param {?} item * @param {?} index * @return {?} */ (item, index) => { item.id = parentId ? Number(parentId + '' + (index + 1)) : index + 1; if (parentId) { item.parentId = parentId; } if (!item.disableCollapse) { item.isCollapsed = true; } item.isActive = false; if (parentId || item.children) { this.itemsByIds[item.id] = item; } if (item.children) { this.monkeyPatchMenu(item.children, item.id); } })); } /** * [setMenuTogglesListeners description] * \@method setMenuTogglesListeners * @private * @return {?} */ setMenuTogglesListeners() { this.toggleListeners = removeListeners(this.toggleListeners); this.ngZone.runOutsideAngular((/** * @return {?} */ () => { this.sidebarLeftToggleDirectives.forEach((/** * @param {?} menuToggle * @return {?} */ (menuToggle) => { this.toggleListeners.push(this.renderer2.listen(menuToggle.elementRef.nativeElement, 'click', (/** * @param {?} event * @return {?} */ (event) => { event.preventDefault(); if (menuToggle.item.isCollapsed) { this.collapsedItems.forEach((/** * @param {?} item * @return {?} */ (item) => { if (!item.disableCollapse) { item.isCollapsed = true; } })); this.collapsedItems = []; this.uncollapseItemParents(menuToggle.item); } else { menuToggle.item.isCollapsed = !menuToggle.item.isCollapsed; } this.changeDetectorRef.detectChanges(); }))); })); })); } /** * [checkMenuWithoutChildren description] * \@method checkMenuWithoutChildren * @private * @return {?} */ checkMenuWithoutChildren() { /** @type {?} */ let menuHaveChildren; this.menu.forEach((/** * @param {?} item * @return {?} */ (item) => { if (item.children) { return menuHaveChildren = true; } })); if (!menuHaveChildren) { this.ngZone.runOutsideAngular((/** * @return {?} */ () => { setTimeout((/** * @return {?} */ () => { this.layoutStore.setSidebarLeftElementHeight(this.sidebarElement.nativeElement.offsetHeight); })); })); } } /** * [setSidebarHeight description] * \@method setSidebarHeight * @private * @return {?} */ setSidebarHeight() { if (this.layout === 'fixed') { /** @type {?} */ const height = this.windowInnerHeight - this.headerService.offsetHeight; if (height && height !== this.sidebarHeight) { this.sidebarHeight = height; this.sidebarOverflow = 'auto'; this.changeDetectorRef.detectChanges(); } } else if (this.sidebarHeight) { this.sidebarOverflow = this.sidebarHeight = null; this.changeDetectorRef.detectChanges(); } } } SidebarLeftComponent.decorators = [ { type: Component, args: [{ selector: 'mk-layout-sidebar-left', template: "<aside class=\"main-sidebar\">\r\n <section class=\"sidebar\" #sidebarElement [style.height.px]=\"sidebarHeight\" [style.overflow]=\"sidebarOverflow\">\r\n <ng-content></ng-content>\r\n <ul class=\"sidebar-menu\">\r\n <ng-container *ngFor=\"let item of menu\">\r\n <ng-container *ngTemplateOutlet=\"sidebarInner; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ul>\r\n </section>\r\n</aside>\r\n\r\n<ng-template #sidebarInner let-item=\"item\">\r\n <li [class.active]=\"item.isActive\" [class.header]=\"item.separator\" [class.menu-open]=\"!item.isCollapsed\">\r\n <span *ngIf=\"item.separator\">{{item.label}}</span>\r\n <a *ngIf=\"!item.separator && item.route\" [routerLink]=\"item.route\">\r\n <i [class]=\"getIconClasses(item)\"></i><span>{{item.label}}</span>\r\n <span *ngIf=\"item.children || item.pullRights\" class=\"pull-right-container\">\r\n <span *ngFor=\"let rightItem of item.pullRights\"\r\n class=\"pull-right {{rightItem.classes}}\">{{rightItem.text}}</span>\r\n <i *ngIf=\"!item.pullRights\" class=\"fa fa-angle-left pull-right\"></i>\r\n </span>\r\n </a>\r\n <a *ngIf=\"!item.separator && !item.route\" href=\"#\" [mkMenuToggle]=\"item\">\r\n <i [class]=\"getIconClasses(item)\"></i><span>{{item.label}}</span>\r\n <span *ngIf=\"item.children || item.pullRights\" class=\"pull-right-container\">\r\n <span *ngFor=\"let rightItem of item.pullRights\"\r\n class=\"pull-right {{rightItem.classes}}\">{{rightItem.text}}</span>\r\n <i *ngIf=\"!item.pullRights\" class=\"fa fa-angle-left pull-right\"></i>\r\n </span>\r\n </a>\r\n <ul *ngIf=\"item.children\" [mkCollapseAnimation]=\"item.isCollapsed\"\r\n (mkCollapseAnimation.start)=\"visibilityStateStart($event)\" class=\"treeview-menu\">\r\n <ng-container *ngFor=\"let item of item.children\">\r\n <ng-container *ngTemplateOutlet=\"sidebarInner; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ul>\r\n </li>\r\n</ng-template>", changeDetection: ChangeDetectionStrategy.OnPush, styles: [".treeview-menu.collapse{display:none}.treeview-menu,.treeview-menu.collapse.in{display:block}"] }] } ]; /** @nocollapse */ SidebarLeftComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: LayoutStore }, { type: NgZone }, { type: Renderer2 }, { type: Router }, { type: RoutingService }, { type: WrapperService }, { type: HeaderService }, { type: ActivatedRoute } ]; SidebarLeftComponent.propDecorators = { sidebarElement: [{ type: ViewChild, args: ['sidebarElement', { static: true },] }], sidebarLeftToggleDirectives: [{ type: ViewChildren, args: [SidebarLeftToggleDirective,] }] }; if (false) { /** @type {?} */ SidebarLeftComponent.prototype.menu; /** @type {?} */ SidebarLeftComponent.prototype.sidebarHeight; /** @type {?} */ SidebarLeftComponent.prototype.sidebarOverflow; /** * @type {?} * @private */ SidebarLeftComponent.prototype.layout; /** * @type {?} * @private */ SidebarLeftComponent.prototype.isSidebarLeftCollapsed; /** * @type {?} * @private */ SidebarLeftComponent.prototype.isSidebarLeftExpandOnOver; /** * @type {?} * @private */ SidebarLeftComponent.prototype.isSidebarLeftMouseOver; /** * @type {?} * @private */ SidebarLeftComponent.prototype.windowInnerWidth; /** * @type {?} * @private */ SidebarLeftComponent.prototype.windowInnerHeight; /** * @type {?} * @private */ SidebarLeftComponent.prototype.collapsedItems; /** * @type {?} * @private */ SidebarLeftComponent.prototype.activatedItems; /** * @type {?} * @private */ SidebarLeftComponent.prototype.toggleListeners; /** * @type {?} * @private */ SidebarLeftComponent.prototype.listeners; /** * @type {?} * @private */ SidebarLeftComponent.prototype.itemsByIds; /** * @type {?} * @private */ SidebarLeftComponent.prototype.runningAnimations; /** * @type {?} * @private */ SidebarLeftComponent.prototype.subscriptions; /** * @type {?} * @private */ SidebarLeftComponent.prototype.activeUrl; /** * @type {?} * @private */ SidebarLeftComponent.prototype.initialized; /** @type {?} */ SidebarLeftComponent.prototype.sidebarElement; /** @type {?} */ SidebarLeftComponent.prototype.sidebarLeftToggleDirectives; /** * @type {?} * @private */ SidebarLeftComponent.prototype.changeDetectorRef; /** * @type {?} * @private */ SidebarLeftComponent.prototype.layoutStore; /** * @type {?} * @private */ SidebarLeftComponent.prototype.ngZone; /** * @type {?} * @private */ SidebarLeftComponent.prototype.renderer2; /** * @type {?} * @private */ SidebarLeftComponent.prototype.router; /** * @type {?} * @private */ SidebarLeftComponent.prototype.routingService; /** * @type {?} * @private */ SidebarLeftComponent.prototype.wrapperService; /** * @type {?} * @private */ SidebarLeftComponent.prototype.headerService; /** * @type {?} * @private */ SidebarLeftComponent.prototype.activatedRoute; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-left.component.js","sourceRoot":"ng://ad-custom-lib/","sources":["lib/layout/sidebar-left/sidebar-left.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, NgZone,\r\n    OnDestroy, OnInit, QueryList, Renderer2, ViewChild, ViewChildren\r\n} from '@angular/core';\r\nimport { Event as RouterEvent, NavigationEnd, PRIMARY_OUTLET, Router, ActivatedRoute } from '@angular/router';\r\n\r\nimport { AnimationEvent } from '../../animations/animations.interface';\r\nimport { removeListeners, removeSubscriptions } from '../../helpers';\r\nimport { RoutingService } from '../../services/routing.service';\r\nimport { HeaderService } from '../header/header.service';\r\nimport { LayoutStore } from '../layout.store';\r\nimport { WrapperService } from '../wrapper/wrapper.service';\r\nimport { SidebarLeftToggleDirective } from './sidebar-left.directive';\r\n\r\nexport interface Item {\r\n    id: number;\r\n    parentId: number;\r\n    label: string;\r\n    route?: string;\r\n    iconClasses?: string;\r\n    children?: Array<Item>;\r\n    isActive?: boolean;\r\n    isCollapsed?: boolean;\r\n    disableCollapse?: boolean;\r\n}\r\n\r\nexport type Items = Array<Item>;\r\n\r\n@Component({\r\n    selector: 'mk-layout-sidebar-left',\r\n    templateUrl: './sidebar-left.component.html',\r\n    styleUrls: ['./sidebar-left.component.css'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SidebarLeftComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    public menu: Array<any>;\r\n    public sidebarHeight: number;\r\n    public sidebarOverflow: string;\r\n\r\n    private layout: string;\r\n    private isSidebarLeftCollapsed: boolean;\r\n    private isSidebarLeftExpandOnOver: boolean;\r\n    private isSidebarLeftMouseOver: boolean;\r\n    private windowInnerWidth: number;\r\n    private windowInnerHeight: number;\r\n    private collapsedItems: Items = [];\r\n    private activatedItems: Items = [];\r\n    private toggleListeners: Array<Function> = [];\r\n    private listeners: Array<Function> = [];\r\n    private itemsByIds: { [propKey: number]: Item } = {};\r\n    private runningAnimations = 0;\r\n    private subscriptions = [];\r\n    private activeUrl: String;\r\n    private initialized: boolean;\r\n\r\n    @ViewChild('sidebarElement', { static: true }) public sidebarElement: ElementRef;\r\n\r\n    @ViewChildren(SidebarLeftToggleDirective) public sidebarLeftToggleDirectives: QueryList<SidebarLeftToggleDirective>;\r\n\r\n    /**\r\n    * @method constructor\r\n    * @param  changeDetectorRef  [description]\r\n    * @param  layoutStore        [description]\r\n    * @param  ngZone             [description]\r\n    * @param  renderer2          [description]\r\n    * @param  router             [description]\r\n    * @param  routingService     [description]\r\n    * @param  wrapperService     [description]\r\n    * @param  headerService      [description]\r\n    */\r\n    constructor(\r\n        private changeDetectorRef: ChangeDetectorRef,\r\n        private layoutStore: LayoutStore,\r\n        private ngZone: NgZone,\r\n        private renderer2: Renderer2,\r\n        private router: Router,\r\n        private routingService: RoutingService,\r\n        private wrapperService: WrapperService,\r\n        private headerService: HeaderService,\r\n        private activatedRoute: ActivatedRoute\r\n    ) { }\r\n\r\n    /**\r\n       * @method ngOnInit\r\n       */\r\n    ngOnInit() {\r\n        this.subscriptions.push(this.layoutStore.sidebarLeftMenu.subscribe(value => {\r\n            this.menu = value;\r\n            this.monkeyPatchMenu(this.menu);\r\n            if (this.initialized) {\r\n                this.setMenuListeners(this.activeUrl);\r\n                this.setSidebarListeners();\r\n                this.setMenuTogglesListeners();\r\n            }\r\n            this.initialized = true;\r\n        }));\r\n        this.subscriptions.push(this.layoutStore.sidebarLeftMenuActiveUrl.subscribe(value => {\r\n            this.activeUrl = value;\r\n            this.setMenuListeners(value);\r\n        }));\r\n        this.subscriptions.push(this.routingService.events.subscribe((event: RouterEvent) => {\r\n            let url;\r\n            if (event instanceof NavigationEnd) {\r\n                url = event.url;\r\n            } else {\r\n                url = this.router.url;\r\n            }\r\n            this.activeUrl = url;\r\n            this.setMenuListeners(url);\r\n            // console.log(url)\r\n        }));\r\n\r\n        this.setSidebarListeners();\r\n    }\r\n\r\n    /**\r\n     * @method ngAfterViewInit\r\n     */\r\n    ngAfterViewInit() {\r\n        this.setMenuTogglesListeners();\r\n        this.checkMenuWithoutChildren();\r\n    }\r\n\r\n    /**\r\n     * @method ngOnDestroy\r\n     */\r\n    ngOnDestroy() {\r\n        this.subscriptions = removeSubscriptions(this.subscriptions);\r\n        this.listeners = removeListeners(this.listeners);\r\n        this.toggleListeners = removeListeners(this.toggleListeners);\r\n    }\r\n\r\n    /**\r\n     * [setSidebarListeners description]\r\n     * @method setSidebarListeners\r\n     */\r\n    setSidebarListeners(): void {\r\n        this.subscriptions.push(this.layoutStore.layout.subscribe((value: string) => {\r\n            this.layout = value;\r\n            this.setSidebarHeight();\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.windowInnerHeight.subscribe((value: number) => {\r\n            this.windowInnerHeight = value;\r\n            this.setSidebarHeight();\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.sidebarLeftMenu.subscribe(() => {\r\n            this.changeDetectorRef.detectChanges();\r\n        }));\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.listeners.push(this.renderer2.listen(this.sidebarElement.nativeElement, 'mouseenter', () => {\r\n                this.layoutStore.sidebarLeftMouseOver(true);\r\n            }));\r\n            this.listeners.push(this.renderer2.listen(this.sidebarElement.nativeElement, 'mouseleave', () => {\r\n                this.layoutStore.sidebarLeftMouseOver(false);\r\n            }));\r\n        });\r\n\r\n        this.subscriptions.push(this.layoutStore.windowInnerWidth.subscribe((value: number) => {\r\n            this.windowInnerWidth = value;\r\n            if (!this.isSidebarLeftCollapsed && this.windowInnerWidth <= 767) {\r\n                this.layoutStore.sidebarLeftCollapsed(true);\r\n            } else if (this.windowInnerWidth > 767 && this.isSidebarLeftCollapsed && !this.isSidebarLeftExpandOnOver) {\r\n                this.layoutStore.sidebarLeftCollapsed(false);\r\n            }\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.isSidebarLeftMouseOver.subscribe((value: boolean) => {\r\n            this.isSidebarLeftMouseOver = value;\r\n            if (this.isSidebarLeftExpandOnOver) {\r\n                this.layoutStore.sidebarLeftCollapsed(!value);\r\n            }\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.isSidebarLeftExpandOnOver.subscribe((value: boolean) => {\r\n            this.isSidebarLeftExpandOnOver = value;\r\n            if (this.windowInnerWidth > 767 && this.isSidebarLeftCollapsed !== undefined) {\r