ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
205 lines • 15.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: tag.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } from "tslib";
/**
* 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 } from 'ng-zorro-antd/core/animation';
import { warnDeprecation } from 'ng-zorro-antd/core/logger';
import { InputBoolean } from 'ng-zorro-antd/core/util';
var NzTagComponent = /** @class */ (function () {
function NzTagComponent(renderer, elementRef) {
this.renderer = renderer;
this.elementRef = elementRef;
this.presetColor = false;
this.cacheClassName = null;
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) ||
/^(success|processing|error|default|warning)$/.test(color));
};
/**
* @private
* @return {?}
*/
NzTagComponent.prototype.updateClassMap = /**
* @private
* @return {?}
*/
function () {
this.presetColor = this.isPresetColor(this.nzColor);
if (this.cacheClassName) {
this.renderer.removeClass(this.elementRef.nativeElement, this.cacheClassName);
}
if (this.presetColor) {
this.cacheClassName = "ant-tag-" + this.nzColor;
this.renderer.addClass(this.elementRef.nativeElement, this.cacheClassName);
}
};
/**
* @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,
animations: [fadeMotion],
template: "\n <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',
'[style.background-color]': 'presetColor ? null : nzColor',
'[class.ant-tag]': "true",
'[class.ant-tag-has-color]': "nzColor && !presetColor",
'[class.ant-tag-checkable]': "nzMode === 'checkable'",
'[class.ant-tag-checkable-checked]': "nzChecked",
'(click)': 'updateCheckedStatus()',
'(@fadeMotion.done)': 'afterAnimation($event)'
}
}] }
];
/** @nocollapse */
NzTagComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef }
]; };
NzTagComponent.propDecorators = {
nzMode: [{ type: Input }],
nzColor: [{ type: Input }],
nzChecked: [{ type: Input }],
nzNoAnimation: [{ type: Input }],
nzAfterClose: [{ type: Output }],
nzOnClose: [{ type: Output }],
nzCheckedChange: [{ type: Output }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzTagComponent.prototype, "nzChecked", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzTagComponent.prototype, "nzNoAnimation", void 0);
return NzTagComponent;
}());
export { NzTagComponent };
if (false) {
/** @type {?} */
NzTagComponent.ngAcceptInputType_nzChecked;
/** @type {?} */
NzTagComponent.ngAcceptInputType_nzNoAnimation;
/** @type {?} */
NzTagComponent.prototype.presetColor;
/** @type {?} */
NzTagComponent.prototype.cacheClassName;
/** @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;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag.component.js","sourceRoot":"ng://ng-zorro-antd/tag/","sources":["tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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';\nimport { fadeMotion } from 'ng-zorro-antd/core/animation';\nimport { warnDeprecation } from 'ng-zorro-antd/core/logger';\nimport { BooleanInput } from 'ng-zorro-antd/core/types';\nimport { InputBoolean } from 'ng-zorro-antd/core/util';\n\n@Component({\n  selector: 'nz-tag',\n  exportAs: 'nzTag',\n  preserveWhitespaces: false,\n  animations: [fadeMotion],\n  template: `\n    <ng-content></ng-content>\n    <i nz-icon nzType=\"close\" *ngIf=\"nzMode === 'closeable'\" tabindex=\"-1\" (click)=\"closeTag($event)\"></i>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[@fadeMotion]': '',\n    '[@.disabled]': 'nzNoAnimation',\n    '[style.background-color]': 'presetColor ? null : nzColor',\n    '[class.ant-tag]': `true`,\n    '[class.ant-tag-has-color]': `nzColor && !presetColor`,\n    '[class.ant-tag-checkable]': `nzMode === 'checkable'`,\n    '[class.ant-tag-checkable-checked]': `nzChecked`,\n    '(click)': 'updateCheckedStatus()',\n    '(@fadeMotion.done)': 'afterAnimation($event)'\n  }\n})\nexport class NzTagComponent implements OnInit, OnChanges {\n  static ngAcceptInputType_nzChecked: BooleanInput;\n  static ngAcceptInputType_nzNoAnimation: BooleanInput;\n\n  presetColor = false;\n  cacheClassName: string | null = null;\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\n    return (\n      /^(pink|red|yellow|orange|cyan|green|blue|purple|geekblue|magenta|volcano|gold|lime)(-inverse)?$/.test(color) ||\n      /^(success|processing|error|default|warning)$/.test(color)\n    );\n  }\n\n  private updateClassMap(): void {\n    this.presetColor = this.isPresetColor(this.nzColor);\n    if (this.cacheClassName) {\n      this.renderer.removeClass(this.elementRef.nativeElement, this.cacheClassName);\n    }\n    if (this.presetColor) {\n      this.cacheClassName = `ant-tag-${this.nzColor}`;\n      this.renderer.addClass(this.elementRef.nativeElement, this.cacheClassName);\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(private renderer: Renderer2, private elementRef: ElementRef) {}\n\n  ngOnInit(): void {\n    this.updateClassMap();\n  }\n\n  ngOnChanges(): void {\n    this.updateClassMap();\n  }\n}\n"]}