UNPKG

ng-zorro-antd

Version:

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

234 lines 22.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Host, Input, Optional, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { zoomMotion } from '../core/animation/zoom'; import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive'; import { NzSelectService } from './nz-select.service'; export class NzSelectTopControlComponent { /** * @param {?} renderer * @param {?} nzSelectService * @param {?} cdr * @param {?=} noAnimation */ constructor(renderer, nzSelectService, cdr, noAnimation) { this.renderer = renderer; this.nzSelectService = nzSelectService; this.cdr = cdr; this.noAnimation = noAnimation; this.isComposing = false; this.destroy$ = new Subject(); this.nzShowSearch = false; this.nzOpen = false; this.nzAllowClear = false; this.nzShowArrow = true; this.nzLoading = false; this.nzTokenSeparators = []; } /** * @param {?} e * @return {?} */ onClearSelection(e) { e.stopPropagation(); this.nzSelectService.updateListOfSelectedValue([], true); } /** * @param {?} value * @return {?} */ setInputValue(value) { if (this.inputElement) { this.inputElement.nativeElement.value = value; } this.inputValue = value; this.updateWidth(); this.nzSelectService.updateSearchValue(value); this.nzSelectService.tokenSeparate(this.inputValue, this.nzTokenSeparators); } /** * @return {?} */ get placeHolderDisplay() { return this.inputValue || this.isComposing || this.nzSelectService.listOfSelectedValue.length ? 'none' : 'block'; } /** * @return {?} */ get selectedValueStyle() { /** @type {?} */ let showSelectedValue = false; /** @type {?} */ let opacity = 1; if (!this.nzShowSearch) { showSelectedValue = true; } else { if (this.nzOpen) { showSelectedValue = !(this.inputValue || this.isComposing); if (showSelectedValue) { opacity = 0.4; } } else { showSelectedValue = true; } } return { display: showSelectedValue ? 'block' : 'none', opacity: `${opacity}` }; } // tslint:disable-next-line:no-any /** * @param {?} _index * @param {?} option * @return {?} */ trackValue(_index, option) { return option.nzValue; } /** * @return {?} */ updateWidth() { if (this.nzSelectService.isMultipleOrTags && this.inputElement) { if (this.inputValue || this.isComposing) { this.renderer.setStyle(this.inputElement.nativeElement, 'width', `${this.inputElement.nativeElement.scrollWidth}px`); } else { this.renderer.removeStyle(this.inputElement.nativeElement, 'width'); } } } /** * @param {?} option * @param {?} e * @return {?} */ removeSelectedValue(option, e) { this.nzSelectService.removeValueFormSelected(option); e.stopPropagation(); } /** * @return {?} */ ngOnInit() { this.nzSelectService.open$.pipe(takeUntil(this.destroy$)).subscribe((/** * @param {?} open * @return {?} */ open => { if (this.inputElement && open) { this.inputElement.nativeElement.focus(); } })); this.nzSelectService.clearInput$.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ () => { this.setInputValue(''); })); this.nzSelectService.check$.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ () => { this.cdr.markForCheck(); })); } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } } NzSelectTopControlComponent.decorators = [ { type: Component, args: [{ selector: '[nz-select-top-control]', preserveWhitespaces: false, animations: [zoomMotion], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ng-template #inputTemplate>\n <input #inputElement\n autocomplete=\"something-new\"\n class=\"ant-select-search__field\"\n (compositionstart)=\"isComposing = true\"\n (compositionend)=\"isComposing = false\"\n (input)=\"updateWidth()\"\n [ngModel]=\"inputValue\"\n (ngModelChange)=\"setInputValue($event)\"\n [disabled]=\"nzSelectService.disabled\">\n</ng-template>\n<div class=\"ant-select-selection__rendered\">\n <div *ngIf=\"nzPlaceHolder\"\n nz-select-unselectable\n [style.display]=\"placeHolderDisplay\"\n class=\"ant-select-selection__placeholder\">{{ nzPlaceHolder }}</div>\n <!--single mode-->\n <ng-container *ngIf=\"nzSelectService.isSingleMode\">\n <!--selected label-->\n <div *ngIf=\"nzSelectService.listOfCachedSelectedOption.length && nzSelectService.listOfSelectedValue.length\"\n class=\"ant-select-selection-selected-value\"\n [attr.title]=\"nzSelectService.listOfCachedSelectedOption[0]?.nzLabel\"\n [ngStyle]=\"selectedValueStyle\">\n {{ nzSelectService.listOfCachedSelectedOption[0]?.nzLabel }}\n </div>\n <!--show search-->\n <div *ngIf=\"nzShowSearch\"\n class=\"ant-select-search ant-select-search--inline\">\n <div class=\"ant-select-search__field__wrap\">\n <ng-template [ngTemplateOutlet]=\"inputTemplate\"></ng-template>\n <span class=\"ant-select-search__field__mirror\">{{inputValue}}&nbsp;</span>\n </div>\n </div>\n </ng-container>\n <!--multiple or tags mode-->\n <ul *ngIf=\"nzSelectService.isMultipleOrTags\">\n <ng-container *ngFor=\"let option of nzSelectService.listOfCachedSelectedOption | slice: 0 : nzMaxTagCount;trackBy:trackValue;\">\n <li [@zoomMotion]\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [attr.title]=\"option.nzLabel\"\n [class.ant-select-selection__choice__disabled]=\"option.nzDisabled\"\n class=\"ant-select-selection__choice\">\n <div class=\"ant-select-selection__choice__content\">{{ option.nzLabel }}</div>\n <span *ngIf=\"!option.nzDisabled\"\n class=\"ant-select-selection__choice__remove\"\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"removeSelectedValue(option, $event)\">\n <i nz-icon type=\"close\" class=\"ant-select-remove-icon\" *ngIf=\"!nzRemoveIcon; else nzRemoveIcon\"></i>\n </span>\n </li>\n </ng-container>\n <li *ngIf=\"nzSelectService.listOfCachedSelectedOption.length > nzMaxTagCount\"\n [@zoomMotion]\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n class=\"ant-select-selection__choice\">\n <div class=\"ant-select-selection__choice__content\">\n <ng-container *ngIf=\"nzMaxTagPlaceholder\">\n <ng-template\n [ngTemplateOutlet]=\"nzMaxTagPlaceholder\"\n [ngTemplateOutletContext]=\"{ $implicit: nzSelectService.listOfSelectedValue | slice: nzMaxTagCount}\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!nzMaxTagPlaceholder\">\n + {{ nzSelectService.listOfCachedSelectedOption.length - nzMaxTagCount }} ...\n </ng-container>\n </div>\n </li>\n <li class=\"ant-select-search ant-select-search--inline\">\n <ng-template [ngTemplateOutlet]=\"inputTemplate\"></ng-template>\n </li>\n </ul>\n</div>\n<span *ngIf=\"nzAllowClear && nzSelectService.listOfSelectedValue.length\"\n class=\"ant-select-selection__clear\"\n nz-select-unselectable\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"onClearSelection($event)\">\n <i nz-icon type=\"close-circle\" theme=\"fill\" *ngIf=\"!nzClearIcon; else nzClearIcon\" class=\"ant-select-close-icon\"></i>\n </span>\n<span class=\"ant-select-arrow\" nz-select-unselectable *ngIf=\"nzShowArrow\">\n <i nz-icon type=\"loading\" *ngIf=\"nzLoading; else defaultArrow\"></i>\n <ng-template #defaultArrow>\n <i nz-icon type=\"down\" class=\"ant-select-arrow-icon\" *ngIf=\"!nzSuffixIcon; else nzSuffixIcon\"></i>\n </ng-template>\n</span>" }] } ]; /** @nocollapse */ NzSelectTopControlComponent.ctorParameters = () => [ { type: Renderer2 }, { type: NzSelectService }, { type: ChangeDetectorRef }, { type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] } ]; NzSelectTopControlComponent.propDecorators = { inputElement: [{ type: ViewChild, args: ['inputElement',] }], nzShowSearch: [{ type: Input }], nzPlaceHolder: [{ type: Input }], nzOpen: [{ type: Input }], nzMaxTagCount: [{ type: Input }], nzAllowClear: [{ type: Input }], nzShowArrow: [{ type: Input }], nzLoading: [{ type: Input }], nzSuffixIcon: [{ type: Input }], nzClearIcon: [{ type: Input }], nzRemoveIcon: [{ type: Input }], nzMaxTagPlaceholder: [{ type: Input }], nzTokenSeparators: [{ type: Input }] }; if (false) { /** @type {?} */ NzSelectTopControlComponent.prototype.inputValue; /** @type {?} */ NzSelectTopControlComponent.prototype.isComposing; /** * @type {?} * @private */ NzSelectTopControlComponent.prototype.destroy$; /** @type {?} */ NzSelectTopControlComponent.prototype.inputElement; /** @type {?} */ NzSelectTopControlComponent.prototype.nzShowSearch; /** @type {?} */ NzSelectTopControlComponent.prototype.nzPlaceHolder; /** @type {?} */ NzSelectTopControlComponent.prototype.nzOpen; /** @type {?} */ NzSelectTopControlComponent.prototype.nzMaxTagCount; /** @type {?} */ NzSelectTopControlComponent.prototype.nzAllowClear; /** @type {?} */ NzSelectTopControlComponent.prototype.nzShowArrow; /** @type {?} */ NzSelectTopControlComponent.prototype.nzLoading; /** @type {?} */ NzSelectTopControlComponent.prototype.nzSuffixIcon; /** @type {?} */ NzSelectTopControlComponent.prototype.nzClearIcon; /** @type {?} */ NzSelectTopControlComponent.prototype.nzRemoveIcon; /** @type {?} */ NzSelectTopControlComponent.prototype.nzMaxTagPlaceholder; /** @type {?} */ NzSelectTopControlComponent.prototype.nzTokenSeparators; /** * @type {?} * @private */ NzSelectTopControlComponent.prototype.renderer; /** @type {?} */ NzSelectTopControlComponent.prototype.nzSelectService; /** * @type {?} * @private */ NzSelectTopControlComponent.prototype.cdr; /** @type {?} */ NzSelectTopControlComponent.prototype.noAnimation; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-select-top-control.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["select/nz-select-top-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Host,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { zoomMotion } from '../core/animation/zoom';\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { NzOptionComponent } from './nz-option.component';\nimport { NzSelectService } from './nz-select.service';\n\n@Component({\n  selector           : '[nz-select-top-control]',\n  preserveWhitespaces: false,\n  animations         : [ zoomMotion ],\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  encapsulation      : ViewEncapsulation.None,\n  templateUrl        : './nz-select-top-control.component.html'\n})\nexport class NzSelectTopControlComponent implements OnInit, OnDestroy {\n  inputValue: string;\n  isComposing = false;\n  private destroy$ = new Subject();\n  @ViewChild('inputElement') inputElement: ElementRef;\n  @Input() nzShowSearch = false;\n  @Input() nzPlaceHolder: string;\n  @Input() nzOpen = false;\n  @Input() nzMaxTagCount: number;\n  @Input() nzAllowClear = false;\n  @Input() nzShowArrow = true;\n  @Input() nzLoading = false;\n  @Input() nzSuffixIcon: TemplateRef<void>;\n  @Input() nzClearIcon: TemplateRef<void>;\n  @Input() nzRemoveIcon: TemplateRef<void>;\n  // tslint:disable-next-line:no-any\n  @Input() nzMaxTagPlaceholder: TemplateRef<{ $implicit: any[] }>;\n  @Input() nzTokenSeparators: string[] = [];\n\n  onClearSelection(e: MouseEvent): void {\n    e.stopPropagation();\n    this.nzSelectService.updateListOfSelectedValue([], true);\n  }\n\n  setInputValue(value: string): void {\n    if (this.inputElement) {\n      this.inputElement.nativeElement.value = value;\n    }\n    this.inputValue = value;\n    this.updateWidth();\n    this.nzSelectService.updateSearchValue(value);\n    this.nzSelectService.tokenSeparate(this.inputValue, this.nzTokenSeparators);\n  }\n\n  get placeHolderDisplay(): string {\n    return this.inputValue || this.isComposing || this.nzSelectService.listOfSelectedValue.length ? 'none' : 'block';\n  }\n\n  get selectedValueStyle(): { [ key: string ]: string } {\n    let showSelectedValue = false;\n    let opacity = 1;\n    if (!this.nzShowSearch) {\n      showSelectedValue = true;\n    } else {\n      if (this.nzOpen) {\n        showSelectedValue = !(this.inputValue || this.isComposing);\n        if (showSelectedValue) {\n          opacity = 0.4;\n        }\n      } else {\n        showSelectedValue = true;\n      }\n    }\n    return {\n      display: showSelectedValue ? 'block' : 'none',\n      opacity: `${opacity}`\n    };\n  }\n\n  // tslint:disable-next-line:no-any\n  trackValue(_index: number, option: NzOptionComponent): any {\n    return option.nzValue;\n  }\n\n  updateWidth(): void {\n    if (this.nzSelectService.isMultipleOrTags && this.inputElement) {\n      if (this.inputValue || this.isComposing) {\n        this.renderer.setStyle(this.inputElement.nativeElement, 'width', `${this.inputElement.nativeElement.scrollWidth}px`);\n      } else {\n        this.renderer.removeStyle(this.inputElement.nativeElement, 'width');\n      }\n    }\n  }\n\n  removeSelectedValue(option: NzOptionComponent, e: KeyboardEvent): void {\n    this.nzSelectService.removeValueFormSelected(option);\n    e.stopPropagation();\n  }\n\n  constructor(private renderer: Renderer2,\n              public nzSelectService: NzSelectService,\n              private cdr: ChangeDetectorRef,\n              @Host() @Optional() public noAnimation?: NzNoAnimationDirective) {\n  }\n\n  ngOnInit(): void {\n    this.nzSelectService.open$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(open => {\n      if (this.inputElement && open) {\n        this.inputElement.nativeElement.focus();\n      }\n    });\n    this.nzSelectService.clearInput$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(() => {\n      this.setInputValue('');\n    });\n    this.nzSelectService.check$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}