ng-zorro-antd-yj
Version:
An enterprise-class UI components based on Ant Design and Angular
233 lines • 21.5 kB
JavaScript
/**
* @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';
export class NzDropDownComponent {
/**
* @param {?} cdr
* @param {?} nzMenuDropdownService
* @param {?=} noAnimation
*/
constructor(cdr, nzMenuDropdownService, noAnimation) {
this.cdr = cdr;
this.nzMenuDropdownService = nzMenuDropdownService;
this.noAnimation = noAnimation;
this.triggerWidth = 0;
this.dropDownPosition = 'bottom';
this.positions = [...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 {?}
*/
setVisibleStateWhen(visible, trigger = 'all') {
if (this.nzTrigger === trigger || trigger === 'all') {
this.visible$.next(visible);
}
}
/**
* @param {?} position
* @return {?}
*/
onPositionChange(position) {
this.dropDownPosition = position.connectionPair.originY;
this.cdr.markForCheck();
}
/**
* @param {?} observable$
* @return {?}
*/
startSubscribe(observable$) {
/** @type {?} */
const click$ = this.nzClickHide ? this.nzMenuDropdownService.menuItemClick$.pipe(mapTo(false)) : EMPTY;
combineLatest(merge(observable$, click$), this.nzMenuDropdownService.menuOpen$)
.pipe(map((/**
* @param {?} value
* @return {?}
*/
value => value[0] || value[1])), debounceTime(50), distinctUntilChanged(), takeUntil(this.destroy$))
.subscribe((/**
* @param {?} visible
* @return {?}
*/
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 {?}
*/
updateDisabledState() {
if (this.nzDropDownDirective) {
this.nzDropDownDirective.setDisabled(this.nzDisabled);
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.startSubscribe(merge(this.visible$, this.nzTrigger === 'hover' ? this.nzDropDownDirective.hover$ : this.nzDropDownDirective.$click));
this.updateDisabledState();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(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 = [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\n cdkConnectedOverlay\n nzConnectedOverlay\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: [`
.ant-dropdown {
top: 100%;
left: 0;
position: relative;
width: 100%;
margin-top: 4px;
margin-bottom: 4px;
}
`]
}] }
];
/** @nocollapse */
NzDropDownComponent.ctorParameters = () => [
{ 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);
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-yj/","sources":["dropdown/nz-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, ConnectedOverlayPositionChange, ConnectionPositionPair } from '@angular/cdk/overlay';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  OnDestroy,\n  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})\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(merge(observable$, click$), this.nzMenuDropdownService.menuOpen$)\n      .pipe(\n        map(value => value[0] || value[1]),\n        debounceTime(50),\n        distinctUntilChanged(),\n        takeUntil(this.destroy$)\n      )\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(\n    protected cdr: ChangeDetectorRef,\n    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(\n      merge(\n        this.visible$,\n        this.nzTrigger === 'hover' ? this.nzDropDownDirective.hover$ : this.nzDropDownDirective.$click\n      )\n    );\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"]}