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 11.0.0 to 11.1.0

7

bundles/angular-svg-icon.umd.js

@@ -470,2 +470,9 @@ (function (global, factory) {

if (changeRecord.klass) {
var elem = this.element.nativeElement;
if (changeRecord.klass.previousValue) {
this.renderer.removeClass(elem, changeRecord.klass.previousValue);
}
if (changeRecord.klass.currentValue) {
this.renderer.addClass(elem, changeRecord.klass.currentValue);
}
if (this.applyClass) {

@@ -472,0 +479,0 @@ this.setClass(changeRecord.klass.previousValue, changeRecord.klass.currentValue);

4

bundles/angular-svg-icon.umd.min.js

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

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common"),require("rxjs"),require("rxjs/operators"),require("@angular/common/http")):"function"==typeof define&&define.amd?define("angular-svg-icon",["exports","@angular/core","@angular/common","rxjs","rxjs/operators","@angular/common/http"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["angular-svg-icon"]={},t.ng.core,t.ng.common,t.rxjs,t.rxjs.operators,t.ng.common.http)}(this,(function(t,e,r,n,i,s){"use strict";
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common"),require("rxjs"),require("rxjs/operators"),require("@angular/common/http")):"function"==typeof define&&define.amd?define("angular-svg-icon",["exports","@angular/core","@angular/common","rxjs","rxjs/operators","@angular/common/http"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["angular-svg-icon"]={},t.ng.core,t.ng.common,t.rxjs,t.rxjs.operators,t.ng.common.http)}(this,(function(t,e,r,s,n,i){"use strict";
/*! *****************************************************************************

@@ -15,3 +15,3 @@ Copyright (c) Microsoft Corporation.

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */var o=function(t,e){return(o=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)e.hasOwnProperty(r)&&(t[r]=e[r])})(t,e)};Object.create;function a(t){var e="function"==typeof Symbol&&Symbol.iterator,r=e&&t[e],n=0;if(r)return r.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&n>=t.length&&(t=void 0),{value:t&&t[n++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function l(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var n,i,s=r.call(t),o=[];try{for(;(void 0===e||e-- >0)&&!(n=s.next()).done;)o.push(n.value)}catch(t){i={error:t}}finally{try{n&&!n.done&&(r=s.return)&&r.call(s)}finally{if(i)throw i.error}}return o}Object.create;var c=function(){},h=function(t){function e(e){var r=t.call(this)||this;return r.http=e,r}return function(t,e){function r(){this.constructor=t}o(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}(e,t),e.prototype.getSvg=function(t){return this.http.get(t,{responseType:"text"})},e}(c);h.decorators=[{type:e.Injectable}],h.ctorParameters=function(){return[{type:s.HttpClient}]};var u=new e.InjectionToken("SERVER_URL"),p=function(){function t(t,e,r,n){this.loader=t,this.platformId=e,this.serverUrl=r,this._document=n,this.iconsByUrl=new Map,this.iconsLoadingByUrl=new Map,this.document=this._document}return t.prototype.addSvg=function(t,e){if(!this.iconsByUrl.has(t)){var r=this.document.createElement("DIV");r.innerHTML=e;var n=r.querySelector("svg");this.iconsByUrl.set(t,n)}},t.prototype.loadSvg=function(t,e){var r=this;if(void 0===e&&(e=t),this.serverUrl&&null===t.match(/^(http(s)?):/)&&(t=this.serverUrl+t,e=t),this.iconsByUrl.has(e))return n.of(this.iconsByUrl.get(e));if(this.iconsLoadingByUrl.has(e))return this.iconsLoadingByUrl.get(e);var s=this.loader.getSvg(t).pipe(i.map((function(t){var e=r.document.createElement("DIV");return e.innerHTML=t,e.querySelector("svg")})),i.tap((function(t){return r.iconsByUrl.set(e,t)})),i.catchError((function(t){return console.error(t),n.throwError(t)})),i.finalize((function(){return r.iconsLoadingByUrl.delete(e)})),i.share());return this.iconsLoadingByUrl.set(e,s),s},t.prototype.getSvgByName=function(t){return this.iconsByUrl.has(t)?n.of(this.iconsByUrl.get(t)):this.iconsLoadingByUrl.has(t)?this.iconsLoadingByUrl.get(t):n.throwError("No svg with name '"+t+"' has been loaded")},t.prototype.unloadSvg=function(t){this.iconsByUrl.has(t)&&this.iconsByUrl.delete(t)},t}();function d(t,e,r,n,i){return t||new p(e,r,n,i)}p.decorators=[{type:e.Injectable}],p.ctorParameters=function(){return[{type:c},{type:Object,decorators:[{type:e.Inject,args:[e.PLATFORM_ID]}]},{type:String,decorators:[{type:e.Optional},{type:e.Inject,args:[u]}]},{type:void 0,decorators:[{type:e.Optional},{type:e.Inject,args:[r.DOCUMENT]}]}]};var f={provide:p,deps:[[new e.Optional,new e.SkipSelf,p],c,[e.PLATFORM_ID],[new e.Optional,u],[new e.Optional,r.DOCUMENT]],useFactory:d},y=function(){function t(t,e,r,n,i){this.element=t,this.differs=e,this.renderer=r,this.iconReg=n,this.cdr=i,this.stretch=!1,this.applyClass=!1,this.applyCss=!1,this.loaded=!1}return Object.defineProperty(t.prototype,"svgStyle",{set:function(t){this._svgStyle=t,!this.differ&&t&&(this.differ=this.differs.find(t).create())},enumerable:!1,configurable:!0}),t.prototype.ngOnInit=function(){this.init()},t.prototype.ngOnDestroy=function(){this.destroy()},t.prototype.ngOnChanges=function(t){(t.src||t.name)&&(this.loaded&&this.destroy(),this.init()),t.stretch&&this.stylize(),t.applyClass&&(this.applyClass?this.setClass(null,this.klass):this.setClass(this.klass,null)),t.svgClass&&this.setClass(t.svgClass.previousValue,t.svgClass.currentValue),t.klass&&(this.applyClass?this.setClass(t.klass.previousValue,t.klass.currentValue):this.setClass(t.klass.previousValue,null)),t.viewBox&&(this.loaded&&this.destroy(),this.init()),t.applyCss&&(console.warn("applyCss deprecated since 9.1.0, will be removed in 10.0.0"),console.warn("use applyClass instead"))},t.prototype.ngDoCheck=function(){if(this.svg&&this.differ){var t=this.differ.diff(this._svgStyle);t&&this.applyChanges(t)}},t.prototype.init=function(){if(this.name)this.icnSub=this.iconReg.getSvgByName(this.name).subscribe(this.initSvg.bind(this));else if(this.src)this.icnSub=this.iconReg.loadSvg(this.src).subscribe(this.initSvg.bind(this));else{this.element.nativeElement.innerHTML="",this.cdr.markForCheck()}},t.prototype.initSvg=function(t){this.loaded||(this.setSvg(t),this.resetDiffer())},t.prototype.destroy=function(){this.svg=void 0,this.differ=void 0,this.loaded=!1,this.icnSub&&this.icnSub.unsubscribe()},t.prototype.resetDiffer=function(){this._svgStyle&&!this.differ&&(this.differ=this.differs.find(this._svgStyle).create())},t.prototype.setSvg=function(t){if(!this.loaded&&t){this.svg=t;var e=t.cloneNode(!0),r=this.element.nativeElement;if(this.copyNgContentAttribute(r,e),this.klass&&this.applyClass&&this.renderer.setAttribute(e,"class",this.klass),this.svgClass&&this.renderer.setAttribute(e,"class",this.svgClass),this.viewBox)if("auto"===this.viewBox){var n=e.getAttribute("width"),i=e.getAttribute("height");if(i&&n){var s="0 0 "+n+" "+i;this.renderer.setAttribute(e,"viewBox",s),this.renderer.removeAttribute(e,"width"),this.renderer.removeAttribute(e,"height")}}else""!==this.viewBox&&(this.renderer.setAttribute(e,"viewBox",this.viewBox),this.renderer.removeAttribute(e,"width"),this.renderer.removeAttribute(e,"height"));r.innerHTML="",this.renderer.appendChild(r,e),this.loaded=!0,this.stylize(),this.cdr.markForCheck()}},t.prototype.copyNgContentAttribute=function(t,e){for(var r=t.attributes,n=r.length,i=0;i<n;i+=1){var s=r.item(i);if(s.name.startsWith("_ngcontent")){this.setNgContentAttribute(e,s.name);break}}},t.prototype.setNgContentAttribute=function(t,e){this.renderer.setAttribute(t,e,"");for(var r=t.childNodes.length,n=0;n<r;n+=1){var i=t.childNodes[n];i instanceof Element&&this.setNgContentAttribute(i,e)}},t.prototype.stylize=function(){if(this.svg){var t=this.element.nativeElement.firstChild;!0===this.stretch?this.renderer.setAttribute(t,"preserveAspectRatio","none"):!1===this.stretch&&this.renderer.removeAttribute(t,"preserveAspectRatio")}},t.prototype.applyChanges=function(t){var e=this;t.forEachRemovedItem((function(t){return e.setStyle(t.key,null)})),t.forEachAddedItem((function(t){return e.setStyle(t.key,t.currentValue)})),t.forEachChangedItem((function(t){return e.setStyle(t.key,t.currentValue)}))},t.prototype.setStyle=function(t,e){var r=l(t.split("."),2),n=r[0],i=r[1];e=null!==e&&i?""+e+i:e;var s=this.element.nativeElement.firstChild;null!==e?this.renderer.setStyle(s,n,e):this.renderer.removeStyle(s,n)},t.prototype.setClass=function(t,e){var r,n,i=this.element.nativeElement.firstChild;if(i&&(t&&this.renderer.removeClass(i,t),e)){var s=e.split(" ");try{for(var o=a(s),l=o.next();!l.done;l=o.next()){var c=l.value;this.renderer.addClass(i,c)}}catch(t){r={error:t}}finally{try{l&&!l.done&&(n=o.return)&&n.call(o)}finally{if(r)throw r.error}}}},t}();y.decorators=[{type:e.Component,args:[{selector:"svg-icon",template:"<ng-content></ng-content>"}]}],y.ctorParameters=function(){return[{type:e.ElementRef},{type:e.KeyValueDiffers},{type:e.Renderer2},{type:p},{type:e.ChangeDetectorRef}]},y.propDecorators={src:[{type:e.Input}],name:[{type:e.Input}],stretch:[{type:e.Input}],applyClass:[{type:e.Input}],applyCss:[{type:e.Input}],svgClass:[{type:e.Input}],klass:[{type:e.Input,args:["class"]}],viewBox:[{type:e.Input}],svgStyle:[{type:e.Input}]};var v=function(){function t(){}return t.forRoot=function(e){return void 0===e&&(e={}),{ngModule:t,providers:[f,e.loader||{provide:c,useClass:h}]}},t}();v.decorators=[{type:e.NgModule,args:[{imports:[r.CommonModule],declarations:[y],exports:[y]}]}],t.AngularSvgIconModule=v,t.SERVER_URL=u,t.SVG_ICON_REGISTRY_PROVIDER=f,t.SVG_ICON_REGISTRY_PROVIDER_FACTORY=d,t.SvgHttpLoader=h,t.SvgIconComponent=y,t.SvgIconRegistryService=p,t.SvgLoader=c,Object.defineProperty(t,"__esModule",{value:!0})}));
***************************************************************************** */var o=function(t,e){return(o=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)e.hasOwnProperty(r)&&(t[r]=e[r])})(t,e)};Object.create;function a(t){var e="function"==typeof Symbol&&Symbol.iterator,r=e&&t[e],s=0;if(r)return r.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&s>=t.length&&(t=void 0),{value:t&&t[s++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function l(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var s,n,i=r.call(t),o=[];try{for(;(void 0===e||e-- >0)&&!(s=i.next()).done;)o.push(s.value)}catch(t){n={error:t}}finally{try{s&&!s.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return o}Object.create;var c=function(){},h=function(t){function e(e){var r=t.call(this)||this;return r.http=e,r}return function(t,e){function r(){this.constructor=t}o(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}(e,t),e.prototype.getSvg=function(t){return this.http.get(t,{responseType:"text"})},e}(c);h.decorators=[{type:e.Injectable}],h.ctorParameters=function(){return[{type:i.HttpClient}]};var u=new e.InjectionToken("SERVER_URL"),p=function(){function t(t,e,r,s){this.loader=t,this.platformId=e,this.serverUrl=r,this._document=s,this.iconsByUrl=new Map,this.iconsLoadingByUrl=new Map,this.document=this._document}return t.prototype.addSvg=function(t,e){if(!this.iconsByUrl.has(t)){var r=this.document.createElement("DIV");r.innerHTML=e;var s=r.querySelector("svg");this.iconsByUrl.set(t,s)}},t.prototype.loadSvg=function(t,e){var r=this;if(void 0===e&&(e=t),this.serverUrl&&null===t.match(/^(http(s)?):/)&&(t=this.serverUrl+t,e=t),this.iconsByUrl.has(e))return s.of(this.iconsByUrl.get(e));if(this.iconsLoadingByUrl.has(e))return this.iconsLoadingByUrl.get(e);var i=this.loader.getSvg(t).pipe(n.map((function(t){var e=r.document.createElement("DIV");return e.innerHTML=t,e.querySelector("svg")})),n.tap((function(t){return r.iconsByUrl.set(e,t)})),n.catchError((function(t){return console.error(t),s.throwError(t)})),n.finalize((function(){return r.iconsLoadingByUrl.delete(e)})),n.share());return this.iconsLoadingByUrl.set(e,i),i},t.prototype.getSvgByName=function(t){return this.iconsByUrl.has(t)?s.of(this.iconsByUrl.get(t)):this.iconsLoadingByUrl.has(t)?this.iconsLoadingByUrl.get(t):s.throwError("No svg with name '"+t+"' has been loaded")},t.prototype.unloadSvg=function(t){this.iconsByUrl.has(t)&&this.iconsByUrl.delete(t)},t}();function d(t,e,r,s,n){return t||new p(e,r,s,n)}p.decorators=[{type:e.Injectable}],p.ctorParameters=function(){return[{type:c},{type:Object,decorators:[{type:e.Inject,args:[e.PLATFORM_ID]}]},{type:String,decorators:[{type:e.Optional},{type:e.Inject,args:[u]}]},{type:void 0,decorators:[{type:e.Optional},{type:e.Inject,args:[r.DOCUMENT]}]}]};var f={provide:p,deps:[[new e.Optional,new e.SkipSelf,p],c,[e.PLATFORM_ID],[new e.Optional,u],[new e.Optional,r.DOCUMENT]],useFactory:d},y=function(){function t(t,e,r,s,n){this.element=t,this.differs=e,this.renderer=r,this.iconReg=s,this.cdr=n,this.stretch=!1,this.applyClass=!1,this.applyCss=!1,this.loaded=!1}return Object.defineProperty(t.prototype,"svgStyle",{set:function(t){this._svgStyle=t,!this.differ&&t&&(this.differ=this.differs.find(t).create())},enumerable:!1,configurable:!0}),t.prototype.ngOnInit=function(){this.init()},t.prototype.ngOnDestroy=function(){this.destroy()},t.prototype.ngOnChanges=function(t){if((t.src||t.name)&&(this.loaded&&this.destroy(),this.init()),t.stretch&&this.stylize(),t.applyClass&&(this.applyClass?this.setClass(null,this.klass):this.setClass(this.klass,null)),t.svgClass&&this.setClass(t.svgClass.previousValue,t.svgClass.currentValue),t.klass){var e=this.element.nativeElement;t.klass.previousValue&&this.renderer.removeClass(e,t.klass.previousValue),t.klass.currentValue&&this.renderer.addClass(e,t.klass.currentValue),this.applyClass?this.setClass(t.klass.previousValue,t.klass.currentValue):this.setClass(t.klass.previousValue,null)}t.viewBox&&(this.loaded&&this.destroy(),this.init()),t.applyCss&&(console.warn("applyCss deprecated since 9.1.0, will be removed in 10.0.0"),console.warn("use applyClass instead"))},t.prototype.ngDoCheck=function(){if(this.svg&&this.differ){var t=this.differ.diff(this._svgStyle);t&&this.applyChanges(t)}},t.prototype.init=function(){if(this.name)this.icnSub=this.iconReg.getSvgByName(this.name).subscribe(this.initSvg.bind(this));else if(this.src)this.icnSub=this.iconReg.loadSvg(this.src).subscribe(this.initSvg.bind(this));else{this.element.nativeElement.innerHTML="",this.cdr.markForCheck()}},t.prototype.initSvg=function(t){this.loaded||(this.setSvg(t),this.resetDiffer())},t.prototype.destroy=function(){this.svg=void 0,this.differ=void 0,this.loaded=!1,this.icnSub&&this.icnSub.unsubscribe()},t.prototype.resetDiffer=function(){this._svgStyle&&!this.differ&&(this.differ=this.differs.find(this._svgStyle).create())},t.prototype.setSvg=function(t){if(!this.loaded&&t){this.svg=t;var e=t.cloneNode(!0),r=this.element.nativeElement;if(this.copyNgContentAttribute(r,e),this.klass&&this.applyClass&&this.renderer.setAttribute(e,"class",this.klass),this.svgClass&&this.renderer.setAttribute(e,"class",this.svgClass),this.viewBox)if("auto"===this.viewBox){var s=e.getAttribute("width"),n=e.getAttribute("height");if(n&&s){var i="0 0 "+s+" "+n;this.renderer.setAttribute(e,"viewBox",i),this.renderer.removeAttribute(e,"width"),this.renderer.removeAttribute(e,"height")}}else""!==this.viewBox&&(this.renderer.setAttribute(e,"viewBox",this.viewBox),this.renderer.removeAttribute(e,"width"),this.renderer.removeAttribute(e,"height"));r.innerHTML="",this.renderer.appendChild(r,e),this.loaded=!0,this.stylize(),this.cdr.markForCheck()}},t.prototype.copyNgContentAttribute=function(t,e){for(var r=t.attributes,s=r.length,n=0;n<s;n+=1){var i=r.item(n);if(i.name.startsWith("_ngcontent")){this.setNgContentAttribute(e,i.name);break}}},t.prototype.setNgContentAttribute=function(t,e){this.renderer.setAttribute(t,e,"");for(var r=t.childNodes.length,s=0;s<r;s+=1){var n=t.childNodes[s];n instanceof Element&&this.setNgContentAttribute(n,e)}},t.prototype.stylize=function(){if(this.svg){var t=this.element.nativeElement.firstChild;!0===this.stretch?this.renderer.setAttribute(t,"preserveAspectRatio","none"):!1===this.stretch&&this.renderer.removeAttribute(t,"preserveAspectRatio")}},t.prototype.applyChanges=function(t){var e=this;t.forEachRemovedItem((function(t){return e.setStyle(t.key,null)})),t.forEachAddedItem((function(t){return e.setStyle(t.key,t.currentValue)})),t.forEachChangedItem((function(t){return e.setStyle(t.key,t.currentValue)}))},t.prototype.setStyle=function(t,e){var r=l(t.split("."),2),s=r[0],n=r[1];e=null!==e&&n?""+e+n:e;var i=this.element.nativeElement.firstChild;null!==e?this.renderer.setStyle(i,s,e):this.renderer.removeStyle(i,s)},t.prototype.setClass=function(t,e){var r,s,n=this.element.nativeElement.firstChild;if(n&&(t&&this.renderer.removeClass(n,t),e)){var i=e.split(" ");try{for(var o=a(i),l=o.next();!l.done;l=o.next()){var c=l.value;this.renderer.addClass(n,c)}}catch(t){r={error:t}}finally{try{l&&!l.done&&(s=o.return)&&s.call(o)}finally{if(r)throw r.error}}}},t}();y.decorators=[{type:e.Component,args:[{selector:"svg-icon",template:"<ng-content></ng-content>"}]}],y.ctorParameters=function(){return[{type:e.ElementRef},{type:e.KeyValueDiffers},{type:e.Renderer2},{type:p},{type:e.ChangeDetectorRef}]},y.propDecorators={src:[{type:e.Input}],name:[{type:e.Input}],stretch:[{type:e.Input}],applyClass:[{type:e.Input}],applyCss:[{type:e.Input}],svgClass:[{type:e.Input}],klass:[{type:e.Input,args:["class"]}],viewBox:[{type:e.Input}],svgStyle:[{type:e.Input}]};var v=function(){function t(){}return t.forRoot=function(e){return void 0===e&&(e={}),{ngModule:t,providers:[f,e.loader||{provide:c,useClass:h}]}},t}();v.decorators=[{type:e.NgModule,args:[{imports:[r.CommonModule],declarations:[y],exports:[y]}]}],t.AngularSvgIconModule=v,t.SERVER_URL=u,t.SVG_ICON_REGISTRY_PROVIDER=f,t.SVG_ICON_REGISTRY_PROVIDER_FACTORY=d,t.SvgHttpLoader=h,t.SvgIconComponent=y,t.SvgIconRegistryService=p,t.SvgLoader=c,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=angular-svg-icon.umd.min.js.map

@@ -51,2 +51,9 @@ import { ChangeDetectorRef, Component, ElementRef, Input, KeyValueDiffers, Renderer2 } from '@angular/core';

if (changeRecord.klass) {
const elem = this.element.nativeElement;
if (changeRecord.klass.previousValue) {
this.renderer.removeClass(elem, changeRecord.klass.previousValue);
}
if (changeRecord.klass.currentValue) {
this.renderer.addClass(elem, changeRecord.klass.currentValue);
}
if (this.applyClass) {

@@ -234,2 +241,2 @@ this.setClass(changeRecord.klass.previousValue, changeRecord.klass.currentValue);

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg-icon.component.js","sourceRoot":"../../../../projects/angular-svg-icon/src/","sources":["lib/svg-icon.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAW,UAAU,EAAE,KAAK,EACT,eAAe,EACxC,SAAS,EAAiB,MAAM,eAAe,CAAC;AAI/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAMrE,MAAM,OAAO,gBAAgB;IA2B5B,YACS,OAAmB,EACnB,OAAwB,EACxB,QAAmB,EACnB,OAA+B,EAC/B,GAAsB;QAJtB,YAAO,GAAP,OAAO,CAAY;QACnB,YAAO,GAAP,OAAO,CAAiB;QACxB,aAAQ,GAAR,QAAQ,CAAW;QACnB,YAAO,GAAP,OAAO,CAAwB;QAC/B,QAAG,GAAH,GAAG,CAAmB;QA7BtB,YAAO,GAAG,KAAK,CAAC;QAChB,eAAU,GAAG,KAAK,CAAC;QAC5B,8BAA8B;QACrB,aAAQ,GAAG,KAAK,CAAC;QAmBlB,WAAM,GAAG,KAAK,CAAC;IAQvB,CAAC;IArBD,uBAAuB;IACvB,IACI,QAAQ,CAAC,CAA2B;QACvC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE;YACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;SAC5C;IACF,CAAC;IAgBD,QAAQ;QACP,IAAI,CAAC,IAAI,EAAE,CAAC;IACb,CAAC;IAED,WAAW;QACV,IAAI,CAAC,OAAO,EAAE,CAAC;IAChB,CAAC;IAED,WAAW,CAAC,YAA2B;QACtC,IAAI,YAAY,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,EAAE;YAC1C,IAAI,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,CAAC,OAAO,EAAE,CAAC;aACf;YACD,IAAI,CAAC,IAAI,EAAE,CAAC;SACZ;QACD,IAAI,YAAY,CAAC,OAAO,EAAE;YACzB,IAAI,CAAC,OAAO,EAAE,CAAC;SACf;QAED,IAAI,YAAY,CAAC,UAAU,EAAE;YAC5B,IAAI,IAAI,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aAChC;iBAAM;gBACN,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;aAChC;SACD;QAED,IAAI,YAAY,CAAC,QAAQ,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,EAAE,YAAY,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;SACvF;QAED,IAAI,YAAY,CAAC,KAAK,EAAE;YACvB,IAAI,IAAI,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,EAAE,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;aACjF;iBAAM;gBACN,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;aACtD;SACD;QAED,IAAI,YAAY,CAAC,OAAO,EAAE;YACzB,IAAI,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,CAAC,OAAO,EAAE,CAAC;aACf;YACD,IAAI,CAAC,IAAI,EAAE,CAAC;SACZ;QACD,IAAI,YAAY,CAAC,QAAQ,EAAE;YAC1B,OAAO,CAAC,IAAI,CAAC,4DAA4D,CAAC,CAAC;YAC3E,OAAO,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;SACvC;IACF,CAAC;IAED,SAAS;QACR,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACjD,IAAI,OAAO,EAAE;gBACZ,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;aAC3B;SACD;IACF,CAAC;IAEO,IAAI;QACX,IAAI,IAAI,CAAC,IAAI,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SACtF;aAAM,IAAI,IAAI,CAAC,GAAG,EAAE;YACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SAChF;aAAM;YACN,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YACxC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACpB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;SACxB;IACF,CAAC;IAEO,OAAO,CAAC,GAAe;QAC9B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACjB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,CAAC,WAAW,EAAE,CAAC;SACnB;IACF,CAAC;IAEO,OAAO;QACd,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;SAC1B;IACF,CAAC;IAEO,WAAW;QAClB,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACnC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC;SACzD;IACF,CAAC;IAEO,MAAM,CAAC,GAAe;QAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,GAAG,EAAE;YACxB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;YACf,MAAM,IAAI,GAAG,GAAG,CAAC,SAAS,CAAC,IAAI,CAAe,CAAC;YAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAGxC,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAExC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE;gBAClC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACtD;YAED,IAAI,IAAI,CAAC,QAAQ,EAAE;gBAClB,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aACzD;YAED,IAAI,IAAI,CAAC,OAAO,EAAE;gBACjB,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE;oBAC5B,kDAAkD;oBAClD,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;oBACrC,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;oBACtC,IAAI,CAAC,IAAI,CAAC,EAAE;wBACX,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;wBAC3B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;wBAChD,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;wBAC7C,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;qBAC9C;iBACD;qBAAM,IAAI,IAAI,CAAC,OAAO,KAAK,EAAE,EAAE;oBAC/B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;oBAC1D,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;oBAC7C,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;iBAC9C;aACD;YAED,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YAEnB,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;SACxB;IACF,CAAC;IAEO,sBAAsB,CAAC,QAAa,EAAE,IAAgB;QAC7D,MAAM,UAAU,GAAG,QAAQ,CAAC,UAA0B,CAAC;QACvD,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC;QAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE;YAChC,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACrC,IAAI,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;gBAC5C,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;gBACjD,MAAM;aACN;SACD;IACF,CAAC;IAEO,qBAAqB,CAAC,MAAY,EAAE,aAAqB;QAChE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QACtD,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;QACrC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE;YAChC,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,KAAK,YAAY,OAAO,EAAE;gBAC7B,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;aACjD;SACD;IACF,CAAC;IAEO,OAAO;QACd,IAAI,IAAI,CAAC,GAAG,EAAE;YACb,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC;YAElD,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,EAAE;gBAC1B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC;aAC/D;iBAAM,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,EAAE;gBAClC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,EAAE,qBAAqB,CAAC,CAAC;aAC1D;SACD;IACF,CAAC;IAEO,YAAY,CAAC,OAA+C;QACnE,OAAO,CAAC,kBAAkB,CAAC,CAAC,MAAmD,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;QACrH,OAAO,CAAC,gBAAgB,CAAC,CAAC,MAAmD,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;QAClI,OAAO,CAAC,kBAAkB,CAAC,CAAC,MAAmD,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;IACrI,CAAC;IAEO,QAAQ,CAAC,WAAmB,EAAE,KAAmC;QACxE,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,KAAK,GAAG,KAAK,KAAK,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC;QAElD,IAAI,KAAK,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,EAAE,KAAe,CAAC,CAAC;SACnD;aAAM;YACN,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;SACrC;IACF,CAAC;IAEO,QAAQ,CAAC,QAAgB,EAAE,OAAe;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC;QAClD,IAAI,GAAG,EAAE;YACR,IAAI,QAAQ,EAAE;gBACb,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;aACzC;YACD,IAAI,OAAO,EAAE;gBACZ,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACnC,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE;oBACxB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;iBAC/B;aACD;SACD;IACF,CAAC;;;YAnPD,SAAS,SAAC;gBACV,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,2BAA2B;aACrC;;;YAX+C,UAAU;YACF,eAAe;YACxC,SAAS;YAI/B,sBAAsB;YANtB,iBAAiB;;;kBAaxB,KAAK;mBACL,KAAK;sBACL,KAAK;yBACL,KAAK;uBAEL,KAAK;uBACL,KAAK;oBAEL,KAAK,SAAC,OAAO;sBACb,KAAK;uBAGL,KAAK","sourcesContent":["import { ChangeDetectorRef, Component, DoCheck, ElementRef, Input,\n\tKeyValueChangeRecord, KeyValueChanges, KeyValueDiffer, KeyValueDiffers,\n\tOnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\n\nimport { Subscription } from 'rxjs';\n\nimport { SvgIconRegistryService } from './svg-icon-registry.service';\n\n@Component({\n\tselector: 'svg-icon',\n\ttemplate: '<ng-content></ng-content>'\n})\nexport class SvgIconComponent implements OnInit, OnDestroy, OnChanges, DoCheck {\n\t@Input() src: string;\n\t@Input() name: string;\n\t@Input() stretch = false;\n\t@Input() applyClass = false;\n\t/** @deprecated since 9.1.0 */\n\t@Input() applyCss = false;\n\t@Input() svgClass: string;\n\t// tslint:disable-next-line:no-input-rename\n\t@Input('class') klass: string;\n\t@Input() viewBox: string;\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\tprivate loaded = false;\n\n\tconstructor(\n\t\tprivate element: ElementRef,\n\t\tprivate differs: KeyValueDiffers,\n\t\tprivate renderer: Renderer2,\n\t\tprivate iconReg: SvgIconRegistryService,\n\t\tprivate cdr: ChangeDetectorRef) {\n\t}\n\n\tngOnInit() {\n\t\tthis.init();\n\t}\n\n\tngOnDestroy() {\n\t\tthis.destroy();\n\t}\n\n\tngOnChanges(changeRecord: SimpleChanges) {\n\t\tif (changeRecord.src || changeRecord.name) {\n\t\t\tif (this.loaded) {\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\n\t\tif (changeRecord.applyClass) {\n\t\t\tif (this.applyClass) {\n\t\t\t\tthis.setClass(null, this.klass);\n\t\t\t} else {\n\t\t\t\tthis.setClass(this.klass, null);\n\t\t\t}\n\t\t}\n\n\t\tif (changeRecord.svgClass) {\n\t\t\tthis.setClass(changeRecord.svgClass.previousValue, changeRecord.svgClass.currentValue);\n\t\t}\n\n\t\tif (changeRecord.klass) {\n\t\t\tif (this.applyClass) {\n\t\t\t\tthis.setClass(changeRecord.klass.previousValue, changeRecord.klass.currentValue);\n\t\t\t} else {\n\t\t\t\tthis.setClass(changeRecord.klass.previousValue, null);\n\t\t\t}\n\t\t}\n\n\t\tif (changeRecord.viewBox) {\n\t\t\tif (this.loaded) {\n\t\t\t\tthis.destroy();\n\t\t\t}\n\t\t\tthis.init();\n\t\t}\n\t\tif (changeRecord.applyCss) {\n\t\t\tconsole.warn('applyCss deprecated since 9.1.0, will be removed in 10.0.0');\n\t\t\tconsole.warn('use applyClass instead');\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\tif (this.name) {\n\t\t\tthis.icnSub = this.iconReg.getSvgByName(this.name).subscribe(this.initSvg.bind(this));\n\t\t} else if (this.src) {\n\t\t\tthis.icnSub = this.iconReg.loadSvg(this.src).subscribe(this.initSvg.bind(this));\n\t\t} else {\n\t\t\tconst elem = this.element.nativeElement;\n\t\t\telem.innerHTML = '';\n\t\t\tthis.cdr.markForCheck();\n\t\t}\n\t}\n\n\tprivate initSvg(svg: SVGElement): void {\n\t\tif (!this.loaded) {\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\tthis.loaded = false;\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 (!this.loaded && svg) {\n\t\t\tthis.svg = svg;\n\t\t\tconst icon = svg.cloneNode(true) as SVGElement;\n\t\t\tconst elem = this.element.nativeElement;\n\n\n\t\t\tthis.copyNgContentAttribute(elem, icon);\n\n\t\t\tif (this.klass && this.applyClass) {\n\t\t\t\tthis.renderer.setAttribute(icon, 'class', this.klass);\n\t\t\t}\n\n\t\t\tif (this.svgClass) {\n\t\t\t\tthis.renderer.setAttribute(icon, 'class', this.svgClass);\n\t\t\t}\n\n\t\t\tif (this.viewBox) {\n\t\t\t\tif (this.viewBox === 'auto') {\n\t\t\t\t\t// Attempt to convert height & width to a viewBox.\n\t\t\t\t\tconst w = icon.getAttribute('width');\n\t\t\t\t\tconst h = icon.getAttribute('height');\n\t\t\t\t\tif (h && w) {\n\t\t\t\t\t\tconst vb = `0 0 ${w} ${h}`;\n\t\t\t\t\t\tthis.renderer.setAttribute(icon, 'viewBox', vb);\n\t\t\t\t\t\tthis.renderer.removeAttribute(icon, 'width');\n\t\t\t\t\t\tthis.renderer.removeAttribute(icon, 'height');\n\t\t\t\t\t}\n\t\t\t\t} else if (this.viewBox !== '') {\n\t\t\t\t\tthis.renderer.setAttribute(icon, 'viewBox', this.viewBox);\n\t\t\t\t\tthis.renderer.removeAttribute(icon, 'width');\n\t\t\t\t\tthis.renderer.removeAttribute(icon, 'height');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\telem.innerHTML = '';\n\t\t\tthis.renderer.appendChild(elem, icon);\n\t\t\tthis.loaded = true;\n\n\t\t\tthis.stylize();\n\t\t\tthis.cdr.markForCheck();\n\t\t}\n\t}\n\n\tprivate copyNgContentAttribute(hostElem: any, icon: SVGElement) {\n\t\tconst attributes = hostElem.attributes as NamedNodeMap;\n\t\tconst len = attributes.length;\n\t\tfor (let i = 0; i < len; i += 1) {\n\t\t\tconst attribute = attributes.item(i);\n\t\t\tif (attribute.name.startsWith('_ngcontent')) {\n\t\t\t\tthis.setNgContentAttribute(icon, attribute.name);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate setNgContentAttribute(parent: Node, attributeName: string) {\n\t\tthis.renderer.setAttribute(parent, attributeName, '');\n\t\tconst len = parent.childNodes.length;\n\t\tfor (let i = 0; i < len; i += 1) {\n\t\t\tconst child = parent.childNodes[i];\n\t\t\tif (child instanceof Element) {\n\t\t\t\tthis.setNgContentAttribute(child, attributeName);\n\t\t\t}\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\tprivate setClass(previous: string, current: string) {\n\t\tconst svg = this.element.nativeElement.firstChild;\n\t\tif (svg) {\n\t\t\tif (previous) {\n\t\t\t\tthis.renderer.removeClass(svg, previous);\n\t\t\t}\n\t\t\tif (current) {\n\t\t\t\tconst klasses = current.split(' ');\n\t\t\t\tfor (const k of klasses) {\n\t\t\t\t\tthis.renderer.addClass(svg, k);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg-icon.component.js","sourceRoot":"../../../../projects/angular-svg-icon/src/","sources":["lib/svg-icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, DoCheck, ElementRef, Input,\n\tKeyValueChangeRecord, KeyValueChanges, KeyValueDiffer, KeyValueDiffers,\n\tOnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\n\nimport { Subscription } from 'rxjs';\n\nimport { SvgIconRegistryService } from './svg-icon-registry.service';\n\n@Component({\n\tselector: 'svg-icon',\n\ttemplate: '<ng-content></ng-content>'\n})\nexport class SvgIconComponent implements OnInit, OnDestroy, OnChanges, DoCheck {\n\t@Input() src: string;\n\t@Input() name: string;\n\t@Input() stretch = false;\n\t@Input() applyClass = false;\n\t/** @deprecated since 9.1.0 */\n\t@Input() applyCss = false;\n\t@Input() svgClass: string;\n\t// tslint:disable-next-line:no-input-rename\n\t@Input('class') klass: string;\n\t@Input() viewBox: string;\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\tprivate loaded = false;\n\n\tconstructor(\n\t\tprivate element: ElementRef,\n\t\tprivate differs: KeyValueDiffers,\n\t\tprivate renderer: Renderer2,\n\t\tprivate iconReg: SvgIconRegistryService,\n\t\tprivate cdr: ChangeDetectorRef) {\n\t}\n\n\tngOnInit() {\n\t\tthis.init();\n\t}\n\n\tngOnDestroy() {\n\t\tthis.destroy();\n\t}\n\n\tngOnChanges(changeRecord: SimpleChanges) {\n\t\tif (changeRecord.src || changeRecord.name) {\n\t\t\tif (this.loaded) {\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\n\t\tif (changeRecord.applyClass) {\n\t\t\tif (this.applyClass) {\n\t\t\t\tthis.setClass(null, this.klass);\n\t\t\t} else {\n\t\t\t\tthis.setClass(this.klass, null);\n\t\t\t}\n\t\t}\n\n\t\tif (changeRecord.svgClass) {\n\t\t\tthis.setClass(changeRecord.svgClass.previousValue, changeRecord.svgClass.currentValue);\n\t\t}\n\n\t\tif (changeRecord.klass) {\n\t\t\tconst elem = this.element.nativeElement;\n\t\t\tif (changeRecord.klass.previousValue) {\n\t\t\t\tthis.renderer.removeClass(elem, changeRecord.klass.previousValue);\n\t\t\t}\n\t\t\tif (changeRecord.klass.currentValue) {\n\t\t\t\tthis.renderer.addClass(elem, changeRecord.klass.currentValue);\n\t\t\t}\n\n\t\t\tif (this.applyClass) {\n\t\t\t\tthis.setClass(changeRecord.klass.previousValue, changeRecord.klass.currentValue);\n\t\t\t} else {\n\t\t\t\tthis.setClass(changeRecord.klass.previousValue, null);\n\t\t\t}\n\t\t}\n\n\t\tif (changeRecord.viewBox) {\n\t\t\tif (this.loaded) {\n\t\t\t\tthis.destroy();\n\t\t\t}\n\t\t\tthis.init();\n\t\t}\n\t\tif (changeRecord.applyCss) {\n\t\t\tconsole.warn('applyCss deprecated since 9.1.0, will be removed in 10.0.0');\n\t\t\tconsole.warn('use applyClass instead');\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\tif (this.name) {\n\t\t\tthis.icnSub = this.iconReg.getSvgByName(this.name).subscribe(this.initSvg.bind(this));\n\t\t} else if (this.src) {\n\t\t\tthis.icnSub = this.iconReg.loadSvg(this.src).subscribe(this.initSvg.bind(this));\n\t\t} else {\n\t\t\tconst elem = this.element.nativeElement;\n\t\t\telem.innerHTML = '';\n\t\t\tthis.cdr.markForCheck();\n\t\t}\n\t}\n\n\tprivate initSvg(svg: SVGElement): void {\n\t\tif (!this.loaded) {\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\tthis.loaded = false;\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 (!this.loaded && svg) {\n\t\t\tthis.svg = svg;\n\t\t\tconst icon = svg.cloneNode(true) as SVGElement;\n\t\t\tconst elem = this.element.nativeElement;\n\n\n\t\t\tthis.copyNgContentAttribute(elem, icon);\n\n\t\t\tif (this.klass && this.applyClass) {\n\t\t\t\tthis.renderer.setAttribute(icon, 'class', this.klass);\n\t\t\t}\n\n\t\t\tif (this.svgClass) {\n\t\t\t\tthis.renderer.setAttribute(icon, 'class', this.svgClass);\n\t\t\t}\n\n\t\t\tif (this.viewBox) {\n\t\t\t\tif (this.viewBox === 'auto') {\n\t\t\t\t\t// Attempt to convert height & width to a viewBox.\n\t\t\t\t\tconst w = icon.getAttribute('width');\n\t\t\t\t\tconst h = icon.getAttribute('height');\n\t\t\t\t\tif (h && w) {\n\t\t\t\t\t\tconst vb = `0 0 ${w} ${h}`;\n\t\t\t\t\t\tthis.renderer.setAttribute(icon, 'viewBox', vb);\n\t\t\t\t\t\tthis.renderer.removeAttribute(icon, 'width');\n\t\t\t\t\t\tthis.renderer.removeAttribute(icon, 'height');\n\t\t\t\t\t}\n\t\t\t\t} else if (this.viewBox !== '') {\n\t\t\t\t\tthis.renderer.setAttribute(icon, 'viewBox', this.viewBox);\n\t\t\t\t\tthis.renderer.removeAttribute(icon, 'width');\n\t\t\t\t\tthis.renderer.removeAttribute(icon, 'height');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\telem.innerHTML = '';\n\t\t\tthis.renderer.appendChild(elem, icon);\n\t\t\tthis.loaded = true;\n\n\t\t\tthis.stylize();\n\t\t\tthis.cdr.markForCheck();\n\t\t}\n\t}\n\n\tprivate copyNgContentAttribute(hostElem: any, icon: SVGElement) {\n\t\tconst attributes = hostElem.attributes as NamedNodeMap;\n\t\tconst len = attributes.length;\n\t\tfor (let i = 0; i < len; i += 1) {\n\t\t\tconst attribute = attributes.item(i);\n\t\t\tif (attribute.name.startsWith('_ngcontent')) {\n\t\t\t\tthis.setNgContentAttribute(icon, attribute.name);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate setNgContentAttribute(parent: Node, attributeName: string) {\n\t\tthis.renderer.setAttribute(parent, attributeName, '');\n\t\tconst len = parent.childNodes.length;\n\t\tfor (let i = 0; i < len; i += 1) {\n\t\t\tconst child = parent.childNodes[i];\n\t\t\tif (child instanceof Element) {\n\t\t\t\tthis.setNgContentAttribute(child, attributeName);\n\t\t\t}\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\tprivate setClass(previous: string, current: string) {\n\t\tconst svg = this.element.nativeElement.firstChild;\n\t\tif (svg) {\n\t\t\tif (previous) {\n\t\t\t\tthis.renderer.removeClass(svg, previous);\n\t\t\t}\n\t\t\tif (current) {\n\t\t\t\tconst klasses = current.split(' ');\n\t\t\t\tfor (const k of klasses) {\n\t\t\t\t\tthis.renderer.addClass(svg, k);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"]}

@@ -156,2 +156,9 @@ import { Injectable, InjectionToken, Inject, PLATFORM_ID, Optional, SkipSelf, Component, ElementRef, KeyValueDiffers, Renderer2, ChangeDetectorRef, Input, NgModule } from '@angular/core';

if (changeRecord.klass) {
const elem = this.element.nativeElement;
if (changeRecord.klass.previousValue) {
this.renderer.removeClass(elem, changeRecord.klass.previousValue);
}
if (changeRecord.klass.currentValue) {
this.renderer.addClass(elem, changeRecord.klass.currentValue);
}
if (this.applyClass) {

@@ -158,0 +165,0 @@ this.setClass(changeRecord.klass.previousValue, changeRecord.klass.currentValue);

{
"name": "angular-svg-icon",
"description": "Angular 11 component for inlining SVGs allowing them to be easily styled with CSS.",
"version": "11.0.0",
"version": "11.1.0",
"repository": {

@@ -6,0 +6,0 @@ "type": "git",

@@ -90,3 +90,3 @@ [![npm version](https://badge.fury.io/js/angular-svg-icon.svg)](https://badge.fury.io/js/angular-svg-icon)

- **[class]** - An optional string of the class or classes to apply to the SVG (duplicates what is set on the `svg-icon`).
- **[applyClass]** - An optional boolean (default is false) that works with **[class]** to duplicate the `class` attribute on the `svg-icon` and apply it to the SVG.
- **[applyClass]** - An optional boolean (default is false) that copies the `class` attribute on the `svg-icon` and adds it to the SVG.
- **[svgClass]** - An optional string of the class or classes to apply to the SVG (independent of what is set for the class on the `svg-icon`).

@@ -93,0 +93,0 @@ - **[viewBox]** - An optional string to set the viewBox on the SVG. If the `viewBox="auto"`, then `svg-icon` will attempt to convert the SVG's width and height attributes to a `viewBox="0 0 w h"`. Both explicitly setting the viewBox or `auto` setting the viewBox will remove the SVG's width and height attributes.

Sorry, the diff of this file is not supported yet

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