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
JavaScript
/**
* @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