UNPKG

ng-zorro-antd

Version:

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

303 lines 19.6 kB
/** * @fileoverview added by tsickle * Generated from: icon.directive.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __extends, __metadata } 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 { Directive, ElementRef, Input, Optional, Renderer2 } from '@angular/core'; import { IconDirective } from '@ant-design/icons-angular'; import { InputBoolean } from 'ng-zorro-antd/core/util'; import { NzIconPatchService, NzIconService } from './icon.service'; var NzIconDirective = /** @class */ (function (_super) { __extends(NzIconDirective, _super); function NzIconDirective(elementRef, iconService, renderer, iconPatch) { var _this = _super.call(this, iconService, elementRef, renderer) || this; _this.iconService = iconService; _this.renderer = renderer; _this.cacheClassName = null; _this.nzRotate = 0; _this.spin = false; if (iconPatch) { iconPatch.doPatch(); } _this.el = elementRef.nativeElement; return _this; } Object.defineProperty(NzIconDirective.prototype, "nzSpin", { set: /** * @param {?} value * @return {?} */ function (value) { this.spin = value; }, enumerable: true, configurable: true }); Object.defineProperty(NzIconDirective.prototype, "nzType", { set: /** * @param {?} value * @return {?} */ function (value) { this.type = value; }, enumerable: true, configurable: true }); Object.defineProperty(NzIconDirective.prototype, "nzTheme", { set: /** * @param {?} value * @return {?} */ function (value) { this.theme = value; }, enumerable: true, configurable: true }); Object.defineProperty(NzIconDirective.prototype, "nzTwotoneColor", { set: /** * @param {?} value * @return {?} */ function (value) { this.twoToneColor = value; }, enumerable: true, configurable: true }); Object.defineProperty(NzIconDirective.prototype, "nzIconfont", { set: /** * @param {?} value * @return {?} */ function (value) { this.iconfont = value; }, enumerable: true, configurable: true }); /** * @param {?} changes * @return {?} */ NzIconDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var nzType = changes.nzType, nzTwotoneColor = changes.nzTwotoneColor, nzSpin = changes.nzSpin, nzTheme = changes.nzTheme, nzRotate = changes.nzRotate; if (nzType || nzTwotoneColor || nzSpin || nzTheme) { this.changeIcon2(); } else if (nzRotate) { this.handleRotate((/** @type {?} */ (this.el.firstChild))); } else { this._setSVGElement(this.iconService.createIconfontIcon("#" + this.iconfont)); } }; /** * @return {?} */ NzIconDirective.prototype.ngOnInit = /** * @return {?} */ function () { this.renderer.setAttribute(this.el, 'class', ("anticon " + this.el.className).trim()); }; /** * If custom content is provided, try to normalize SVG elements. */ /** * If custom content is provided, try to normalize SVG elements. * @return {?} */ NzIconDirective.prototype.ngAfterContentChecked = /** * If custom content is provided, try to normalize SVG elements. * @return {?} */ function () { if (!this.type) { /** @type {?} */ var children = this.el.children; /** @type {?} */ var length_1 = children.length; if (!this.type && children.length) { while (length_1--) { /** @type {?} */ var child = children[length_1]; if (child.tagName.toLowerCase() === 'svg') { this.iconService.normalizeSvgElement((/** @type {?} */ (child))); } } } } }; /** * Replacement of `changeIcon` for more modifications. */ /** * Replacement of `changeIcon` for more modifications. * @private * @return {?} */ NzIconDirective.prototype.changeIcon2 = /** * Replacement of `changeIcon` for more modifications. * @private * @return {?} */ function () { var _this = this; this.setClassName(); this._changeIcon().then((/** * @param {?} svgOrRemove * @return {?} */ function (svgOrRemove) { if (svgOrRemove) { _this.setSVGData(svgOrRemove); _this.handleSpin(svgOrRemove); _this.handleRotate(svgOrRemove); } })); }; /** * @private * @param {?} svg * @return {?} */ NzIconDirective.prototype.handleSpin = /** * @private * @param {?} svg * @return {?} */ function (svg) { if (this.spin || this.type === 'loading') { this.renderer.addClass(svg, 'anticon-spin'); } else { this.renderer.removeClass(svg, 'anticon-spin'); } }; /** * @private * @param {?} svg * @return {?} */ NzIconDirective.prototype.handleRotate = /** * @private * @param {?} svg * @return {?} */ function (svg) { if (this.nzRotate) { this.renderer.setAttribute(svg, 'style', "transform: rotate(" + this.nzRotate + "deg)"); } else { this.renderer.removeAttribute(svg, 'style'); } }; /** * @private * @return {?} */ NzIconDirective.prototype.setClassName = /** * @private * @return {?} */ function () { if (this.cacheClassName) { this.renderer.removeClass(this.el, this.cacheClassName); } this.cacheClassName = "anticon-" + this.type; this.renderer.addClass(this.el, this.cacheClassName); }; /** * @private * @param {?} svg * @return {?} */ NzIconDirective.prototype.setSVGData = /** * @private * @param {?} svg * @return {?} */ function (svg) { this.renderer.setAttribute(svg, 'data-icon', this.type); this.renderer.setAttribute(svg, 'aria-hidden', 'true'); }; NzIconDirective.decorators = [ { type: Directive, args: [{ selector: '[nz-icon]', exportAs: 'nzIcon', host: { '[class.anticon]': 'true' } },] } ]; /** @nocollapse */ NzIconDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: NzIconService }, { type: Renderer2 }, { type: NzIconPatchService, decorators: [{ type: Optional }] } ]; }; NzIconDirective.propDecorators = { nzSpin: [{ type: Input }], nzRotate: [{ type: Input }], nzType: [{ type: Input }], nzTheme: [{ type: Input }], nzTwotoneColor: [{ type: Input }], nzIconfont: [{ type: Input }] }; __decorate([ InputBoolean(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], NzIconDirective.prototype, "nzSpin", null); return NzIconDirective; }(IconDirective)); export { NzIconDirective }; if (false) { /** @type {?} */ NzIconDirective.prototype.cacheClassName; /** @type {?} */ NzIconDirective.prototype.nzRotate; /** * @type {?} * @private */ NzIconDirective.prototype.el; /** @type {?} */ NzIconDirective.prototype.type; /** @type {?} */ NzIconDirective.prototype.theme; /** @type {?} */ NzIconDirective.prototype.hostClass; /** @type {?} */ NzIconDirective.prototype.twotoneColor; /** * @type {?} * @private */ NzIconDirective.prototype.iconfont; /** * @type {?} * @private */ NzIconDirective.prototype.spin; /** @type {?} */ NzIconDirective.prototype.iconService; /** @type {?} */ NzIconDirective.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.directive.js","sourceRoot":"ng://ng-zorro-antd/icon/","sources":["icon.directive.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 { AfterContentChecked, Directive, ElementRef, Input, OnChanges, OnInit, Optional, Renderer2, SimpleChanges } from '@angular/core';\nimport { IconDirective, ThemeType } from '@ant-design/icons-angular';\nimport { InputBoolean } from 'ng-zorro-antd/core/util';\n\nimport { NzIconPatchService, NzIconService } from './icon.service';\n\n@Directive({\n  selector: '[nz-icon]',\n  exportAs: 'nzIcon',\n  host: {\n    '[class.anticon]': 'true'\n  }\n})\nexport class NzIconDirective extends IconDirective implements OnInit, OnChanges, AfterContentChecked {\n  cacheClassName: string | null = null;\n  @Input()\n  @InputBoolean()\n  set nzSpin(value: boolean) {\n    this.spin = value;\n  }\n\n  @Input() nzRotate: number = 0;\n\n  @Input()\n  set nzType(value: string) {\n    this.type = value;\n  }\n\n  @Input()\n  set nzTheme(value: ThemeType) {\n    this.theme = value;\n  }\n\n  @Input()\n  set nzTwotoneColor(value: string) {\n    this.twoToneColor = value;\n  }\n\n  @Input()\n  set nzIconfont(value: string) {\n    this.iconfont = value;\n  }\n\n  private readonly el: HTMLElement;\n\n  type: string;\n  theme: ThemeType;\n  hostClass: string;\n  // @ts-ignore\n  twotoneColor: string;\n\n  private iconfont: string;\n  private spin: boolean = false;\n\n  constructor(\n    elementRef: ElementRef,\n    public iconService: NzIconService,\n    public renderer: Renderer2,\n    @Optional() iconPatch: NzIconPatchService\n  ) {\n    super(iconService, elementRef, renderer);\n\n    if (iconPatch) {\n      iconPatch.doPatch();\n    }\n\n    this.el = elementRef.nativeElement;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzType, nzTwotoneColor, nzSpin, nzTheme, nzRotate } = changes;\n\n    if (nzType || nzTwotoneColor || nzSpin || nzTheme) {\n      this.changeIcon2();\n    } else if (nzRotate) {\n      this.handleRotate(this.el.firstChild as SVGElement);\n    } else {\n      this._setSVGElement(this.iconService.createIconfontIcon(`#${this.iconfont}`));\n    }\n  }\n\n  ngOnInit(): void {\n    this.renderer.setAttribute(this.el, 'class', `anticon ${this.el.className}`.trim());\n  }\n\n  /**\n   * If custom content is provided, try to normalize SVG elements.\n   */\n  ngAfterContentChecked(): void {\n    if (!this.type) {\n      const children = this.el.children;\n      let length = children.length;\n      if (!this.type && children.length) {\n        while (length--) {\n          const child = children[length];\n          if (child.tagName.toLowerCase() === 'svg') {\n            this.iconService.normalizeSvgElement(child as SVGElement);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Replacement of `changeIcon` for more modifications.\n   */\n  private changeIcon2(): void {\n    this.setClassName();\n    this._changeIcon().then(svgOrRemove => {\n      if (svgOrRemove) {\n        this.setSVGData(svgOrRemove);\n        this.handleSpin(svgOrRemove);\n        this.handleRotate(svgOrRemove);\n      }\n    });\n  }\n\n  private handleSpin(svg: SVGElement): void {\n    if (this.spin || this.type === 'loading') {\n      this.renderer.addClass(svg, 'anticon-spin');\n    } else {\n      this.renderer.removeClass(svg, 'anticon-spin');\n    }\n  }\n\n  private handleRotate(svg: SVGElement): void {\n    if (this.nzRotate) {\n      this.renderer.setAttribute(svg, 'style', `transform: rotate(${this.nzRotate}deg)`);\n    } else {\n      this.renderer.removeAttribute(svg, 'style');\n    }\n  }\n\n  private setClassName(): void {\n    if (this.cacheClassName) {\n      this.renderer.removeClass(this.el, this.cacheClassName);\n    }\n    this.cacheClassName = `anticon-${this.type}`;\n    this.renderer.addClass(this.el, this.cacheClassName);\n  }\n\n  private setSVGData(svg: SVGElement): void {\n    this.renderer.setAttribute(svg, 'data-icon', this.type);\n    this.renderer.setAttribute(svg, 'aria-hidden', 'true');\n  }\n}\n"]}