ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
431 lines • 34 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: nz-icon.directive.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 { Platform } from '@angular/cdk/platform';
import { Directive, ElementRef, Input, Renderer2 } from '@angular/core';
import { IconDirective } from '@ant-design/icons-angular';
import { warnDeprecation, InputBoolean } from 'ng-zorro-antd/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NzIconService } from './nz-icon.service';
/** @type {?} */
const iconTypeRE = /^anticon\-\w/;
/** @type {?} */
const getIconTypeClass = (/**
* @param {?} className
* @return {?}
*/
(className) => {
if (!className) {
return undefined;
}
else {
/** @type {?} */
const classArr = className.split(/\s/);
/** @type {?} */
const index = classArr.findIndex((/**
* @param {?} cls
* @return {?}
*/
cls => cls !== 'anticon' && cls !== 'anticon-spin' && !!cls.match(iconTypeRE)));
return index === -1 ? undefined : { name: classArr[index], index };
}
});
const ɵ0 = getIconTypeClass;
/** @type {?} */
const normalizeType = (/**
* @param {?} rawType
* @return {?}
*/
(rawType) => {
/** @type {?} */
const 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;
});
const ɵ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`.
*/
export class NzIconDirective extends IconDirective {
/**
* @param {?} iconService
* @param {?} elementRef
* @param {?} renderer
* @param {?} platform
*/
constructor(iconService, elementRef, renderer, platform) {
super(iconService, elementRef, renderer);
this.iconService = iconService;
this.elementRef = elementRef;
this.renderer = renderer;
this.platform = platform;
this.nzRotate = 0;
/**
* @deprecated 8.0.0 avoid exposing low layer API.
*/
this.spin = false;
this.el = this.elementRef.nativeElement;
this.destroy$ = new Subject();
}
/**
* @param {?} value
* @return {?}
*/
set nzSpin(value) {
this.spin = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzType(value) {
this.type = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzTheme(value) {
this.theme = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzTwotoneColor(value) {
this.twoToneColor = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzIconfont(value) {
this.iconfont = value;
}
/**
* @param {?} value
* @return {?}
*/
set type(value) {
if (value && value.startsWith('anticon')) {
/** @type {?} */
const rawClass = getIconTypeClass(value);
/** @type {?} */
const type = rawClass ? normalizeType(rawClass.name).type : '';
if (type && this.type !== type) {
this._type = type;
}
}
else {
this._type = value;
}
}
/**
* @return {?}
*/
get type() {
return this._type;
}
/**
* Replacement of `changeIcon` for more modifications.
* @private
* @param {?=} oldAPI
* @return {?}
*/
changeIcon2(oldAPI = false) {
if (!oldAPI) {
this.setClassName();
}
this._changeIcon().then((/**
* @param {?} svg
* @return {?}
*/
svg => {
this.setSVGData(svg);
if (!oldAPI && svg) {
this.handleSpin(svg);
this.handleRotate(svg);
}
}));
}
/**
* @private
* @param {?} className
* @return {?}
*/
classChangeHandler(className) {
/** @type {?} */
const ret = getIconTypeClass(className);
if (ret) {
const { type, crossError, verticalError } = normalizeType(ret.name);
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 {?}
*/
handleSpin(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 {?}
*/
handleRotate(svg) {
if (this.nzRotate) {
this.renderer.setAttribute(svg, 'style', `transform: rotate(${this.nzRotate}deg)`);
}
else {
this.renderer.removeAttribute(svg, 'style');
}
}
/**
* @private
* @return {?}
*/
setClassName() {
if (typeof this.type === 'string') {
/** @type {?} */
const iconClassNameArr = this.el.className.split(/\s/);
/** @type {?} */
const 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 {?}
*/
setSVGData(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 {?}
*/
ngOnChanges(changes) {
const { type, nzType, nzTwotoneColor, twoToneColor, spin, nzSpin, theme, nzTheme, nzRotate } = changes;
if (type && !nzType) {
warnDeprecation(`APIs for Icon without 'nz' prefix are deprecated and will be removed in 9.0.0! Please check icons with this type: '${type.currentValue}'.`);
}
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}`));
}
if (type && !nzType) {
warnDeprecation(`APIs for Icon without 'nz' prefix are deprecated and will be removed in 9.0.0! Please check icons with this type: '${this.type}'.`);
}
}
/**
* @return {?}
*/
ngOnInit() {
// 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);
if (this.platform.isBrowser) {
// Add `class` mutation observer.
this.classNameObserver = new MutationObserver((/**
* @param {?} mutations
* @return {?}
*/
(mutations) => {
mutations
.filter((/**
* @param {?} mutation
* @return {?}
*/
(mutation) => mutation.attributeName === 'class'))
.forEach((/**
* @param {?} mutation
* @return {?}
*/
(mutation) => 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());
}
this.iconService.configUpdated$
.asObservable()
.pipe(takeUntil(this.destroy$))
.subscribe((/**
* @return {?}
*/
() => {
if (this.type) {
this.changeIcon2();
}
}));
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this.classNameObserver) {
this.classNameObserver.disconnect();
}
this.destroy$.next();
this.destroy$.complete();
}
/**
* If custom content is provided, try to normalize SVG elements.
* @return {?}
*/
ngAfterContentChecked() {
/** @type {?} */
const children = this.el.children;
/** @type {?} */
let length = children.length;
if (!this.type && children.length) {
while (length--) {
/** @type {?} */
const child = children[length];
if (child.tagName.toLowerCase() === 'svg') {
this.iconService.normalizeSvgElement((/** @type {?} */ (child)));
}
}
}
}
}
NzIconDirective.decorators = [
{ type: Directive, args: [{
selector: 'i.anticon, [nz-icon]',
exportAs: 'nzIcon'
},] }
];
/** @nocollapse */
NzIconDirective.ctorParameters = () => [
{ type: NzIconService },
{ type: ElementRef },
{ type: Renderer2 },
{ type: Platform }
];
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);
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.destroy$;
/**
* @type {?}
* @private
*/
NzIconDirective.prototype._type;
/** @type {?} */
NzIconDirective.prototype.iconService;
/** @type {?} */
NzIconDirective.prototype.elementRef;
/** @type {?} */
NzIconDirective.prototype.renderer;
/**
* @type {?}
* @private
*/
NzIconDirective.prototype.platform;
}
export { ɵ0, ɵ1 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-icon.directive.js","sourceRoot":"ng://ng-zorro-antd/icon/","sources":["nz-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 { Platform } from '@angular/cdk/platform';\nimport {\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 { warnDeprecation, InputBoolean } from 'ng-zorro-antd/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\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  exportAs: 'nzIcon'\n})\nexport class NzIconDirective extends IconDirective implements OnInit, OnChanges, OnDestroy, AfterContentChecked {\n  @Input()\n  @InputBoolean()\n  set nzSpin(value: boolean) {\n    this.spin = value;\n  }\n\n  @Input() nzRotate: number = 0;\n\n  @Input() set nzType(value: string) {\n    this.type = value;\n  }\n\n  @Input() set nzTheme(value: ThemeType) {\n    this.theme = value;\n  }\n\n  @Input() set nzTwotoneColor(value: string) {\n    this.twoToneColor = value;\n  }\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 destroy$ = new Subject<void>();\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(\n    public iconService: NzIconService,\n    public elementRef: ElementRef,\n    public renderer: Renderer2,\n    private platform: Platform\n  ) {\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) {\n      warnDeprecation(\n        `APIs for Icon without 'nz' prefix are deprecated and will be removed in 9.0.0! Please check icons with this type: '${type.currentValue}'.`\n      );\n    }\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    if (type && !nzType) {\n      warnDeprecation(\n        `APIs for Icon without 'nz' prefix are deprecated and will be removed in 9.0.0! Please check icons with this type: '${this.type}'.`\n      );\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      if (this.platform.isBrowser) {\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    }\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    this.iconService.configUpdated$\n      .asObservable()\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.type) {\n          this.changeIcon2();\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    if (this.classNameObserver) {\n      this.classNameObserver.disconnect();\n    }\n\n    this.destroy$.next();\n    this.destroy$.complete();\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"]}