UNPKG

ng-zorro-antd

Version:

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

205 lines 15.1 kB
/** * @fileoverview added by tsickle * Generated from: nz-tag.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @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, Component, ElementRef, EventEmitter, Input, Output, Renderer2, ViewEncapsulation } from '@angular/core'; import { fadeMotion, warnDeprecation, InputBoolean, NzUpdateHostClassService } from 'ng-zorro-antd/core'; var NzTagComponent = /** @class */ (function () { function NzTagComponent(renderer, elementRef, nzUpdateHostClassService) { this.renderer = renderer; this.elementRef = elementRef; this.nzUpdateHostClassService = nzUpdateHostClassService; this.presetColor = false; this.nzMode = 'default'; this.nzChecked = false; this.nzNoAnimation = false; this.nzAfterClose = new EventEmitter(); this.nzOnClose = new EventEmitter(); this.nzCheckedChange = new EventEmitter(); } /** * @private * @param {?=} color * @return {?} */ NzTagComponent.prototype.isPresetColor = /** * @private * @param {?=} color * @return {?} */ function (color) { if (!color) { return false; } return /^(pink|red|yellow|orange|cyan|green|blue|purple|geekblue|magenta|volcano|gold|lime)(-inverse)?$/.test(color); }; /** * @private * @return {?} */ NzTagComponent.prototype.updateClassMap = /** * @private * @return {?} */ function () { var _a; this.presetColor = this.isPresetColor(this.nzColor); /** @type {?} */ var prefix = 'ant-tag'; this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, (_a = {}, _a["" + prefix] = true, _a[prefix + "-has-color"] = this.nzColor && !this.presetColor, _a[prefix + "-" + this.nzColor] = this.presetColor, _a[prefix + "-checkable"] = this.nzMode === 'checkable', _a[prefix + "-checkable-checked"] = this.nzChecked, _a)); }; /** * @return {?} */ NzTagComponent.prototype.updateCheckedStatus = /** * @return {?} */ function () { if (this.nzMode === 'checkable') { this.nzChecked = !this.nzChecked; this.nzCheckedChange.emit(this.nzChecked); this.updateClassMap(); } }; /** * @param {?} e * @return {?} */ NzTagComponent.prototype.closeTag = /** * @param {?} e * @return {?} */ function (e) { this.nzOnClose.emit(e); if (!e.defaultPrevented) { this.renderer.removeChild(this.renderer.parentNode(this.elementRef.nativeElement), this.elementRef.nativeElement); } }; /** * @param {?} e * @return {?} */ NzTagComponent.prototype.afterAnimation = /** * @param {?} e * @return {?} */ function (e) { if (e.toState === 'void') { this.nzAfterClose.emit(); if (this.nzAfterClose.observers.length) { warnDeprecation("'(nzAfterClose)' Output is going to be removed in 9.0.0. Please use '(nzOnClose)' instead."); } } }; /** * @return {?} */ NzTagComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.updateClassMap(); }; /** * @return {?} */ NzTagComponent.prototype.ngOnChanges = /** * @return {?} */ function () { this.updateClassMap(); }; NzTagComponent.decorators = [ { type: Component, args: [{ selector: 'nz-tag', exportAs: 'nzTag', preserveWhitespaces: false, providers: [NzUpdateHostClassService], animations: [fadeMotion], template: "<ng-content></ng-content>\n<i nz-icon nzType=\"close\" *ngIf=\"nzMode==='closeable'\" tabindex=\"-1\" (click)=\"closeTag($event)\"></i>\n", changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { '[@fadeMotion]': '', '[@.disabled]': 'nzNoAnimation', '(@fadeMotion.done)': 'afterAnimation($event)', '(click)': 'updateCheckedStatus()', '[style.background-color]': 'presetColor? null : nzColor' } }] } ]; /** @nocollapse */ NzTagComponent.ctorParameters = function () { return [ { type: Renderer2 }, { type: ElementRef }, { type: NzUpdateHostClassService } ]; }; NzTagComponent.propDecorators = { nzMode: [{ type: Input }], nzColor: [{ type: Input }], nzChecked: [{ type: Input }], nzNoAnimation: [{ type: Input }], nzAfterClose: [{ type: Output }], nzOnClose: [{ type: Output }], nzCheckedChange: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzTagComponent.prototype, "nzChecked", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzTagComponent.prototype, "nzNoAnimation", void 0); return NzTagComponent; }()); export { NzTagComponent }; if (false) { /** @type {?} */ NzTagComponent.prototype.presetColor; /** @type {?} */ NzTagComponent.prototype.nzMode; /** @type {?} */ NzTagComponent.prototype.nzColor; /** @type {?} */ NzTagComponent.prototype.nzChecked; /** @type {?} */ NzTagComponent.prototype.nzNoAnimation; /** @type {?} */ NzTagComponent.prototype.nzAfterClose; /** @type {?} */ NzTagComponent.prototype.nzOnClose; /** @type {?} */ NzTagComponent.prototype.nzCheckedChange; /** * @type {?} * @private */ NzTagComponent.prototype.renderer; /** * @type {?} * @private */ NzTagComponent.prototype.elementRef; /** * @type {?} * @private */ NzTagComponent.prototype.nzUpdateHostClassService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tag.component.js","sourceRoot":"ng://ng-zorro-antd/tag/","sources":["nz-tag.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 { AnimationEvent } from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport { fadeMotion, warnDeprecation, InputBoolean, NzUpdateHostClassService } from 'ng-zorro-antd/core';\n\n@Component({\n  selector: 'nz-tag',\n  exportAs: 'nzTag',\n  preserveWhitespaces: false,\n  providers: [NzUpdateHostClassService],\n  animations: [fadeMotion],\n  templateUrl: './nz-tag.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[@fadeMotion]': '',\n    '[@.disabled]': 'nzNoAnimation',\n    '(@fadeMotion.done)': 'afterAnimation($event)',\n    '(click)': 'updateCheckedStatus()',\n    '[style.background-color]': 'presetColor? null : nzColor'\n  }\n})\nexport class NzTagComponent implements OnInit, OnChanges {\n  presetColor = false;\n  @Input() nzMode: 'default' | 'closeable' | 'checkable' = 'default';\n  @Input() nzColor: string;\n  @Input() @InputBoolean() nzChecked = false;\n  @Input() @InputBoolean() nzNoAnimation = false;\n  @Output() readonly nzAfterClose = new EventEmitter<void>();\n  @Output() readonly nzOnClose = new EventEmitter<MouseEvent>();\n  @Output() readonly nzCheckedChange = new EventEmitter<boolean>();\n\n  private isPresetColor(color?: string): boolean {\n    if (!color) {\n      return false;\n    }\n    return /^(pink|red|yellow|orange|cyan|green|blue|purple|geekblue|magenta|volcano|gold|lime)(-inverse)?$/.test(\n      color\n    );\n  }\n\n  private updateClassMap(): void {\n    this.presetColor = this.isPresetColor(this.nzColor);\n    const prefix = 'ant-tag';\n    this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, {\n      [`${prefix}`]: true,\n      [`${prefix}-has-color`]: this.nzColor && !this.presetColor,\n      [`${prefix}-${this.nzColor}`]: this.presetColor,\n      [`${prefix}-checkable`]: this.nzMode === 'checkable',\n      [`${prefix}-checkable-checked`]: this.nzChecked\n    });\n  }\n\n  updateCheckedStatus(): void {\n    if (this.nzMode === 'checkable') {\n      this.nzChecked = !this.nzChecked;\n      this.nzCheckedChange.emit(this.nzChecked);\n      this.updateClassMap();\n    }\n  }\n\n  closeTag(e: MouseEvent): void {\n    this.nzOnClose.emit(e);\n    if (!e.defaultPrevented) {\n      this.renderer.removeChild(this.renderer.parentNode(this.elementRef.nativeElement), this.elementRef.nativeElement);\n    }\n  }\n\n  afterAnimation(e: AnimationEvent): void {\n    if (e.toState === 'void') {\n      this.nzAfterClose.emit();\n      if (this.nzAfterClose.observers.length) {\n        warnDeprecation(`'(nzAfterClose)' Output is going to be removed in 9.0.0. Please use '(nzOnClose)' instead.`);\n      }\n    }\n  }\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef,\n    private nzUpdateHostClassService: NzUpdateHostClassService\n  ) {}\n\n  ngOnInit(): void {\n    this.updateClassMap();\n  }\n\n  ngOnChanges(): void {\n    this.updateClassMap();\n  }\n}\n"]}