UNPKG

ng-zorro-antd-yj

Version:

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

214 lines 15.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ElementRef, Input, Optional, Renderer2 } from '@angular/core'; import { merge, EMPTY, Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { NzUpdateHostClassService } from '../core/services/update-host-class.service'; import { isNotNil } from '../core/util'; import { InputBoolean } from '../core/util/convert'; import { NzMenuService } from './nz-menu.service'; import { NzSubmenuService } from './nz-submenu.service'; export class NzMenuItemDirective { /** * @param {?} nzUpdateHostClassService * @param {?} nzMenuService * @param {?} nzSubmenuService * @param {?} renderer * @param {?} elementRef */ constructor(nzUpdateHostClassService, nzMenuService, nzSubmenuService, renderer, elementRef) { this.nzUpdateHostClassService = nzUpdateHostClassService; this.nzMenuService = nzMenuService; this.nzSubmenuService = nzSubmenuService; this.renderer = renderer; this.elementRef = elementRef; this.el = this.elementRef.nativeElement; this.destroy$ = new Subject(); this.originalPadding = null; this.selected$ = new Subject(); this.nzDisabled = false; this.nzSelected = false; } /** * clear all item selected status except this * @param {?} e * @return {?} */ clickMenuItem(e) { if (this.nzDisabled) { e.preventDefault(); e.stopPropagation(); return; } this.nzMenuService.onMenuItemClick(this); if (this.nzSubmenuService) { this.nzSubmenuService.onMenuItemClick(); } } /** * @return {?} */ setClassMap() { /** @type {?} */ const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu-item' : 'ant-menu-item'; this.nzUpdateHostClassService.updateHostClass(this.el, { [`${prefixName}`]: true, [`${prefixName}-selected`]: this.nzSelected, [`${prefixName}-disabled`]: this.nzDisabled }); } /** * @param {?} value * @return {?} */ setSelectedState(value) { this.nzSelected = value; this.selected$.next(value); this.setClassMap(); } /** * @return {?} */ ngOnInit() { /** * store origin padding in padding * @type {?} */ const 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 {?} */ () => { /** @type {?} */ let padding = null; if (this.nzMenuService.mode === 'inline') { if (isNotNil(this.nzPaddingLeft)) { padding = this.nzPaddingLeft; } else { /** @type {?} */ const 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(); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.nzSelected) { this.setSelectedState(this.nzSelected); } if (changes.nzDisabled) { this.setClassMap(); } } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } } NzMenuItemDirective.decorators = [ { type: Directive, args: [{ selector: '[nz-menu-item]', providers: [NzUpdateHostClassService], host: { '(click)': 'clickMenuItem($event)' } },] } ]; /** @nocollapse */ NzMenuItemDirective.ctorParameters = () => [ { type: NzUpdateHostClassService }, { type: NzMenuService }, { type: NzSubmenuService, decorators: [{ type: Optional }] }, { type: Renderer2 }, { type: ElementRef } ]; NzMenuItemDirective.propDecorators = { nzPaddingLeft: [{ type: Input }], nzDisabled: [{ type: Input }], nzSelected: [{ type: Input }] }; 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); if (false) { /** * @type {?} * @private */ NzMenuItemDirective.prototype.el; /** * @type {?} * @private */ NzMenuItemDirective.prototype.destroy$; /** * @type {?} * @private */ NzMenuItemDirective.prototype.originalPadding; /** @type {?} */ NzMenuItemDirective.prototype.selected$; /** @type {?} */ NzMenuItemDirective.prototype.nzPaddingLeft; /** @type {?} */ NzMenuItemDirective.prototype.nzDisabled; /** @type {?} */ NzMenuItemDirective.prototype.nzSelected; /** * @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; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-menu-item.directive.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["menu/nz-menu-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\nimport { merge, EMPTY, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NzUpdateHostClassService } from '../core/services/update-host-class.service';\nimport { isNotNil } from '../core/util';\n\nimport { InputBoolean } from '../core/util/convert';\nimport { NzMenuService } from './nz-menu.service';\nimport { NzSubmenuService } from './nz-submenu.service';\n\n@Directive({\n  selector: '[nz-menu-item]',\n  providers: [NzUpdateHostClassService],\n  host: {\n    '(click)': 'clickMenuItem($event)'\n  }\n})\nexport class NzMenuItemDirective implements OnInit, OnChanges, OnDestroy {\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() nzPaddingLeft: number;\n  @Input() @InputBoolean() nzDisabled = false;\n  @Input() @InputBoolean() nzSelected = false;\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  constructor(\n    private nzUpdateHostClassService: NzUpdateHostClassService,\n    private nzMenuService: NzMenuService,\n    @Optional() private nzSubmenuService: NzSubmenuService,\n    private renderer: Renderer2,\n    private elementRef: ElementRef\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  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"]}