UNPKG

ng-zorro-antd

Version:

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

247 lines 22.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { CdkConnectedOverlay } from '@angular/cdk/overlay'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Host, Input, Optional, Output, ViewChild, ViewEncapsulation } from '@angular/core'; import { combineLatest, merge, EMPTY, Subject } from 'rxjs'; import { debounceTime, distinctUntilChanged, map, mapTo, takeUntil } from 'rxjs/operators'; import { slideMotion } from '../core/animation/slide'; import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive'; import { DEFAULT_DROPDOWN_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position'; import { InputBoolean } from '../core/util/convert'; import { NzMenuDirective } from '../menu/nz-menu.directive'; import { NzDropDownDirective } from './nz-dropdown.directive'; import { NzMenuDropdownService } from './nz-menu-dropdown.service'; var NzDropDownComponent = /** @class */ (function () { function NzDropDownComponent(cdr, nzMenuDropdownService, noAnimation) { this.cdr = cdr; this.nzMenuDropdownService = nzMenuDropdownService; this.noAnimation = noAnimation; this.triggerWidth = 0; this.dropDownPosition = 'bottom'; this.positions = tslib_1.__spread(DEFAULT_DROPDOWN_POSITIONS); this.visible$ = new Subject(); this.destroy$ = new Subject(); this.nzTrigger = 'hover'; this.nzOverlayClassName = ''; this.nzOverlayStyle = {}; this.nzPlacement = 'bottomLeft'; this.nzClickHide = true; this.nzDisabled = false; this.nzVisible = false; this.nzTableFilter = false; this.nzVisibleChange = new EventEmitter(); } /** * @param {?} visible * @param {?=} trigger * @return {?} */ NzDropDownComponent.prototype.setVisibleStateWhen = /** * @param {?} visible * @param {?=} trigger * @return {?} */ function (visible, trigger) { if (trigger === void 0) { trigger = 'all'; } if (this.nzTrigger === trigger || trigger === 'all') { this.visible$.next(visible); } }; /** * @param {?} position * @return {?} */ NzDropDownComponent.prototype.onPositionChange = /** * @param {?} position * @return {?} */ function (position) { this.dropDownPosition = position.connectionPair.originY; this.cdr.markForCheck(); }; /** * @param {?} observable$ * @return {?} */ NzDropDownComponent.prototype.startSubscribe = /** * @param {?} observable$ * @return {?} */ function (observable$) { var _this = this; /** @type {?} */ var click$ = this.nzClickHide ? this.nzMenuDropdownService.menuItemClick$.pipe(mapTo(false)) : EMPTY; combineLatest(merge(observable$, click$), this.nzMenuDropdownService.menuOpen$).pipe(map((/** * @param {?} value * @return {?} */ function (value) { return value[0] || value[1]; })), debounceTime(50), distinctUntilChanged(), takeUntil(this.destroy$)).subscribe((/** * @param {?} visible * @return {?} */ function (visible) { if (!_this.nzDisabled && _this.nzVisible !== visible) { _this.nzVisible = visible; _this.nzVisibleChange.emit(_this.nzVisible); _this.triggerWidth = _this.nzDropDownDirective.elementRef.nativeElement.getBoundingClientRect().width; _this.cdr.markForCheck(); } })); }; /** * @return {?} */ NzDropDownComponent.prototype.updateDisabledState = /** * @return {?} */ function () { if (this.nzDropDownDirective) { this.nzDropDownDirective.setDisabled(this.nzDisabled); } }; /** * @return {?} */ NzDropDownComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); }; /** * @return {?} */ NzDropDownComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { this.startSubscribe(merge(this.visible$, this.nzTrigger === 'hover' ? this.nzDropDownDirective.hover$ : this.nzDropDownDirective.$click)); this.updateDisabledState(); }; /** * @param {?} changes * @return {?} */ NzDropDownComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzVisible) { this.visible$.next(this.nzVisible); } if (changes.nzDisabled) { this.updateDisabledState(); } if (changes.nzPlacement) { this.dropDownPosition = this.nzPlacement.indexOf('top') !== -1 ? 'top' : 'bottom'; this.positions = tslib_1.__spread([POSITION_MAP[this.nzPlacement]], this.positions); } }; NzDropDownComponent.decorators = [ { type: Component, args: [{ selector: 'nz-dropdown', preserveWhitespaces: false, providers: [NzMenuDropdownService], animations: [slideMotion], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content select=\"[nz-dropdown]\"></ng-content>\n<ng-template cdkConnectedOverlay\n [cdkConnectedOverlayHasBackdrop]=\"nzTrigger === 'click'\"\n [cdkConnectedOverlayPositions]=\"positions\"\n [cdkConnectedOverlayOrigin]=\"nzDropDownDirective\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"nzVisible\"\n (backdropClick)=\"setVisibleStateWhen(false)\"\n (detach)=\"setVisibleStateWhen(false)\"\n (positionChange)=\"onPositionChange($event)\">\n <div class=\"{{'ant-dropdown ant-dropdown-placement-'+nzPlacement}}\"\n [ngClass]=\"nzOverlayClassName\"\n [ngStyle]=\"nzOverlayStyle\"\n [@slideMotion]=\"dropDownPosition\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [style.minWidth.px]=\"triggerWidth\"\n (mouseenter)=\"setVisibleStateWhen(true,'hover')\"\n (mouseleave)=\"setVisibleStateWhen(false,'hover')\">\n <div [class.ant-table-filter-dropdown]=\"nzTableFilter\">\n <ng-content select=\"[nz-menu]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n</ng-template>", styles: ["\n .ant-dropdown {\n top: 100%;\n left: 0;\n position: relative;\n width: 100%;\n margin-top: 4px;\n margin-bottom: 4px;\n }\n "] }] } ]; /** @nocollapse */ NzDropDownComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: NzMenuDropdownService }, { type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] } ]; }; NzDropDownComponent.propDecorators = { nzDropDownDirective: [{ type: ContentChild, args: [NzDropDownDirective,] }], nzMenuDirective: [{ type: ContentChild, args: [NzMenuDirective,] }], cdkConnectedOverlay: [{ type: ViewChild, args: [CdkConnectedOverlay,] }], nzTrigger: [{ type: Input }], nzOverlayClassName: [{ type: Input }], nzOverlayStyle: [{ type: Input }], nzPlacement: [{ type: Input }], nzClickHide: [{ type: Input }], nzDisabled: [{ type: Input }], nzVisible: [{ type: Input }], nzTableFilter: [{ type: Input }], nzVisibleChange: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzDropDownComponent.prototype, "nzClickHide", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzDropDownComponent.prototype, "nzDisabled", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzDropDownComponent.prototype, "nzVisible", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzDropDownComponent.prototype, "nzTableFilter", void 0); return NzDropDownComponent; }()); export { NzDropDownComponent }; if (false) { /** @type {?} */ NzDropDownComponent.prototype.triggerWidth; /** @type {?} */ NzDropDownComponent.prototype.dropDownPosition; /** @type {?} */ NzDropDownComponent.prototype.positions; /** @type {?} */ NzDropDownComponent.prototype.visible$; /** * @type {?} * @private */ NzDropDownComponent.prototype.destroy$; /** @type {?} */ NzDropDownComponent.prototype.nzDropDownDirective; /** @type {?} */ NzDropDownComponent.prototype.nzMenuDirective; /** @type {?} */ NzDropDownComponent.prototype.cdkConnectedOverlay; /** @type {?} */ NzDropDownComponent.prototype.nzTrigger; /** @type {?} */ NzDropDownComponent.prototype.nzOverlayClassName; /** @type {?} */ NzDropDownComponent.prototype.nzOverlayStyle; /** @type {?} */ NzDropDownComponent.prototype.nzPlacement; /** @type {?} */ NzDropDownComponent.prototype.nzClickHide; /** @type {?} */ NzDropDownComponent.prototype.nzDisabled; /** @type {?} */ NzDropDownComponent.prototype.nzVisible; /** @type {?} */ NzDropDownComponent.prototype.nzTableFilter; /** @type {?} */ NzDropDownComponent.prototype.nzVisibleChange; /** * @type {?} * @protected */ NzDropDownComponent.prototype.cdr; /** * @type {?} * @private */ NzDropDownComponent.prototype.nzMenuDropdownService; /** @type {?} */ NzDropDownComponent.prototype.noAnimation; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-dropdown.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["dropdown/nz-dropdown.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,mBAAmB,EAA0D,MAAM,sBAAsB,CAAC;AACnH,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,YAAY,EAAE,IAAI,EAClB,KAAK,EAEM,QAAQ,EACnB,MAAM,EAEN,SAAS,EACT,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3F,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,gDAAgD,CAAC;AACxF,OAAO,EAAE,0BAA0B,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAC5F,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAInE;IA8EE,6BAAsB,GAAsB,EAAU,qBAA4C,EAC3D,WAAoC;QADrD,QAAG,GAAH,GAAG,CAAmB;QAAU,0BAAqB,GAArB,qBAAqB,CAAuB;QAC3D,gBAAW,GAAX,WAAW,CAAyB;QAxD3E,iBAAY,GAAG,CAAC,CAAC;QACjB,qBAAgB,GAAgC,QAAQ,CAAC;QACzD,cAAS,oBAAkC,0BAA0B,EAAG;QACxE,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QAC1B,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAI9B,cAAS,GAAsB,OAAO,CAAC;QACvC,uBAAkB,GAAG,EAAE,CAAC;QACxB,mBAAc,GAAgC,EAAE,CAAC;QACjD,gBAAW,GAAgB,YAAY,CAAC;QACxB,gBAAW,GAAG,IAAI,CAAC;QACnB,eAAU,GAAG,KAAK,CAAC;QACnB,cAAS,GAAG,KAAK,CAAC;QAClB,kBAAa,GAAG,KAAK,CAAC;QAC5B,oBAAe,GAA0B,IAAI,YAAY,EAAE,CAAC;IAyC/E,CAAC;;;;;;IAvCD,iDAAmB;;;;;IAAnB,UAAoB,OAAgB,EAAE,OAA0C;QAA1C,wBAAA,EAAA,eAA0C;QAC9E,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,IAAI,OAAO,KAAK,KAAK,EAAE;YACnD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC7B;IACH,CAAC;;;;;IAED,8CAAgB;;;;IAAhB,UAAiB,QAAwC;QACvD,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC;QACxD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;;;IAED,4CAAc;;;;IAAd,UAAe,WAAgC;QAA/C,iBAkBC;;YAjBO,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK;QACtG,aAAa,CACX,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,EAC1B,IAAI,CAAC,qBAAqB,CAAC,SAAS,CACrC,CAAC,IAAI,CACJ,GAAG;;;;QAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAE,CAAC,CAAE,IAAI,KAAK,CAAE,CAAC,CAAE,EAAxB,CAAwB,EAAC,EACtC,YAAY,CAAC,EAAE,CAAC,EAChB,oBAAoB,EAAE,EACtB,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CACzB,CAAC,SAAS;;;;QAAC,UAAC,OAAO;YAClB,IAAI,CAAC,KAAI,CAAC,UAAU,IAAI,KAAI,CAAC,SAAS,KAAK,OAAO,EAAE;gBAClD,KAAI,CAAC,SAAS,GAAG,OAAO,CAAC;gBACzB,KAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAI,CAAC,SAAS,CAAC,CAAC;gBAC1C,KAAI,CAAC,YAAY,GAAG,KAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;gBACpG,KAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,iDAAmB;;;IAAnB;QACE,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACvD;IACH,CAAC;;;;IAMD,yCAAW;;;IAAX;QACE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;;;IAED,gDAAkB;;;IAAlB;QACE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1I,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;;;;;IAED,yCAAW;;;;IAAX,UAAY,OAAsB;QAChC,IAAI,OAAO,CAAC,SAAS,EAAE;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACpC;QACD,IAAI,OAAO,CAAC,UAAU,EAAE;YACtB,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;QACD,IAAI,OAAO,CAAC,WAAW,EAAE;YACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC;YAClF,IAAI,CAAC,SAAS,qBAAK,YAAY,CAAE,IAAI,CAAC,WAAW,CAAE,GAAK,IAAI,CAAC,SAAS,CAAE,CAAC;SAC1E;IACH,CAAC;;gBAvGF,SAAS,SAAC;oBACT,QAAQ,EAAa,aAAa;oBAClC,mBAAmB,EAAE,KAAK;oBAC1B,SAAS,EAAY,CAAE,qBAAqB,CAAE;oBAC9C,UAAU,EAAW,CAAE,WAAW,CAAE;oBACpC,aAAa,EAAQ,iBAAiB,CAAC,IAAI;oBAC3C,eAAe,EAAM,uBAAuB,CAAC,MAAM;oBACnD,ujCAAmD;6BAE/C,wLASD;iBAEJ;;;;gBA5CC,iBAAiB;gBAoBV,qBAAqB;gBALrB,sBAAsB,uBAwFhB,IAAI,YAAI,QAAQ;;;sCAnD5B,YAAY,SAAC,mBAAmB;kCAChC,YAAY,SAAC,eAAe;sCAC5B,SAAS,SAAC,mBAAmB;4BAC7B,KAAK;qCACL,KAAK;iCACL,KAAK;8BACL,KAAK;8BACL,KAAK;6BACL,KAAK;4BACL,KAAK;gCACL,KAAK;kCACL,MAAM;;IAJkB;QAAf,YAAY,EAAE;;4DAAoB;IACnB;QAAf,YAAY,EAAE;;2DAAoB;IACnB;QAAf,YAAY,EAAE;;0DAAmB;IAClB;QAAf,YAAY,EAAE;;8DAAuB;IAkEjD,0BAAC;CAAA,AAxGD,IAwGC;SAlFY,mBAAmB;;;IAC9B,2CAAiB;;IACjB,+CAAyD;;IACzD,wCAAwE;;IACxE,uCAAkC;;;;;IAClC,uCAAuC;;IACvC,kDAA4E;;IAC5E,8CAAgE;;IAChE,kDAAyE;;IACzE,wCAAgD;;IAChD,iDAAiC;;IACjC,6CAA0D;;IAC1D,0CAAiD;;IACjD,0CAA4C;;IAC5C,yCAA4C;;IAC5C,wCAA2C;;IAC3C,4CAA+C;;IAC/C,8CAA+E;;;;;IAuCnE,kCAAgC;;;;;IAAE,oDAAoD;;IACtF,0CAA+D","sourcesContent":["import { CdkConnectedOverlay, ConnectedOverlayPositionChange, ConnectionPositionPair } from '@angular/cdk/overlay';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter, Host,\n  Input,\n  OnChanges,\n  OnDestroy, Optional,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { combineLatest, merge, EMPTY, Observable, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, map, mapTo, takeUntil } from 'rxjs/operators';\nimport { slideMotion } from '../core/animation/slide';\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { DEFAULT_DROPDOWN_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position';\nimport { InputBoolean } from '../core/util/convert';\nimport { NzMenuDirective } from '../menu/nz-menu.directive';\nimport { NzDropDownDirective } from './nz-dropdown.directive';\nimport { NzMenuDropdownService } from './nz-menu-dropdown.service';\n\nexport type NzPlacement = 'bottomLeft' | 'bottomCenter' | 'bottomRight' | 'topLeft' | 'topCenter' | 'topRight';\n\n@Component({\n  selector           : 'nz-dropdown',\n  preserveWhitespaces: false,\n  providers          : [ NzMenuDropdownService ],\n  animations         : [ slideMotion ],\n  encapsulation      : ViewEncapsulation.None,\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  templateUrl        : './nz-dropdown.component.html',\n  styles             : [\n      `\n      .ant-dropdown {\n        top: 100%;\n        left: 0;\n        position: relative;\n        width: 100%;\n        margin-top: 4px;\n        margin-bottom: 4px;\n      }\n    `\n  ]\n})\n\nexport class NzDropDownComponent implements OnDestroy, AfterContentInit, OnChanges {\n  triggerWidth = 0;\n  dropDownPosition: 'top' | 'center' | 'bottom' = 'bottom';\n  positions: ConnectionPositionPair[] = [ ...DEFAULT_DROPDOWN_POSITIONS ];\n  visible$ = new Subject<boolean>();\n  private destroy$ = new Subject<void>();\n  @ContentChild(NzDropDownDirective) nzDropDownDirective: NzDropDownDirective;\n  @ContentChild(NzMenuDirective) nzMenuDirective: NzMenuDirective;\n  @ViewChild(CdkConnectedOverlay) cdkConnectedOverlay: CdkConnectedOverlay;\n  @Input() nzTrigger: 'click' | 'hover' = 'hover';\n  @Input() nzOverlayClassName = '';\n  @Input() nzOverlayStyle: { [ key: string ]: string } = {};\n  @Input() nzPlacement: NzPlacement = 'bottomLeft';\n  @Input() @InputBoolean() nzClickHide = true;\n  @Input() @InputBoolean() nzDisabled = false;\n  @Input() @InputBoolean() nzVisible = false;\n  @Input() @InputBoolean() nzTableFilter = false;\n  @Output() readonly nzVisibleChange: EventEmitter<boolean> = new EventEmitter();\n\n  setVisibleStateWhen(visible: boolean, trigger: 'click' | 'hover' | 'all' = 'all'): void {\n    if (this.nzTrigger === trigger || trigger === 'all') {\n      this.visible$.next(visible);\n    }\n  }\n\n  onPositionChange(position: ConnectedOverlayPositionChange): void {\n    this.dropDownPosition = position.connectionPair.originY;\n    this.cdr.markForCheck();\n  }\n\n  startSubscribe(observable$: Observable<boolean>): void {\n    const click$ = this.nzClickHide ? this.nzMenuDropdownService.menuItemClick$.pipe(mapTo(false)) : EMPTY;\n    combineLatest(\n      merge(observable$, click$),\n      this.nzMenuDropdownService.menuOpen$\n    ).pipe(\n      map(value => value[ 0 ] || value[ 1 ]),\n      debounceTime(50),\n      distinctUntilChanged(),\n      takeUntil(this.destroy$)\n    ).subscribe((visible) => {\n      if (!this.nzDisabled && this.nzVisible !== visible) {\n        this.nzVisible = visible;\n        this.nzVisibleChange.emit(this.nzVisible);\n        this.triggerWidth = this.nzDropDownDirective.elementRef.nativeElement.getBoundingClientRect().width;\n        this.cdr.markForCheck();\n      }\n    });\n  }\n\n  updateDisabledState(): void {\n    if (this.nzDropDownDirective) {\n      this.nzDropDownDirective.setDisabled(this.nzDisabled);\n    }\n  }\n\n  constructor(protected cdr: ChangeDetectorRef, private nzMenuDropdownService: NzMenuDropdownService,\n              @Host() @Optional() public noAnimation?: NzNoAnimationDirective) {\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  ngAfterContentInit(): void {\n    this.startSubscribe(merge(this.visible$, this.nzTrigger === 'hover' ? this.nzDropDownDirective.hover$ : this.nzDropDownDirective.$click));\n    this.updateDisabledState();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzVisible) {\n      this.visible$.next(this.nzVisible);\n    }\n    if (changes.nzDisabled) {\n      this.updateDisabledState();\n    }\n    if (changes.nzPlacement) {\n      this.dropDownPosition = this.nzPlacement.indexOf('top') !== -1 ? 'top' : 'bottom';\n      this.positions = [ POSITION_MAP[ this.nzPlacement ], ...this.positions ];\n    }\n  }\n}\n"]}