UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

550 lines 45.7 kB
/** * @fileoverview added by tsickle * Generated from: sidebar-nav.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __metadata } from "tslib"; import { DOCUMENT } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Inject, Input, NgZone, Output, Renderer2, ViewEncapsulation, } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { NavigationEnd, Router } from '@angular/router'; import { MenuService, SettingsService, WINDOW } from '@ohayojp.com/theme'; import { InputBoolean, InputNumber } from '@ohayojp.com/util'; import { Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; /** @type {?} */ const SHOWCLS = 'sidebar-nav__floating-show'; /** @type {?} */ const FLOATINGCLS = 'sidebar-nav__floating'; export class SidebarNavComponent { /** * @param {?} menuSrv * @param {?} settings * @param {?} router * @param {?} render * @param {?} cdr * @param {?} ngZone * @param {?} sanitizer * @param {?} doc * @param {?} win */ constructor(menuSrv, settings, router, render, cdr, ngZone, sanitizer, doc, win) { this.menuSrv = menuSrv; this.settings = settings; this.router = router; this.render = render; this.cdr = cdr; this.ngZone = ngZone; this.sanitizer = sanitizer; this.doc = doc; this.win = win; this.unsubscribe$ = new Subject(); this.list = []; this.disabledAcl = false; this.autoCloseUnderPad = true; this.recursivePath = true; this.openStrictly = false; this.maxLevelIcon = 3; // tslint:disable-next-line:no-output-native this.select = new EventEmitter(); } /** * @return {?} */ get collapsed() { return this.settings.layout.collapsed; } /** * @private * @param {?} node * @return {?} */ getLinkNode(node) { node = node.nodeName === 'A' ? node : ((/** @type {?} */ (node.parentNode))); return node.nodeName !== 'A' ? null : node; } /** * @private * @param {?} e * @return {?} */ floatingClickHandle(e) { e.stopPropagation(); /** @type {?} */ const linkNode = this.getLinkNode((/** @type {?} */ (e.target))); if (linkNode == null) { return false; } /** @type {?} */ const id = +(/** @type {?} */ ((/** @type {?} */ (linkNode.dataset)).id)); // Should be ingore children title trigger event if (isNaN(id)) { return false; } /** @type {?} */ let item; this.menuSrv.visit(this.list, (/** * @param {?} i * @return {?} */ (i) => { if (!item && i._id === id) { item = i; } })); this.to((/** @type {?} */ (item))); this.hideAll(); e.preventDefault(); return false; } /** * @private * @return {?} */ clearFloating() { if (!this.floatingEl) return; this.floatingEl.removeEventListener('click', this.floatingClickHandle.bind(this)); // fix ie: https://github.com/ohayojp/ohayo/issues/52 if (this.floatingEl.hasOwnProperty('remove')) { this.floatingEl.remove(); } else if (this.floatingEl.parentNode) { this.floatingEl.parentNode.removeChild(this.floatingEl); } } /** * @private * @return {?} */ genFloating() { this.clearFloating(); this.floatingEl = this.render.createElement('div'); this.floatingEl.classList.add(FLOATINGCLS + '-container'); this.floatingEl.addEventListener('click', this.floatingClickHandle.bind(this), false); this.bodyEl.appendChild(this.floatingEl); } /** * @private * @param {?} linkNode * @param {?} item * @return {?} */ genSubNode(linkNode, item) { /** @type {?} */ const id = `_sidebar-nav-${item._id}`; /** @type {?} */ const childNode = item.badge ? (/** @type {?} */ ((/** @type {?} */ (linkNode.nextElementSibling)).nextElementSibling)) : (/** @type {?} */ (linkNode.nextElementSibling)); /** @type {?} */ const node = (/** @type {?} */ (childNode.cloneNode(true))); node.id = id; node.classList.add(FLOATINGCLS); node.addEventListener('mouseleave', (/** * @return {?} */ () => { node.classList.remove(SHOWCLS); }), false); this.floatingEl.appendChild(node); return node; } /** * @private * @return {?} */ hideAll() { /** @type {?} */ const allNode = this.floatingEl.querySelectorAll('.' + FLOATINGCLS); // tslint:disable-next-line:prefer-for-of for (let i = 0; i < allNode.length; i++) { allNode[i].classList.remove(SHOWCLS); } } // calculate the node position values. /** * @private * @param {?} linkNode * @param {?} node * @return {?} */ calPos(linkNode, node) { /** @type {?} */ const rect = linkNode.getBoundingClientRect(); // bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/14721015/ /** @type {?} */ const scrollTop = Math.max(this.doc.documentElement.scrollTop, this.bodyEl.scrollTop); /** @type {?} */ const docHeight = Math.max(this.doc.documentElement.clientHeight, this.bodyEl.clientHeight); /** @type {?} */ const spacing = 5; /** @type {?} */ let offsetHeight = -spacing; if (docHeight < rect.top + node.clientHeight) { offsetHeight = rect.top + node.clientHeight - docHeight + spacing; } node.style.top = `${rect.top + scrollTop - offsetHeight}px`; node.style.left = `${rect.right + spacing}px`; } /** * @param {?} e * @param {?} item * @return {?} */ showSubMenu(e, item) { if (this.collapsed !== true) { return; } this.ngZone.runOutsideAngular((/** * @return {?} */ () => { e.preventDefault(); /** @type {?} */ const linkNode = (/** @type {?} */ (e.target)); this.genFloating(); /** @type {?} */ const subNode = this.genSubNode((/** @type {?} */ (linkNode)), item); this.hideAll(); subNode.classList.add(SHOWCLS); this.calPos((/** @type {?} */ (linkNode)), subNode); })); } /** * @param {?} item * @return {?} */ to(item) { this.select.emit(item); if (item.disabled) return; if (item.externalLink) { if (item.target === '_blank') { this.win.open(item.externalLink); } else { this.win.location.href = item.externalLink; } return; } this.ngZone.run((/** * @return {?} */ () => this.router.navigateByUrl((/** @type {?} */ (item.link))))); } /** * @param {?} item * @return {?} */ toggleOpen(item) { if (!this.openStrictly) { this.menuSrv.visit(this.list, (/** * @param {?} i * @return {?} */ (i) => { if (i !== item) i._open = false; })); /** @type {?} */ let pItem = (/** @type {?} */ (item._parent)); while (pItem) { pItem._open = true; pItem = (/** @type {?} */ (pItem._parent)); } } item._open = !item._open; this.cdr.markForCheck(); } /** * @return {?} */ _click() { if (this.isPad && this.collapsed) { this.openAside(false); this.hideAll(); } } /** * @return {?} */ _docClick() { if (this.collapsed) { this.hideAll(); } } /** * @private * @param {?} url * @return {?} */ openedByUrl(url) { const { menuSrv, recursivePath, openStrictly } = this; /** @type {?} */ let findItem = menuSrv.getHit(this.menuSrv.menus, (/** @type {?} */ (url)), recursivePath, (/** * @param {?} i * @return {?} */ (i) => { i._selected = false; if (!openStrictly) { i._open = false; } })); if (findItem == null) return; do { findItem._selected = true; if (!openStrictly) { findItem._open = true; } findItem = (/** @type {?} */ (findItem._parent)); } while (findItem); } /** * @return {?} */ ngOnInit() { const { doc, router, unsubscribe$, menuSrv, settings, cdr } = this; this.bodyEl = doc.querySelector('body'); this.openedByUrl(router.url); this.ngZone.runOutsideAngular((/** * @return {?} */ () => this.genFloating())); menuSrv.change.pipe(takeUntil(unsubscribe$)).subscribe((/** * @param {?} data * @return {?} */ data => { menuSrv.visit(data, (/** * @param {?} i * @param {?} _p * @param {?} depth * @return {?} */ (i, _p, depth) => { i._text = this.sanitizer.bypassSecurityTrustHtml((/** @type {?} */ (i.text))); i._needIcon = (/** @type {?} */ (depth)) <= this.maxLevelIcon && !!i.icon; if (!i._aclResult) { if (this.disabledAcl) { i.disabled = true; } else { i._hidden = true; } } if (this.openStrictly) { i._open = i.open != null ? i.open : false; } })); this.list = menuSrv.menus.filter((/** * @param {?} w * @return {?} */ (w) => w._hidden !== true)); cdr.detectChanges(); })); router.events.pipe(takeUntil(unsubscribe$)).subscribe((/** * @param {?} e * @return {?} */ e => { if (e instanceof NavigationEnd) { this.openedByUrl(e.urlAfterRedirects); this.underPad(); this.cdr.detectChanges(); } })); settings.notify .pipe(takeUntil(unsubscribe$), filter((/** * @param {?} t * @return {?} */ t => t.type === 'layout' && t.name === 'collapsed'))) .subscribe((/** * @return {?} */ () => this.clearFloating())); this.underPad(); } /** * @return {?} */ ngOnDestroy() { const { unsubscribe$ } = this; unsubscribe$.next(); unsubscribe$.complete(); this.clearFloating(); } // #region Under pad /** * @private * @return {?} */ get isPad() { return window.innerWidth < 768; } /** * @private * @return {?} */ underPad() { if (this.autoCloseUnderPad && this.isPad && !this.collapsed) { setTimeout((/** * @return {?} */ () => this.openAside(true))); } } /** * @private * @param {?} status * @return {?} */ openAside(status) { this.settings.setLayout('collapsed', status); } } SidebarNavComponent.decorators = [ { type: Component, args: [{ selector: 'sidebar-nav', exportAs: 'sidebarNav', template: "<ng-template #icon let-i>\n <ng-container *ngIf=\"i\" [ngSwitch]=\"i.type\">\n <i\n *ngSwitchCase=\"'icon'\"\n class=\"sidebar-nav__item-icon\"\n nz-icon\n [nzType]=\"i.value\"\n [nzTheme]=\"i.theme\"\n [nzSpin]=\"i.spin\"\n [nzTwotoneColor]=\"i.twoToneColor\"\n [nzIconfont]=\"i.iconfont\"\n [nzRotate]=\"i.rotate\"\n ></i>\n <i *ngSwitchCase=\"'iconfont'\" class=\"sidebar-nav__item-icon\" nz-icon [nzIconfont]=\"i.iconfont\"></i>\n <img *ngSwitchCase=\"'img'\" [src]=\"i.value\" class=\"sidebar-nav__item-icon sidebar-nav__item-img\" />\n <i *ngSwitchDefault class=\"sidebar-nav__item-icon {{ i.value }}\"></i>\n </ng-container>\n</ng-template>\n<ng-template #tree let-ls>\n <ng-container *ngFor=\"let i of ls\">\n <li *ngIf=\"i._hidden !== true\" class=\"sidebar-nav__item\" [class.sidebar-nav__selected]=\"i._selected\" [class.sidebar-nav__open]=\"i._open\">\n <!-- link -->\n <a\n *ngIf=\"i.children.length === 0\"\n (click)=\"to(i)\"\n [attr.data-id]=\"i._id\"\n class=\"sidebar-nav__item-link\"\n [ngClass]=\"{ 'sidebar-nav__item-disabled': i.disabled }\"\n >\n <ng-container *ngIf=\"i._needIcon\">\n <ng-container *ngIf=\"!collapsed\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </ng-container>\n <span *ngIf=\"collapsed\" nz-tooltip nzTooltipPlacement=\"right\" [nzTooltipTitle]=\"i.text\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </span>\n </ng-container>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n </a>\n <!-- has children link -->\n <a *ngIf=\"i.children.length > 0\" (click)=\"toggleOpen(i)\" (mouseenter)=\"showSubMenu($event, i)\" class=\"sidebar-nav__item-link\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n <i class=\"sidebar-nav__sub-arrow\"></i>\n </a>\n <!-- badge -->\n <div *ngIf=\"i.badge\" [attr.title]=\"i.badge\" class=\"badge badge-{{ i.badgeStatus }}\" [class.badge-dot]=\"i.badgeDot\">\n <em>{{ i.badge }}</em>\n </div>\n <ul *ngIf=\"i.children.length > 0\" class=\"sidebar-nav sidebar-nav__sub sidebar-nav__depth{{ i._depth }}\">\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: i.children }\"></ng-template>\n </ul>\n </li>\n </ng-container>\n</ng-template>\n<ul class=\"sidebar-nav\">\n <ng-container *ngFor=\"let group of list\">\n <li class=\"sidebar-nav__item sidebar-nav__group-title\" *ngIf=\"group.group\">\n <span [innerHTML]=\"group._text\"></span>\n </li>\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: group.children }\"></ng-template>\n </ng-container>\n</ul>\n", host: { '(click)': '_click()', '(document:click)': '_docClick()', }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ SidebarNavComponent.ctorParameters = () => [ { type: MenuService }, { type: SettingsService }, { type: Router }, { type: Renderer2 }, { type: ChangeDetectorRef }, { type: NgZone }, { type: DomSanitizer }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }, { type: Window, decorators: [{ type: Inject, args: [WINDOW,] }] } ]; SidebarNavComponent.propDecorators = { disabledAcl: [{ type: Input }], autoCloseUnderPad: [{ type: Input }], recursivePath: [{ type: Input }], openStrictly: [{ type: Input }], maxLevelIcon: [{ type: Input }], select: [{ type: Output }] }; __decorate([ InputBoolean(), __metadata("design:type", Object) ], SidebarNavComponent.prototype, "disabledAcl", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], SidebarNavComponent.prototype, "autoCloseUnderPad", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], SidebarNavComponent.prototype, "recursivePath", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], SidebarNavComponent.prototype, "openStrictly", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], SidebarNavComponent.prototype, "maxLevelIcon", void 0); if (false) { /** @type {?} */ SidebarNavComponent.ngAcceptInputType_disabledAcl; /** @type {?} */ SidebarNavComponent.ngAcceptInputType_autoCloseUnderPad; /** @type {?} */ SidebarNavComponent.ngAcceptInputType_recursivePath; /** @type {?} */ SidebarNavComponent.ngAcceptInputType_openStrictly; /** @type {?} */ SidebarNavComponent.ngAcceptInputType_maxLevelIcon; /** * @type {?} * @private */ SidebarNavComponent.prototype.bodyEl; /** * @type {?} * @private */ SidebarNavComponent.prototype.unsubscribe$; /** * @type {?} * @private */ SidebarNavComponent.prototype.floatingEl; /** @type {?} */ SidebarNavComponent.prototype.list; /** @type {?} */ SidebarNavComponent.prototype.disabledAcl; /** @type {?} */ SidebarNavComponent.prototype.autoCloseUnderPad; /** @type {?} */ SidebarNavComponent.prototype.recursivePath; /** @type {?} */ SidebarNavComponent.prototype.openStrictly; /** @type {?} */ SidebarNavComponent.prototype.maxLevelIcon; /** @type {?} */ SidebarNavComponent.prototype.select; /** * @type {?} * @private */ SidebarNavComponent.prototype.menuSrv; /** * @type {?} * @private */ SidebarNavComponent.prototype.settings; /** * @type {?} * @private */ SidebarNavComponent.prototype.router; /** * @type {?} * @private */ SidebarNavComponent.prototype.render; /** * @type {?} * @private */ SidebarNavComponent.prototype.cdr; /** * @type {?} * @private */ SidebarNavComponent.prototype.ngZone; /** * @type {?} * @private */ SidebarNavComponent.prototype.sanitizer; /** * @type {?} * @private */ SidebarNavComponent.prototype.doc; /** * @type {?} * @private */ SidebarNavComponent.prototype.win; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-nav.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/sidebar-nav/","sources":["sidebar-nav.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { Menu, MenuService, SettingsService, WINDOW } from '@ohayo/theme';\nimport { BooleanInput, InputBoolean, InputNumber, NumberInput } from '@ohayo/util';\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Nav } from './sidebar-nav.types';\n\nconst SHOWCLS = 'sidebar-nav__floating-show';\nconst FLOATINGCLS = 'sidebar-nav__floating';\n\n@Component({\n  selector: 'sidebar-nav',\n  exportAs: 'sidebarNav',\n  templateUrl: './sidebar-nav.component.html',\n  host: {\n    '(click)': '_click()',\n    '(document:click)': '_docClick()',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SidebarNavComponent implements OnInit, OnDestroy {\n  static ngAcceptInputType_disabledAcl: BooleanInput;\n  static ngAcceptInputType_autoCloseUnderPad: BooleanInput;\n  static ngAcceptInputType_recursivePath: BooleanInput;\n  static ngAcceptInputType_openStrictly: BooleanInput;\n  static ngAcceptInputType_maxLevelIcon: NumberInput;\n\n  private bodyEl: HTMLBodyElement;\n  private unsubscribe$ = new Subject<void>();\n  private floatingEl: HTMLDivElement;\n  list: Nav[] = [];\n\n  @Input() @InputBoolean() disabledAcl = false;\n  @Input() @InputBoolean() autoCloseUnderPad = true;\n  @Input() @InputBoolean() recursivePath = true;\n  @Input() @InputBoolean() openStrictly = false;\n  @Input() @InputNumber() maxLevelIcon = 3;\n  // tslint:disable-next-line:no-output-native\n  @Output() readonly select = new EventEmitter<Menu>();\n\n  get collapsed(): boolean {\n    return this.settings.layout.collapsed;\n  }\n\n  constructor(\n    private menuSrv: MenuService,\n    private settings: SettingsService,\n    private router: Router,\n    private render: Renderer2,\n    private cdr: ChangeDetectorRef,\n    private ngZone: NgZone,\n    private sanitizer: DomSanitizer,\n    @Inject(DOCUMENT) private doc: any,\n    @Inject(WINDOW) private win: Window,\n  ) { }\n\n  private getLinkNode(node: HTMLElement): HTMLElement | null {\n    node = node.nodeName === 'A' ? node : (node.parentNode as HTMLElement);\n    return node.nodeName !== 'A' ? null : node;\n  }\n\n  private floatingClickHandle(e: MouseEvent): boolean {\n    e.stopPropagation();\n    const linkNode = this.getLinkNode(e.target as HTMLElement);\n    if (linkNode == null) {\n      return false;\n    }\n    const id = +linkNode.dataset!.id!;\n    // Should be ingore children title trigger event\n    if (isNaN(id)) {\n      return false;\n    }\n\n    let item: Nav;\n    this.menuSrv.visit(this.list, (i: Nav) => {\n      if (!item && i._id === id) {\n        item = i;\n      }\n    });\n    this.to(item!);\n    this.hideAll();\n    e.preventDefault();\n    return false;\n  }\n\n  private clearFloating(): void {\n    if (!this.floatingEl) return;\n    this.floatingEl.removeEventListener('click', this.floatingClickHandle.bind(this));\n    // fix ie: https://github.com/ohayojp/ohayo/issues/52\n    if (this.floatingEl.hasOwnProperty('remove')) {\n      this.floatingEl.remove();\n    } else if (this.floatingEl.parentNode) {\n      this.floatingEl.parentNode.removeChild(this.floatingEl);\n    }\n  }\n\n  private genFloating(): void {\n    this.clearFloating();\n    this.floatingEl = this.render.createElement('div');\n    this.floatingEl.classList.add(FLOATINGCLS + '-container');\n    this.floatingEl.addEventListener('click', this.floatingClickHandle.bind(this), false);\n    this.bodyEl.appendChild(this.floatingEl);\n  }\n\n  private genSubNode(linkNode: HTMLLinkElement, item: Nav): HTMLUListElement {\n    const id = `_sidebar-nav-${item._id}`;\n    const childNode = item.badge ? linkNode.nextElementSibling!.nextElementSibling! : linkNode.nextElementSibling!;\n    const node = childNode.cloneNode(true) as HTMLUListElement;\n    node.id = id;\n    node.classList.add(FLOATINGCLS);\n    node.addEventListener(\n      'mouseleave',\n      () => {\n        node.classList.remove(SHOWCLS);\n      },\n      false,\n    );\n    this.floatingEl.appendChild(node);\n    return node;\n  }\n\n  private hideAll(): void {\n    const allNode = this.floatingEl.querySelectorAll('.' + FLOATINGCLS);\n    // tslint:disable-next-line:prefer-for-of\n    for (let i = 0; i < allNode.length; i++) {\n      allNode[i].classList.remove(SHOWCLS);\n    }\n  }\n\n  // calculate the node position values.\n  private calPos(linkNode: HTMLLinkElement, node: HTMLUListElement): void {\n    const rect = linkNode.getBoundingClientRect();\n    // bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/14721015/\n    const scrollTop = Math.max(this.doc.documentElement.scrollTop, this.bodyEl.scrollTop);\n    const docHeight = Math.max(this.doc.documentElement.clientHeight, this.bodyEl.clientHeight);\n    const spacing = 5;\n    let offsetHeight = -spacing;\n    if (docHeight < rect.top + node.clientHeight) {\n      offsetHeight = rect.top + node.clientHeight - docHeight + spacing;\n    }\n    node.style.top = `${rect.top + scrollTop - offsetHeight}px`;\n    node.style.left = `${rect.right + spacing}px`;\n  }\n\n  showSubMenu(e: MouseEvent, item: Nav): void {\n    if (this.collapsed !== true) {\n      return;\n    }\n    this.ngZone.runOutsideAngular(() => {\n      e.preventDefault();\n      const linkNode = e.target as Element;\n      this.genFloating();\n      const subNode = this.genSubNode(linkNode as HTMLLinkElement, item);\n      this.hideAll();\n      subNode.classList.add(SHOWCLS);\n      this.calPos(linkNode as HTMLLinkElement, subNode);\n    });\n  }\n\n  to(item: Menu): void {\n    this.select.emit(item);\n    if (item.disabled) return;\n\n    if (item.externalLink) {\n      if (item.target === '_blank') {\n        this.win.open(item.externalLink);\n      } else {\n        this.win.location.href = item.externalLink;\n      }\n      return;\n    }\n    this.ngZone.run(() => this.router.navigateByUrl(item.link!));\n  }\n\n  toggleOpen(item: Nav): void {\n    if (!this.openStrictly) {\n      this.menuSrv.visit(this.list, (i: Nav) => {\n        if (i !== item) i._open = false;\n      });\n      let pItem = item._parent as Nav;\n      while (pItem) {\n        pItem._open = true;\n        pItem = pItem._parent!;\n      }\n    }\n    item._open = !item._open;\n    this.cdr.markForCheck();\n  }\n\n  _click(): void {\n    if (this.isPad && this.collapsed) {\n      this.openAside(false);\n      this.hideAll();\n    }\n  }\n\n  _docClick(): void {\n    if (this.collapsed) {\n      this.hideAll();\n    }\n  }\n\n  private openedByUrl(url: string | null): void {\n    const { menuSrv, recursivePath, openStrictly } = this;\n    let findItem: Nav | null = menuSrv.getHit(this.menuSrv.menus, url!, recursivePath, (i: Nav) => {\n      i._selected = false;\n      if (!openStrictly) {\n        i._open = false;\n      }\n    });\n    if (findItem == null) return;\n\n    do {\n      findItem._selected = true;\n      if (!openStrictly) {\n        findItem._open = true;\n      }\n      findItem = findItem._parent!;\n    } while (findItem);\n  }\n\n  ngOnInit(): void {\n    const { doc, router, unsubscribe$, menuSrv, settings, cdr } = this;\n    this.bodyEl = doc.querySelector('body');\n    this.openedByUrl(router.url);\n    this.ngZone.runOutsideAngular(() => this.genFloating());\n    menuSrv.change.pipe(takeUntil(unsubscribe$)).subscribe(data => {\n      menuSrv.visit(data, (i: Nav, _p, depth) => {\n        i._text = this.sanitizer.bypassSecurityTrustHtml(i.text!);\n        i._needIcon = depth! <= this.maxLevelIcon && !!i.icon;\n        if (!i._aclResult) {\n          if (this.disabledAcl) {\n            i.disabled = true;\n          } else {\n            i._hidden = true;\n          }\n        }\n        if (this.openStrictly) {\n          i._open = i.open != null ? i.open : false;\n        }\n      });\n      this.list = menuSrv.menus.filter((w: Nav) => w._hidden !== true);\n      cdr.detectChanges();\n    });\n    router.events.pipe(takeUntil(unsubscribe$)).subscribe(e => {\n      if (e instanceof NavigationEnd) {\n        this.openedByUrl(e.urlAfterRedirects);\n        this.underPad();\n        this.cdr.detectChanges();\n      }\n    });\n    settings.notify\n      .pipe(\n        takeUntil(unsubscribe$),\n        filter(t => t.type === 'layout' && t.name === 'collapsed'),\n      )\n      .subscribe(() => this.clearFloating());\n    this.underPad();\n  }\n\n  ngOnDestroy(): void {\n    const { unsubscribe$ } = this;\n    unsubscribe$.next();\n    unsubscribe$.complete();\n    this.clearFloating();\n  }\n\n  // #region Under pad\n\n  private get isPad(): boolean {\n    return window.innerWidth < 768;\n  }\n\n  private underPad(): void {\n    if (this.autoCloseUnderPad && this.isPad && !this.collapsed) {\n      setTimeout(() => this.openAside(true));\n    }\n  }\n\n  private openAside(status: boolean): void {\n    this.settings.setLayout('collapsed', status);\n  }\n\n  // #endregion\n}\n"]}