UNPKG

ng-zorro-antd

Version:

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

262 lines 21.2 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, EventEmitter, Input, Optional, Output, QueryList, SkipSelf } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { InputBoolean, NzDropdownHigherOrderServiceToken, NzMenuBaseService, NzUpdateHostClassService } from 'ng-zorro-antd/core'; import { NzMenuItemDirective } from './nz-menu-item.directive'; import { NzMenuServiceFactory } from './nz-menu.resolver'; import { NzMenuService } from './nz-menu.service'; import { NzSubMenuComponent } from './nz-submenu.component'; var ɵ0 = NzMenuServiceFactory; var NzMenuDirective = /** @class */ (function () { function NzMenuDirective(elementRef, nzMenuService, nzUpdateHostClassService) { this.elementRef = elementRef; this.nzMenuService = nzMenuService; this.nzUpdateHostClassService = nzUpdateHostClassService; this.destroy$ = new Subject(); this.listOfOpenedNzSubMenuComponent = []; this.nzInlineIndent = 24; this.nzTheme = 'light'; this.nzMode = 'vertical'; this.nzInDropDown = false; this.nzInlineCollapsed = false; this.nzSelectable = !this.nzMenuService.isInDropDown; this.nzClick = new EventEmitter(); } /** * @return {?} */ NzMenuDirective.prototype.updateInlineCollapse = /** * @return {?} */ function () { if (this.listOfNzMenuItemDirective) { if (this.nzInlineCollapsed) { this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter((/** * @param {?} submenu * @return {?} */ function (submenu) { return submenu.nzOpen; })); this.listOfNzSubMenuComponent.forEach((/** * @param {?} submenu * @return {?} */ function (submenu) { return submenu.setOpenState(false); })); this.nzMode = 'vertical'; } else { this.listOfOpenedNzSubMenuComponent.forEach((/** * @param {?} submenu * @return {?} */ function (submenu) { return submenu.setOpenState(true); })); this.listOfOpenedNzSubMenuComponent = []; this.nzMode = this.cacheMode; } this.nzMenuService.setMode(this.nzMode); } }; /** * @return {?} */ NzMenuDirective.prototype.setClassMap = /** * @return {?} */ function () { var _a; /** @type {?} */ var prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu' : 'ant-menu'; this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, (_a = {}, _a["" + prefixName] = true, _a[prefixName + "-root"] = true, _a[prefixName + "-" + this.nzTheme] = true, _a[prefixName + "-" + this.nzMode] = true, _a[prefixName + "-inline-collapsed"] = this.nzInlineCollapsed, _a)); }; /** * @return {?} */ NzMenuDirective.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.setClassMap(); this.nzMenuService.menuItemClick$.pipe(takeUntil(this.destroy$)).subscribe((/** * @param {?} menu * @return {?} */ function (menu) { _this.nzClick.emit(menu); if (_this.nzSelectable) { _this.listOfNzMenuItemDirective.forEach((/** * @param {?} item * @return {?} */ function (item) { return item.setSelectedState(item === menu); })); } })); }; /** * @return {?} */ NzMenuDirective.prototype.ngAfterContentInit = /** * @return {?} */ function () { this.cacheMode = this.nzMode; this.updateInlineCollapse(); }; /** * @param {?} changes * @return {?} */ NzMenuDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzInlineCollapsed) { this.updateInlineCollapse(); } if (changes.nzInlineIndent) { this.nzMenuService.setInlineIndent(this.nzInlineIndent); } if (changes.nzInDropDown) { this.nzMenuService.isInDropDown = this.nzInDropDown; } if (changes.nzTheme) { this.nzMenuService.setTheme(this.nzTheme); } if (changes.nzMode) { this.nzMenuService.setMode(this.nzMode); if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) { this.listOfNzSubMenuComponent.forEach((/** * @param {?} submenu * @return {?} */ function (submenu) { return submenu.setOpenState(false); })); } } if (changes.nzTheme || changes.nzMode || changes.nzInlineCollapsed) { this.setClassMap(); } }; /** * @return {?} */ NzMenuDirective.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); }; NzMenuDirective.decorators = [ { type: Directive, args: [{ selector: '[nz-menu]', exportAs: 'nzMenu', providers: [ NzUpdateHostClassService, NzMenuService, { provide: NzMenuBaseService, useFactory: ɵ0, deps: [[new SkipSelf(), new Optional(), NzDropdownHigherOrderServiceToken], NzMenuService] } ] },] } ]; /** @nocollapse */ NzMenuDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: NzMenuBaseService }, { type: NzUpdateHostClassService } ]; }; NzMenuDirective.propDecorators = { listOfNzMenuItemDirective: [{ type: ContentChildren, args: [NzMenuItemDirective, { descendants: true },] }], listOfNzSubMenuComponent: [{ type: ContentChildren, args: [NzSubMenuComponent, { descendants: true },] }], nzInlineIndent: [{ type: Input }], nzTheme: [{ type: Input }], nzMode: [{ type: Input }], nzInDropDown: [{ type: Input }], nzInlineCollapsed: [{ type: Input }], nzSelectable: [{ type: Input }], nzClick: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuDirective.prototype, "nzInDropDown", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuDirective.prototype, "nzInlineCollapsed", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzMenuDirective.prototype, "nzSelectable", void 0); return NzMenuDirective; }()); export { NzMenuDirective }; if (false) { /** * @type {?} * @private */ NzMenuDirective.prototype.destroy$; /** * @type {?} * @private */ NzMenuDirective.prototype.cacheMode; /** * @type {?} * @private */ NzMenuDirective.prototype.listOfOpenedNzSubMenuComponent; /** @type {?} */ NzMenuDirective.prototype.listOfNzMenuItemDirective; /** @type {?} */ NzMenuDirective.prototype.listOfNzSubMenuComponent; /** @type {?} */ NzMenuDirective.prototype.nzInlineIndent; /** @type {?} */ NzMenuDirective.prototype.nzTheme; /** @type {?} */ NzMenuDirective.prototype.nzMode; /** @type {?} */ NzMenuDirective.prototype.nzInDropDown; /** @type {?} */ NzMenuDirective.prototype.nzInlineCollapsed; /** @type {?} */ NzMenuDirective.prototype.nzSelectable; /** @type {?} */ NzMenuDirective.prototype.nzClick; /** @type {?} */ NzMenuDirective.prototype.elementRef; /** * @type {?} * @private */ NzMenuDirective.prototype.nzMenuService; /** * @type {?} * @private */ NzMenuDirective.prototype.nzUpdateHostClassService; } export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-menu.directive.js","sourceRoot":"ng://ng-zorro-antd/menu/","sources":["nz-menu.directive.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EAEL,eAAe,EACf,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAIL,QAAQ,EACR,MAAM,EACN,SAAS,EAET,QAAQ,EACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EACL,YAAY,EAEZ,iCAAiC,EACjC,iBAAiB,EACjB,wBAAwB,EACzB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;SAU1C,oBAAoB;AARtC;IAuDE,yBACS,UAAsB,EACrB,aAAgC,EAChC,wBAAkD;QAFnD,eAAU,GAAV,UAAU,CAAY;QACrB,kBAAa,GAAb,aAAa,CAAmB;QAChC,6BAAwB,GAAxB,wBAAwB,CAA0B;QA5CpD,aAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;QAEzB,mCAA8B,GAAyB,EAAE,CAAC;QAKzD,mBAAc,GAAG,EAAE,CAAC;QACpB,YAAO,GAAqB,OAAO,CAAC;QACpC,WAAM,GAAuB,UAAU,CAAC;QACxB,iBAAY,GAAG,KAAK,CAAC;QACrB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,iBAAY,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;QACtD,YAAO,GAAG,IAAI,YAAY,EAAuB,CAAC;IAgClE,CAAC;;;;IA9BJ,8CAAoB;;;IAApB;QACE,IAAI,IAAI,CAAC,yBAAyB,EAAE;YAClC,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBAC1B,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC,wBAAwB,CAAC,MAAM;;;;gBAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,MAAM,EAAd,CAAc,EAAC,CAAC;gBACtG,IAAI,CAAC,wBAAwB,CAAC,OAAO;;;;gBAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,EAA3B,CAA2B,EAAC,CAAC;gBAC9E,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC;aAC1B;iBAAM;gBACL,IAAI,CAAC,8BAA8B,CAAC,OAAO;;;;gBAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,EAA1B,CAA0B,EAAC,CAAC;gBACnF,IAAI,CAAC,8BAA8B,GAAG,EAAE,CAAC;gBACzC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC;aAC9B;YACD,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACzC;IACH,CAAC;;;;IAED,qCAAW;;;IAAX;;;YACQ,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,UAAU;QACrF,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa;YACzE,GAAC,KAAG,UAAY,IAAG,IAAI;YACvB,GAAI,UAAU,UAAO,IAAG,IAAI;YAC5B,GAAI,UAAU,SAAI,IAAI,CAAC,OAAS,IAAG,IAAI;YACvC,GAAI,UAAU,SAAI,IAAI,CAAC,MAAQ,IAAG,IAAI;YACtC,GAAI,UAAU,sBAAmB,IAAG,IAAI,CAAC,iBAAiB;gBAC1D,CAAC;IACL,CAAC;;;;IAQD,kCAAQ;;;IAAR;QAAA,iBAQC;QAPC,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;;QAAC,UAAA,IAAI;YAC7E,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,KAAI,CAAC,YAAY,EAAE;gBACrB,KAAI,CAAC,yBAAyB,CAAC,OAAO;;;;gBAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,gBAAgB,CAAC,IAAI,KAAK,IAAI,CAAC,EAApC,CAAoC,EAAC,CAAC;aACtF;QACH,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,4CAAkB;;;IAAlB;QACE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC;QAC7B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;;;;;IAED,qCAAW;;;;IAAX,UAAY,OAAsB;QAChC,IAAI,OAAO,CAAC,iBAAiB,EAAE;YAC7B,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;QACD,IAAI,OAAO,CAAC,cAAc,EAAE;YAC1B,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACzD;QACD,IAAI,OAAO,CAAC,YAAY,EAAE;YACxB,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;SACrD;QACD,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC3C;QACD,IAAI,OAAO,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACxC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,wBAAwB,EAAE;gBACpE,IAAI,CAAC,wBAAwB,CAAC,OAAO;;;;gBAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,EAA3B,CAA2B,EAAC,CAAC;aAC/E;SACF;QACD,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,iBAAiB,EAAE;YAClE,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;;;;IAED,qCAAW;;;IAAX;QACE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;gBAvGF,SAAS,SAAC;oBACT,QAAQ,EAAE,WAAW;oBACrB,QAAQ,EAAE,QAAQ;oBAClB,SAAS,EAAE;wBACT,wBAAwB;wBACxB,aAAa;wBACb;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,UAAU,IAAsB;4BAChC,IAAI,EAAE,CAAC,CAAC,IAAI,QAAQ,EAAE,EAAE,IAAI,QAAQ,EAAE,EAAE,iCAAiC,CAAC,EAAE,aAAa,CAAC;yBAC3F;qBACF;iBACF;;;;gBAzCC,UAAU;gBAoBV,iBAAiB;gBACjB,wBAAwB;;;4CAyBvB,eAAe,SAAC,mBAAmB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;2CAG1D,eAAe,SAAC,kBAAkB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;iCACzD,KAAK;0BACL,KAAK;yBACL,KAAK;+BACL,KAAK;oCACL,KAAK;+BACL,KAAK;0BACL,MAAM;;IAHkB;QAAf,YAAY,EAAE;;yDAAsB;IACrB;QAAf,YAAY,EAAE;;8DAA2B;IAC1B;QAAf,YAAY,EAAE;;yDAAiD;IA8E3E,sBAAC;CAAA,AAxGD,IAwGC;SA3FY,eAAe;;;;;;IAC1B,mCAAiC;;;;;IACjC,oCAAsC;;;;;IACtC,yDAAkE;;IAClE,oDAEE;;IACF,mDAAoH;;IACpH,yCAA6B;;IAC7B,kCAA6C;;IAC7C,iCAAiD;;IACjD,uCAA8C;;IAC9C,4CAAmD;;IACnD,uCAAyE;;IACzE,kCAAqE;;IA6BnE,qCAA6B;;;;;IAC7B,wCAAwC;;;;;IACxC,mDAA0D","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  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  SkipSelf\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport {\n  InputBoolean,\n  NzDirectionVHIType,\n  NzDropdownHigherOrderServiceToken,\n  NzMenuBaseService,\n  NzUpdateHostClassService\n} from 'ng-zorro-antd/core';\n\nimport { NzMenuItemDirective } from './nz-menu-item.directive';\nimport { NzMenuServiceFactory } from './nz-menu.resolver';\nimport { NzMenuService } from './nz-menu.service';\nimport { NzSubMenuComponent } from './nz-submenu.component';\n\n@Directive({\n  selector: '[nz-menu]',\n  exportAs: 'nzMenu',\n  providers: [\n    NzUpdateHostClassService,\n    NzMenuService,\n    {\n      provide: NzMenuBaseService,\n      useFactory: NzMenuServiceFactory,\n      deps: [[new SkipSelf(), new Optional(), NzDropdownHigherOrderServiceToken], NzMenuService]\n    }\n  ]\n})\nexport class NzMenuDirective implements AfterContentInit, OnInit, OnChanges, OnDestroy {\n  private destroy$ = new Subject();\n  private cacheMode: NzDirectionVHIType;\n  private listOfOpenedNzSubMenuComponent: NzSubMenuComponent[] = [];\n  @ContentChildren(NzMenuItemDirective, { descendants: true }) listOfNzMenuItemDirective: QueryList<\n    NzMenuItemDirective\n  >;\n  @ContentChildren(NzSubMenuComponent, { descendants: true }) listOfNzSubMenuComponent: QueryList<NzSubMenuComponent>;\n  @Input() nzInlineIndent = 24;\n  @Input() nzTheme: 'light' | 'dark' = 'light';\n  @Input() nzMode: NzDirectionVHIType = 'vertical';\n  @Input() @InputBoolean() nzInDropDown = false;\n  @Input() @InputBoolean() nzInlineCollapsed = false;\n  @Input() @InputBoolean() nzSelectable = !this.nzMenuService.isInDropDown;\n  @Output() readonly nzClick = new EventEmitter<NzMenuItemDirective>();\n\n  updateInlineCollapse(): void {\n    if (this.listOfNzMenuItemDirective) {\n      if (this.nzInlineCollapsed) {\n        this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter(submenu => submenu.nzOpen);\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenState(false));\n        this.nzMode = 'vertical';\n      } else {\n        this.listOfOpenedNzSubMenuComponent.forEach(submenu => submenu.setOpenState(true));\n        this.listOfOpenedNzSubMenuComponent = [];\n        this.nzMode = this.cacheMode;\n      }\n      this.nzMenuService.setMode(this.nzMode);\n    }\n  }\n\n  setClassMap(): void {\n    const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu' : 'ant-menu';\n    this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, {\n      [`${prefixName}`]: true,\n      [`${prefixName}-root`]: true,\n      [`${prefixName}-${this.nzTheme}`]: true,\n      [`${prefixName}-${this.nzMode}`]: true,\n      [`${prefixName}-inline-collapsed`]: this.nzInlineCollapsed\n    });\n  }\n\n  constructor(\n    public elementRef: ElementRef,\n    private nzMenuService: NzMenuBaseService,\n    private nzUpdateHostClassService: NzUpdateHostClassService\n  ) {}\n\n  ngOnInit(): void {\n    this.setClassMap();\n    this.nzMenuService.menuItemClick$.pipe(takeUntil(this.destroy$)).subscribe(menu => {\n      this.nzClick.emit(menu);\n      if (this.nzSelectable) {\n        this.listOfNzMenuItemDirective.forEach(item => item.setSelectedState(item === menu));\n      }\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.cacheMode = this.nzMode;\n    this.updateInlineCollapse();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzInlineCollapsed) {\n      this.updateInlineCollapse();\n    }\n    if (changes.nzInlineIndent) {\n      this.nzMenuService.setInlineIndent(this.nzInlineIndent);\n    }\n    if (changes.nzInDropDown) {\n      this.nzMenuService.isInDropDown = this.nzInDropDown;\n    }\n    if (changes.nzTheme) {\n      this.nzMenuService.setTheme(this.nzTheme);\n    }\n    if (changes.nzMode) {\n      this.nzMenuService.setMode(this.nzMode);\n      if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) {\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenState(false));\n      }\n    }\n    if (changes.nzTheme || changes.nzMode || changes.nzInlineCollapsed) {\n      this.setClassMap();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}