UNPKG

ng-zorro-antd

Version:

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

165 lines 15.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, NgZone, Output, QueryList, TemplateRef, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core'; import { fromEvent, Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { NzOptionLiComponent } from './nz-option-li.component'; import { NzSelectService } from './nz-select.service'; export class NzOptionContainerComponent { /** * @param {?} nzSelectService * @param {?} cdr * @param {?} ngZone */ constructor(nzSelectService, cdr, ngZone) { this.nzSelectService = nzSelectService; this.cdr = cdr; this.ngZone = ngZone; this.destroy$ = new Subject(); this.nzScrollToBottom = new EventEmitter(); } /** * @param {?} option * @return {?} */ scrollIntoViewIfNeeded(option) { // delay after open setTimeout((/** * @return {?} */ () => { if (this.listOfNzOptionLiComponent && this.listOfNzOptionLiComponent.length && option) { /** @type {?} */ const targetOption = this.listOfNzOptionLiComponent.find((/** * @param {?} o * @return {?} */ o => this.nzSelectService.compareWith(o.nzOption.nzValue, option.nzValue))); /* tslint:disable-next-line:no-string-literal */ if (targetOption && targetOption.el && targetOption.el['scrollIntoViewIfNeeded']) { /* tslint:disable-next-line:no-string-literal */ targetOption.el['scrollIntoViewIfNeeded'](false); } } })); } /** * @param {?} _index * @param {?} option * @return {?} */ trackLabel(_index, option) { return option.nzLabel; } // tslint:disable-next-line:no-any /** * @param {?} _index * @param {?} option * @return {?} */ trackValue(_index, option) { return option.nzValue; } /** * @return {?} */ ngOnInit() { this.nzSelectService.activatedOption$.pipe(takeUntil(this.destroy$)).subscribe((/** * @param {?} option * @return {?} */ (option) => { this.scrollIntoViewIfNeeded(option); })); this.nzSelectService.check$.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ () => { this.cdr.markForCheck(); })); this.ngZone.runOutsideAngular((/** * @return {?} */ () => { /** @type {?} */ const ul = this.dropdownUl.nativeElement; fromEvent(ul, 'scroll').pipe(takeUntil(this.destroy$)).subscribe((/** * @param {?} e * @return {?} */ e => { e.preventDefault(); e.stopPropagation(); if (ul && (ul.scrollHeight < (ul.clientHeight + ul.scrollTop + 10))) { this.ngZone.run((/** * @return {?} */ () => { this.nzScrollToBottom.emit(); })); } })); })); } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } } NzOptionContainerComponent.decorators = [ { type: Component, args: [{ selector: '[nz-option-container]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<ul #dropdownUl\n class=\"ant-select-dropdown-menu ant-select-dropdown-menu-root ant-select-dropdown-menu-vertical\"\n role=\"menu\"\n tabindex=\"0\">\n <li *ngIf=\"nzSelectService.isShowNotFound\"\n nz-select-unselectable\n class=\"ant-select-dropdown-menu-item ant-select-dropdown-menu-item-disabled\">\n <nz-embed-empty [nzComponentName]=\"'select'\" [specificContent]=\"nzNotFoundContent\"></nz-embed-empty>\n </li>\n <li nz-option-li\n *ngIf=\"nzSelectService.addedTagOption\"\n [nzMenuItemSelectedIcon]=\"nzMenuItemSelectedIcon\"\n [nzOption]=\"nzSelectService.addedTagOption\">\n </li>\n <li nz-option-li\n *ngFor=\"let option of nzSelectService.listOfNzOptionComponent | nzFilterOption : nzSelectService.searchValue : nzSelectService.filterOption : nzSelectService.serverSearch; trackBy: trackValue\"\n [nzMenuItemSelectedIcon]=\"nzMenuItemSelectedIcon\"\n [nzOption]=\"option\">\n </li>\n <li class=\"ant-select-dropdown-menu-item-group\"\n *ngFor=\"let group of nzSelectService.listOfNzOptionGroupComponent | nzFilterGroupOption : nzSelectService.searchValue : nzSelectService.filterOption :nzSelectService.serverSearch; trackBy: trackLabel\">\n <div class=\"ant-select-dropdown-menu-item-group-title\"\n [attr.title]=\"group.isLabelString ? group.nzLabel : ''\">\n <ng-container *nzStringTemplateOutlet=\"group.nzLabel\"> {{group.nzLabel}} </ng-container>\n </div>\n <ul class=\"ant-select-dropdown-menu-item-group-list\">\n <li nz-option-li\n *ngFor=\"let option of group.listOfNzOptionComponent | nzFilterOption : nzSelectService.searchValue : nzSelectService.filterOption :nzSelectService.serverSearch; trackBy: trackValue\"\n [nzMenuItemSelectedIcon]=\"nzMenuItemSelectedIcon\"\n [nzOption]=\"option\">\n </li>\n </ul>\n </li>\n <li nz-option-li\n *ngFor=\"let option of nzSelectService.listOfTagOption | nzFilterOption : nzSelectService.searchValue : nzSelectService.filterOption : nzSelectService.serverSearch; trackBy: trackValue \"\n [nzMenuItemSelectedIcon]=\"nzMenuItemSelectedIcon\"\n [nzOption]=\"option\">\n </li>\n</ul>\n" }] } ]; /** @nocollapse */ NzOptionContainerComponent.ctorParameters = () => [ { type: NzSelectService }, { type: ChangeDetectorRef }, { type: NgZone } ]; NzOptionContainerComponent.propDecorators = { listOfNzOptionLiComponent: [{ type: ViewChildren, args: [NzOptionLiComponent,] }], dropdownUl: [{ type: ViewChild, args: ['dropdownUl',] }], nzNotFoundContent: [{ type: Input }], nzMenuItemSelectedIcon: [{ type: Input }], nzScrollToBottom: [{ type: Output }] }; if (false) { /** * @type {?} * @private */ NzOptionContainerComponent.prototype.destroy$; /** @type {?} */ NzOptionContainerComponent.prototype.listOfNzOptionLiComponent; /** @type {?} */ NzOptionContainerComponent.prototype.dropdownUl; /** @type {?} */ NzOptionContainerComponent.prototype.nzNotFoundContent; /** @type {?} */ NzOptionContainerComponent.prototype.nzMenuItemSelectedIcon; /** @type {?} */ NzOptionContainerComponent.prototype.nzScrollToBottom; /** @type {?} */ NzOptionContainerComponent.prototype.nzSelectService; /** * @type {?} * @private */ NzOptionContainerComponent.prototype.cdr; /** * @type {?} * @private */ NzOptionContainerComponent.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-option-container.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["select/nz-option-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation\n} from '@angular/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NzOptionGroupComponent } from './nz-option-group.component';\nimport { NzOptionLiComponent } from './nz-option-li.component';\nimport { NzOptionComponent } from './nz-option.component';\nimport { NzSelectService } from './nz-select.service';\n\n@Component({\n  selector           : '[nz-option-container]',\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  encapsulation      : ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  templateUrl        : './nz-option-container.component.html'\n})\nexport class NzOptionContainerComponent implements OnDestroy, OnInit {\n  private destroy$ = new Subject();\n  @ViewChildren(NzOptionLiComponent) listOfNzOptionLiComponent: QueryList<NzOptionLiComponent>;\n  @ViewChild('dropdownUl') dropdownUl: ElementRef;\n  @Input() nzNotFoundContent: string;\n  @Input() nzMenuItemSelectedIcon: TemplateRef<void>;\n  @Output() readonly nzScrollToBottom = new EventEmitter<void>();\n\n  scrollIntoViewIfNeeded(option: NzOptionComponent): void {\n    // delay after open\n    setTimeout(() => {\n      if (this.listOfNzOptionLiComponent && this.listOfNzOptionLiComponent.length && option) {\n        const targetOption = this.listOfNzOptionLiComponent.find(\n          o => this.nzSelectService.compareWith(o.nzOption.nzValue, option.nzValue)\n        );\n        /* tslint:disable-next-line:no-string-literal */\n        if (targetOption && targetOption.el && targetOption.el[ 'scrollIntoViewIfNeeded' ]) {\n          /* tslint:disable-next-line:no-string-literal */\n          targetOption.el[ 'scrollIntoViewIfNeeded' ](false);\n        }\n      }\n    });\n  }\n\n  trackLabel(_index: number, option: NzOptionGroupComponent): string | TemplateRef<void> {\n    return option.nzLabel;\n  }\n\n  // tslint:disable-next-line:no-any\n  trackValue(_index: number, option: NzOptionComponent): any {\n    return option.nzValue;\n  }\n\n  constructor(public nzSelectService: NzSelectService, private cdr: ChangeDetectorRef, private ngZone: NgZone) {\n  }\n\n  ngOnInit(): void {\n    this.nzSelectService.activatedOption$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe((option) => {\n      this.scrollIntoViewIfNeeded(option);\n    });\n    this.nzSelectService.check$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n    this.ngZone.runOutsideAngular(() => {\n      const ul = this.dropdownUl.nativeElement;\n      fromEvent<MouseEvent>(ul, 'scroll').pipe(\n        takeUntil(this.destroy$)\n      ).subscribe(e => {\n        e.preventDefault();\n        e.stopPropagation();\n        if (ul && (ul.scrollHeight < (ul.clientHeight + ul.scrollTop + 10))) {\n          this.ngZone.run(() => {\n            this.nzScrollToBottom.emit();\n          });\n        }\n      });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}