Socket
Socket
Sign inDemoInstall

angular-svg-icon

Package Overview
Dependencies
Maintainers
1
Versions
37
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-svg-icon - npm Package Compare versions

Comparing version 6.0.0 to 6.0.1

esm2015/index.js

618

bundles/angular-svg-icon.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common/http'), require('rxjs'), require('rxjs/operators'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('angular-svg-icon', ['exports', '@angular/core', '@angular/common/http', 'rxjs', 'rxjs/operators', '@angular/common'], factory) :
(factory((global['angular-svg-icon'] = {}),global.ng.core,global.ng.common.http,global.rxjs,global.Rx.Observable.prototype,global.ng.common));
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common/http'), require('rxjs'), require('rxjs/operators'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('angular-svg-icon', ['exports', '@angular/core', '@angular/common/http', 'rxjs', 'rxjs/operators', '@angular/common'], factory) :
(factory((global['angular-svg-icon'] = {}),global.ng.core,global.ng.common.http,global.rxjs,global.rxjs.operators,global.ng.common));
}(this, (function (exports,core,http,rxjs,operators,common) { 'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
/* global Reflect, Promise */
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var SvgIconRegistryService = (function () {
function SvgIconRegistryService(http$$1) {
this.http = http$$1;
this.iconsByUrl = new Map();
this.iconsLoadingByUrl = new Map();
}
/** Add a SVG to the registry by passing a name and the SVG. */
/**
* Add a SVG to the registry by passing a name and the SVG.
* @param {?} name
* @param {?} data
* @return {?}
*/
SvgIconRegistryService.prototype.addSvg = /**
* Add a SVG to the registry by passing a name and the SVG.
* @param {?} name
* @param {?} data
* @return {?}
*/
function (name, data) {
if (!this.iconsByUrl.has(name)) {
/** @type {?} */
var div = document.createElement('DIV');
div.innerHTML = data;
/** @type {?} */
var svg = (div.querySelector('svg'));
this.iconsByUrl.set(name, svg);
}
};
/** Load a SVG to the registry from a URL. */
/**
* Load a SVG to the registry from a URL.
* @param {?} url
* @return {?}
*/
SvgIconRegistryService.prototype.loadSvg = /**
* Load a SVG to the registry from a URL.
* @param {?} url
* @return {?}
*/
function (url) {
var _this = this;
if (this.iconsByUrl.has(url)) {
return rxjs.of(this.iconsByUrl.get(url));
}
else if (this.iconsLoadingByUrl.has(url)) {
return this.iconsLoadingByUrl.get(url);
}
else {
/** @type {?} */
var o = (this.http.get(url, { responseType: 'text' }).pipe(operators.map(function (svg) {
/** @type {?} */
var div = document.createElement('DIV');
div.innerHTML = svg;
return /** @type {?} */ (div.querySelector('svg'));
}), operators.tap(function (svg) { return _this.iconsByUrl.set(url, svg); }), operators.catchError(function (err) {
console.error(err);
return rxjs.throwError(err);
}), operators.finalize(function () { return _this.iconsLoadingByUrl.delete(url); }), operators.share()));
this.iconsLoadingByUrl.set(url, o);
return o;
}
};
/** Remove a SVG from the registry by URL (or name). */
/**
* Remove a SVG from the registry by URL (or name).
* @param {?} url
* @return {?}
*/
SvgIconRegistryService.prototype.unloadSvg = /**
* Remove a SVG from the registry by URL (or name).
* @param {?} url
* @return {?}
*/
function (url) {
if (this.iconsByUrl.has(url)) {
this.iconsByUrl.delete(url);
}
};
SvgIconRegistryService.decorators = [
{ type: core.Injectable }
];
/** @nocollapse */
SvgIconRegistryService.ctorParameters = function () {
return [
{ type: http.HttpClient }
];
};
return SvgIconRegistryService;
}());
/**
* @param {?} parentRegistry
* @param {?} http
* @return {?}
*/
function SVG_ICON_REGISTRY_PROVIDER_FACTORY(parentRegistry, http$$1) {
return parentRegistry || new SvgIconRegistryService(http$$1);
}
/** @type {?} */
var SVG_ICON_REGISTRY_PROVIDER = {
provide: SvgIconRegistryService,
deps: [[new core.Optional(), new core.SkipSelf(), SvgIconRegistryService], http.HttpClient],
useFactory: SVG_ICON_REGISTRY_PROVIDER_FACTORY
};
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m)
return o;
var i = m.call(o), r, ar = [], e;
try {
if (r && !r.done && (m = i["return"])) m.call(i);
while ((n === void 0 || n-- > 0) && !(r = i.next()).done)
ar.push(r.value);
}
finally { if (e) throw e.error; }
}
return ar;
}
var SvgIconRegistryService = /** @class */ (function () {
function SvgIconRegistryService(http$$1) {
this.http = http$$1;
this.iconsByUrl = new Map();
this.iconsLoadingByUrl = new Map();
}
SvgIconRegistryService.prototype.addSvg = function (name, data) {
if (!this.iconsByUrl.has(name)) {
var div = document.createElement('DIV');
div.innerHTML = data;
var svg = (div.querySelector('svg'));
this.iconsByUrl.set(name, svg);
catch (error) {
e = { error: error };
}
};
SvgIconRegistryService.prototype.loadSvg = function (url) {
var _this = this;
if (this.iconsByUrl.has(url)) {
return rxjs.of(this.iconsByUrl.get(url));
}
else if (this.iconsLoadingByUrl.has(url)) {
return this.iconsLoadingByUrl.get(url);
}
else {
var o = (this.http.get(url, { responseType: 'text' }).pipe(operators.map(function (svg) {
var div = document.createElement('DIV');
div.innerHTML = svg;
return (div.querySelector('svg'));
}), operators.tap(function (svg) { return _this.iconsByUrl.set(url, svg); }), operators.catchError(function (err) {
console.error(err);
return rxjs.throwError(err);
}), operators.finalize(function () { return _this.iconsLoadingByUrl.delete(url); }), operators.share()));
this.iconsLoadingByUrl.set(url, o);
return o;
}
};
SvgIconRegistryService.prototype.unloadSvg = function (url) {
if (this.iconsByUrl.has(url)) {
this.iconsByUrl.delete(url);
}
};
return SvgIconRegistryService;
}());
SvgIconRegistryService.decorators = [
{ type: core.Injectable },
];
SvgIconRegistryService.ctorParameters = function () { return [
{ type: http.HttpClient, },
]; };
function SVG_ICON_REGISTRY_PROVIDER_FACTORY(parentRegistry, http$$1) {
return parentRegistry || new SvgIconRegistryService(http$$1);
}
var SVG_ICON_REGISTRY_PROVIDER = {
provide: SvgIconRegistryService,
deps: [[new core.Optional(), new core.SkipSelf(), SvgIconRegistryService], http.HttpClient],
useFactory: SVG_ICON_REGISTRY_PROVIDER_FACTORY
};
var SvgIconComponent = /** @class */ (function () {
function SvgIconComponent(element, differs, renderer, iconReg) {
this.element = element;
this.differs = differs;
this.renderer = renderer;
this.iconReg = iconReg;
this.stretch = false;
}
Object.defineProperty(SvgIconComponent.prototype, "svgStyle", {
set: function (v) {
this._svgStyle = v;
if (!this.differ && v) {
this.differ = this.differs.find(v).create();
finally {
try {
if (r && !r.done && (m = i["return"]))
m.call(i);
}
},
enumerable: true,
configurable: true
});
SvgIconComponent.prototype.ngOnInit = function () {
this.init();
};
SvgIconComponent.prototype.ngOnDestroy = function () {
this.destroy();
};
SvgIconComponent.prototype.ngOnChanges = function (changeRecord) {
if (changeRecord['src']) {
if (this.svg) {
this.destroy();
finally {
if (e)
throw e.error;
}
this.init();
}
if (changeRecord['stretch']) {
this.stylize();
return ar;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var SvgIconComponent = (function () {
function SvgIconComponent(element, differs, renderer, iconReg) {
this.element = element;
this.differs = differs;
this.renderer = renderer;
this.iconReg = iconReg;
this.stretch = false;
}
};
SvgIconComponent.prototype.ngDoCheck = function () {
if (this.svg && this.differ) {
var changes = this.differ.diff(this._svgStyle);
if (changes) {
this.applyChanges(changes);
}
}
};
SvgIconComponent.prototype.init = function () {
var _this = this;
this.icnSub = this.iconReg.loadSvg(this.src).subscribe(function (svg) {
_this.setSvg(svg);
_this.resetDiffer();
Object.defineProperty(SvgIconComponent.prototype, "svgStyle", {
// Adapted from ngStyle
set: /**
* @param {?} v
* @return {?}
*/ function (v) {
this._svgStyle = v;
if (!this.differ && v) {
this.differ = this.differs.find(v).create();
}
},
enumerable: true,
configurable: true
});
};
SvgIconComponent.prototype.destroy = function () {
this.svg = undefined;
this.differ = undefined;
if (this.icnSub) {
this.icnSub.unsubscribe();
/**
* @return {?}
*/
SvgIconComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.init();
};
/**
* @return {?}
*/
SvgIconComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy();
};
/**
* @param {?} changeRecord
* @return {?}
*/
SvgIconComponent.prototype.ngOnChanges = /**
* @param {?} changeRecord
* @return {?}
*/
function (changeRecord) {
if (changeRecord['src']) {
if (this.svg) {
this.destroy();
}
this.init();
}
if (changeRecord['stretch']) {
this.stylize();
}
};
/**
* @return {?}
*/
SvgIconComponent.prototype.ngDoCheck = /**
* @return {?}
*/
function () {
if (this.svg && this.differ) {
/** @type {?} */
var changes = this.differ.diff(this._svgStyle);
if (changes) {
this.applyChanges(changes);
}
}
};
/**
* @return {?}
*/
SvgIconComponent.prototype.init = /**
* @return {?}
*/
function () {
var _this = this;
this.icnSub = this.iconReg.loadSvg(this.src).subscribe(function (svg) {
_this.setSvg(svg);
_this.resetDiffer();
});
};
/**
* @return {?}
*/
SvgIconComponent.prototype.destroy = /**
* @return {?}
*/
function () {
this.svg = undefined;
this.differ = undefined;
if (this.icnSub) {
this.icnSub.unsubscribe();
}
};
/**
* @return {?}
*/
SvgIconComponent.prototype.resetDiffer = /**
* @return {?}
*/
function () {
if (this._svgStyle && !this.differ) {
this.differ = this.differs.find(this._svgStyle).create();
}
};
/**
* @param {?} svg
* @return {?}
*/
SvgIconComponent.prototype.setSvg = /**
* @param {?} svg
* @return {?}
*/
function (svg) {
if (svg) {
this.svg = svg;
/** @type {?} */
var icon = (svg.cloneNode(true));
/** @type {?} */
var elem = this.element.nativeElement;
elem.innerHTML = '';
this.renderer.appendChild(elem, icon);
this.stylize();
}
};
/**
* @return {?}
*/
SvgIconComponent.prototype.stylize = /**
* @return {?}
*/
function () {
if (this.svg) {
/** @type {?} */
var svg = this.element.nativeElement.firstChild;
if (this.stretch === true) {
this.renderer.setAttribute(svg, 'preserveAspectRatio', 'none');
}
else if (this.stretch === false) {
this.renderer.removeAttribute(svg, 'preserveAspectRatio');
}
}
};
/**
* @param {?} changes
* @return {?}
*/
SvgIconComponent.prototype.applyChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
changes.forEachRemovedItem(function (record) { return _this.setStyle(record.key, null); });
changes.forEachAddedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
changes.forEachChangedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
};
/**
* @param {?} nameAndUnit
* @param {?} value
* @return {?}
*/
SvgIconComponent.prototype.setStyle = /**
* @param {?} nameAndUnit
* @param {?} value
* @return {?}
*/
function (nameAndUnit, value) {
var _a = __read(nameAndUnit.split('.'), 2), name = _a[0], unit = _a[1];
value = value !== null && unit ? "" + value + unit : value;
/** @type {?} */
var svg = this.element.nativeElement.firstChild;
if (value !== null) {
this.renderer.setStyle(svg, name, /** @type {?} */ (value));
}
else {
this.renderer.removeStyle(svg, name);
}
};
SvgIconComponent.decorators = [
{ type: core.Component, args: [{
selector: 'svg-icon',
template: '<ng-content></ng-content>',
styles: [":host { display: inline-block; }"]
}] }
];
/** @nocollapse */
SvgIconComponent.ctorParameters = function () {
return [
{ type: core.ElementRef },
{ type: core.KeyValueDiffers },
{ type: core.Renderer2 },
{ type: SvgIconRegistryService }
];
};
SvgIconComponent.propDecorators = {
src: [{ type: core.Input }],
stretch: [{ type: core.Input }],
svgStyle: [{ type: core.Input }]
};
return SvgIconComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var AngularSvgIconModule = (function () {
function AngularSvgIconModule() {
}
};
SvgIconComponent.prototype.resetDiffer = function () {
if (this._svgStyle && !this.differ) {
this.differ = this.differs.find(this._svgStyle).create();
}
};
SvgIconComponent.prototype.setSvg = function (svg) {
if (svg) {
this.svg = svg;
var icon = (svg.cloneNode(true));
var elem = this.element.nativeElement;
elem.innerHTML = '';
this.renderer.appendChild(elem, icon);
this.stylize();
}
};
SvgIconComponent.prototype.stylize = function () {
if (this.svg) {
var svg = this.element.nativeElement.firstChild;
if (this.stretch === true) {
this.renderer.setAttribute(svg, 'preserveAspectRatio', 'none');
}
else if (this.stretch === false) {
this.renderer.removeAttribute(svg, 'preserveAspectRatio');
}
}
};
SvgIconComponent.prototype.applyChanges = function (changes) {
var _this = this;
changes.forEachRemovedItem(function (record) { return _this.setStyle(record.key, null); });
changes.forEachAddedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
changes.forEachChangedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
};
SvgIconComponent.prototype.setStyle = function (nameAndUnit, value) {
var _a = __read(nameAndUnit.split('.'), 2), name = _a[0], unit = _a[1];
value = value !== null && unit ? "" + value + unit : value;
var svg = this.element.nativeElement.firstChild;
if (value !== null) {
this.renderer.setStyle(svg, name, (value));
}
else {
this.renderer.removeStyle(svg, name);
}
};
return SvgIconComponent;
}());
SvgIconComponent.decorators = [
{ type: core.Component, args: [{
selector: 'svg-icon',
styles: [":host { display: inline-block; }"],
template: '<ng-content></ng-content>'
},] },
];
SvgIconComponent.ctorParameters = function () { return [
{ type: core.ElementRef, },
{ type: core.KeyValueDiffers, },
{ type: core.Renderer2, },
{ type: SvgIconRegistryService, },
]; };
SvgIconComponent.propDecorators = {
"src": [{ type: core.Input },],
"stretch": [{ type: core.Input },],
"svgStyle": [{ type: core.Input },],
};
var AngularSvgIconModule = /** @class */ (function () {
function AngularSvgIconModule() {
}
return AngularSvgIconModule;
}());
AngularSvgIconModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule,
],
declarations: [SvgIconComponent],
providers: [SVG_ICON_REGISTRY_PROVIDER],
exports: [SvgIconComponent]
},] },
];
AngularSvgIconModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule,
],
declarations: [SvgIconComponent],
providers: [SVG_ICON_REGISTRY_PROVIDER],
exports: [SvgIconComponent]
},] }
];
return AngularSvgIconModule;
}());
exports.AngularSvgIconModule = AngularSvgIconModule;
exports.SvgIconRegistryService = SvgIconRegistryService;
exports.SVG_ICON_REGISTRY_PROVIDER_FACTORY = SVG_ICON_REGISTRY_PROVIDER_FACTORY;
exports.SVG_ICON_REGISTRY_PROVIDER = SVG_ICON_REGISTRY_PROVIDER;
exports.SvgIconComponent = SvgIconComponent;
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
Object.defineProperty(exports, '__esModule', { value: true });
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
exports.AngularSvgIconModule = AngularSvgIconModule;
exports.SvgIconRegistryService = SvgIconRegistryService;
exports.SVG_ICON_REGISTRY_PROVIDER_FACTORY = SVG_ICON_REGISTRY_PROVIDER_FACTORY;
exports.SVG_ICON_REGISTRY_PROVIDER = SVG_ICON_REGISTRY_PROVIDER;
exports.SvgIconComponent = SvgIconComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=angular-svg-icon.umd.js.map
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-svg-icon.umd.js.map","sources":["ng://angular-svg-icon/src/svg-icon-registry.service.ts","node_modules/tslib/tslib.es6.js","ng://angular-svg-icon/src/svg-icon.component.ts","ng://angular-svg-icon/src/angular-svg-icon.module.ts"],"sourcesContent":["import { Injectable, Optional, SkipSelf } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\n\nimport { Observable, of as observableOf, throwError as observableThrowError } from 'rxjs';\nimport { map, tap, catchError, finalize, share } from 'rxjs/operators';\n\n@Injectable()\nexport class SvgIconRegistryService {\n\n\tprivate iconsByUrl = new Map<string, SVGElement>();\n\tprivate iconsLoadingByUrl = new Map<string, Observable<SVGElement>>();\n\n\tconstructor(private http:HttpClient) {\n\t}\n\n\t/** Add a SVG to the registry by passing a name and the SVG. */\n\taddSvg(name:string, data:string) {\n\t\tif (!this.iconsByUrl.has(name)) {\n\t\t\tconst div = document.createElement('DIV');\n\t\t\tdiv.innerHTML = data;\n\t\t\tconst svg = <SVGElement>div.querySelector('svg');\n\t\t\tthis.iconsByUrl.set(name, svg);\n\t\t}\n\t}\n\n\t/** Load a SVG to the registry from a URL. */\n\tloadSvg(url:string) : Observable<SVGElement> {\n\n\t\tif (this.iconsByUrl.has(url)) {\n\t\t\treturn observableOf(this.iconsByUrl.get(url));\n\t\t} else if (this.iconsLoadingByUrl.has(url)) {\n\t\t\treturn this.iconsLoadingByUrl.get(url);\n\t\t} else {\n\t\t\tconst o = <Observable<SVGElement>> this.http.get(url, { responseType: 'text' }).pipe(\n\t\t\t\tmap(svg => {\n\t\t\t\t\tconst div = document.createElement('DIV');\n\t\t\t\t\tdiv.innerHTML = svg;\n\t\t\t\t\treturn <SVGElement>div.querySelector('svg');\n\t\t\t\t}),\n\t\t\t\ttap (svg => this.iconsByUrl.set(url, svg) ),\n\t\t\t\tcatchError(err => {\n\t\t\t\t\tconsole.error(err);\n\t\t\t\t\treturn observableThrowError(err);\n\t\t\t\t}),\n\t\t\t\tfinalize(() => this.iconsLoadingByUrl.delete(url) ),\n\t\t\t\tshare()\n\t\t\t);\n\n\t\t\tthis.iconsLoadingByUrl.set(url, o);\n\t\t\treturn o;\n\t\t}\n\t}\n\n\t/** Remove a SVG from the registry by URL (or name). */\n\tunloadSvg(url:string) {\n\t\tif (this.iconsByUrl.has(url)) {\n\t\t\tthis.iconsByUrl.delete(url);\n\t\t}\n\t}\n}\n\nexport function SVG_ICON_REGISTRY_PROVIDER_FACTORY(parentRegistry:SvgIconRegistryService, http:HttpClient) {\n\treturn parentRegistry || new SvgIconRegistryService(http);\n}\n\nexport const SVG_ICON_REGISTRY_PROVIDER = {\n\tprovide: SvgIconRegistryService,\n\tdeps: [ [new Optional(), new SkipSelf(), SvgIconRegistryService], HttpClient ],\n\tuseFactory: SVG_ICON_REGISTRY_PROVIDER_FACTORY\n};\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)\r\n            t[p[i]] = s[p[i]];\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n    if (m) return m.call(o);\r\n    return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","import { Component, DoCheck, ElementRef, HostBinding, Input,\n\tKeyValueChangeRecord, KeyValueChanges, KeyValueDiffer, KeyValueDiffers,\n\tOnChanges, OnDestroy, OnInit, Renderer2, SimpleChange } from '@angular/core';\n\nimport { Subscription } from 'rxjs';\n\nimport { SvgIconRegistryService } from './svg-icon-registry.service';\n\n\n@Component({\n\tselector: 'svg-icon',\n\tstyles: [ `:host { display: inline-block; }` ],\n\ttemplate: '<ng-content></ng-content>'\n})\n\nexport class SvgIconComponent implements OnInit, OnDestroy, OnChanges, DoCheck {\n\t@Input() src:string;\n\t@Input() stretch = false;\n\n\t// Adapted from ngStyle\n\t@Input()\n\tset svgStyle(v: {[key:string]: string }) {\n\t\tthis._svgStyle = v;\n\t\tif (!this.differ && v) {\n\t\t\tthis.differ = this.differs.find(v).create();\n\t\t}\n\t}\n\n\tprivate svg:SVGElement;\n\tprivate icnSub:Subscription;\n\tprivate differ:KeyValueDiffer<string, string|number>;\n\tprivate _svgStyle: {[key:string]:string};\n\n\tconstructor(private element:ElementRef,\n\t\tprivate differs:KeyValueDiffers,\n\t\tprivate renderer:Renderer2,\n\t\tprivate iconReg:SvgIconRegistryService) {\n\t}\n\n\tngOnInit() {\n\t\tthis.init();\n\t}\n\n\tngOnDestroy() {\n\t\tthis.destroy();\n\t}\n\n\tngOnChanges(changeRecord: {[key:string]:SimpleChange}) {\n\t\tif (changeRecord['src']) {\n\t\t\tif (this.svg) {\n\t\t\t\tthis.destroy();\n\t\t\t}\n\t\t\tthis.init();\n\t\t}\n\t\tif (changeRecord['stretch']) {\n\t\t\tthis.stylize();\n\t\t}\n\t}\n\n\tngDoCheck() {\n\t\tif (this.svg && this.differ) {\n\t\t\tconst changes = this.differ.diff(this._svgStyle);\n\t\t\tif (changes) {\n\t\t\t\tthis.applyChanges(changes);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate init() {\n\t\tthis.icnSub = this.iconReg.loadSvg(this.src).subscribe(svg => {\n\t\t\tthis.setSvg(svg);\n\t\t\tthis.resetDiffer();\n\t\t});\n\t}\n\n\tprivate destroy() {\n\t\tthis.svg = undefined;\n\t\tthis.differ = undefined;\n\t\tif (this.icnSub) {\n\t\t\tthis.icnSub.unsubscribe();\n\t\t}\n\t}\n\n\tprivate resetDiffer() {\n\t\tif (this._svgStyle && !this.differ) {\n\t\t\tthis.differ = this.differs.find(this._svgStyle).create();\n\t\t}\n\t}\n\n\tprivate setSvg(svg:SVGElement) {\n\t\tif (svg) {\n\t\t\tthis.svg = svg;\n\t\t\tconst icon = <SVGElement>svg.cloneNode(true);\n\t\t\tconst elem = this.element.nativeElement;\n\n\t\t\telem.innerHTML = '';\n\t\t\tthis.renderer.appendChild(elem, icon);\n\n\t\t\tthis.stylize();\n\t\t}\n\t}\n\n\tprivate stylize() {\n\t\tif (this.svg) {\n\t\t\tconst svg = this.element.nativeElement.firstChild;\n\n\t\t\tif (this.stretch === true) {\n\t\t\t\tthis.renderer.setAttribute(svg, 'preserveAspectRatio', 'none');\n\t\t\t} else if (this.stretch === false) {\n\t\t\t\tthis.renderer.removeAttribute(svg, 'preserveAspectRatio');\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate applyChanges(changes: KeyValueChanges<string, string|number>) {\n\t\tchanges.forEachRemovedItem((record:KeyValueChangeRecord<string, string|number>) => this.setStyle(record.key, null));\n\t\tchanges.forEachAddedItem((record:KeyValueChangeRecord<string, string|number>) => this.setStyle(record.key, record.currentValue));\n\t\tchanges.forEachChangedItem((record:KeyValueChangeRecord<string, string|number>) => this.setStyle(record.key, record.currentValue));\n\t}\n\n\tprivate setStyle(nameAndUnit: string, value: string|number|null|undefined) {\n\t\tconst [name, unit] = nameAndUnit.split('.');\n\t\tvalue = value !== null && unit ? `${value}${unit}` : value;\n\t\tconst svg = this.element.nativeElement.firstChild;\n\n\t\tif (value !== null) {\n\t\t\tthis.renderer.setStyle(svg, name, value as string);\n\t\t} else {\n\t\t\tthis.renderer.removeStyle(svg, name);\n\t\t}\n\t}\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\n\nimport { SVG_ICON_REGISTRY_PROVIDER } from './svg-icon-registry.service';\nimport { SvgIconComponent } from './svg-icon.component';\n\n@NgModule({\n\timports:\t  [\n\t\tCommonModule,\n\t],\n\tdeclarations: [ SvgIconComponent ],\n\tproviders:    [ SVG_ICON_REGISTRY_PROVIDER ],\n\texports:      [ SvgIconComponent ]\n})\n\nexport class AngularSvgIconModule {}\n"],"names":["http","observableOf","map","tap","catchError","observableThrowError","finalize","share","Injectable","HttpClient","Optional","SkipSelf","Component","ElementRef","KeyValueDiffers","Renderer2","Input","NgModule","CommonModule"],"mappings":"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"}

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common/http"),require("rxjs"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-svg-icon",["exports","@angular/core","@angular/common/http","rxjs","rxjs/operators","@angular/common"],t):t(e["angular-svg-icon"]={},e.ng.core,e.ng.common.http,e.rxjs,e.Rx.Observable.prototype,e.ng.common)}(this,function(e,t,r,n,i,o){"use strict";var s=function(){function e(e){this.http=e,this.iconsByUrl=new Map,this.iconsLoadingByUrl=new Map}return e.prototype.addSvg=function(e,t){if(!this.iconsByUrl.has(e)){var r=document.createElement("DIV");r.innerHTML=t;var n=r.querySelector("svg");this.iconsByUrl.set(e,n)}},e.prototype.loadSvg=function(t){var r=this;if(this.iconsByUrl.has(t))return n.of(this.iconsByUrl.get(t));if(this.iconsLoadingByUrl.has(t))return this.iconsLoadingByUrl.get(t);var e=this.http.get(t,{responseType:"text"}).pipe(i.map(function(e){var t=document.createElement("DIV");return t.innerHTML=e,t.querySelector("svg")}),i.tap(function(e){return r.iconsByUrl.set(t,e)}),i.catchError(function(e){return console.error(e),n.throwError(e)}),i.finalize(function(){return r.iconsLoadingByUrl["delete"](t)}),i.share());return this.iconsLoadingByUrl.set(t,e),e},e.prototype.unloadSvg=function(e){this.iconsByUrl.has(e)&&this.iconsByUrl["delete"](e)},e}();function c(e,t){return e||new s(t)}s.decorators=[{type:t.Injectable}],s.ctorParameters=function(){return[{type:r.HttpClient}]};var a={provide:s,deps:[[new t.Optional,new t.SkipSelf,s],r.HttpClient],useFactory:c},u=function(){function e(e,t,r,n){this.element=e,this.differs=t,this.renderer=r,this.iconReg=n,this.stretch=!1}return Object.defineProperty(e.prototype,"svgStyle",{set:function(e){this._svgStyle=e,!this.differ&&e&&(this.differ=this.differs.find(e).create())},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.init()},e.prototype.ngOnDestroy=function(){this.destroy()},e.prototype.ngOnChanges=function(e){e.src&&(this.svg&&this.destroy(),this.init()),e.stretch&&this.stylize()},e.prototype.ngDoCheck=function(){if(this.svg&&this.differ){var e=this.differ.diff(this._svgStyle);e&&this.applyChanges(e)}},e.prototype.init=function(){var t=this;this.icnSub=this.iconReg.loadSvg(this.src).subscribe(function(e){t.setSvg(e),t.resetDiffer()})},e.prototype.destroy=function(){this.svg=undefined,this.differ=undefined,this.icnSub&&this.icnSub.unsubscribe()},e.prototype.resetDiffer=function(){this._svgStyle&&!this.differ&&(this.differ=this.differs.find(this._svgStyle).create())},e.prototype.setSvg=function(e){if(e){var t=(this.svg=e).cloneNode(!0),r=this.element.nativeElement;r.innerHTML="",this.renderer.appendChild(r,t),this.stylize()}},e.prototype.stylize=function(){if(this.svg){var e=this.element.nativeElement.firstChild;!0===this.stretch?this.renderer.setAttribute(e,"preserveAspectRatio","none"):!1===this.stretch&&this.renderer.removeAttribute(e,"preserveAspectRatio")}},e.prototype.applyChanges=function(e){var t=this;e.forEachRemovedItem(function(e){return t.setStyle(e.key,null)}),e.forEachAddedItem(function(e){return t.setStyle(e.key,e.currentValue)}),e.forEachChangedItem(function(e){return t.setStyle(e.key,e.currentValue)})},e.prototype.setStyle=function(e,t){var r=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,i,o=r.call(e),s=[];try{for(;(void 0===t||0<t--)&&!(n=o.next()).done;)s.push(n.value)}catch(c){i={error:c}}finally{try{n&&!n.done&&(r=o["return"])&&r.call(o)}finally{if(i)throw i.error}}return s}(e.split("."),2),n=r[0],i=r[1];t=null!==t&&i?""+t+i:t;var o=this.element.nativeElement.firstChild;null!==t?this.renderer.setStyle(o,n,t):this.renderer.removeStyle(o,n)},e}();u.decorators=[{type:t.Component,args:[{selector:"svg-icon",styles:[":host { display: inline-block; }"],template:"<ng-content></ng-content>"}]}],u.ctorParameters=function(){return[{type:t.ElementRef},{type:t.KeyValueDiffers},{type:t.Renderer2},{type:s}]},u.propDecorators={src:[{type:t.Input}],stretch:[{type:t.Input}],svgStyle:[{type:t.Input}]};var l=function(){};l.decorators=[{type:t.NgModule,args:[{imports:[o.CommonModule],declarations:[u],providers:[a],exports:[u]}]}],e.AngularSvgIconModule=l,e.SvgIconRegistryService=s,e.SVG_ICON_REGISTRY_PROVIDER_FACTORY=c,e.SVG_ICON_REGISTRY_PROVIDER=a,e.SvgIconComponent=u,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-svg-icon.umd.min.js.map
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common/http"),require("rxjs"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-svg-icon",["exports","@angular/core","@angular/common/http","rxjs","rxjs/operators","@angular/common"],t):t(e["angular-svg-icon"]={},e.ng.core,e.ng.common.http,e.rxjs,e.rxjs.operators,e.ng.common)}(this,function(e,t,r,n,i,o){"use strict";var s=function(){function e(e){this.http=e,this.iconsByUrl=new Map,this.iconsLoadingByUrl=new Map}return e.prototype.addSvg=function(e,t){if(!this.iconsByUrl.has(e)){var r=document.createElement("DIV");r.innerHTML=t;var n=r.querySelector("svg");this.iconsByUrl.set(e,n)}},e.prototype.loadSvg=function(t){var r=this;if(this.iconsByUrl.has(t))return n.of(this.iconsByUrl.get(t));if(this.iconsLoadingByUrl.has(t))return this.iconsLoadingByUrl.get(t);var e=this.http.get(t,{responseType:"text"}).pipe(i.map(function(e){var t=document.createElement("DIV");return t.innerHTML=e,t.querySelector("svg")}),i.tap(function(e){return r.iconsByUrl.set(t,e)}),i.catchError(function(e){return console.error(e),n.throwError(e)}),i.finalize(function(){return r.iconsLoadingByUrl["delete"](t)}),i.share());return this.iconsLoadingByUrl.set(t,e),e},e.prototype.unloadSvg=function(e){this.iconsByUrl.has(e)&&this.iconsByUrl["delete"](e)},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:r.HttpClient}]},e}();function c(e,t){return e||new s(t)}var u={provide:s,deps:[[new t.Optional,new t.SkipSelf,s],r.HttpClient],useFactory:c};var a=function(){function e(e,t,r,n){this.element=e,this.differs=t,this.renderer=r,this.iconReg=n,this.stretch=!1}return Object.defineProperty(e.prototype,"svgStyle",{set:function(e){this._svgStyle=e,!this.differ&&e&&(this.differ=this.differs.find(e).create())},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.init()},e.prototype.ngOnDestroy=function(){this.destroy()},e.prototype.ngOnChanges=function(e){e.src&&(this.svg&&this.destroy(),this.init()),e.stretch&&this.stylize()},e.prototype.ngDoCheck=function(){if(this.svg&&this.differ){var e=this.differ.diff(this._svgStyle);e&&this.applyChanges(e)}},e.prototype.init=function(){var t=this;this.icnSub=this.iconReg.loadSvg(this.src).subscribe(function(e){t.setSvg(e),t.resetDiffer()})},e.prototype.destroy=function(){this.svg=undefined,this.differ=undefined,this.icnSub&&this.icnSub.unsubscribe()},e.prototype.resetDiffer=function(){this._svgStyle&&!this.differ&&(this.differ=this.differs.find(this._svgStyle).create())},e.prototype.setSvg=function(e){if(e){var t=(this.svg=e).cloneNode(!0),r=this.element.nativeElement;r.innerHTML="",this.renderer.appendChild(r,t),this.stylize()}},e.prototype.stylize=function(){if(this.svg){var e=this.element.nativeElement.firstChild;!0===this.stretch?this.renderer.setAttribute(e,"preserveAspectRatio","none"):!1===this.stretch&&this.renderer.removeAttribute(e,"preserveAspectRatio")}},e.prototype.applyChanges=function(e){var t=this;e.forEachRemovedItem(function(e){return t.setStyle(e.key,null)}),e.forEachAddedItem(function(e){return t.setStyle(e.key,e.currentValue)}),e.forEachChangedItem(function(e){return t.setStyle(e.key,e.currentValue)})},e.prototype.setStyle=function(e,t){var r=function u(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,i,o=r.call(e),s=[];try{for(;(void 0===t||0<t--)&&!(n=o.next()).done;)s.push(n.value)}catch(c){i={error:c}}finally{try{n&&!n.done&&(r=o["return"])&&r.call(o)}finally{if(i)throw i.error}}return s}(e.split("."),2),n=r[0],i=r[1];t=null!==t&&i?""+t+i:t;var o=this.element.nativeElement.firstChild;null!==t?this.renderer.setStyle(o,n,t):this.renderer.removeStyle(o,n)},e.decorators=[{type:t.Component,args:[{selector:"svg-icon",template:"<ng-content></ng-content>",styles:[":host { display: inline-block; }"]}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.KeyValueDiffers},{type:t.Renderer2},{type:s}]},e.propDecorators={src:[{type:t.Input}],stretch:[{type:t.Input}],svgStyle:[{type:t.Input}]},e}(),l=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{imports:[o.CommonModule],declarations:[a],providers:[u],exports:[a]}]}],e}();e.AngularSvgIconModule=l,e.SvgIconRegistryService=s,e.SVG_ICON_REGISTRY_PROVIDER_FACTORY=c,e.SVG_ICON_REGISTRY_PROVIDER=u,e.SvgIconComponent=a,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-svg-icon.umd.min.js.map

@@ -1,289 +0,10 @@

import { Injectable, Optional, SkipSelf, Component, ElementRef, Input, KeyValueDiffers, Renderer2, NgModule } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { of, throwError } from 'rxjs';
import { map, tap, catchError, finalize, share } from 'rxjs/operators';
import { CommonModule } from '@angular/common';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
class SvgIconRegistryService {
/**
* @param {?} http
*/
constructor(http) {
this.http = http;
this.iconsByUrl = new Map();
this.iconsLoadingByUrl = new Map();
}
/**
* Add a SVG to the registry by passing a name and the SVG.
* @param {?} name
* @param {?} data
* @return {?}
*/
addSvg(name, data) {
if (!this.iconsByUrl.has(name)) {
const /** @type {?} */ div = document.createElement('DIV');
div.innerHTML = data;
const /** @type {?} */ svg = /** @type {?} */ (div.querySelector('svg'));
this.iconsByUrl.set(name, svg);
}
}
/**
* Load a SVG to the registry from a URL.
* @param {?} url
* @return {?}
*/
loadSvg(url) {
if (this.iconsByUrl.has(url)) {
return of(this.iconsByUrl.get(url));
}
else if (this.iconsLoadingByUrl.has(url)) {
return this.iconsLoadingByUrl.get(url);
}
else {
const /** @type {?} */ o = /** @type {?} */ (this.http.get(url, { responseType: 'text' }).pipe(map(svg => {
const /** @type {?} */ div = document.createElement('DIV');
div.innerHTML = svg;
return /** @type {?} */ (div.querySelector('svg'));
}), tap(svg => this.iconsByUrl.set(url, svg)), catchError(err => {
console.error(err);
return throwError(err);
}), finalize(() => this.iconsLoadingByUrl.delete(url)), share()));
this.iconsLoadingByUrl.set(url, o);
return o;
}
}
/**
* Remove a SVG from the registry by URL (or name).
* @param {?} url
* @return {?}
*/
unloadSvg(url) {
if (this.iconsByUrl.has(url)) {
this.iconsByUrl.delete(url);
}
}
}
SvgIconRegistryService.decorators = [
{ type: Injectable },
];
/** @nocollapse */
SvgIconRegistryService.ctorParameters = () => [
{ type: HttpClient, },
];
/**
* @param {?} parentRegistry
* @param {?} http
* @return {?}
*/
function SVG_ICON_REGISTRY_PROVIDER_FACTORY(parentRegistry, http) {
return parentRegistry || new SvgIconRegistryService(http);
}
const SVG_ICON_REGISTRY_PROVIDER = {
provide: SvgIconRegistryService,
deps: [[new Optional(), new SkipSelf(), SvgIconRegistryService], HttpClient],
useFactory: SVG_ICON_REGISTRY_PROVIDER_FACTORY
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class SvgIconComponent {
/**
* @param {?} element
* @param {?} differs
* @param {?} renderer
* @param {?} iconReg
*/
constructor(element, differs, renderer, iconReg) {
this.element = element;
this.differs = differs;
this.renderer = renderer;
this.iconReg = iconReg;
this.stretch = false;
}
/**
* @param {?} v
* @return {?}
*/
set svgStyle(v) {
this._svgStyle = v;
if (!this.differ && v) {
this.differ = this.differs.find(v).create();
}
}
/**
* @return {?}
*/
ngOnInit() {
this.init();
}
/**
* @return {?}
*/
ngOnDestroy() {
this.destroy();
}
/**
* @param {?} changeRecord
* @return {?}
*/
ngOnChanges(changeRecord) {
if (changeRecord['src']) {
if (this.svg) {
this.destroy();
}
this.init();
}
if (changeRecord['stretch']) {
this.stylize();
}
}
/**
* @return {?}
*/
ngDoCheck() {
if (this.svg && this.differ) {
const /** @type {?} */ changes = this.differ.diff(this._svgStyle);
if (changes) {
this.applyChanges(changes);
}
}
}
/**
* @return {?}
*/
init() {
this.icnSub = this.iconReg.loadSvg(this.src).subscribe(svg => {
this.setSvg(svg);
this.resetDiffer();
});
}
/**
* @return {?}
*/
destroy() {
this.svg = undefined;
this.differ = undefined;
if (this.icnSub) {
this.icnSub.unsubscribe();
}
}
/**
* @return {?}
*/
resetDiffer() {
if (this._svgStyle && !this.differ) {
this.differ = this.differs.find(this._svgStyle).create();
}
}
/**
* @param {?} svg
* @return {?}
*/
setSvg(svg) {
if (svg) {
this.svg = svg;
const /** @type {?} */ icon = /** @type {?} */ (svg.cloneNode(true));
const /** @type {?} */ elem = this.element.nativeElement;
elem.innerHTML = '';
this.renderer.appendChild(elem, icon);
this.stylize();
}
}
/**
* @return {?}
*/
stylize() {
if (this.svg) {
const /** @type {?} */ svg = this.element.nativeElement.firstChild;
if (this.stretch === true) {
this.renderer.setAttribute(svg, 'preserveAspectRatio', 'none');
}
else if (this.stretch === false) {
this.renderer.removeAttribute(svg, 'preserveAspectRatio');
}
}
}
/**
* @param {?} changes
* @return {?}
*/
applyChanges(changes) {
changes.forEachRemovedItem((record) => this.setStyle(record.key, null));
changes.forEachAddedItem((record) => this.setStyle(record.key, record.currentValue));
changes.forEachChangedItem((record) => this.setStyle(record.key, record.currentValue));
}
/**
* @param {?} nameAndUnit
* @param {?} value
* @return {?}
*/
setStyle(nameAndUnit, value) {
const [name, unit] = nameAndUnit.split('.');
value = value !== null && unit ? `${value}${unit}` : value;
const /** @type {?} */ svg = this.element.nativeElement.firstChild;
if (value !== null) {
this.renderer.setStyle(svg, name, /** @type {?} */ (value));
}
else {
this.renderer.removeStyle(svg, name);
}
}
}
SvgIconComponent.decorators = [
{ type: Component, args: [{
selector: 'svg-icon',
styles: [`:host { display: inline-block; }`],
template: '<ng-content></ng-content>'
},] },
];
/** @nocollapse */
SvgIconComponent.ctorParameters = () => [
{ type: ElementRef, },
{ type: KeyValueDiffers, },
{ type: Renderer2, },
{ type: SvgIconRegistryService, },
];
SvgIconComponent.propDecorators = {
"src": [{ type: Input },],
"stretch": [{ type: Input },],
"svgStyle": [{ type: Input },],
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class AngularSvgIconModule {
}
AngularSvgIconModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule,
],
declarations: [SvgIconComponent],
providers: [SVG_ICON_REGISTRY_PROVIDER],
exports: [SvgIconComponent]
},] },
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* Generated bundle index. Do not edit.
*/
export { AngularSvgIconModule, SvgIconRegistryService, SVG_ICON_REGISTRY_PROVIDER_FACTORY, SVG_ICON_REGISTRY_PROVIDER, SvgIconComponent } from './index';
export { AngularSvgIconModule, SvgIconRegistryService, SVG_ICON_REGISTRY_PROVIDER_FACTORY, SVG_ICON_REGISTRY_PROVIDER, SvgIconComponent };
//# sourceMappingURL=angular-svg-icon.js.map
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdmctaWNvbi5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3ZnLWljb24vIiwic291cmNlcyI6WyJhbmd1bGFyLXN2Zy1pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSwrSUFBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19

@@ -1,201 +0,10 @@

import { __read } from 'tslib';
import { Injectable, Optional, SkipSelf, Component, ElementRef, Input, KeyValueDiffers, Renderer2, NgModule } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { of, throwError } from 'rxjs';
import { map, tap, catchError, finalize, share } from 'rxjs/operators';
import { CommonModule } from '@angular/common';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* Generated bundle index. Do not edit.
*/
export { AngularSvgIconModule, SvgIconRegistryService, SVG_ICON_REGISTRY_PROVIDER_FACTORY, SVG_ICON_REGISTRY_PROVIDER, SvgIconComponent } from './index';
var SvgIconRegistryService = /** @class */ (function () {
function SvgIconRegistryService(http) {
this.http = http;
this.iconsByUrl = new Map();
this.iconsLoadingByUrl = new Map();
}
SvgIconRegistryService.prototype.addSvg = function (name, data) {
if (!this.iconsByUrl.has(name)) {
var div = document.createElement('DIV');
div.innerHTML = data;
var svg = (div.querySelector('svg'));
this.iconsByUrl.set(name, svg);
}
};
SvgIconRegistryService.prototype.loadSvg = function (url) {
var _this = this;
if (this.iconsByUrl.has(url)) {
return of(this.iconsByUrl.get(url));
}
else if (this.iconsLoadingByUrl.has(url)) {
return this.iconsLoadingByUrl.get(url);
}
else {
var o = (this.http.get(url, { responseType: 'text' }).pipe(map(function (svg) {
var div = document.createElement('DIV');
div.innerHTML = svg;
return (div.querySelector('svg'));
}), tap(function (svg) { return _this.iconsByUrl.set(url, svg); }), catchError(function (err) {
console.error(err);
return throwError(err);
}), finalize(function () { return _this.iconsLoadingByUrl.delete(url); }), share()));
this.iconsLoadingByUrl.set(url, o);
return o;
}
};
SvgIconRegistryService.prototype.unloadSvg = function (url) {
if (this.iconsByUrl.has(url)) {
this.iconsByUrl.delete(url);
}
};
return SvgIconRegistryService;
}());
SvgIconRegistryService.decorators = [
{ type: Injectable },
];
SvgIconRegistryService.ctorParameters = function () { return [
{ type: HttpClient, },
]; };
function SVG_ICON_REGISTRY_PROVIDER_FACTORY(parentRegistry, http) {
return parentRegistry || new SvgIconRegistryService(http);
}
var SVG_ICON_REGISTRY_PROVIDER = {
provide: SvgIconRegistryService,
deps: [[new Optional(), new SkipSelf(), SvgIconRegistryService], HttpClient],
useFactory: SVG_ICON_REGISTRY_PROVIDER_FACTORY
};
var SvgIconComponent = /** @class */ (function () {
function SvgIconComponent(element, differs, renderer, iconReg) {
this.element = element;
this.differs = differs;
this.renderer = renderer;
this.iconReg = iconReg;
this.stretch = false;
}
Object.defineProperty(SvgIconComponent.prototype, "svgStyle", {
set: function (v) {
this._svgStyle = v;
if (!this.differ && v) {
this.differ = this.differs.find(v).create();
}
},
enumerable: true,
configurable: true
});
SvgIconComponent.prototype.ngOnInit = function () {
this.init();
};
SvgIconComponent.prototype.ngOnDestroy = function () {
this.destroy();
};
SvgIconComponent.prototype.ngOnChanges = function (changeRecord) {
if (changeRecord['src']) {
if (this.svg) {
this.destroy();
}
this.init();
}
if (changeRecord['stretch']) {
this.stylize();
}
};
SvgIconComponent.prototype.ngDoCheck = function () {
if (this.svg && this.differ) {
var changes = this.differ.diff(this._svgStyle);
if (changes) {
this.applyChanges(changes);
}
}
};
SvgIconComponent.prototype.init = function () {
var _this = this;
this.icnSub = this.iconReg.loadSvg(this.src).subscribe(function (svg) {
_this.setSvg(svg);
_this.resetDiffer();
});
};
SvgIconComponent.prototype.destroy = function () {
this.svg = undefined;
this.differ = undefined;
if (this.icnSub) {
this.icnSub.unsubscribe();
}
};
SvgIconComponent.prototype.resetDiffer = function () {
if (this._svgStyle && !this.differ) {
this.differ = this.differs.find(this._svgStyle).create();
}
};
SvgIconComponent.prototype.setSvg = function (svg) {
if (svg) {
this.svg = svg;
var icon = (svg.cloneNode(true));
var elem = this.element.nativeElement;
elem.innerHTML = '';
this.renderer.appendChild(elem, icon);
this.stylize();
}
};
SvgIconComponent.prototype.stylize = function () {
if (this.svg) {
var svg = this.element.nativeElement.firstChild;
if (this.stretch === true) {
this.renderer.setAttribute(svg, 'preserveAspectRatio', 'none');
}
else if (this.stretch === false) {
this.renderer.removeAttribute(svg, 'preserveAspectRatio');
}
}
};
SvgIconComponent.prototype.applyChanges = function (changes) {
var _this = this;
changes.forEachRemovedItem(function (record) { return _this.setStyle(record.key, null); });
changes.forEachAddedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
changes.forEachChangedItem(function (record) { return _this.setStyle(record.key, record.currentValue); });
};
SvgIconComponent.prototype.setStyle = function (nameAndUnit, value) {
var _a = __read(nameAndUnit.split('.'), 2), name = _a[0], unit = _a[1];
value = value !== null && unit ? "" + value + unit : value;
var svg = this.element.nativeElement.firstChild;
if (value !== null) {
this.renderer.setStyle(svg, name, (value));
}
else {
this.renderer.removeStyle(svg, name);
}
};
return SvgIconComponent;
}());
SvgIconComponent.decorators = [
{ type: Component, args: [{
selector: 'svg-icon',
styles: [":host { display: inline-block; }"],
template: '<ng-content></ng-content>'
},] },
];
SvgIconComponent.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: KeyValueDiffers, },
{ type: Renderer2, },
{ type: SvgIconRegistryService, },
]; };
SvgIconComponent.propDecorators = {
"src": [{ type: Input },],
"stretch": [{ type: Input },],
"svgStyle": [{ type: Input },],
};
var AngularSvgIconModule = /** @class */ (function () {
function AngularSvgIconModule() {
}
return AngularSvgIconModule;
}());
AngularSvgIconModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule,
],
declarations: [SvgIconComponent],
providers: [SVG_ICON_REGISTRY_PROVIDER],
exports: [SvgIconComponent]
},] },
];
export { AngularSvgIconModule, SvgIconRegistryService, SVG_ICON_REGISTRY_PROVIDER_FACTORY, SVG_ICON_REGISTRY_PROVIDER, SvgIconComponent };
//# sourceMappingURL=angular-svg-icon.js.map
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdmctaWNvbi5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3ZnLWljb24vIiwic291cmNlcyI6WyJhbmd1bGFyLXN2Zy1pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSwrSUFBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
{
"$schema": "../../node_modules/ng-packagr/package.schema.json",
"name": "angular-svg-icon",
"description": "Angular 6 component for inlining SVGs allowing them to be easily styled with CSS.",
"version": "6.0.0",
"description": "Angular 6+ component for inlining SVGs allowing them to be easily styled with CSS.",
"version": "6.0.1",
"repository": {

@@ -18,11 +18,16 @@ "type": "git",

"peerDependencies": {
"@angular/core": "^6.0.0",
"@angular/common": "^6.0.0",
"rxjs": "^6.0.0"
"@angular/core": ">=6.0.0",
"@angular/common": ">=6.0.0",
"rxjs": ">=6.0.0"
},
"main": "bundles/angular-svg-icon.umd.js",
"module": "esm5/angular-svg-icon.js",
"es2015": "esm2015/angular-svg-icon.js",
"module": "fesm5/angular-svg-icon.js",
"es2015": "fesm2015/angular-svg-icon.js",
"esm5": "esm5/angular-svg-icon.js",
"esm2015": "esm2015/angular-svg-icon.js",
"fesm5": "fesm5/angular-svg-icon.js",
"fesm2015": "fesm2015/angular-svg-icon.js",
"typings": "angular-svg-icon.d.ts",
"metadata": "angular-svg-icon.metadata.json",
"sideEffects": false,
"dependencies": {

@@ -29,0 +34,0 @@ "tslib": "^1.9.0"

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc