UNPKG

ng-zorro-antd-yj

Version:

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

463 lines 32.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ElementRef, Input, Renderer2 } from '@angular/core'; import { IconDirective } from '@ant-design/icons-angular'; import { InputBoolean } from '../core/util'; import { NzIconService } from './nz-icon.service'; /** @type {?} */ var iconTypeRE = /^anticon\-\w/; /** @type {?} */ var getIconTypeClass = (/** * @param {?} className * @return {?} */ function (className) { if (!className) { return undefined; } else { /** @type {?} */ var classArr = className.split(/\s/); /** @type {?} */ var index = classArr.findIndex((/** * @param {?} cls * @return {?} */ function (cls) { return cls !== 'anticon' && cls !== 'anticon-spin' && !!cls.match(iconTypeRE); })); return index === -1 ? undefined : { name: classArr[index], index: index }; } }); var ɵ0 = getIconTypeClass; /** @type {?} */ var normalizeType = (/** * @param {?} rawType * @return {?} */ function (rawType) { /** @type {?} */ var ret = { type: rawType, crossError: false, verticalError: false }; ret.type = rawType ? rawType.replace('anticon-', '') : ''; if (ret.type.includes('verticle')) { ret.type = 'up'; ret.verticalError = true; } if (ret.type.startsWith('cross')) { ret.type = 'close'; ret.crossError = true; } return ret; }); var ɵ1 = normalizeType; /** * This directive extends IconDirective to provide: * * - IconFont support * - spinning * - old API compatibility * * \@break-changes * * - old API compatibility, icon class names would not be supported. * - properties that not started with `nz`. */ var NzIconDirective = /** @class */ (function (_super) { tslib_1.__extends(NzIconDirective, _super); function NzIconDirective(iconService, elementRef, renderer) { var _this = _super.call(this, iconService, elementRef, renderer) || this; _this.iconService = iconService; _this.elementRef = elementRef; _this.renderer = renderer; _this.nzRotate = 0; /** * @deprecated 8.0.0 avoid exposing low layer API. */ _this.spin = false; _this.el = _this.elementRef.nativeElement; return _this; } Object.defineProperty(NzIconDirective.prototype, "nzSpin", { /** Properties with `nz` prefix. */ set: /** * Properties with `nz` prefix. * @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 }); Object.defineProperty(NzIconDirective.prototype, "type", { get: /** * @return {?} */ function () { return this._type; }, set: /** * @param {?} value * @return {?} */ function (value) { if (value && value.startsWith('anticon')) { /** @type {?} */ var rawClass = getIconTypeClass(value); /** @type {?} */ var type = rawClass ? normalizeType(rawClass.name).type : ''; if (type && this.type !== type) { this._type = type; } } else { this._type = value; } }, enumerable: true, configurable: true }); /** * Replacement of `changeIcon` for more modifications. * @param oldAPI */ /** * Replacement of `changeIcon` for more modifications. * @private * @param {?=} oldAPI * @return {?} */ NzIconDirective.prototype.changeIcon2 = /** * Replacement of `changeIcon` for more modifications. * @private * @param {?=} oldAPI * @return {?} */ function (oldAPI) { var _this = this; if (oldAPI === void 0) { oldAPI = false; } if (!oldAPI) { this.setClassName(); } this._changeIcon().then((/** * @param {?} svg * @return {?} */ function (svg) { _this.setSVGData(svg); if (!oldAPI && svg) { _this.handleSpin(svg); _this.handleRotate(svg); } })); }; /** * @private * @param {?} className * @return {?} */ NzIconDirective.prototype.classChangeHandler = /** * @private * @param {?} className * @return {?} */ function (className) { /** @type {?} */ var ret = getIconTypeClass(className); if (ret) { var _a = normalizeType(ret.name), type = _a.type, crossError = _a.crossError, verticalError = _a.verticalError; if (crossError) { this.iconService.warnAPI('cross'); } if (verticalError) { this.iconService.warnAPI('vertical'); } if (this.type !== type) { this._type = type; this.changeIcon2(true); } } }; /** * @private * @param {?} svg * @return {?} */ NzIconDirective.prototype.handleSpin = /** * @private * @param {?} svg * @return {?} */ function (svg) { if ((this.spin || this.type === 'loading') && !this.elementRef.nativeElement.classList.contains('anticon-spin')) { 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 (typeof this.type === 'string') { /** @type {?} */ var iconClassNameArr = this.el.className.split(/\s/); /** @type {?} */ var ret = getIconTypeClass(this.el.className); if (ret) { iconClassNameArr.splice(ret.index, 1, "anticon-" + this.type); this.renderer.setAttribute(this.el, 'class', iconClassNameArr.join(' ')); } else { this.renderer.addClass(this.el, "anticon-" + this.type); } } }; /** * @private * @param {?} svg * @return {?} */ NzIconDirective.prototype.setSVGData = /** * @private * @param {?} svg * @return {?} */ function (svg) { if (typeof this.type === 'string' && svg) { this.renderer.setAttribute(svg, 'data-icon', this.type); this.renderer.setAttribute(svg, 'aria-hidden', 'true'); } }; /** * @param {?} changes * @return {?} */ NzIconDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var type = changes.type, nzType = changes.nzType, nzTwotoneColor = changes.nzTwotoneColor, twoToneColor = changes.twoToneColor, spin = changes.spin, nzSpin = changes.nzSpin, theme = changes.theme, nzTheme = changes.nzTheme, nzRotate = changes.nzRotate; if (type || nzType || nzTwotoneColor || twoToneColor || spin || nzSpin || theme || nzTheme) { this.changeIcon2(); } else if (nzRotate) { this.handleRotate(this.el.firstChild); } else { this._setSVGElement(this.iconService.createIconfontIcon("#" + this.iconfont)); } }; /** * @return {?} */ NzIconDirective.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; // If `this.type` is not specified and `classList` contains `anticon`, it should be an icon using old API. if (!this.type && this.el.classList.contains('anticon')) { this.iconService.warnAPI('old'); // Get `type` from `className`. If not, initial rendering would be missed. this.classChangeHandler(this.el.className); // Add `class` mutation observer. this.classNameObserver = new MutationObserver((/** * @param {?} mutations * @return {?} */ function (mutations) { mutations .filter((/** * @param {?} mutation * @return {?} */ function (mutation) { return mutation.attributeName === 'class'; })) .forEach((/** * @param {?} mutation * @return {?} */ function (mutation) { return _this.classChangeHandler(((/** @type {?} */ (mutation.target))).className); })); })); this.classNameObserver.observe(this.el, { attributes: true }); } // If `classList` does not contain `anticon`, add it before other class names. if (!this.el.classList.contains('anticon')) { this.renderer.setAttribute(this.el, 'class', ("anticon " + this.el.className).trim()); } }; /** * @return {?} */ NzIconDirective.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.classNameObserver) { this.classNameObserver.disconnect(); } }; /** * 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 () { /** @type {?} */ var children = this.el.children; /** @type {?} */ var length = children.length; if (!this.type && children.length) { while (length--) { /** @type {?} */ var child = children[length]; if (child.tagName.toLowerCase() === 'svg') { this.iconService.normalizeSvgElement((/** @type {?} */ (child))); } } } }; NzIconDirective.decorators = [ { type: Directive, args: [{ selector: 'i.anticon, [nz-icon]' },] } ]; /** @nocollapse */ NzIconDirective.ctorParameters = function () { return [ { type: NzIconService }, { type: ElementRef }, { type: Renderer2 } ]; }; NzIconDirective.propDecorators = { nzSpin: [{ type: Input }], nzRotate: [{ type: Input }], nzType: [{ type: Input }], nzTheme: [{ type: Input }], nzTwotoneColor: [{ type: Input }], nzIconfont: [{ type: Input }], spin: [{ type: Input }], iconfont: [{ type: Input }], type: [{ type: Input }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean), tslib_1.__metadata("design:paramtypes", [Boolean]) ], NzIconDirective.prototype, "nzSpin", null); return NzIconDirective; }(IconDirective)); export { NzIconDirective }; if (false) { /** @type {?} */ NzIconDirective.prototype.nzRotate; /** * @deprecated 8.0.0 avoid exposing low layer API. * @type {?} */ NzIconDirective.prototype.spin; /** * @deprecated 8.0.0 avoid exposing low layer API. * @type {?} */ NzIconDirective.prototype.iconfont; /** * @type {?} * @private */ NzIconDirective.prototype.classNameObserver; /** * @type {?} * @private */ NzIconDirective.prototype.el; /** * @type {?} * @private */ NzIconDirective.prototype._type; /** @type {?} */ NzIconDirective.prototype.iconService; /** @type {?} */ NzIconDirective.prototype.elementRef; /** @type {?} */ NzIconDirective.prototype.renderer; } export { ɵ0, ɵ1 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-icon.directive.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["icon/nz-icon.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\nimport { IconDirective, ThemeType } from '@ant-design/icons-angular';\nimport { InputBoolean } from '../core/util';\nimport { NzIconService } from './nz-icon.service';\n\nconst iconTypeRE = /^anticon\\-\\w/;\n\nconst getIconTypeClass = (className: string): { name: string; index: number } | undefined => {\n  if (!className) {\n    return undefined;\n  } else {\n    const classArr = className.split(/\\s/);\n    const index = classArr.findIndex(cls => cls !== 'anticon' && cls !== 'anticon-spin' && !!cls.match(iconTypeRE));\n    return index === -1 ? undefined : { name: classArr[index], index };\n  }\n};\n\nconst normalizeType = (rawType: string): { type: string; crossError: boolean; verticalError: boolean } => {\n  const ret = { type: rawType, crossError: false, verticalError: false };\n  ret.type = rawType ? rawType.replace('anticon-', '') : '';\n  if (ret.type.includes('verticle')) {\n    ret.type = 'up';\n    ret.verticalError = true;\n  }\n  if (ret.type.startsWith('cross')) {\n    ret.type = 'close';\n    ret.crossError = true;\n  }\n  return ret;\n};\n\n/**\n * This directive extends IconDirective to provide:\n *\n * - IconFont support\n * - spinning\n * - old API compatibility\n *\n * @break-changes\n *\n * - old API compatibility, icon class names would not be supported.\n * - properties that not started with `nz`.\n */\n@Directive({\n  selector: 'i.anticon, [nz-icon]'\n})\nexport class NzIconDirective extends IconDirective implements OnInit, OnChanges, OnDestroy, AfterContentChecked {\n  /** Properties with `nz` prefix. */\n  @Input() @InputBoolean() set nzSpin(value: boolean) {\n    this.spin = value;\n  }\n  @Input() nzRotate: number = 0;\n  @Input() set nzType(value: string) {\n    this.type = value;\n  }\n  @Input() set nzTheme(value: ThemeType) {\n    this.theme = value;\n  }\n  @Input() set nzTwotoneColor(value: string) {\n    this.twoToneColor = value;\n  }\n  @Input() set nzIconfont(value: string) {\n    this.iconfont = value;\n  }\n\n  /** @deprecated 8.0.0 avoid exposing low layer API. */\n  @Input() spin = false;\n\n  /** @deprecated 8.0.0 avoid exposing low layer API. */\n  @Input() iconfont: string;\n\n  @Input()\n  set type(value: string) {\n    if (value && value.startsWith('anticon')) {\n      const rawClass = getIconTypeClass(value);\n      const type = rawClass ? normalizeType(rawClass.name).type : '';\n      if (type && this.type !== type) {\n        this._type = type;\n      }\n    } else {\n      this._type = value;\n    }\n  }\n\n  get type(): string {\n    return this._type;\n  }\n\n  private classNameObserver: MutationObserver;\n  private el = this.elementRef.nativeElement;\n  private _type: string;\n\n  /**\n   * Replacement of `changeIcon` for more modifications.\n   * @param oldAPI\n   */\n  private changeIcon2(oldAPI: boolean = false): void {\n    if (!oldAPI) {\n      this.setClassName();\n    }\n    this._changeIcon().then(svg => {\n      this.setSVGData(svg);\n      if (!oldAPI && svg) {\n        this.handleSpin(svg);\n        this.handleRotate(svg);\n      }\n    });\n  }\n\n  private classChangeHandler(className: string): void {\n    const ret = getIconTypeClass(className);\n    if (ret) {\n      const { type, crossError, verticalError } = normalizeType(ret.name);\n      if (crossError) {\n        this.iconService.warnAPI('cross');\n      }\n      if (verticalError) {\n        this.iconService.warnAPI('vertical');\n      }\n      if (this.type !== type) {\n        this._type = type;\n        this.changeIcon2(true);\n      }\n    }\n  }\n\n  private handleSpin(svg: SVGElement): void {\n    if ((this.spin || this.type === 'loading') && !this.elementRef.nativeElement.classList.contains('anticon-spin')) {\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 (typeof this.type === 'string') {\n      const iconClassNameArr = this.el.className.split(/\\s/);\n      const ret = getIconTypeClass(this.el.className);\n      if (ret) {\n        iconClassNameArr.splice(ret.index, 1, `anticon-${this.type}`);\n        this.renderer.setAttribute(this.el, 'class', iconClassNameArr.join(' '));\n      } else {\n        this.renderer.addClass(this.el, `anticon-${this.type}`);\n      }\n    }\n  }\n\n  private setSVGData(svg: SVGElement | null): void {\n    if (typeof this.type === 'string' && svg) {\n      this.renderer.setAttribute(svg, 'data-icon', this.type);\n      this.renderer.setAttribute(svg, 'aria-hidden', 'true');\n    }\n  }\n\n  constructor(public iconService: NzIconService, public elementRef: ElementRef, public renderer: Renderer2) {\n    super(iconService, elementRef, renderer);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { type, nzType, nzTwotoneColor, twoToneColor, spin, nzSpin, theme, nzTheme, nzRotate } = changes;\n\n    if (type || nzType || nzTwotoneColor || twoToneColor || spin || nzSpin || theme || nzTheme) {\n      this.changeIcon2();\n    } else if (nzRotate) {\n      this.handleRotate(this.el.firstChild);\n    } else {\n      this._setSVGElement(this.iconService.createIconfontIcon(`#${this.iconfont}`));\n    }\n  }\n\n  ngOnInit(): void {\n    // If `this.type` is not specified and `classList` contains `anticon`, it should be an icon using old API.\n    if (!this.type && this.el.classList.contains('anticon')) {\n      this.iconService.warnAPI('old');\n      // Get `type` from `className`. If not, initial rendering would be missed.\n      this.classChangeHandler(this.el.className);\n      // Add `class` mutation observer.\n      this.classNameObserver = new MutationObserver((mutations: MutationRecord[]) => {\n        mutations\n          .filter((mutation: MutationRecord) => mutation.attributeName === 'class')\n          .forEach((mutation: MutationRecord) => this.classChangeHandler((mutation.target as HTMLElement).className));\n      });\n      this.classNameObserver.observe(this.el, { attributes: true });\n    }\n    // If `classList` does not contain `anticon`, add it before other class names.\n    if (!this.el.classList.contains('anticon')) {\n      this.renderer.setAttribute(this.el, 'class', `anticon ${this.el.className}`.trim());\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.classNameObserver) {\n      this.classNameObserver.disconnect();\n    }\n  }\n\n  /**\n   * If custom content is provided, try to normalize SVG elements.\n   */\n  ngAfterContentChecked(): void {\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"]}