UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

377 lines 27.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { ContentChildren, Directive, ElementRef, Input, Optional, QueryList, Renderer2 } from '@angular/core'; import { NavigationEnd, Router, RouterLink, RouterLinkWithHref } from '@angular/router'; import { isNotNil, InputBoolean, NzMenuBaseService, NzUpdateHostClassService } from 'ng-zorro-antd/core'; import { merge, EMPTY, Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; import { NzSubmenuService } from './nz-submenu.service'; var NzMenuItemDirective = /** @class */ (function () { function NzMenuItemDirective(nzUpdateHostClassService, nzMenuService, nzSubmenuService, renderer, elementRef, routerLink, routerLinkWithHref, router) { var _this = this; this.nzUpdateHostClassService = nzUpdateHostClassService; this.nzMenuService = nzMenuService; this.nzSubmenuService = nzSubmenuService; this.renderer = renderer; this.elementRef = elementRef; this.routerLink = routerLink; this.routerLinkWithHref = routerLinkWithHref; this.router = router; this.el = this.elementRef.nativeElement; this.destroy$ = new Subject(); this.originalPadding = null; this.selected$ = new Subject(); this.nzDisabled = false; this.nzSelected = false; this.nzMatchRouterExact = false; this.nzMatchRouter = false; if (router) { (/** @type {?} */ (this.router)).events.pipe(takeUntil(this.destroy$), filter((/** * @param {?} e * @return {?} */ function (e) { return e instanceof NavigationEnd; }))).subscribe((/** * @return {?} */ function () { _this.updateRouterActive(); })); } } /** clear all item selected status except this */ /** * clear all item selected status except this * @param {?} e * @return {?} */ NzMenuItemDirective.prototype.clickMenuItem = /** * clear all item selected status except this * @param {?} e * @return {?} */ function (e) { if (this.nzDisabled) { e.preventDefault(); e.stopPropagation(); return; } this.nzMenuService.onMenuItemClick(this); if (this.nzSubmenuService) { this.nzSubmenuService.onMenuItemClick(); } }; /** * @return {?} */ NzMenuItemDirective.prototype.setClassMap = /** * @return {?} */ function () { var _a; /** @type {?} */ var prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu-item' : 'ant-menu-item'; this.nzUpdateHostClassService.updateHostClass(this.el, (_a = {}, _a["" + prefixName] = true, _a[prefixName + "-selected"] = this.nzSelected, _a[prefixName + "-disabled"] = this.nzDisabled, _a)); }; /** * @param {?} value * @return {?} */ NzMenuItemDirective.prototype.setSelectedState = /** * @param {?} value * @return {?} */ function (value) { this.nzSelected = value; this.selected$.next(value); this.setClassMap(); }; /** * @private * @return {?} */ NzMenuItemDirective.prototype.updateRouterActive = /** * @private * @return {?} */ function () { var _this = this; if (!this.listOfRouterLink || !this.listOfRouterLinkWithHref || !this.router || !this.router.navigated || !this.nzMatchRouter) { return; } Promise.resolve().then((/** * @return {?} */ function () { /** @type {?} */ var hasActiveLinks = _this.hasActiveLinks(); if (_this.nzSelected !== hasActiveLinks) { _this.nzSelected = hasActiveLinks; _this.setSelectedState(_this.nzSelected); } })); }; /** * @private * @return {?} */ NzMenuItemDirective.prototype.hasActiveLinks = /** * @private * @return {?} */ function () { /** @type {?} */ var isActiveCheckFn = this.isLinkActive((/** @type {?} */ (this.router))); return ((this.routerLink && isActiveCheckFn(this.routerLink)) || (this.routerLinkWithHref && isActiveCheckFn(this.routerLinkWithHref)) || this.listOfRouterLink.some(isActiveCheckFn) || this.listOfRouterLinkWithHref.some(isActiveCheckFn)); }; /** * @private * @param {?} router * @return {?} */ NzMenuItemDirective.prototype.isLinkActive = /** * @private * @param {?} router * @return {?} */ function (router) { var _this = this; return (/** * @param {?} link * @return {?} */ function (link) { return router.isActive(link.urlTree, _this.nzMatchRouterExact); }); }; /** * @return {?} */ NzMenuItemDirective.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; /** * store origin padding in padding * @type {?} */ var paddingLeft = this.el.style.paddingLeft; if (paddingLeft) { this.originalPadding = parseInt(paddingLeft, 10); } merge(this.nzMenuService.mode$, this.nzMenuService.inlineIndent$, this.nzSubmenuService ? this.nzSubmenuService.level$ : EMPTY) .pipe(takeUntil(this.destroy$)) .subscribe((/** * @return {?} */ function () { /** @type {?} */ var padding = null; if (_this.nzMenuService.mode === 'inline') { if (isNotNil(_this.nzPaddingLeft)) { padding = _this.nzPaddingLeft; } else { /** @type {?} */ var level = _this.nzSubmenuService ? _this.nzSubmenuService.level + 1 : 1; padding = level * _this.nzMenuService.inlineIndent; } } else { padding = _this.originalPadding; } if (padding) { _this.renderer.setStyle(_this.el, 'padding-left', padding + "px"); } else { _this.renderer.removeStyle(_this.el, 'padding-left'); } })); this.setClassMap(); }; /** * @return {?} */ NzMenuItemDirective.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; this.listOfRouterLink.changes.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ function () { return _this.updateRouterActive(); })); this.listOfRouterLinkWithHref.changes.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ function () { return _this.updateRouterActive(); })); this.updateRouterActive(); }; /** * @param {?} changes * @return {?} */ NzMenuItemDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzSelected) { this.setSelectedState(this.nzSelected); } if (changes.nzDisabled) { this.setClassMap(); } }; /** * @return {?} */ NzMenuItemDirective.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); }; NzMenuItemDirective.decorators = [ { type: Directive, args: [{ selector: '[nz-menu-item]', exportAs: 'nzMenuItem', providers: [NzUpdateHostClassService], host: { '(click)': 'clickMenuItem($event)' } },] } ]; /** @nocollapse */ NzMenuItemDirective.ctorParameters = function () { return [ { type: NzUpdateHostClassService }, { type: NzMenuBaseService }, { type: NzSubmenuService, decorators: [{ type: Optional }] }, { type: Renderer2 }, { type: ElementRef }, { type: RouterLink, decorators: [{ type: Optional }] }, { type: RouterLinkWithHref, decorators: [{ type: Optional }] }, { type: Router, decorators: [{ type: Optional }] } ]; }; NzMenuItemDirective.propDecorators = { nzDisabled: [{ type: Input }], nzSelected: [{ type: Input }], nzPaddingLeft: [{ type: Input }], nzMatchRouterExact: [{ type: Input }], nzMatchRouter: [{ type: Input }], listOfRouterLink: [{ type: ContentChildren, args: [RouterLink, { descendants: true },] }], listOfRouterLinkWithHref: [{ type: ContentChildren, args: [RouterLinkWithHref, { descendants: true },] }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuItemDirective.prototype, "nzDisabled", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuItemDirective.prototype, "nzSelected", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuItemDirective.prototype, "nzMatchRouterExact", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuItemDirective.prototype, "nzMatchRouter", void 0); return NzMenuItemDirective; }()); export { NzMenuItemDirective }; if (false) { /** * @type {?} * @private */ NzMenuItemDirective.prototype.el; /** * @type {?} * @private */ NzMenuItemDirective.prototype.destroy$; /** * @type {?} * @private */ NzMenuItemDirective.prototype.originalPadding; /** @type {?} */ NzMenuItemDirective.prototype.selected$; /** @type {?} */ NzMenuItemDirective.prototype.nzDisabled; /** @type {?} */ NzMenuItemDirective.prototype.nzSelected; /** @type {?} */ NzMenuItemDirective.prototype.nzPaddingLeft; /** @type {?} */ NzMenuItemDirective.prototype.nzMatchRouterExact; /** @type {?} */ NzMenuItemDirective.prototype.nzMatchRouter; /** @type {?} */ NzMenuItemDirective.prototype.listOfRouterLink; /** @type {?} */ NzMenuItemDirective.prototype.listOfRouterLinkWithHref; /** * @type {?} * @private */ NzMenuItemDirective.prototype.nzUpdateHostClassService; /** * @type {?} * @private */ NzMenuItemDirective.prototype.nzMenuService; /** * @type {?} * @private */ NzMenuItemDirective.prototype.nzSubmenuService; /** * @type {?} * @private */ NzMenuItemDirective.prototype.renderer; /** * @type {?} * @private */ NzMenuItemDirective.prototype.elementRef; /** * @type {?} * @private */ NzMenuItemDirective.prototype.routerLink; /** * @type {?} * @private */ NzMenuItemDirective.prototype.routerLinkWithHref; /** * @type {?} * @private */ NzMenuItemDirective.prototype.router; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-menu-item.directive.js","sourceRoot":"ng://ng-zorro-antd/menu/","sources":["nz-menu-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  AfterContentInit,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  QueryList,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\nimport { NavigationEnd, Router, RouterLink, RouterLinkWithHref } from '@angular/router';\nimport { isNotNil, InputBoolean, NzMenuBaseService, NzUpdateHostClassService } from 'ng-zorro-antd/core';\nimport { merge, EMPTY, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { NzSubmenuService } from './nz-submenu.service';\n\n@Directive({\n  selector: '[nz-menu-item]',\n  exportAs: 'nzMenuItem',\n  providers: [NzUpdateHostClassService],\n  host: {\n    '(click)': 'clickMenuItem($event)'\n  }\n})\nexport class NzMenuItemDirective implements OnInit, OnChanges, OnDestroy, AfterContentInit {\n  private el: HTMLElement = this.elementRef.nativeElement;\n  private destroy$ = new Subject();\n  private originalPadding: number | null = null;\n  selected$ = new Subject<boolean>();\n  @Input() @InputBoolean() nzDisabled = false;\n  @Input() @InputBoolean() nzSelected = false;\n  @Input() nzPaddingLeft: number;\n  @Input() @InputBoolean() nzMatchRouterExact = false;\n  @Input() @InputBoolean() nzMatchRouter = false;\n  @ContentChildren(RouterLink, { descendants: true }) listOfRouterLink: QueryList<RouterLink>;\n  @ContentChildren(RouterLinkWithHref, { descendants: true }) listOfRouterLinkWithHref: QueryList<RouterLinkWithHref>;\n\n  /** clear all item selected status except this */\n  clickMenuItem(e: MouseEvent): void {\n    if (this.nzDisabled) {\n      e.preventDefault();\n      e.stopPropagation();\n      return;\n    }\n    this.nzMenuService.onMenuItemClick(this);\n    if (this.nzSubmenuService) {\n      this.nzSubmenuService.onMenuItemClick();\n    }\n  }\n\n  setClassMap(): void {\n    const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu-item' : 'ant-menu-item';\n    this.nzUpdateHostClassService.updateHostClass(this.el, {\n      [`${prefixName}`]: true,\n      [`${prefixName}-selected`]: this.nzSelected,\n      [`${prefixName}-disabled`]: this.nzDisabled\n    });\n  }\n\n  setSelectedState(value: boolean): void {\n    this.nzSelected = value;\n    this.selected$.next(value);\n    this.setClassMap();\n  }\n\n  private updateRouterActive(): void {\n    if (\n      !this.listOfRouterLink ||\n      !this.listOfRouterLinkWithHref ||\n      !this.router ||\n      !this.router.navigated ||\n      !this.nzMatchRouter\n    ) {\n      return;\n    }\n    Promise.resolve().then(() => {\n      const hasActiveLinks = this.hasActiveLinks();\n      if (this.nzSelected !== hasActiveLinks) {\n        this.nzSelected = hasActiveLinks;\n        this.setSelectedState(this.nzSelected);\n      }\n    });\n  }\n\n  private hasActiveLinks(): boolean {\n    const isActiveCheckFn = this.isLinkActive(this.router!);\n    return (\n      (this.routerLink && isActiveCheckFn(this.routerLink)) ||\n      (this.routerLinkWithHref && isActiveCheckFn(this.routerLinkWithHref)) ||\n      this.listOfRouterLink.some(isActiveCheckFn) ||\n      this.listOfRouterLinkWithHref.some(isActiveCheckFn)\n    );\n  }\n\n  private isLinkActive(router: Router): (link: RouterLink | RouterLinkWithHref) => boolean {\n    return (link: RouterLink | RouterLinkWithHref) => router.isActive(link.urlTree, this.nzMatchRouterExact);\n  }\n\n  constructor(\n    private nzUpdateHostClassService: NzUpdateHostClassService,\n    private nzMenuService: NzMenuBaseService,\n    @Optional() private nzSubmenuService: NzSubmenuService,\n    private renderer: Renderer2,\n    private elementRef: ElementRef,\n    @Optional() private routerLink?: RouterLink,\n    @Optional() private routerLinkWithHref?: RouterLinkWithHref,\n    @Optional() private router?: Router\n  ) {\n    if (router) {\n      this.router!.events.pipe(\n        takeUntil(this.destroy$),\n        filter(e => e instanceof NavigationEnd)\n      ).subscribe(() => {\n        this.updateRouterActive();\n      });\n    }\n  }\n\n  ngOnInit(): void {\n    /** store origin padding in padding */\n    const paddingLeft = this.el.style.paddingLeft;\n    if (paddingLeft) {\n      this.originalPadding = parseInt(paddingLeft, 10);\n    }\n    merge(\n      this.nzMenuService.mode$,\n      this.nzMenuService.inlineIndent$,\n      this.nzSubmenuService ? this.nzSubmenuService.level$ : EMPTY\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        let padding: number | null = null;\n        if (this.nzMenuService.mode === 'inline') {\n          if (isNotNil(this.nzPaddingLeft)) {\n            padding = this.nzPaddingLeft;\n          } else {\n            const level = this.nzSubmenuService ? this.nzSubmenuService.level + 1 : 1;\n            padding = level * this.nzMenuService.inlineIndent;\n          }\n        } else {\n          padding = this.originalPadding;\n        }\n        if (padding) {\n          this.renderer.setStyle(this.el, 'padding-left', `${padding}px`);\n        } else {\n          this.renderer.removeStyle(this.el, 'padding-left');\n        }\n      });\n    this.setClassMap();\n  }\n\n  ngAfterContentInit(): void {\n    this.listOfRouterLink.changes.pipe(takeUntil(this.destroy$)).subscribe(() => this.updateRouterActive());\n    this.listOfRouterLinkWithHref.changes.pipe(takeUntil(this.destroy$)).subscribe(() => this.updateRouterActive());\n    this.updateRouterActive();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzSelected) {\n      this.setSelectedState(this.nzSelected);\n    }\n    if (changes.nzDisabled) {\n      this.setClassMap();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}