Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ngx-gravatar

Package Overview
Dependencies
Maintainers
1
Versions
35
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-gravatar - npm Package Compare versions

Comparing version 7.2.1 to 7.2.2

7

bundles/ngx-gravatar.umd.js

@@ -263,3 +263,5 @@ (function (global, factory) {

this.renderer.listen(this.elementRef.nativeElement, 'error', function (event) {
_this.initializeAvatar(true); // Force using gravatar
if (!_this.isGravatarUsed) {
_this.initializeAvatar(true); // Force using gravatar
}
});

@@ -276,2 +278,3 @@ }

this.initialized = true;
this.isGravatarUsed = false;
};

@@ -337,2 +340,3 @@ /**

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -345,2 +349,3 @@ else { // this.preferGravatar == false

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -347,0 +352,0 @@ }

2

bundles/ngx-gravatar.umd.min.js

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

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("ts-md5/dist/md5")):"function"==typeof define&&define.amd?define("ngx-gravatar",["exports","@angular/core","ts-md5/dist/md5"],e):e(t["ngx-gravatar"]={},t.ng.core,t.md5)}(this,function(t,r,s){"use strict";var i=new r.InjectionToken("gravatarCustom.config"),e=function(){return(e=Object.assign||function(t){for(var e,r=1,i=arguments.length;r<i;r++)for(var a in e=arguments[r])Object.prototype.hasOwnProperty.call(e,a)&&(t[a]=e[a]);return t}).apply(this,arguments)},a={blank:"blank",identicon:"identicon",mm:"mm",mp:"mp",monsterid:"monsterid",retro:"retro",robohash:"robohash",wavatar:"wavatar"},n={g:"g",pg:"pg",r:"r",x:"x"},o={fallback:a.retro,size:40,cornerRadius:0,preferGravatar:!1,hasBorder:!1,borderColor:"#000000",borderRadius:"50%",borderStyle:"solid",borderWidth:1,round:!0,backgroundColor:"transparent",rating:n.g,ratio:2},d=function(){function t(t){this.gravatarConfig=t,this.defaultConfig=e({},o),this.gravatarConfig&&(this.gravatarConfig.rating=this.determineRating(this.gravatarConfig.rating),this.gravatarConfig.fallback=this.determineFallback(this.gravatarConfig.fallback),this.defaultConfig=e({},this.defaultConfig,this.gravatarConfig))}return t.prototype.getDefaultConfig=function(){return this.defaultConfig},t.prototype.generateGravatarUrl=function(t,e,r,i,a){var n;if(e)n=e;else{try{t=t.trim().toLowerCase()}catch(o){console.error("[ngx-gravatar] - Email ("+t+") is not a string. Empty string is used as a default email."),t=""}n=s.Md5.hashStr(t)}return"//www.gravatar.com/avatar/"+n+"?s="+(r=r||this.defaultConfig.size)+"&r="+(i=this.determineRating(i,this.defaultConfig.rating))+"&d="+(a=this.determineFallback(a,this.defaultConfig.fallback))},t.prototype.determineFallback=function(t,e){return void 0===e&&(e=o.fallback),t===undefined?e:a[t]===undefined?(console.error('[ngx-gravatar] - "'+t+'" is invalid gravatar fallback type. Default fallback "'+e+'" is used.'),e):t},t.prototype.determineRating=function(t,e){return void 0===e&&(e=o.rating),t===undefined?e:n[t]===undefined?(console.error('[ngx-gravatar] - "'+t+'" is invalid gravatar rating type. Default rating "'+e+'" is used.'),e):t},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[{type:undefined,decorators:[{type:r.Optional},{type:r.Inject,args:[i]}]}]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t(r.inject(i,8))},token:t,providedIn:"root"}),t}(),u=function(){function t(t,e,r){var i=this;this.elementRef=t,this.renderer=e,this.gravatarService=r,this.style={},this.initialized=!1,this.defaultConfig=this.gravatarService.getDefaultConfig(),this.renderer.listen(this.elementRef.nativeElement,"error",function(t){i.initializeAvatar(!0)})}return t.prototype.ngOnInit=function(){this.initializeAvatar(),this.initialized=!0},t.prototype.ngOnChanges=function(){this.initialized&&this.initializeAvatar()},t.prototype.setDefaultValues=function(){this.size=this.computeSize(),this.ratio=this.ratio===undefined?this.defaultConfig.ratio:this.ratio,this.requestedSize=this.size*this.ratio,this.round=this.round===undefined?this.defaultConfig.round:this.round,this.cornerRadius=this.cornerRadius===undefined?this.defaultConfig.cornerRadius:this.cornerRadius,this.preferGravatar=this.preferGravatar===undefined?this.defaultConfig.preferGravatar:this.preferGravatar},t.prototype.initializeAvatar=function(t){this.setDefaultValues();var e="";e=this.preferGravatar||t?this.gravatarService.generateGravatarUrl(this.email,this.md5Hash,this.requestedSize,this.rating,this.fallback):this.src?this.src:this.gravatarService.generateGravatarUrl(this.email,this.md5Hash,this.requestedSize,this.rating,this.fallback),this.renderer.setProperty(this.elementRef.nativeElement,"src",e),this.setStyle(this.avatarStyle())},t.prototype.computeSize=function(){var t=this.size===undefined?this.defaultConfig.size:this.size;if(this.style&&this.style.width)try{var e=this.style.width.trim();e.match(/^\d+px$/)&&(t=e.replace("px",""))}catch(r){return t}return t},t.prototype.avatarStyle=function(){var t={width:this.size+"px",height:this.size+"px",borderRadius:this.round?this.defaultConfig.borderRadius:this.cornerRadius+"px",borderStyle:this.defaultConfig.hasBorder||this.borderColor||this.borderWidth?this.defaultConfig.borderStyle:"none",borderColor:this.borderColor?this.borderColor:this.defaultConfig.borderColor,borderWidth:this.borderWidth?this.borderWidth+"px":this.defaultConfig.borderWidth+"px",backgroundColor:this.backgroundColor?this.backgroundColor:this.defaultConfig.backgroundColor};return e({},t,this.style)},t.prototype.setStyle=function(e){var r=this;Object.keys(e).forEach(function(t){r.renderer.setStyle(r.elementRef.nativeElement,t,e[t])})},t.decorators=[{type:r.Directive,args:[{selector:"[ngx-gravatar], [ngxGravatar]"}]}],t.ctorParameters=function(){return[{type:r.ElementRef},{type:r.Renderer2},{type:d}]},t.propDecorators={src:[{type:r.Input}],email:[{type:r.Input}],md5Hash:[{type:r.Input}],size:[{type:r.Input}],fallback:[{type:r.Input}],rating:[{type:r.Input}],round:[{type:r.Input}],cornerRadius:[{type:r.Input}],borderColor:[{type:r.Input}],borderWidth:[{type:r.Input}],style:[{type:r.Input}],preferGravatar:[{type:r.Input}],backgroundColor:[{type:r.Input}],ratio:[{type:r.Input}]},t}(),l=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:i,useValue:t}]}},e.decorators=[{type:r.NgModule,args:[{declarations:[u],exports:[u]}]}],e}();t.GravatarModule=l,t.FALLBACK=a,t.RATING=n,t.ɵc=i,t.ɵa=u,t.ɵb=d,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("ts-md5/dist/md5")):"function"==typeof define&&define.amd?define("ngx-gravatar",["exports","@angular/core","ts-md5/dist/md5"],e):e(t["ngx-gravatar"]={},t.ng.core,t.md5)}(this,function(t,r,s){"use strict";var i=new r.InjectionToken("gravatarCustom.config"),e=function(){return(e=Object.assign||function(t){for(var e,r=1,i=arguments.length;r<i;r++)for(var a in e=arguments[r])Object.prototype.hasOwnProperty.call(e,a)&&(t[a]=e[a]);return t}).apply(this,arguments)},a={blank:"blank",identicon:"identicon",mm:"mm",mp:"mp",monsterid:"monsterid",retro:"retro",robohash:"robohash",wavatar:"wavatar"},n={g:"g",pg:"pg",r:"r",x:"x"},o={fallback:a.retro,size:40,cornerRadius:0,preferGravatar:!1,hasBorder:!1,borderColor:"#000000",borderRadius:"50%",borderStyle:"solid",borderWidth:1,round:!0,backgroundColor:"transparent",rating:n.g,ratio:2},d=function(){function t(t){this.gravatarConfig=t,this.defaultConfig=e({},o),this.gravatarConfig&&(this.gravatarConfig.rating=this.determineRating(this.gravatarConfig.rating),this.gravatarConfig.fallback=this.determineFallback(this.gravatarConfig.fallback),this.defaultConfig=e({},this.defaultConfig,this.gravatarConfig))}return t.prototype.getDefaultConfig=function(){return this.defaultConfig},t.prototype.generateGravatarUrl=function(t,e,r,i,a){var n;if(e)n=e;else{try{t=t.trim().toLowerCase()}catch(o){console.error("[ngx-gravatar] - Email ("+t+") is not a string. Empty string is used as a default email."),t=""}n=s.Md5.hashStr(t)}return"//www.gravatar.com/avatar/"+n+"?s="+(r=r||this.defaultConfig.size)+"&r="+(i=this.determineRating(i,this.defaultConfig.rating))+"&d="+(a=this.determineFallback(a,this.defaultConfig.fallback))},t.prototype.determineFallback=function(t,e){return void 0===e&&(e=o.fallback),t===undefined?e:a[t]===undefined?(console.error('[ngx-gravatar] - "'+t+'" is invalid gravatar fallback type. Default fallback "'+e+'" is used.'),e):t},t.prototype.determineRating=function(t,e){return void 0===e&&(e=o.rating),t===undefined?e:n[t]===undefined?(console.error('[ngx-gravatar] - "'+t+'" is invalid gravatar rating type. Default rating "'+e+'" is used.'),e):t},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[{type:undefined,decorators:[{type:r.Optional},{type:r.Inject,args:[i]}]}]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t(r.inject(i,8))},token:t,providedIn:"root"}),t}(),u=function(){function t(t,e,r){var i=this;this.elementRef=t,this.renderer=e,this.gravatarService=r,this.style={},this.initialized=!1,this.defaultConfig=this.gravatarService.getDefaultConfig(),this.renderer.listen(this.elementRef.nativeElement,"error",function(t){i.isGravatarUsed||i.initializeAvatar(!0)})}return t.prototype.ngOnInit=function(){this.initializeAvatar(),this.initialized=!0,this.isGravatarUsed=!1},t.prototype.ngOnChanges=function(){this.initialized&&this.initializeAvatar()},t.prototype.setDefaultValues=function(){this.size=this.computeSize(),this.ratio=this.ratio===undefined?this.defaultConfig.ratio:this.ratio,this.requestedSize=this.size*this.ratio,this.round=this.round===undefined?this.defaultConfig.round:this.round,this.cornerRadius=this.cornerRadius===undefined?this.defaultConfig.cornerRadius:this.cornerRadius,this.preferGravatar=this.preferGravatar===undefined?this.defaultConfig.preferGravatar:this.preferGravatar},t.prototype.initializeAvatar=function(t){this.setDefaultValues();var e="";this.preferGravatar||t?(e=this.gravatarService.generateGravatarUrl(this.email,this.md5Hash,this.requestedSize,this.rating,this.fallback),this.isGravatarUsed=!0):this.src?e=this.src:(e=this.gravatarService.generateGravatarUrl(this.email,this.md5Hash,this.requestedSize,this.rating,this.fallback),this.isGravatarUsed=!0),this.renderer.setProperty(this.elementRef.nativeElement,"src",e),this.setStyle(this.avatarStyle())},t.prototype.computeSize=function(){var t=this.size===undefined?this.defaultConfig.size:this.size;if(this.style&&this.style.width)try{var e=this.style.width.trim();e.match(/^\d+px$/)&&(t=e.replace("px",""))}catch(r){return t}return t},t.prototype.avatarStyle=function(){var t={width:this.size+"px",height:this.size+"px",borderRadius:this.round?this.defaultConfig.borderRadius:this.cornerRadius+"px",borderStyle:this.defaultConfig.hasBorder||this.borderColor||this.borderWidth?this.defaultConfig.borderStyle:"none",borderColor:this.borderColor?this.borderColor:this.defaultConfig.borderColor,borderWidth:this.borderWidth?this.borderWidth+"px":this.defaultConfig.borderWidth+"px",backgroundColor:this.backgroundColor?this.backgroundColor:this.defaultConfig.backgroundColor};return e({},t,this.style)},t.prototype.setStyle=function(e){var r=this;Object.keys(e).forEach(function(t){r.renderer.setStyle(r.elementRef.nativeElement,t,e[t])})},t.decorators=[{type:r.Directive,args:[{selector:"[ngx-gravatar], [ngxGravatar]"}]}],t.ctorParameters=function(){return[{type:r.ElementRef},{type:r.Renderer2},{type:d}]},t.propDecorators={src:[{type:r.Input}],email:[{type:r.Input}],md5Hash:[{type:r.Input}],size:[{type:r.Input}],fallback:[{type:r.Input}],rating:[{type:r.Input}],round:[{type:r.Input}],cornerRadius:[{type:r.Input}],borderColor:[{type:r.Input}],borderWidth:[{type:r.Input}],style:[{type:r.Input}],preferGravatar:[{type:r.Input}],backgroundColor:[{type:r.Input}],ratio:[{type:r.Input}]},t}(),h=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:i,useValue:t}]}},e.decorators=[{type:r.NgModule,args:[{declarations:[u],exports:[u]}]}],e}();t.GravatarModule=h,t.FALLBACK=a,t.RATING=n,t.ɵc=i,t.ɵa=u,t.ɵb=d,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=ngx-gravatar.umd.min.js.map

@@ -0,1 +1,4 @@

# v7.2.2
* BugFix: Gravatar is requested infinitely [#7](https://github.com/t-ho/ngx-gravatar/issues/7)
# v7.2.1

@@ -5,3 +8,3 @@ * Update dependencies

# v7.2.0
* Support hashed email as input parameter #6
* Support hashed email as input parameter [#6](https://github.com/t-ho/ngx-gravatar/pull/6)

@@ -8,0 +11,0 @@ # v7.1.0

@@ -22,3 +22,5 @@ /**

this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {
this.initializeAvatar(true); // Force using gravatar
if (!this.isGravatarUsed) {
this.initializeAvatar(true); // Force using gravatar
}
});

@@ -32,2 +34,3 @@ }

this.initialized = true;
this.isGravatarUsed = false;
}

@@ -69,2 +72,3 @@ /**

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -77,2 +81,3 @@ else { // this.preferGravatar == false

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -197,2 +202,4 @@ }

NgxGravatarDirective.prototype.requestedSize;
/** @type {?} */
NgxGravatarDirective.prototype.isGravatarUsed;
/**

@@ -214,2 +221,2 @@ * @type {?}

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-gravatar.directive.js","sourceRoot":"ng://ngx-gravatar/","sources":["lib/ngx-gravatar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnInit, Renderer2 } from '@angular/core';\nimport { NgxGravatarService } from './ngx-gravatar.service';\nimport { GravatarConfig } from './gravatar-config';\n\n@Directive({\n  selector: '[ngx-gravatar], [ngxGravatar]'\n})\nexport class NgxGravatarDirective implements OnChanges, OnInit {\n  @Input() src: string;\n  @Input() email: string;\n  @Input() md5Hash: string;\n  @Input() size: number;\n  @Input() fallback: string; // enum: ['blank', 'identicon', 'mm', 'monsterid', 'retro', 'robohash', 'wavatar']\n  @Input() rating: string; // enum: ['g', 'pg', 'r', 'x']\n  @Input() round: boolean;\n  @Input() cornerRadius: number;\n  @Input() borderColor: string;\n  @Input() borderWidth: number;\n  @Input() style: any = {};\n  @Input() preferGravatar: boolean;\n  @Input() backgroundColor: boolean;\n  @Input() ratio: number;\n\n  initialized: boolean;\n  defaultConfig: GravatarConfig;\n  requestedSize: number;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private gravatarService: NgxGravatarService,\n  ) {\n    this.initialized = false;\n    this.defaultConfig = this.gravatarService.getDefaultConfig();\n    // Listen for error when fetching custom src\n    this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {\n      this.initializeAvatar(true); // Force using gravatar\n    });\n  }\n\n  ngOnInit() {\n    this.initializeAvatar();\n    this.initialized = true;\n  }\n\n  ngOnChanges() {\n    if (this.initialized) {\n      this.initializeAvatar();\n    }\n  }\n\n  /**\n   * Set default values for user inputs if they are not provided\n   */\n  private setDefaultValues() {\n    this.size = this.computeSize();\n    this.ratio = this.ratio === undefined ? this.defaultConfig.ratio : this.ratio;\n    this.requestedSize = this.size * this.ratio;\n    this.round = this.round === undefined ? this.defaultConfig.round : this.round;\n    this.cornerRadius = this.cornerRadius === undefined ? this.defaultConfig.cornerRadius : this.cornerRadius;\n    this.preferGravatar = this.preferGravatar === undefined ? this.defaultConfig.preferGravatar : this.preferGravatar;\n  }\n\n  /**\n   * Initialize avatar.\n   * Custom source has higher priority if preferGravatar is not set on.\n   * Finally, set styles for the avatar.\n   */\n  private initializeAvatar(forcedGravatar?: boolean) {\n    this.setDefaultValues();\n    let url = '';\n    if (this.preferGravatar || forcedGravatar) {\n      url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n    } else { // this.preferGravatar == false\n      if (this.src) {\n        url = this.src;\n      } else { // fallback to gravatar\n        url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n      }\n    }\n    this.renderer.setProperty(this.elementRef.nativeElement, 'src', url);\n    this.setStyle(this.avatarStyle());\n  }\n\n  /**\n   * Compute the size of the avatar\n   * @return size\n   */\n  private computeSize(): number {\n    let size = this.size === undefined ? this.defaultConfig.size : this.size;\n    if (this.style && this.style.width) {\n      try {\n        const width = this.style.width.trim();\n        if (width.match(/^\\d+px$/)) { // width with px unit\n          size = width.replace('px', '');\n        }\n      } catch (e) {\n        return size;\n      }\n    }\n    return size;\n  }\n\n  /**\n   * Compute style object\n   * @return style object\n   */\n  private avatarStyle() {\n    const style = {\n      width: this.size + 'px',\n      height: this.size + 'px',\n      borderRadius: this.round ? this.defaultConfig.borderRadius : this.cornerRadius + 'px',\n      borderStyle: this.defaultConfig.hasBorder || this.borderColor || this.borderWidth ? this.defaultConfig.borderStyle : 'none',\n      borderColor: this.borderColor ? this.borderColor : this.defaultConfig.borderColor,\n      borderWidth: this.borderWidth ? this.borderWidth + 'px' : this.defaultConfig.borderWidth + 'px',\n      backgroundColor: this.backgroundColor ? this.backgroundColor : this.defaultConfig.backgroundColor,\n    };\n    return { ...style, ...this.style };\n  }\n\n  /**\n   * Set style for the avatar\n   * @param styles style object\n   */\n  private setStyle(styles: any) {\n    Object.keys(styles).forEach(key => {\n      this.renderer.setStyle(this.elementRef.nativeElement, key, styles[key]);\n    });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-gravatar.directive.js","sourceRoot":"ng://ngx-gravatar/","sources":["lib/ngx-gravatar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnInit, Renderer2 } from '@angular/core';\nimport { NgxGravatarService } from './ngx-gravatar.service';\nimport { GravatarConfig } from './gravatar-config';\n\n@Directive({\n  selector: '[ngx-gravatar], [ngxGravatar]'\n})\nexport class NgxGravatarDirective implements OnChanges, OnInit {\n  @Input() src: string;\n  @Input() email: string;\n  @Input() md5Hash: string;\n  @Input() size: number;\n  @Input() fallback: string; // enum: ['blank', 'identicon', 'mm', 'monsterid', 'retro', 'robohash', 'wavatar']\n  @Input() rating: string; // enum: ['g', 'pg', 'r', 'x']\n  @Input() round: boolean;\n  @Input() cornerRadius: number;\n  @Input() borderColor: string;\n  @Input() borderWidth: number;\n  @Input() style: any = {};\n  @Input() preferGravatar: boolean;\n  @Input() backgroundColor: boolean;\n  @Input() ratio: number;\n\n  initialized: boolean;\n  defaultConfig: GravatarConfig;\n  requestedSize: number;\n  isGravatarUsed: boolean;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private gravatarService: NgxGravatarService,\n  ) {\n    this.initialized = false;\n    this.defaultConfig = this.gravatarService.getDefaultConfig();\n    // Listen for error when fetching custom src\n    this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {\n      if (!this.isGravatarUsed) {\n        this.initializeAvatar(true); // Force using gravatar\n      }\n    });\n  }\n\n  ngOnInit() {\n    this.initializeAvatar();\n    this.initialized = true;\n    this.isGravatarUsed = false;\n  }\n\n  ngOnChanges() {\n    if (this.initialized) {\n      this.initializeAvatar();\n    }\n  }\n\n  /**\n   * Set default values for user inputs if they are not provided\n   */\n  private setDefaultValues() {\n    this.size = this.computeSize();\n    this.ratio = this.ratio === undefined ? this.defaultConfig.ratio : this.ratio;\n    this.requestedSize = this.size * this.ratio;\n    this.round = this.round === undefined ? this.defaultConfig.round : this.round;\n    this.cornerRadius = this.cornerRadius === undefined ? this.defaultConfig.cornerRadius : this.cornerRadius;\n    this.preferGravatar = this.preferGravatar === undefined ? this.defaultConfig.preferGravatar : this.preferGravatar;\n  }\n\n  /**\n   * Initialize avatar.\n   * Custom source has higher priority if preferGravatar is not set on.\n   * Finally, set styles for the avatar.\n   */\n  private initializeAvatar(forcedGravatar?: boolean) {\n    this.setDefaultValues();\n    let url = '';\n    if (this.preferGravatar || forcedGravatar) {\n      url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n      this.isGravatarUsed = true;\n    } else { // this.preferGravatar == false\n      if (this.src) {\n        url = this.src;\n      } else { // fallback to gravatar\n        url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n        this.isGravatarUsed = true;\n      }\n    }\n    this.renderer.setProperty(this.elementRef.nativeElement, 'src', url);\n    this.setStyle(this.avatarStyle());\n  }\n\n  /**\n   * Compute the size of the avatar\n   * @return size\n   */\n  private computeSize(): number {\n    let size = this.size === undefined ? this.defaultConfig.size : this.size;\n    if (this.style && this.style.width) {\n      try {\n        const width = this.style.width.trim();\n        if (width.match(/^\\d+px$/)) { // width with px unit\n          size = width.replace('px', '');\n        }\n      } catch (e) {\n        return size;\n      }\n    }\n    return size;\n  }\n\n  /**\n   * Compute style object\n   * @return style object\n   */\n  private avatarStyle() {\n    const style = {\n      width: this.size + 'px',\n      height: this.size + 'px',\n      borderRadius: this.round ? this.defaultConfig.borderRadius : this.cornerRadius + 'px',\n      borderStyle: this.defaultConfig.hasBorder || this.borderColor || this.borderWidth ? this.defaultConfig.borderStyle : 'none',\n      borderColor: this.borderColor ? this.borderColor : this.defaultConfig.borderColor,\n      borderWidth: this.borderWidth ? this.borderWidth + 'px' : this.defaultConfig.borderWidth + 'px',\n      backgroundColor: this.backgroundColor ? this.backgroundColor : this.defaultConfig.backgroundColor,\n    };\n    return { ...style, ...this.style };\n  }\n\n  /**\n   * Set style for the avatar\n   * @param styles style object\n   */\n  private setStyle(styles: any) {\n    Object.keys(styles).forEach(key => {\n      this.renderer.setStyle(this.elementRef.nativeElement, key, styles[key]);\n    });\n  }\n}\n"]}

@@ -19,3 +19,5 @@ /**

this.renderer.listen(this.elementRef.nativeElement, 'error', function (event) {
_this.initializeAvatar(true); // Force using gravatar
if (!_this.isGravatarUsed) {
_this.initializeAvatar(true); // Force using gravatar
}
});

@@ -32,2 +34,3 @@ }

this.initialized = true;
this.isGravatarUsed = false;
};

@@ -93,2 +96,3 @@ /**

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -101,2 +105,3 @@ else { // this.preferGravatar == false

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -252,2 +257,4 @@ }

NgxGravatarDirective.prototype.requestedSize;
/** @type {?} */
NgxGravatarDirective.prototype.isGravatarUsed;
/**

@@ -269,2 +276,2 @@ * @type {?}

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-gravatar.directive.js","sourceRoot":"ng://ngx-gravatar/","sources":["lib/ngx-gravatar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnInit, Renderer2 } from '@angular/core';\nimport { NgxGravatarService } from './ngx-gravatar.service';\nimport { GravatarConfig } from './gravatar-config';\n\n@Directive({\n  selector: '[ngx-gravatar], [ngxGravatar]'\n})\nexport class NgxGravatarDirective implements OnChanges, OnInit {\n  @Input() src: string;\n  @Input() email: string;\n  @Input() md5Hash: string;\n  @Input() size: number;\n  @Input() fallback: string; // enum: ['blank', 'identicon', 'mm', 'monsterid', 'retro', 'robohash', 'wavatar']\n  @Input() rating: string; // enum: ['g', 'pg', 'r', 'x']\n  @Input() round: boolean;\n  @Input() cornerRadius: number;\n  @Input() borderColor: string;\n  @Input() borderWidth: number;\n  @Input() style: any = {};\n  @Input() preferGravatar: boolean;\n  @Input() backgroundColor: boolean;\n  @Input() ratio: number;\n\n  initialized: boolean;\n  defaultConfig: GravatarConfig;\n  requestedSize: number;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private gravatarService: NgxGravatarService,\n  ) {\n    this.initialized = false;\n    this.defaultConfig = this.gravatarService.getDefaultConfig();\n    // Listen for error when fetching custom src\n    this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {\n      this.initializeAvatar(true); // Force using gravatar\n    });\n  }\n\n  ngOnInit() {\n    this.initializeAvatar();\n    this.initialized = true;\n  }\n\n  ngOnChanges() {\n    if (this.initialized) {\n      this.initializeAvatar();\n    }\n  }\n\n  /**\n   * Set default values for user inputs if they are not provided\n   */\n  private setDefaultValues() {\n    this.size = this.computeSize();\n    this.ratio = this.ratio === undefined ? this.defaultConfig.ratio : this.ratio;\n    this.requestedSize = this.size * this.ratio;\n    this.round = this.round === undefined ? this.defaultConfig.round : this.round;\n    this.cornerRadius = this.cornerRadius === undefined ? this.defaultConfig.cornerRadius : this.cornerRadius;\n    this.preferGravatar = this.preferGravatar === undefined ? this.defaultConfig.preferGravatar : this.preferGravatar;\n  }\n\n  /**\n   * Initialize avatar.\n   * Custom source has higher priority if preferGravatar is not set on.\n   * Finally, set styles for the avatar.\n   */\n  private initializeAvatar(forcedGravatar?: boolean) {\n    this.setDefaultValues();\n    let url = '';\n    if (this.preferGravatar || forcedGravatar) {\n      url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n    } else { // this.preferGravatar == false\n      if (this.src) {\n        url = this.src;\n      } else { // fallback to gravatar\n        url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n      }\n    }\n    this.renderer.setProperty(this.elementRef.nativeElement, 'src', url);\n    this.setStyle(this.avatarStyle());\n  }\n\n  /**\n   * Compute the size of the avatar\n   * @return size\n   */\n  private computeSize(): number {\n    let size = this.size === undefined ? this.defaultConfig.size : this.size;\n    if (this.style && this.style.width) {\n      try {\n        const width = this.style.width.trim();\n        if (width.match(/^\\d+px$/)) { // width with px unit\n          size = width.replace('px', '');\n        }\n      } catch (e) {\n        return size;\n      }\n    }\n    return size;\n  }\n\n  /**\n   * Compute style object\n   * @return style object\n   */\n  private avatarStyle() {\n    const style = {\n      width: this.size + 'px',\n      height: this.size + 'px',\n      borderRadius: this.round ? this.defaultConfig.borderRadius : this.cornerRadius + 'px',\n      borderStyle: this.defaultConfig.hasBorder || this.borderColor || this.borderWidth ? this.defaultConfig.borderStyle : 'none',\n      borderColor: this.borderColor ? this.borderColor : this.defaultConfig.borderColor,\n      borderWidth: this.borderWidth ? this.borderWidth + 'px' : this.defaultConfig.borderWidth + 'px',\n      backgroundColor: this.backgroundColor ? this.backgroundColor : this.defaultConfig.backgroundColor,\n    };\n    return { ...style, ...this.style };\n  }\n\n  /**\n   * Set style for the avatar\n   * @param styles style object\n   */\n  private setStyle(styles: any) {\n    Object.keys(styles).forEach(key => {\n      this.renderer.setStyle(this.elementRef.nativeElement, key, styles[key]);\n    });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-gravatar.directive.js","sourceRoot":"ng://ngx-gravatar/","sources":["lib/ngx-gravatar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnInit, Renderer2 } from '@angular/core';\nimport { NgxGravatarService } from './ngx-gravatar.service';\nimport { GravatarConfig } from './gravatar-config';\n\n@Directive({\n  selector: '[ngx-gravatar], [ngxGravatar]'\n})\nexport class NgxGravatarDirective implements OnChanges, OnInit {\n  @Input() src: string;\n  @Input() email: string;\n  @Input() md5Hash: string;\n  @Input() size: number;\n  @Input() fallback: string; // enum: ['blank', 'identicon', 'mm', 'monsterid', 'retro', 'robohash', 'wavatar']\n  @Input() rating: string; // enum: ['g', 'pg', 'r', 'x']\n  @Input() round: boolean;\n  @Input() cornerRadius: number;\n  @Input() borderColor: string;\n  @Input() borderWidth: number;\n  @Input() style: any = {};\n  @Input() preferGravatar: boolean;\n  @Input() backgroundColor: boolean;\n  @Input() ratio: number;\n\n  initialized: boolean;\n  defaultConfig: GravatarConfig;\n  requestedSize: number;\n  isGravatarUsed: boolean;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private gravatarService: NgxGravatarService,\n  ) {\n    this.initialized = false;\n    this.defaultConfig = this.gravatarService.getDefaultConfig();\n    // Listen for error when fetching custom src\n    this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {\n      if (!this.isGravatarUsed) {\n        this.initializeAvatar(true); // Force using gravatar\n      }\n    });\n  }\n\n  ngOnInit() {\n    this.initializeAvatar();\n    this.initialized = true;\n    this.isGravatarUsed = false;\n  }\n\n  ngOnChanges() {\n    if (this.initialized) {\n      this.initializeAvatar();\n    }\n  }\n\n  /**\n   * Set default values for user inputs if they are not provided\n   */\n  private setDefaultValues() {\n    this.size = this.computeSize();\n    this.ratio = this.ratio === undefined ? this.defaultConfig.ratio : this.ratio;\n    this.requestedSize = this.size * this.ratio;\n    this.round = this.round === undefined ? this.defaultConfig.round : this.round;\n    this.cornerRadius = this.cornerRadius === undefined ? this.defaultConfig.cornerRadius : this.cornerRadius;\n    this.preferGravatar = this.preferGravatar === undefined ? this.defaultConfig.preferGravatar : this.preferGravatar;\n  }\n\n  /**\n   * Initialize avatar.\n   * Custom source has higher priority if preferGravatar is not set on.\n   * Finally, set styles for the avatar.\n   */\n  private initializeAvatar(forcedGravatar?: boolean) {\n    this.setDefaultValues();\n    let url = '';\n    if (this.preferGravatar || forcedGravatar) {\n      url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n      this.isGravatarUsed = true;\n    } else { // this.preferGravatar == false\n      if (this.src) {\n        url = this.src;\n      } else { // fallback to gravatar\n        url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);\n        this.isGravatarUsed = true;\n      }\n    }\n    this.renderer.setProperty(this.elementRef.nativeElement, 'src', url);\n    this.setStyle(this.avatarStyle());\n  }\n\n  /**\n   * Compute the size of the avatar\n   * @return size\n   */\n  private computeSize(): number {\n    let size = this.size === undefined ? this.defaultConfig.size : this.size;\n    if (this.style && this.style.width) {\n      try {\n        const width = this.style.width.trim();\n        if (width.match(/^\\d+px$/)) { // width with px unit\n          size = width.replace('px', '');\n        }\n      } catch (e) {\n        return size;\n      }\n    }\n    return size;\n  }\n\n  /**\n   * Compute style object\n   * @return style object\n   */\n  private avatarStyle() {\n    const style = {\n      width: this.size + 'px',\n      height: this.size + 'px',\n      borderRadius: this.round ? this.defaultConfig.borderRadius : this.cornerRadius + 'px',\n      borderStyle: this.defaultConfig.hasBorder || this.borderColor || this.borderWidth ? this.defaultConfig.borderStyle : 'none',\n      borderColor: this.borderColor ? this.borderColor : this.defaultConfig.borderColor,\n      borderWidth: this.borderWidth ? this.borderWidth + 'px' : this.defaultConfig.borderWidth + 'px',\n      backgroundColor: this.backgroundColor ? this.backgroundColor : this.defaultConfig.backgroundColor,\n    };\n    return { ...style, ...this.style };\n  }\n\n  /**\n   * Set style for the avatar\n   * @param styles style object\n   */\n  private setStyle(styles: any) {\n    Object.keys(styles).forEach(key => {\n      this.renderer.setStyle(this.elementRef.nativeElement, key, styles[key]);\n    });\n  }\n}\n"]}

@@ -180,3 +180,5 @@ import { InjectionToken, Inject, Injectable, Optional, Directive, ElementRef, Input, Renderer2, NgModule, defineInjectable, inject } from '@angular/core';

this.renderer.listen(this.elementRef.nativeElement, 'error', (event) => {
this.initializeAvatar(true); // Force using gravatar
if (!this.isGravatarUsed) {
this.initializeAvatar(true); // Force using gravatar
}
});

@@ -190,2 +192,3 @@ }

this.initialized = true;
this.isGravatarUsed = false;
}

@@ -227,2 +230,3 @@ /**

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -235,2 +239,3 @@ else { // this.preferGravatar == false

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -237,0 +242,0 @@ }

@@ -228,3 +228,5 @@ import { __assign } from 'tslib';

this.renderer.listen(this.elementRef.nativeElement, 'error', function (event) {
_this.initializeAvatar(true); // Force using gravatar
if (!_this.isGravatarUsed) {
_this.initializeAvatar(true); // Force using gravatar
}
});

@@ -241,2 +243,3 @@ }

this.initialized = true;
this.isGravatarUsed = false;
};

@@ -302,2 +305,3 @@ /**

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -310,2 +314,3 @@ else { // this.preferGravatar == false

url = this.gravatarService.generateGravatarUrl(this.email, this.md5Hash, this.requestedSize, this.rating, this.fallback);
this.isGravatarUsed = true;
}

@@ -312,0 +317,0 @@ }

@@ -25,2 +25,3 @@ import { ElementRef, OnChanges, OnInit, Renderer2 } from '@angular/core';

requestedSize: number;
isGravatarUsed: boolean;
constructor(elementRef: ElementRef, renderer: Renderer2, gravatarService: NgxGravatarService);

@@ -27,0 +28,0 @@ ngOnInit(): void;

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

{"__symbolic":"module","version":4,"metadata":{"GravatarModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["gravatarConfig"],"value":{"ngModule":{"__symbolic":"reference","name":"GravatarModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵc"},"useValue":{"__symbolic":"reference","name":"gravatarConfig"}}]}}}},"GravatarConfig":{"__symbolic":"interface"},"FALLBACK":{"blank":"blank","identicon":"identicon","mm":"mm","mp":"mp","monsterid":"monsterid","retro":"retro","robohash":"robohash","wavatar":"wavatar"},"RATING":{"g":"g","pg":"pg","r":"r","x":"x"},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":4,"character":1},"arguments":[{"selector":"[ngx-gravatar], [ngxGravatar]"}]}],"members":{"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}],"email":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"md5Hash":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"fallback":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"rating":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"round":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"cornerRadius":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"borderColor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"borderWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"style":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"preferGravatar":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"backgroundColor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":28,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":29,"character":22},{"__symbolic":"reference","name":"ɵb"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"setDefaultValues":[{"__symbolic":"method"}],"initializeAvatar":[{"__symbolic":"method"}],"computeSize":[{"__symbolic":"method"}],"avatarStyle":[{"__symbolic":"method"}],"setStyle":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":14,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":14,"character":27},"arguments":[{"__symbolic":"reference","name":"ɵc"}]}]],"parameters":[{"__symbolic":"reference","name":"GravatarConfig"}]}],"getDefaultConfig":[{"__symbolic":"method"}],"generateGravatarUrl":[{"__symbolic":"method"}],"determineFallback":[{"__symbolic":"method"}],"determineRating":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"ɵc":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":6,"character":41},"arguments":["gravatarCustom.config"]}},"origins":{"GravatarModule":"./lib/gravatar.module","GravatarConfig":"./lib/gravatar-config","FALLBACK":"./lib/ngx-gravatar.enums","RATING":"./lib/ngx-gravatar.enums","ɵa":"./lib/ngx-gravatar.directive","ɵb":"./lib/ngx-gravatar.service","ɵc":"./lib/gravatar-config.token"},"importAs":"ngx-gravatar"}
{"__symbolic":"module","version":4,"metadata":{"GravatarModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["gravatarConfig"],"value":{"ngModule":{"__symbolic":"reference","name":"GravatarModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵc"},"useValue":{"__symbolic":"reference","name":"gravatarConfig"}}]}}}},"GravatarConfig":{"__symbolic":"interface"},"FALLBACK":{"blank":"blank","identicon":"identicon","mm":"mm","mp":"mp","monsterid":"monsterid","retro":"retro","robohash":"robohash","wavatar":"wavatar"},"RATING":{"g":"g","pg":"pg","r":"r","x":"x"},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":4,"character":1},"arguments":[{"selector":"[ngx-gravatar], [ngxGravatar]"}]}],"members":{"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}],"email":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"md5Hash":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"fallback":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"rating":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"round":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"cornerRadius":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"borderColor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"borderWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"style":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"preferGravatar":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"backgroundColor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":29,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":30,"character":22},{"__symbolic":"reference","name":"ɵb"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"setDefaultValues":[{"__symbolic":"method"}],"initializeAvatar":[{"__symbolic":"method"}],"computeSize":[{"__symbolic":"method"}],"avatarStyle":[{"__symbolic":"method"}],"setStyle":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":14,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":14,"character":27},"arguments":[{"__symbolic":"reference","name":"ɵc"}]}]],"parameters":[{"__symbolic":"reference","name":"GravatarConfig"}]}],"getDefaultConfig":[{"__symbolic":"method"}],"generateGravatarUrl":[{"__symbolic":"method"}],"determineFallback":[{"__symbolic":"method"}],"determineRating":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"ɵc":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":6,"character":41},"arguments":["gravatarCustom.config"]}},"origins":{"GravatarModule":"./lib/gravatar.module","GravatarConfig":"./lib/gravatar-config","FALLBACK":"./lib/ngx-gravatar.enums","RATING":"./lib/ngx-gravatar.enums","ɵa":"./lib/ngx-gravatar.directive","ɵb":"./lib/ngx-gravatar.service","ɵc":"./lib/gravatar-config.token"},"importAs":"ngx-gravatar"}
{
"name": "ngx-gravatar",
"description": "A customizable Gravatar for Angular 4, 5, 6 and 7+ applications - AoT compatible. It supports custom image and Gravatar sources",
"version": "7.2.1",
"version": "7.2.2",
"repository": {

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

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

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