ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
259 lines • 19.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: icon.service.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __extends, __read, __spread } 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 { DOCUMENT } from '@angular/common';
import { HttpBackend } from '@angular/common/http';
import { Inject, Injectable, InjectionToken, Optional, RendererFactory2, Self } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { IconService } from '@ant-design/icons-angular';
import { NzConfigService } from 'ng-zorro-antd/core/config';
import { warn } from 'ng-zorro-antd/core/logger';
import { Subject } from 'rxjs';
import { NZ_ICONS_USED_BY_ZORRO } from './icons';
import * as i0 from "@angular/core";
import * as i1 from "@angular/platform-browser";
import * as i2 from "ng-zorro-antd/core/config";
import * as i3 from "@angular/common/http";
import * as i4 from "@angular/common";
/**
* @record
*/
export function NzIconfontOption() { }
if (false) {
/** @type {?} */
NzIconfontOption.prototype.scriptUrl;
}
/** @type {?} */
export var NZ_ICONS = new InjectionToken('nz_icons');
/** @type {?} */
export var NZ_ICON_DEFAULT_TWOTONE_COLOR = new InjectionToken('nz_icon_default_twotone_color');
/** @type {?} */
export var DEFAULT_TWOTONE_COLOR = '#1890ff';
/**
* It should be a global singleton, otherwise registered icons could not be found.
*/
var NzIconService = /** @class */ (function (_super) {
__extends(NzIconService, _super);
function NzIconService(rendererFactory, sanitizer, nzConfigService, handler, _document, icons) {
var _this = _super.call(this, rendererFactory, handler, _document, sanitizer) || this;
_this.nzConfigService = nzConfigService;
_this.configUpdated$ = new Subject();
_this.iconfontCache = new Set();
_this.onConfigChange();
_this.addIcon.apply(_this, __spread(NZ_ICONS_USED_BY_ZORRO, (icons || [])));
_this.configDefaultTwotoneColor();
_this.configDefaultTheme();
return _this;
}
/**
* @param {?} svg
* @return {?}
*/
NzIconService.prototype.normalizeSvgElement = /**
* @param {?} svg
* @return {?}
*/
function (svg) {
if (!svg.getAttribute('viewBox')) {
this._renderer.setAttribute(svg, 'viewBox', '0 0 1024 1024');
}
if (!svg.getAttribute('width') || !svg.getAttribute('height')) {
this._renderer.setAttribute(svg, 'width', '1em');
this._renderer.setAttribute(svg, 'height', '1em');
}
if (!svg.getAttribute('fill')) {
this._renderer.setAttribute(svg, 'fill', 'currentColor');
}
};
/**
* @param {?} opt
* @return {?}
*/
NzIconService.prototype.fetchFromIconfont = /**
* @param {?} opt
* @return {?}
*/
function (opt) {
var scriptUrl = opt.scriptUrl;
if (this._document && !this.iconfontCache.has(scriptUrl)) {
/** @type {?} */
var script = this._renderer.createElement('script');
this._renderer.setAttribute(script, 'src', scriptUrl);
this._renderer.setAttribute(script, 'data-namespace', scriptUrl.replace(/^(https?|http):/g, ''));
this._renderer.appendChild(this._document.body, script);
this.iconfontCache.add(scriptUrl);
}
};
/**
* @param {?} type
* @return {?}
*/
NzIconService.prototype.createIconfontIcon = /**
* @param {?} type
* @return {?}
*/
function (type) {
return this._createSVGElementFromString("<svg><use xlink:href=\"" + type + "\"></svg>");
};
/**
* @private
* @return {?}
*/
NzIconService.prototype.onConfigChange = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.nzConfigService.getConfigChangeEventForComponent('icon').subscribe((/**
* @return {?}
*/
function () {
_this.configDefaultTwotoneColor();
_this.configDefaultTheme();
_this.configUpdated$.next();
}));
};
/**
* @private
* @return {?}
*/
NzIconService.prototype.configDefaultTheme = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var iconConfig = this.getConfig();
this.defaultTheme = iconConfig.nzTheme || 'outline';
};
/**
* @private
* @return {?}
*/
NzIconService.prototype.configDefaultTwotoneColor = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var iconConfig = this.getConfig();
/** @type {?} */
var defaultTwotoneColor = iconConfig.nzTwotoneColor || DEFAULT_TWOTONE_COLOR;
/** @type {?} */
var primaryColor = DEFAULT_TWOTONE_COLOR;
if (defaultTwotoneColor) {
if (defaultTwotoneColor.startsWith('#')) {
primaryColor = defaultTwotoneColor;
}
else {
warn('Twotone color must be a hex color!');
}
}
this.twoToneColor = { primaryColor: primaryColor };
};
/**
* @private
* @return {?}
*/
NzIconService.prototype.getConfig = /**
* @private
* @return {?}
*/
function () {
return this.nzConfigService.getConfigForComponent('icon') || {};
};
NzIconService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] }
];
/** @nocollapse */
NzIconService.ctorParameters = function () { return [
{ type: RendererFactory2 },
{ type: DomSanitizer },
{ type: NzConfigService },
{ type: HttpBackend, decorators: [{ type: Optional }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] },
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NZ_ICONS,] }] }
]; };
/** @nocollapse */ NzIconService.ɵprov = i0.ɵɵdefineInjectable({ factory: function NzIconService_Factory() { return new NzIconService(i0.ɵɵinject(i0.RendererFactory2), i0.ɵɵinject(i1.DomSanitizer), i0.ɵɵinject(i2.NzConfigService), i0.ɵɵinject(i3.HttpBackend, 8), i0.ɵɵinject(i4.DOCUMENT, 8), i0.ɵɵinject(NZ_ICONS, 8)); }, token: NzIconService, providedIn: "root" });
return NzIconService;
}(IconService));
export { NzIconService };
if (false) {
/** @type {?} */
NzIconService.prototype.configUpdated$;
/**
* @type {?}
* @private
*/
NzIconService.prototype.iconfontCache;
/**
* @type {?}
* @protected
*/
NzIconService.prototype.nzConfigService;
}
/** @type {?} */
export var NZ_ICONS_PATCH = new InjectionToken('nz_icons_patch');
var NzIconPatchService = /** @class */ (function () {
function NzIconPatchService(extraIcons, rootIconService) {
this.extraIcons = extraIcons;
this.rootIconService = rootIconService;
this.patched = false;
}
/**
* @return {?}
*/
NzIconPatchService.prototype.doPatch = /**
* @return {?}
*/
function () {
var _this = this;
if (this.patched) {
return;
}
this.extraIcons.forEach((/**
* @param {?} iconDefinition
* @return {?}
*/
function (iconDefinition) { return _this.rootIconService.addIcon(iconDefinition); }));
this.patched = true;
};
NzIconPatchService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
NzIconPatchService.ctorParameters = function () { return [
{ type: Array, decorators: [{ type: Self }, { type: Inject, args: [NZ_ICONS_PATCH,] }] },
{ type: NzIconService }
]; };
return NzIconPatchService;
}());
export { NzIconPatchService };
if (false) {
/** @type {?} */
NzIconPatchService.prototype.patched;
/**
* @type {?}
* @private
*/
NzIconPatchService.prototype.extraIcons;
/**
* @type {?}
* @private
*/
NzIconPatchService.prototype.rootIconService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.service.js","sourceRoot":"ng://ng-zorro-antd/icon/","sources":["icon.service.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 { DOCUMENT } from '@angular/common';\nimport { HttpBackend } from '@angular/common/http';\nimport { Inject, Injectable, InjectionToken, Optional, RendererFactory2, Self } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IconDefinition, IconService } from '@ant-design/icons-angular';\nimport { IconConfig, NzConfigService } from 'ng-zorro-antd/core/config';\nimport { warn } from 'ng-zorro-antd/core/logger';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { Subject } from 'rxjs';\nimport { NZ_ICONS_USED_BY_ZORRO } from './icons';\n\nexport interface NzIconfontOption {\n  scriptUrl: string;\n}\n\nexport const NZ_ICONS = new InjectionToken('nz_icons');\nexport const NZ_ICON_DEFAULT_TWOTONE_COLOR = new InjectionToken('nz_icon_default_twotone_color');\nexport const DEFAULT_TWOTONE_COLOR = '#1890ff';\n\n/**\n * It should be a global singleton, otherwise registered icons could not be found.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class NzIconService extends IconService {\n  configUpdated$ = new Subject<void>();\n\n  private iconfontCache = new Set<string>();\n\n  normalizeSvgElement(svg: SVGElement): void {\n    if (!svg.getAttribute('viewBox')) {\n      this._renderer.setAttribute(svg, 'viewBox', '0 0 1024 1024');\n    }\n    if (!svg.getAttribute('width') || !svg.getAttribute('height')) {\n      this._renderer.setAttribute(svg, 'width', '1em');\n      this._renderer.setAttribute(svg, 'height', '1em');\n    }\n    if (!svg.getAttribute('fill')) {\n      this._renderer.setAttribute(svg, 'fill', 'currentColor');\n    }\n  }\n\n  fetchFromIconfont(opt: NzIconfontOption): void {\n    const { scriptUrl } = opt;\n    if (this._document && !this.iconfontCache.has(scriptUrl)) {\n      const script = this._renderer.createElement('script');\n      this._renderer.setAttribute(script, 'src', scriptUrl);\n      this._renderer.setAttribute(script, 'data-namespace', scriptUrl.replace(/^(https?|http):/g, ''));\n      this._renderer.appendChild(this._document.body, script);\n      this.iconfontCache.add(scriptUrl);\n    }\n  }\n\n  createIconfontIcon(type: string): SVGElement {\n    return this._createSVGElementFromString(`<svg><use xlink:href=\"${type}\"></svg>`);\n  }\n\n  constructor(\n    rendererFactory: RendererFactory2,\n    sanitizer: DomSanitizer,\n    protected nzConfigService: NzConfigService,\n    @Optional() handler: HttpBackend,\n    @Optional() @Inject(DOCUMENT) _document: NzSafeAny,\n    @Optional() @Inject(NZ_ICONS) icons?: IconDefinition[]\n  ) {\n    super(rendererFactory, handler, _document, sanitizer);\n\n    this.onConfigChange();\n    this.addIcon(...NZ_ICONS_USED_BY_ZORRO, ...(icons || []));\n    this.configDefaultTwotoneColor();\n    this.configDefaultTheme();\n  }\n\n  private onConfigChange(): void {\n    this.nzConfigService.getConfigChangeEventForComponent('icon').subscribe(() => {\n      this.configDefaultTwotoneColor();\n      this.configDefaultTheme();\n      this.configUpdated$.next();\n    });\n  }\n\n  private configDefaultTheme(): void {\n    const iconConfig = this.getConfig();\n    this.defaultTheme = iconConfig.nzTheme || 'outline';\n  }\n\n  private configDefaultTwotoneColor(): void {\n    const iconConfig = this.getConfig();\n    const defaultTwotoneColor = iconConfig.nzTwotoneColor || DEFAULT_TWOTONE_COLOR;\n\n    let primaryColor = DEFAULT_TWOTONE_COLOR;\n\n    if (defaultTwotoneColor) {\n      if (defaultTwotoneColor.startsWith('#')) {\n        primaryColor = defaultTwotoneColor;\n      } else {\n        warn('Twotone color must be a hex color!');\n      }\n    }\n\n    this.twoToneColor = { primaryColor };\n  }\n\n  private getConfig(): IconConfig {\n    return this.nzConfigService.getConfigForComponent('icon') || {};\n  }\n}\n\nexport const NZ_ICONS_PATCH = new InjectionToken('nz_icons_patch');\n\n@Injectable()\nexport class NzIconPatchService {\n  patched = false;\n\n  constructor(@Self() @Inject(NZ_ICONS_PATCH) private extraIcons: IconDefinition[], private rootIconService: NzIconService) {}\n\n  doPatch(): void {\n    if (this.patched) {\n      return;\n    }\n\n    this.extraIcons.forEach(iconDefinition => this.rootIconService.addIcon(iconDefinition));\n    this.patched = true;\n  }\n}\n"]}