ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
317 lines • 28.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: nz-select-top-control.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @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 { 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, NzNoAnimationDirective } from 'ng-zorro-antd/core';
import { NzSelectService } from './nz-select.service';
var NzSelectTopControlComponent = /** @class */ (function () {
function NzSelectTopControlComponent(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 {?}
*/
NzSelectTopControlComponent.prototype.onClearSelection = /**
* @param {?} e
* @return {?}
*/
function (e) {
e.stopPropagation();
this.nzSelectService.updateListOfSelectedValue([], true);
};
/**
* @param {?} value
* @return {?}
*/
NzSelectTopControlComponent.prototype.setInputValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** fix clear value https://github.com/NG-ZORRO/ng-zorro-antd/issues/3825 **/
if (this.inputDOM && !value) {
this.inputDOM.value = value;
}
this.inputValue = value;
this.updateWidth();
this.nzSelectService.updateSearchValue(value);
this.nzSelectService.tokenSeparate(this.inputValue, this.nzTokenSeparators);
};
Object.defineProperty(NzSelectTopControlComponent.prototype, "mirrorDOM", {
get: /**
* @return {?}
*/
function () {
return this.mirrorElement && this.mirrorElement.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzSelectTopControlComponent.prototype, "inputDOM", {
get: /**
* @return {?}
*/
function () {
return this.inputElement && this.inputElement.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzSelectTopControlComponent.prototype, "placeHolderDisplay", {
get: /**
* @return {?}
*/
function () {
return this.inputValue || this.isComposing || this.nzSelectService.listOfSelectedValue.length ? 'none' : 'block';
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzSelectTopControlComponent.prototype, "selectedValueStyle", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var showSelectedValue = false;
/** @type {?} */
var 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
};
},
enumerable: true,
configurable: true
});
// tslint:disable-next-line:no-any
// tslint:disable-next-line:no-any
/**
* @param {?} _index
* @param {?} option
* @return {?}
*/
NzSelectTopControlComponent.prototype.trackValue =
// tslint:disable-next-line:no-any
/**
* @param {?} _index
* @param {?} option
* @return {?}
*/
function (_index, option) {
return option.nzValue;
};
/**
* @return {?}
*/
NzSelectTopControlComponent.prototype.updateWidth = /**
* @return {?}
*/
function () {
if (this.mirrorDOM && this.inputDOM && this.inputDOM.value) {
this.mirrorDOM.innerText = this.inputDOM.value + " ";
this.renderer.removeStyle(this.inputDOM, 'width');
this.renderer.setStyle(this.inputDOM, 'width', this.mirrorDOM.clientWidth + "px");
}
else if (this.inputDOM) {
this.renderer.removeStyle(this.inputDOM, 'width');
this.mirrorDOM.innerText = '';
}
};
/**
* @param {?} option
* @param {?} e
* @return {?}
*/
NzSelectTopControlComponent.prototype.removeSelectedValue = /**
* @param {?} option
* @param {?} e
* @return {?}
*/
function (option, e) {
this.nzSelectService.removeValueFormSelected(option);
e.stopPropagation();
};
/**
* @return {?}
*/
NzSelectTopControlComponent.prototype.animationEnd = /**
* @return {?}
*/
function () {
this.nzSelectService.animationEvent$.next();
};
/**
* @return {?}
*/
NzSelectTopControlComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.nzSelectService.open$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @param {?} open
* @return {?}
*/
function (open) {
if (_this.inputElement && open) {
setTimeout((/**
* @return {?}
*/
function () { return _this.inputDOM.focus(); }));
}
}));
this.nzSelectService.clearInput$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @return {?}
*/
function () {
_this.setInputValue('');
}));
this.nzSelectService.check$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @return {?}
*/
function () {
_this.cdr.markForCheck();
}));
};
/**
* @return {?}
*/
NzSelectTopControlComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy$.next();
this.destroy$.complete();
};
NzSelectTopControlComponent.decorators = [
{ type: Component, args: [{
selector: '[nz-select-top-control]',
exportAs: 'nzSelectTopControl',
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 [ngModel]=\"inputValue\"\n (ngModelChange)=\"setInputValue($event)\"\n [disabled]=\"nzSelectService.disabled\">\n <span #mirrorElement class=\"ant-select-search__field__mirror\"></span>\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 <ng-container *nzStringTemplateOutlet=\"nzCustomTemplate; context: { $implicit: nzSelectService.listOfCachedSelectedOption[0] }\">\n <ng-container>{{ nzSelectService.listOfCachedSelectedOption[0]?.nzLabel }}</ng-container>\n </ng-container>\n </div>\n <!--show search-->\n <div *ngIf=\"nzShowSearch\"\n class=\"ant-select-search ant-select-search--inline\" [style.display]=\"nzOpen ? 'block' : 'none'\">\n <div class=\"ant-select-search__field__wrap\">\n <ng-template [ngTemplateOutlet]=\"inputTemplate\"></ng-template>\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; let index = index\">\n <li [@zoomMotion]\n [@.disabled]=\"noAnimation?.nzNoAnimation\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [attr.title]=\"option.nzLabel\"\n [class.ant-select-selection__choice__disabled]=\"option.nzDisabled\"\n (@zoomMotion.done)=\"animationEnd()\"\n class=\"ant-select-selection__choice\">\n <ng-container *nzStringTemplateOutlet=\"nzCustomTemplate; context:{ $implicit: nzSelectService.listOfCachedSelectedOption[index] }\">\n <div class=\"ant-select-selection__choice__content\">{{ option.nzLabel }}</div>\n </ng-container>\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 nzType=\"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 [@.disabled]=\"noAnimation?.nzNoAnimation\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n (@zoomMotion.done)=\"animationEnd()\"\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 nzType=\"close-circle\" nzTheme=\"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 nzType=\"loading\" *ngIf=\"nzLoading; else defaultArrow\"></i>\n <ng-template #defaultArrow>\n <i nz-icon nzType=\"down\" class=\"ant-select-arrow-icon\" *ngIf=\"!nzSuffixIcon; else nzSuffixIcon\"></i>\n </ng-template>\n</span>"
}] }
];
/** @nocollapse */
NzSelectTopControlComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: NzSelectService },
{ type: ChangeDetectorRef },
{ type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] }
]; };
NzSelectTopControlComponent.propDecorators = {
inputElement: [{ type: ViewChild, args: ['inputElement', { static: false },] }],
mirrorElement: [{ type: ViewChild, args: ['mirrorElement', { static: false },] }],
nzShowSearch: [{ type: Input }],
nzPlaceHolder: [{ type: Input }],
nzOpen: [{ type: Input }],
nzMaxTagCount: [{ type: Input }],
nzAllowClear: [{ type: Input }],
nzShowArrow: [{ type: Input }],
nzLoading: [{ type: Input }],
nzCustomTemplate: [{ type: Input }],
nzSuffixIcon: [{ type: Input }],
nzClearIcon: [{ type: Input }],
nzRemoveIcon: [{ type: Input }],
nzMaxTagPlaceholder: [{ type: Input }],
nzTokenSeparators: [{ type: Input }]
};
return NzSelectTopControlComponent;
}());
export { NzSelectTopControlComponent };
if (false) {
/** @type {?} */
NzSelectTopControlComponent.prototype.inputValue;
/** @type {?} */
NzSelectTopControlComponent.prototype.isComposing;
/**
* @type {?}
* @private
*/
NzSelectTopControlComponent.prototype.destroy$;
/** @type {?} */
NzSelectTopControlComponent.prototype.inputElement;
/** @type {?} */
NzSelectTopControlComponent.prototype.mirrorElement;
/** @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.nzCustomTemplate;
/** @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/select/","sources":["nz-select-top-control.component.ts"],"names":[],"mappings":"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","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  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';\n\nimport { zoomMotion, NzNoAnimationDirective } from 'ng-zorro-antd/core';\n\nimport { NzOptionComponent } from './nz-option.component';\nimport { NzSelectService } from './nz-select.service';\n\n@Component({\n  selector: '[nz-select-top-control]',\n  exportAs: 'nzSelectTopControl',\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', { static: false }) inputElement: ElementRef;\n  @ViewChild('mirrorElement', { static: false }) mirrorElement: 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() nzCustomTemplate: TemplateRef<{ $implicit: NzOptionComponent }>;\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    /** fix clear value https://github.com/NG-ZORRO/ng-zorro-antd/issues/3825 **/\n    if (this.inputDOM && !value) {\n      this.inputDOM.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 mirrorDOM(): HTMLElement {\n    return this.mirrorElement && this.mirrorElement.nativeElement;\n  }\n\n  get inputDOM(): HTMLInputElement {\n    return this.inputElement && this.inputElement.nativeElement;\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.mirrorDOM && this.inputDOM && this.inputDOM.value) {\n      this.mirrorDOM.innerText = `${this.inputDOM.value}&nbsp;`;\n      this.renderer.removeStyle(this.inputDOM, 'width');\n      this.renderer.setStyle(this.inputDOM, 'width', `${this.mirrorDOM.clientWidth}px`);\n    } else if (this.inputDOM) {\n      this.renderer.removeStyle(this.inputDOM, 'width');\n      this.mirrorDOM.innerText = '';\n    }\n  }\n\n  removeSelectedValue(option: NzOptionComponent, e: MouseEvent): void {\n    this.nzSelectService.removeValueFormSelected(option);\n    e.stopPropagation();\n  }\n\n  animationEnd(): void {\n    this.nzSelectService.animationEvent$.next();\n  }\n\n  constructor(\n    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(takeUntil(this.destroy$)).subscribe(open => {\n      if (this.inputElement && open) {\n        setTimeout(() => this.inputDOM.focus());\n      }\n    });\n    this.nzSelectService.clearInput$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.setInputValue('');\n    });\n    this.nzSelectService.check$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}