Socket
Socket
Sign inDemoInstall

ngx-avatar

Package Overview
Dependencies
9
Maintainers
1
Versions
45
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 3.3.2 to 3.3.3

2

bundles/ngx-avatar.umd.min.js

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

!function(t,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("is-retina"),require("ts-md5/dist/md5"),require("@angular/core"),require("@angular/common/http"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-avatar",["exports","is-retina","ts-md5/dist/md5","@angular/core","@angular/common/http","rxjs/operators","@angular/common"],r):r(t["ngx-avatar"]={},t.isRetina,t.md5,t.ng.core,t.ng.common.http,t.rxjs.operators,t.ng.common)}(this,function(t,e,r,o,n,i,s){"use strict";e=e&&e.hasOwnProperty("default")?e["default"]:e;var a=function(t,r){return(a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,r){t.__proto__=r}||function(t,r){for(var e in r)r.hasOwnProperty(e)&&(t[e]=r[e])})(t,r)};function u(t,r){function e(){this.constructor=t}a(t,r),t.prototype=null===r?Object.create(r):(e.prototype=r.prototype,new e)}var c=function(){return(c=Object.assign||function(t){for(var r,e=1,o=arguments.length;e<o;e++)for(var n in r=arguments[e])Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n]);return t}).apply(this,arguments)};function p(t,r){var e="function"==typeof Symbol&&t[Symbol.iterator];if(!e)return t;var o,n,i=e.call(t),s=[];try{for(;(void 0===r||0<r--)&&!(o=i.next()).done;)s.push(o.value)}catch(a){n={error:a}}finally{try{o&&!o.done&&(e=i["return"])&&e.call(i)}finally{if(n)throw n.error}}return s}function h(){for(var t=[],r=0;r<arguments.length;r++)t=t.concat(p(arguments[r]));return t}var l=function P(t){this.sourceId=t},f={FACEBOOK:"facebook",GOOGLE:"google",TWITTER:"twitter",VKONTAKTE:"vkontakte",SKYPE:"skype",GRAVATAR:"gravatar",GITHUB:"github",CUSTOM:"custom",INITIALS:"initials",VALUE:"value"},v=function(){function t(t){this.sourceId=t,this.sourceType=f.FACEBOOK}return t.prototype.getAvatar=function(t){return"https://graph.facebook.com/"+this.sourceId+"/picture?width="+t+"&height="+t},t}(),y=function(){function t(t){this.sourceId=t,this.sourceType=f.TWITTER}return t.prototype.getAvatar=function(t){var r=this.getImageSize(t);return"https://twitter.com/"+this.sourceId+"/profile_image?size="+r},t.prototype.getImageSize=function(t){return t<=24?"mini":t<=48?"normal":t<=73?"bigger":"original"},t}(),d=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.GOOGLE,r}return u(t,e),t.prototype.getAvatar=function(){return"https://picasaweb.google.com/data/entry/api/user/"+this.sourceId+"?alt=json"},t.prototype.processResponse=function(t,r){var e=t.entry.gphoto$thumbnail.$t;if(e)return e.replace("s64","s"+r)},t}(l),g=function(){function t(t){this.sourceId=t,this.sourceType=f.CUSTOM}return t.prototype.getAvatar=function(){return this.sourceId},t}(),I=function(){function t(t){this.sourceId=t,this.sourceType=f.INITIALS}return t.prototype.getAvatar=function(t){return this.getInitials(this.sourceId,t)},t.prototype.getInitials=function(t,r){if(!(t=t?t.trim():null))return"";var e=t.split(" ");return r&&r<e.length?this.constructInitials(e.slice(0,r)):this.constructInitials(e)},t.prototype.constructInitials=function(t){return t&&t.length?t.filter(function(t){return t&&0<t.length}).map(function(t){return t[0].toUpperCase()}).join(""):""},t}(),A=function(){function t(t){this.value=t,this.sourceType=f.GRAVATAR,this.sourceId=t.match("^[a-f0-9]{32}$")?t:r.Md5.hashStr(t).toString()}return t.prototype.getAvatar=function(t){var r=e()?2*t:t;return"https://secure.gravatar.com/avatar/"+this.sourceId+"?s="+r+"&d=404"},t}(),S=function(){function t(t){this.sourceId=t,this.sourceType=f.SKYPE}return t.prototype.getAvatar=function(){return"https://api.skype.com/users/"+this.sourceId+"/profile/avatar"},t}(),m=function(){function t(t){this.sourceId=t,this.sourceType=f.VALUE}return t.prototype.getAvatar=function(){return this.sourceId},t}(),T=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.VKONTAKTE,r}return u(t,e),t.prototype.getAvatar=function(t){var r=this.getImageSize(t);return"https://api.vk.com/method/users.get?user_id="+this.sourceId+"&v=5.8&fields="+r},t.prototype.processResponse=function(t){var r=Object.keys(t.response[0]).pop();return t.response[0][r]},t.prototype.getImageSize=function(t){return t<=50?"photo_50":t<=100?"photo_100":t<=200?"photo_200":"photo_max"},t}(l),C=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.GITHUB,r}return u(t,e),t.prototype.getAvatar=function(){return"https://api.github.com/users/"+this.sourceId},t.prototype.processResponse=function(t,r){return r?t.avatar_url+"&s="+r:t.avatar_url},t}(l),b=function(){function t(){this.sources={},this.sources[f.FACEBOOK]=v,this.sources[f.TWITTER]=y,this.sources[f.GOOGLE]=d,this.sources[f.SKYPE]=S,this.sources[f.GRAVATAR]=A,this.sources[f.CUSTOM]=g,this.sources[f.INITIALS]=I,this.sources[f.VALUE]=m,this.sources[f.VKONTAKTE]=T,this.sources[f.GITHUB]=C}return t.prototype.newInstance=function(t,r){return new this.sources[t](r)},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[]},t}(),O=new o.InjectionToken("avatar.config"),x=function(){function t(t){this.userConfig=t}return t.prototype.getAvatarSources=function(r){if(this.userConfig&&this.userConfig.sourcePriorityOrder&&this.userConfig.sourcePriorityOrder.length){var e=h(new Set(this.userConfig.sourcePriorityOrder)).filter(function(t){return r.includes(t)});return h(e,r.filter(function(t){return!e.includes(t)}))}return r},t.prototype.getAvatarColors=function(t){return this.userConfig&&this.userConfig.colors&&this.userConfig.colors.length&&this.userConfig.colors||t},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[{type:undefined,decorators:[{type:o.Optional},{type:o.Inject,args:[O]}]}]},t}(),R=[f.FACEBOOK,f.GOOGLE,f.TWITTER,f.VKONTAKTE,f.SKYPE,f.GRAVATAR,f.GITHUB,f.CUSTOM,f.INITIALS,f.VALUE],E=["#1abc9c","#3498db","#f1c40f","#8e44ad","#e74c3c","#d35400","#2c3e50","#7f8c8d"],k=function(){function t(t,r){this.http=t,this.avatarConfigService=r,this.avatarSources=R,this.avatarColors=E,this.overrideAvatarSources(),this.overrideAvatarColors()}return t.prototype.fetchAvatar=function(t){return this.http.get(t)},t.prototype.getRandomColor=function(t){if(!t)return"transparent";var r=this.calculateAsciiCode(t);return this.avatarColors[r%this.avatarColors.length]},t.prototype.copmareSources=function(t,r){return this.getSourcePriority(t)-this.getSourcePriority(r)},t.prototype.isSource=function(t){return this.avatarSources.includes(t)},t.prototype.isTextAvatar=function(t){return[f.INITIALS,f.VALUE].includes(t)},t.prototype.overrideAvatarSources=function(){this.avatarSources=this.avatarConfigService.getAvatarSources(R)},t.prototype.overrideAvatarColors=function(){this.avatarColors=this.avatarConfigService.getAvatarColors(E)},t.prototype.calculateAsciiCode=function(t){return t.split("").map(function(t){return t.charCodeAt(0)}).reduce(function(t,r){return t+r})},t.prototype.getSourcePriority=function(t){return this.avatarSources.indexOf(t)},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[{type:n.HttpClient},{type:x}]},t}(),z=function(){function t(t,r,e){this.elementRef=t,this.sourceFactory=r,this.avatarService=e,this.round=!0,this.size=50,this.textSizeRatio=3,this.fgColor="#FFF",this.style={},this.cornerRadius=0,this.clickOnAvatar=new o.EventEmitter,this.isAlive=!0,this.avatarStyle={},this.hostStyle={},this.currentSource=0,this.sources=Array()}return t.prototype.onAvatarClicked=function(){this.clickOnAvatar.emit(this.sources[this.currentSource-1])},t.prototype.ngOnChanges=function(t){for(var r in t)if(this.avatarService.isSource(r)&&t[r].currentValue){var e=t[r].currentValue;this.addSource(f[r.toUpperCase()],e)}this.initializeAvatar()},t.prototype.fetchAvatarSource=function(t){var r=this.sources[this.currentSource];r&&(this.avatarService.isTextAvatar(r.sourceType)?(this.buildTextAvatar(r),this.avatarSrc=undefined):this.buildImageAvatar(r),this.currentSource++)},t.prototype.ngOnDestroy=function(){this.isAlive=!1},t.prototype.initializeAvatar=function(){(this.currentSource=0)<this.sources.length&&this.sources[this.currentSource]&&(this.sortAvatarSources(),this.fetchAvatarSource(),this.hostStyle={width:this.size+"px",height:this.size+"px"})},t.prototype.sortAvatarSources=function(){var e=this;this.sources.sort(function(t,r){return e.avatarService.copmareSources(t.sourceType,r.sourceType)})},t.prototype.buildTextAvatar=function(t){this.avatarText=t.getAvatar(this.initialsSize),this.avatarStyle=this.getInitialsStyle(t.sourceId)},t.prototype.buildImageAvatar=function(t){this.avatarStyle=this.getImageStyle(),t instanceof l?this.fetchAndProcessAsyncAvatar(t):this.avatarSrc=t.getAvatar(this.size)},t.prototype.getInitialsStyle=function(t){return c({textAlign:"center",borderRadius:this.round?"100%":this.cornerRadius+"px",border:this.borderColor?"1px solid "+this.borderColor:"",textTransform:"uppercase",color:this.fgColor,backgroundColor:this.bgColor?this.bgColor:this.avatarService.getRandomColor(t),font:Math.floor(this.size/this.textSizeRatio)+"px Helvetica, Arial, sans-serif",lineHeight:this.size+"px"},this.style)},t.prototype.getImageStyle=function(){return c({maxWidth:"100%",borderRadius:this.round?"50%":this.cornerRadius+"px",border:this.borderColor?"1px solid "+this.borderColor:"",width:this.size,height:this.size},this.style)},t.prototype.fetchAndProcessAsyncAvatar=function(r){var e=this;this.avatarService.fetchAvatar(r.getAvatar()).pipe(i.takeWhile(function(){return!e.isAlive}),i.map(function(t){return r.processResponse(t,e.size)})).subscribe(function(t){return e.avatarSrc=t},function(t){console.error("ngx-avatar: error while fetching "+r.sourceType+" avatar ")})},t.prototype.addSource=function(r,t){if(this.isSourceExist(r)){var e=this.sources.findIndex(function(t){return t.sourceType===r});this.sources[e].sourceId=t}else this.sources.push(this.sourceFactory.newInstance(r,t))},t.prototype.isSourceExist=function(t){return this.sources.map(function(t){return t.sourceType}).includes(t)},t.decorators=[{type:o.Component,args:[{selector:"ngx-avatar",template:'\n <div\n (click)="onAvatarClicked()"\n class="avatar-container"\n [ngStyle]="hostStyle"\n >\n <img\n *ngIf="avatarSrc; else textAvatar"\n [src]="avatarSrc"\n [width]="size"\n [height]="size"\n [ngStyle]="avatarStyle"\n (error)="fetchAvatarSource($event)"\n class="avatar-content"\n />\n <ng-template #textAvatar>\n <div *ngIf="avatarText" class="avatar-content" [ngStyle]="avatarStyle">\n {{ avatarText }}\n </div>\n </ng-template>\n </div>\n ',styles:["\n :host {\n border-radius: '50%';\n }\n "]}]}],t.ctorParameters=function(){return[{type:o.ElementRef},{type:b},{type:k}]},t.propDecorators={round:[{type:o.Input}],size:[{type:o.Input}],textSizeRatio:[{type:o.Input}],bgColor:[{type:o.Input}],fgColor:[{type:o.Input}],borderColor:[{type:o.Input}],style:[{type:o.Input}],cornerRadius:[{type:o.Input}],facebook:[{type:o.Input,args:["facebookId"]}],twitter:[{type:o.Input,args:["twitterId"]}],google:[{type:o.Input,args:["googleId"]}],vkontakte:[{type:o.Input,args:["vkontakteId"]}],skype:[{type:o.Input,args:["skypeId"]}],gravatar:[{type:o.Input,args:["gravatarId"]}],github:[{type:o.Input,args:["githubId"]}],custom:[{type:o.Input,args:["src"]}],initials:[{type:o.Input,args:["name"]}],value:[{type:o.Input,args:["value"]}],placeholder:[{type:o.Input,args:["placeholder"]}],initialsSize:[{type:o.Input,args:["initialsSize"]}],clickOnAvatar:[{type:o.Output}]},t}(),w=function(){function r(){}return r.forRoot=function(t){return{ngModule:r,providers:[{provide:O,useValue:t||{}}]}},r.decorators=[{type:o.NgModule,args:[{imports:[s.CommonModule,n.HttpClientModule],declarations:[z],providers:[b,k,x],exports:[z]}]}],r}();t.AvatarModule=w,t.defaultSources=R,t.defaultColors=E,t.AvatarService=k,t.AvatarSource=f,t.ɵc=x,t.ɵd=O,t.ɵa=z,t.ɵb=b,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("is-retina"),require("ts-md5/dist/md5"),require("@angular/core"),require("@angular/common/http"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-avatar",["exports","is-retina","ts-md5/dist/md5","@angular/core","@angular/common/http","rxjs/operators","@angular/common"],r):r(t["ngx-avatar"]={},t.isRetina,t.md5,t.ng.core,t.ng.common.http,t.rxjs.operators,t.ng.common)}(this,function(t,e,r,o,n,i,s){"use strict";e=e&&e.hasOwnProperty("default")?e["default"]:e;var a=function(t,r){return(a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,r){t.__proto__=r}||function(t,r){for(var e in r)r.hasOwnProperty(e)&&(t[e]=r[e])})(t,r)};function u(t,r){function e(){this.constructor=t}a(t,r),t.prototype=null===r?Object.create(r):(e.prototype=r.prototype,new e)}var c=function(){return(c=Object.assign||function(t){for(var r,e=1,o=arguments.length;e<o;e++)for(var n in r=arguments[e])Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n]);return t}).apply(this,arguments)};function p(t,r){var e="function"==typeof Symbol&&t[Symbol.iterator];if(!e)return t;var o,n,i=e.call(t),s=[];try{for(;(void 0===r||0<r--)&&!(o=i.next()).done;)s.push(o.value)}catch(a){n={error:a}}finally{try{o&&!o.done&&(e=i["return"])&&e.call(i)}finally{if(n)throw n.error}}return s}function h(){for(var t=[],r=0;r<arguments.length;r++)t=t.concat(p(arguments[r]));return t}var l=function P(t){this.sourceId=t},f={FACEBOOK:"facebook",GOOGLE:"google",TWITTER:"twitter",VKONTAKTE:"vkontakte",SKYPE:"skype",GRAVATAR:"gravatar",GITHUB:"github",CUSTOM:"custom",INITIALS:"initials",VALUE:"value"},v=function(){function t(t){this.sourceId=t,this.sourceType=f.FACEBOOK}return t.prototype.getAvatar=function(t){return"https://graph.facebook.com/"+this.sourceId+"/picture?width="+t+"&height="+t},t}(),y=function(){function t(t){this.sourceId=t,this.sourceType=f.TWITTER}return t.prototype.getAvatar=function(t){var r=this.getImageSize(t);return"https://twitter.com/"+this.sourceId+"/profile_image?size="+r},t.prototype.getImageSize=function(t){return t<=24?"mini":t<=48?"normal":t<=73?"bigger":"original"},t}(),d=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.GOOGLE,r}return u(t,e),t.prototype.getAvatar=function(){return"https://picasaweb.google.com/data/entry/api/user/"+this.sourceId+"?alt=json"},t.prototype.processResponse=function(t,r){var e=t.entry.gphoto$thumbnail.$t;if(e)return e.replace("s64","s"+r)},t}(l),g=function(){function t(t){this.sourceId=t,this.sourceType=f.CUSTOM}return t.prototype.getAvatar=function(){return this.sourceId},t}(),I=function(){function t(t){this.sourceId=t,this.sourceType=f.INITIALS}return t.prototype.getAvatar=function(t){return this.getInitials(this.sourceId,t)},t.prototype.getInitials=function(t,r){if(!(t=t?t.trim():null))return"";var e=t.split(" ");return r&&r<e.length?this.constructInitials(e.slice(0,r)):this.constructInitials(e)},t.prototype.constructInitials=function(t){return t&&t.length?t.filter(function(t){return t&&0<t.length}).map(function(t){return t[0].toUpperCase()}).join(""):""},t}(),A=function(){function t(t){this.value=t,this.sourceType=f.GRAVATAR,this.sourceId=t.match("^[a-f0-9]{32}$")?t:r.Md5.hashStr(t).toString()}return t.prototype.getAvatar=function(t){var r=e()?2*t:t;return"https://secure.gravatar.com/avatar/"+this.sourceId+"?s="+r+"&d=404"},t}(),S=function(){function t(t){this.sourceId=t,this.sourceType=f.SKYPE}return t.prototype.getAvatar=function(){return"https://api.skype.com/users/"+this.sourceId+"/profile/avatar"},t}(),m=function(){function t(t){this.sourceId=t,this.sourceType=f.VALUE}return t.prototype.getAvatar=function(){return this.sourceId},t}(),T=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.VKONTAKTE,r}return u(t,e),t.prototype.getAvatar=function(t){var r=this.getImageSize(t);return"https://api.vk.com/method/users.get?user_id="+this.sourceId+"&v=5.8&fields="+r},t.prototype.processResponse=function(t){var r=Object.keys(t.response[0]).pop();return t.response[0][r]},t.prototype.getImageSize=function(t){return t<=50?"photo_50":t<=100?"photo_100":t<=200?"photo_200":"photo_max"},t}(l),C=function(e){function t(t){var r=e.call(this,t)||this;return r.sourceType=f.GITHUB,r}return u(t,e),t.prototype.getAvatar=function(){return"https://api.github.com/users/"+this.sourceId},t.prototype.processResponse=function(t,r){return r?t.avatar_url+"&s="+r:t.avatar_url},t}(l),b=function(){function t(){this.sources={},this.sources[f.FACEBOOK]=v,this.sources[f.TWITTER]=y,this.sources[f.GOOGLE]=d,this.sources[f.SKYPE]=S,this.sources[f.GRAVATAR]=A,this.sources[f.CUSTOM]=g,this.sources[f.INITIALS]=I,this.sources[f.VALUE]=m,this.sources[f.VKONTAKTE]=T,this.sources[f.GITHUB]=C}return t.prototype.newInstance=function(t,r){return new this.sources[t](r)},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[]},t}(),O=new o.InjectionToken("avatar.config"),x=function(){function t(t){this.userConfig=t}return t.prototype.getAvatarSources=function(r){if(this.userConfig&&this.userConfig.sourcePriorityOrder&&this.userConfig.sourcePriorityOrder.length){var e=h(new Set(this.userConfig.sourcePriorityOrder)).filter(function(t){return r.includes(t)});return h(e,r.filter(function(t){return!e.includes(t)}))}return r},t.prototype.getAvatarColors=function(t){return this.userConfig&&this.userConfig.colors&&this.userConfig.colors.length&&this.userConfig.colors||t},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[{type:undefined,decorators:[{type:o.Optional},{type:o.Inject,args:[O]}]}]},t}(),R=[f.FACEBOOK,f.GOOGLE,f.TWITTER,f.VKONTAKTE,f.SKYPE,f.GRAVATAR,f.GITHUB,f.CUSTOM,f.INITIALS,f.VALUE],E=["#1abc9c","#3498db","#f1c40f","#8e44ad","#e74c3c","#d35400","#2c3e50","#7f8c8d"],k=function(){function t(t,r){this.http=t,this.avatarConfigService=r,this.avatarSources=R,this.avatarColors=E,this.overrideAvatarSources(),this.overrideAvatarColors()}return t.prototype.fetchAvatar=function(t){return this.http.get(t)},t.prototype.getRandomColor=function(t){if(!t)return"transparent";var r=this.calculateAsciiCode(t);return this.avatarColors[r%this.avatarColors.length]},t.prototype.copmareSources=function(t,r){return this.getSourcePriority(t)-this.getSourcePriority(r)},t.prototype.isSource=function(t){return this.avatarSources.includes(t)},t.prototype.isTextAvatar=function(t){return[f.INITIALS,f.VALUE].includes(t)},t.prototype.overrideAvatarSources=function(){this.avatarSources=this.avatarConfigService.getAvatarSources(R)},t.prototype.overrideAvatarColors=function(){this.avatarColors=this.avatarConfigService.getAvatarColors(E)},t.prototype.calculateAsciiCode=function(t){return t.split("").map(function(t){return t.charCodeAt(0)}).reduce(function(t,r){return t+r})},t.prototype.getSourcePriority=function(t){return this.avatarSources.indexOf(t)},t.decorators=[{type:o.Injectable}],t.ctorParameters=function(){return[{type:n.HttpClient},{type:x}]},t}(),z=function(){function t(t,r,e){this.elementRef=t,this.sourceFactory=r,this.avatarService=e,this.round=!0,this.size=50,this.textSizeRatio=3,this.fgColor="#FFF",this.style={},this.cornerRadius=0,this.clickOnAvatar=new o.EventEmitter,this.isAlive=!0,this.avatarStyle={},this.hostStyle={},this.currentSource=0,this.sources=Array()}return t.prototype.onAvatarClicked=function(){this.clickOnAvatar.emit(this.sources[this.currentSource-1])},t.prototype.ngOnChanges=function(t){for(var r in t)if(this.avatarService.isSource(r)&&t[r].currentValue){var e=t[r].currentValue;this.addSource(f[r.toUpperCase()],e)}this.initializeAvatar()},t.prototype.fetchAvatarSource=function(t){var r=this.sources[this.currentSource];r&&(this.avatarService.isTextAvatar(r.sourceType)?(this.buildTextAvatar(r),this.avatarSrc=undefined):this.buildImageAvatar(r),this.currentSource++)},t.prototype.ngOnDestroy=function(){this.isAlive=!1},t.prototype.initializeAvatar=function(){(this.currentSource=0)<this.sources.length&&this.sources[this.currentSource]&&(this.sortAvatarSources(),this.fetchAvatarSource(),this.hostStyle={width:this.size+"px",height:this.size+"px"})},t.prototype.sortAvatarSources=function(){var e=this;this.sources.sort(function(t,r){return e.avatarService.copmareSources(t.sourceType,r.sourceType)})},t.prototype.buildTextAvatar=function(t){this.avatarText=t.getAvatar(this.initialsSize),this.avatarStyle=this.getInitialsStyle(t.sourceId)},t.prototype.buildImageAvatar=function(t){this.avatarStyle=this.getImageStyle(),t instanceof l?this.fetchAndProcessAsyncAvatar(t):this.avatarSrc=t.getAvatar(this.size)},t.prototype.getInitialsStyle=function(t){return c({textAlign:"center",borderRadius:this.round?"100%":this.cornerRadius+"px",border:this.borderColor?"1px solid "+this.borderColor:"",textTransform:"uppercase",color:this.fgColor,backgroundColor:this.bgColor?this.bgColor:this.avatarService.getRandomColor(t),font:Math.floor(this.size/this.textSizeRatio)+"px Helvetica, Arial, sans-serif",lineHeight:this.size+"px"},this.style)},t.prototype.getImageStyle=function(){return c({maxWidth:"100%",borderRadius:this.round?"50%":this.cornerRadius+"px",border:this.borderColor?"1px solid "+this.borderColor:"",width:this.size,height:this.size},this.style)},t.prototype.fetchAndProcessAsyncAvatar=function(r){var e=this;this.avatarService.fetchAvatar(r.getAvatar()).pipe(i.takeWhile(function(){return e.isAlive}),i.map(function(t){return r.processResponse(t,e.size)})).subscribe(function(t){return e.avatarSrc=t},function(t){console.error("ngx-avatar: error while fetching "+r.sourceType+" avatar ")})},t.prototype.addSource=function(r,t){if(this.isSourceExist(r)){var e=this.sources.findIndex(function(t){return t.sourceType===r});this.sources[e].sourceId=t}else this.sources.push(this.sourceFactory.newInstance(r,t))},t.prototype.isSourceExist=function(t){return this.sources.map(function(t){return t.sourceType}).includes(t)},t.decorators=[{type:o.Component,args:[{selector:"ngx-avatar",template:'\n <div\n (click)="onAvatarClicked()"\n class="avatar-container"\n [ngStyle]="hostStyle"\n >\n <img\n *ngIf="avatarSrc; else textAvatar"\n [src]="avatarSrc"\n [width]="size"\n [height]="size"\n [ngStyle]="avatarStyle"\n (error)="fetchAvatarSource($event)"\n class="avatar-content"\n />\n <ng-template #textAvatar>\n <div *ngIf="avatarText" class="avatar-content" [ngStyle]="avatarStyle">\n {{ avatarText }}\n </div>\n </ng-template>\n </div>\n ',styles:["\n :host {\n border-radius: '50%';\n }\n "]}]}],t.ctorParameters=function(){return[{type:o.ElementRef},{type:b},{type:k}]},t.propDecorators={round:[{type:o.Input}],size:[{type:o.Input}],textSizeRatio:[{type:o.Input}],bgColor:[{type:o.Input}],fgColor:[{type:o.Input}],borderColor:[{type:o.Input}],style:[{type:o.Input}],cornerRadius:[{type:o.Input}],facebook:[{type:o.Input,args:["facebookId"]}],twitter:[{type:o.Input,args:["twitterId"]}],google:[{type:o.Input,args:["googleId"]}],vkontakte:[{type:o.Input,args:["vkontakteId"]}],skype:[{type:o.Input,args:["skypeId"]}],gravatar:[{type:o.Input,args:["gravatarId"]}],github:[{type:o.Input,args:["githubId"]}],custom:[{type:o.Input,args:["src"]}],initials:[{type:o.Input,args:["name"]}],value:[{type:o.Input,args:["value"]}],placeholder:[{type:o.Input,args:["placeholder"]}],initialsSize:[{type:o.Input,args:["initialsSize"]}],clickOnAvatar:[{type:o.Output}]},t}(),w=function(){function r(){}return r.forRoot=function(t){return{ngModule:r,providers:[{provide:O,useValue:t||{}}]}},r.decorators=[{type:o.NgModule,args:[{imports:[s.CommonModule,n.HttpClientModule],declarations:[z],providers:[b,k,x],exports:[z]}]}],r}();t.AvatarModule=w,t.defaultSources=R,t.defaultColors=E,t.AvatarService=k,t.AvatarSource=f,t.ɵc=x,t.ɵd=O,t.ɵa=z,t.ɵb=b,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=ngx-avatar.umd.min.js.map

@@ -178,3 +178,3 @@ /**

.fetchAvatar(source.getAvatar())
.pipe(takeWhile(() => !this.isAlive), map(response => source.processResponse(response, this.size)))
.pipe(takeWhile(() => this.isAlive), map(response => source.processResponse(response, this.size)))
.subscribe(avatarSrc => (this.avatarSrc = avatarSrc), err => {

@@ -337,2 +337,2 @@ console.error(`ngx-avatar: error while fetching ${source.sourceType} avatar `);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"ng://ngx-avatar/","sources":["lib/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  SimpleChange,\n  OnDestroy\n} from '@angular/core';\n\nimport { Source } from './sources/source';\nimport { AsyncSource } from './sources/async-source';\nimport { SourceFactory } from './sources/source.factory';\nimport { AvatarService } from './avatar.service';\nimport { AvatarSource } from './sources/avatar-source.enum';\nimport { takeWhile, map } from 'rxjs/operators';\n\n/**\n * Universal avatar component that\n * generates avatar from different sources\n *\n * export\n * class AvatarComponent\n * implements {OnChanges}\n */\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'ngx-avatar',\n  styles: [\n    `\n      :host {\n        border-radius: '50%';\n      }\n    `\n  ],\n  template: `\n    <div\n      (click)=\"onAvatarClicked()\"\n      class=\"avatar-container\"\n      [ngStyle]=\"hostStyle\"\n    >\n      <img\n        *ngIf=\"avatarSrc; else textAvatar\"\n        [src]=\"avatarSrc\"\n        [width]=\"size\"\n        [height]=\"size\"\n        [ngStyle]=\"avatarStyle\"\n        (error)=\"fetchAvatarSource($event)\"\n        class=\"avatar-content\"\n      />\n      <ng-template #textAvatar>\n        <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n          {{ avatarText }}\n        </div>\n      </ng-template>\n    </div>\n  `\n})\nexport class AvatarComponent implements OnChanges, OnDestroy {\n  @Input()\n  public round = true;\n  @Input()\n  public size = 50;\n  @Input()\n  public textSizeRatio = 3;\n  @Input()\n  public bgColor: string;\n  @Input()\n  public fgColor = '#FFF';\n  @Input()\n  public borderColor: string;\n  @Input()\n  public style: any = {};\n  @Input()\n  public cornerRadius = 0;\n  @Input('facebookId')\n  public facebook: string;\n  @Input('twitterId')\n  public twitter: string;\n  @Input('googleId')\n  public google: string;\n  @Input('vkontakteId')\n  public vkontakte: string;\n  @Input('skypeId')\n  public skype: string;\n  @Input('gravatarId')\n  public gravatar: string;\n  @Input('githubId')\n  public github: string;\n  @Input('src')\n  public custom: string;\n  @Input('name')\n  public initials: string;\n  @Input('value')\n  public value: string;\n  @Input('placeholder')\n  public placeholder: string;\n  @Input('initialsSize')\n  public initialsSize: number;\n\n  @Output()\n  public clickOnAvatar: EventEmitter<any> = new EventEmitter<any>();\n\n  public isAlive = true;\n  public avatarSrc: string;\n  public avatarText: string;\n  public avatarStyle: any = {};\n  public hostStyle: any = {};\n\n  private currentSource = 0;\n  private sources: Source[] = Array();\n\n  constructor(\n    public elementRef: ElementRef,\n    public sourceFactory: SourceFactory,\n    private avatarService: AvatarService\n  ) {}\n\n  public onAvatarClicked(): void {\n    this.clickOnAvatar.emit(this.sources[this.currentSource - 1]);\n  }\n\n  /**\n   * Detect inputs change\n   *\n   * param {{ [propKey: string]: SimpleChange }} changes\n   *\n   * memberof AvatarComponent\n   */\n  public ngOnChanges(changes: { [propKey: string]: SimpleChange }): void {\n    for (const propName in changes) {\n      if (\n        this.avatarService.isSource(propName) &&\n        changes[propName].currentValue\n      ) {\n        const currentValue = changes[propName].currentValue;\n        this.addSource(AvatarSource[propName.toUpperCase()], currentValue);\n      }\n    }\n    // reintialize the avatar component when a source property value has changed\n    // the fallback system must be re-invoked with the new values.\n    this.initializeAvatar();\n  }\n\n  /**\n   * Fetch avatar source\n   *\n   * param {any} event\n   *\n   * memberOf AvatarComponent\n   */\n  public fetchAvatarSource(event?: any): void {\n    const avatarSource = this.sources[this.currentSource];\n    if (!avatarSource) {\n      return;\n    }\n    if (this.avatarService.isTextAvatar(avatarSource.sourceType)) {\n      this.buildTextAvatar(avatarSource);\n      // TODO: check if this is needed\n      this.avatarSrc = undefined;\n    } else {\n      this.buildImageAvatar(avatarSource);\n    }\n    this.currentSource++;\n  }\n\n  public ngOnDestroy(): void {\n    this.isAlive = false;\n  }\n\n  /**\n   * Initialize the avatar component and its fallback system\n   */\n  private initializeAvatar(): void {\n    this.currentSource = 0;\n    if (this.sources.length > 0 && this.sources[this.currentSource]) {\n      this.sortAvatarSources();\n      this.fetchAvatarSource();\n      this.hostStyle = {\n        width: this.size + 'px',\n        height: this.size + 'px'\n      };\n    }\n  }\n\n  private sortAvatarSources(): void {\n    this.sources.sort((source1, source2) =>\n      this.avatarService.copmareSources(source1.sourceType, source2.sourceType)\n    );\n  }\n\n  private buildTextAvatar(avatarSource: Source): void {\n    this.avatarText = avatarSource.getAvatar(this.initialsSize);\n    this.avatarStyle = this.getInitialsStyle(avatarSource.sourceId);\n  }\n\n  private buildImageAvatar(avatarSource: Source): void {\n    this.avatarStyle = this.getImageStyle();\n    if (avatarSource instanceof AsyncSource) {\n      this.fetchAndProcessAsyncAvatar(avatarSource);\n    } else {\n      this.avatarSrc = avatarSource.getAvatar(this.size);\n    }\n  }\n\n  /**\n   *\n   * returns initials style\n   *\n   * memberOf AvatarComponent\n   */\n  private getInitialsStyle(avatarValue: string): void {\n    return {\n      textAlign: 'center',\n      borderRadius: this.round ? '100%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      textTransform: 'uppercase',\n      color: this.fgColor,\n      backgroundColor: this.bgColor\n        ? this.bgColor\n        : this.avatarService.getRandomColor(avatarValue),\n      font:\n        Math.floor(this.size / this.textSizeRatio) +\n        'px Helvetica, Arial, sans-serif',\n      lineHeight: this.size + 'px',\n      ...this.style\n    };\n  }\n\n  /**\n   *\n   * returns image style\n   *\n   * memberOf AvatarComponent\n   */\n  private getImageStyle(): void {\n    return {\n      maxWidth: '100%',\n      borderRadius: this.round ? '50%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      width: this.size,\n      height: this.size,\n      ...this.style\n    };\n  }\n  /**\n   * Fetch avatar image asynchrounsly.\n   *\n   * param {Source} source represents avatar source\n   * memberof AvatarComponent\n   */\n  private fetchAndProcessAsyncAvatar(source: AsyncSource): void {\n    this.avatarService\n      .fetchAvatar(source.getAvatar())\n      .pipe(\n        takeWhile(() => !this.isAlive),\n        map(response => source.processResponse(response, this.size))\n      )\n      .subscribe(\n        avatarSrc => (this.avatarSrc = avatarSrc),\n        err => {\n          console.error(\n            `ngx-avatar: error while fetching ${source.sourceType} avatar `\n          );\n        }\n      );\n  }\n\n  /**\n   * Add avatar source\n   *\n   * param sourceType avatar source type e.g facebook,twitter, etc.\n   * param sourceValue  source value e.g facebookId value, etc.\n   */\n  private addSource(sourceType: AvatarSource, sourceValue: string): void {\n    if (!this.isSourceExist(sourceType)) {\n      this.sources.push(\n        this.sourceFactory.newInstance(sourceType, sourceValue)\n      );\n    } else {\n      const index = this.sources.findIndex(\n        source => source.sourceType === sourceType\n      );\n      this.sources[index].sourceId = sourceValue;\n    }\n  }\n\n  private isSourceExist(avatarSource: AvatarSource): boolean {\n    return this.sources.map(source => source.sourceType).includes(avatarSource);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"ng://ngx-avatar/","sources":["lib/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  SimpleChange,\n  OnDestroy\n} from '@angular/core';\n\nimport { Source } from './sources/source';\nimport { AsyncSource } from './sources/async-source';\nimport { SourceFactory } from './sources/source.factory';\nimport { AvatarService } from './avatar.service';\nimport { AvatarSource } from './sources/avatar-source.enum';\nimport { takeWhile, map } from 'rxjs/operators';\n\n/**\n * Universal avatar component that\n * generates avatar from different sources\n *\n * export\n * class AvatarComponent\n * implements {OnChanges}\n */\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'ngx-avatar',\n  styles: [\n    `\n      :host {\n        border-radius: '50%';\n      }\n    `\n  ],\n  template: `\n    <div\n      (click)=\"onAvatarClicked()\"\n      class=\"avatar-container\"\n      [ngStyle]=\"hostStyle\"\n    >\n      <img\n        *ngIf=\"avatarSrc; else textAvatar\"\n        [src]=\"avatarSrc\"\n        [width]=\"size\"\n        [height]=\"size\"\n        [ngStyle]=\"avatarStyle\"\n        (error)=\"fetchAvatarSource($event)\"\n        class=\"avatar-content\"\n      />\n      <ng-template #textAvatar>\n        <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n          {{ avatarText }}\n        </div>\n      </ng-template>\n    </div>\n  `\n})\nexport class AvatarComponent implements OnChanges, OnDestroy {\n  @Input()\n  public round = true;\n  @Input()\n  public size = 50;\n  @Input()\n  public textSizeRatio = 3;\n  @Input()\n  public bgColor: string;\n  @Input()\n  public fgColor = '#FFF';\n  @Input()\n  public borderColor: string;\n  @Input()\n  public style: any = {};\n  @Input()\n  public cornerRadius = 0;\n  @Input('facebookId')\n  public facebook: string;\n  @Input('twitterId')\n  public twitter: string;\n  @Input('googleId')\n  public google: string;\n  @Input('vkontakteId')\n  public vkontakte: string;\n  @Input('skypeId')\n  public skype: string;\n  @Input('gravatarId')\n  public gravatar: string;\n  @Input('githubId')\n  public github: string;\n  @Input('src')\n  public custom: string;\n  @Input('name')\n  public initials: string;\n  @Input('value')\n  public value: string;\n  @Input('placeholder')\n  public placeholder: string;\n  @Input('initialsSize')\n  public initialsSize: number;\n\n  @Output()\n  public clickOnAvatar: EventEmitter<any> = new EventEmitter<any>();\n\n  public isAlive = true;\n  public avatarSrc: string;\n  public avatarText: string;\n  public avatarStyle: any = {};\n  public hostStyle: any = {};\n\n  private currentSource = 0;\n  private sources: Source[] = Array();\n\n  constructor(\n    public elementRef: ElementRef,\n    public sourceFactory: SourceFactory,\n    private avatarService: AvatarService\n  ) {}\n\n  public onAvatarClicked(): void {\n    this.clickOnAvatar.emit(this.sources[this.currentSource - 1]);\n  }\n\n  /**\n   * Detect inputs change\n   *\n   * param {{ [propKey: string]: SimpleChange }} changes\n   *\n   * memberof AvatarComponent\n   */\n  public ngOnChanges(changes: { [propKey: string]: SimpleChange }): void {\n    for (const propName in changes) {\n      if (\n        this.avatarService.isSource(propName) &&\n        changes[propName].currentValue\n      ) {\n        const currentValue = changes[propName].currentValue;\n        this.addSource(AvatarSource[propName.toUpperCase()], currentValue);\n      }\n    }\n    // reintialize the avatar component when a source property value has changed\n    // the fallback system must be re-invoked with the new values.\n    this.initializeAvatar();\n  }\n\n  /**\n   * Fetch avatar source\n   *\n   * param {any} event\n   *\n   * memberOf AvatarComponent\n   */\n  public fetchAvatarSource(event?: any): void {\n    const avatarSource = this.sources[this.currentSource];\n    if (!avatarSource) {\n      return;\n    }\n    if (this.avatarService.isTextAvatar(avatarSource.sourceType)) {\n      this.buildTextAvatar(avatarSource);\n      // TODO: check if this is needed\n      this.avatarSrc = undefined;\n    } else {\n      this.buildImageAvatar(avatarSource);\n    }\n    this.currentSource++;\n  }\n\n  public ngOnDestroy(): void {\n    this.isAlive = false;\n  }\n\n  /**\n   * Initialize the avatar component and its fallback system\n   */\n  private initializeAvatar(): void {\n    this.currentSource = 0;\n    if (this.sources.length > 0 && this.sources[this.currentSource]) {\n      this.sortAvatarSources();\n      this.fetchAvatarSource();\n      this.hostStyle = {\n        width: this.size + 'px',\n        height: this.size + 'px'\n      };\n    }\n  }\n\n  private sortAvatarSources(): void {\n    this.sources.sort((source1, source2) =>\n      this.avatarService.copmareSources(source1.sourceType, source2.sourceType)\n    );\n  }\n\n  private buildTextAvatar(avatarSource: Source): void {\n    this.avatarText = avatarSource.getAvatar(this.initialsSize);\n    this.avatarStyle = this.getInitialsStyle(avatarSource.sourceId);\n  }\n\n  private buildImageAvatar(avatarSource: Source): void {\n    this.avatarStyle = this.getImageStyle();\n    if (avatarSource instanceof AsyncSource) {\n      this.fetchAndProcessAsyncAvatar(avatarSource);\n    } else {\n      this.avatarSrc = avatarSource.getAvatar(this.size);\n    }\n  }\n\n  /**\n   *\n   * returns initials style\n   *\n   * memberOf AvatarComponent\n   */\n  private getInitialsStyle(avatarValue: string): void {\n    return {\n      textAlign: 'center',\n      borderRadius: this.round ? '100%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      textTransform: 'uppercase',\n      color: this.fgColor,\n      backgroundColor: this.bgColor\n        ? this.bgColor\n        : this.avatarService.getRandomColor(avatarValue),\n      font:\n        Math.floor(this.size / this.textSizeRatio) +\n        'px Helvetica, Arial, sans-serif',\n      lineHeight: this.size + 'px',\n      ...this.style\n    };\n  }\n\n  /**\n   *\n   * returns image style\n   *\n   * memberOf AvatarComponent\n   */\n  private getImageStyle(): void {\n    return {\n      maxWidth: '100%',\n      borderRadius: this.round ? '50%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      width: this.size,\n      height: this.size,\n      ...this.style\n    };\n  }\n  /**\n   * Fetch avatar image asynchrounsly.\n   *\n   * param {Source} source represents avatar source\n   * memberof AvatarComponent\n   */\n  private fetchAndProcessAsyncAvatar(source: AsyncSource): void {\n    this.avatarService\n      .fetchAvatar(source.getAvatar())\n      .pipe(\n        takeWhile(() => this.isAlive),\n        map(response => source.processResponse(response, this.size))\n      )\n      .subscribe(\n        avatarSrc => (this.avatarSrc = avatarSrc),\n        err => {\n          console.error(\n            `ngx-avatar: error while fetching ${source.sourceType} avatar `\n          );\n        }\n      );\n  }\n\n  /**\n   * Add avatar source\n   *\n   * param sourceType avatar source type e.g facebook,twitter, etc.\n   * param sourceValue  source value e.g facebookId value, etc.\n   */\n  private addSource(sourceType: AvatarSource, sourceValue: string): void {\n    if (!this.isSourceExist(sourceType)) {\n      this.sources.push(\n        this.sourceFactory.newInstance(sourceType, sourceValue)\n      );\n    } else {\n      const index = this.sources.findIndex(\n        source => source.sourceType === sourceType\n      );\n      this.sources[index].sourceId = sourceValue;\n    }\n  }\n\n  private isSourceExist(avatarSource: AvatarSource): boolean {\n    return this.sources.map(source => source.sourceType).includes(avatarSource);\n  }\n}\n"]}

@@ -275,3 +275,3 @@ /**

.fetchAvatar(source.getAvatar())
.pipe(takeWhile(function () { return !_this.isAlive; }), map(function (response) { return source.processResponse(response, _this.size); }))
.pipe(takeWhile(function () { return _this.isAlive; }), map(function (response) { return source.processResponse(response, _this.size); }))
.subscribe(function (avatarSrc) { return (_this.avatarSrc = avatarSrc); }, function (err) {

@@ -430,2 +430,2 @@ console.error("ngx-avatar: error while fetching " + source.sourceType + " avatar ");

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"ng://ngx-avatar/","sources":["lib/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  SimpleChange,\n  OnDestroy\n} from '@angular/core';\n\nimport { Source } from './sources/source';\nimport { AsyncSource } from './sources/async-source';\nimport { SourceFactory } from './sources/source.factory';\nimport { AvatarService } from './avatar.service';\nimport { AvatarSource } from './sources/avatar-source.enum';\nimport { takeWhile, map } from 'rxjs/operators';\n\n/**\n * Universal avatar component that\n * generates avatar from different sources\n *\n * export\n * class AvatarComponent\n * implements {OnChanges}\n */\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'ngx-avatar',\n  styles: [\n    `\n      :host {\n        border-radius: '50%';\n      }\n    `\n  ],\n  template: `\n    <div\n      (click)=\"onAvatarClicked()\"\n      class=\"avatar-container\"\n      [ngStyle]=\"hostStyle\"\n    >\n      <img\n        *ngIf=\"avatarSrc; else textAvatar\"\n        [src]=\"avatarSrc\"\n        [width]=\"size\"\n        [height]=\"size\"\n        [ngStyle]=\"avatarStyle\"\n        (error)=\"fetchAvatarSource($event)\"\n        class=\"avatar-content\"\n      />\n      <ng-template #textAvatar>\n        <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n          {{ avatarText }}\n        </div>\n      </ng-template>\n    </div>\n  `\n})\nexport class AvatarComponent implements OnChanges, OnDestroy {\n  @Input()\n  public round = true;\n  @Input()\n  public size = 50;\n  @Input()\n  public textSizeRatio = 3;\n  @Input()\n  public bgColor: string;\n  @Input()\n  public fgColor = '#FFF';\n  @Input()\n  public borderColor: string;\n  @Input()\n  public style: any = {};\n  @Input()\n  public cornerRadius = 0;\n  @Input('facebookId')\n  public facebook: string;\n  @Input('twitterId')\n  public twitter: string;\n  @Input('googleId')\n  public google: string;\n  @Input('vkontakteId')\n  public vkontakte: string;\n  @Input('skypeId')\n  public skype: string;\n  @Input('gravatarId')\n  public gravatar: string;\n  @Input('githubId')\n  public github: string;\n  @Input('src')\n  public custom: string;\n  @Input('name')\n  public initials: string;\n  @Input('value')\n  public value: string;\n  @Input('placeholder')\n  public placeholder: string;\n  @Input('initialsSize')\n  public initialsSize: number;\n\n  @Output()\n  public clickOnAvatar: EventEmitter<any> = new EventEmitter<any>();\n\n  public isAlive = true;\n  public avatarSrc: string;\n  public avatarText: string;\n  public avatarStyle: any = {};\n  public hostStyle: any = {};\n\n  private currentSource = 0;\n  private sources: Source[] = Array();\n\n  constructor(\n    public elementRef: ElementRef,\n    public sourceFactory: SourceFactory,\n    private avatarService: AvatarService\n  ) {}\n\n  public onAvatarClicked(): void {\n    this.clickOnAvatar.emit(this.sources[this.currentSource - 1]);\n  }\n\n  /**\n   * Detect inputs change\n   *\n   * param {{ [propKey: string]: SimpleChange }} changes\n   *\n   * memberof AvatarComponent\n   */\n  public ngOnChanges(changes: { [propKey: string]: SimpleChange }): void {\n    for (const propName in changes) {\n      if (\n        this.avatarService.isSource(propName) &&\n        changes[propName].currentValue\n      ) {\n        const currentValue = changes[propName].currentValue;\n        this.addSource(AvatarSource[propName.toUpperCase()], currentValue);\n      }\n    }\n    // reintialize the avatar component when a source property value has changed\n    // the fallback system must be re-invoked with the new values.\n    this.initializeAvatar();\n  }\n\n  /**\n   * Fetch avatar source\n   *\n   * param {any} event\n   *\n   * memberOf AvatarComponent\n   */\n  public fetchAvatarSource(event?: any): void {\n    const avatarSource = this.sources[this.currentSource];\n    if (!avatarSource) {\n      return;\n    }\n    if (this.avatarService.isTextAvatar(avatarSource.sourceType)) {\n      this.buildTextAvatar(avatarSource);\n      // TODO: check if this is needed\n      this.avatarSrc = undefined;\n    } else {\n      this.buildImageAvatar(avatarSource);\n    }\n    this.currentSource++;\n  }\n\n  public ngOnDestroy(): void {\n    this.isAlive = false;\n  }\n\n  /**\n   * Initialize the avatar component and its fallback system\n   */\n  private initializeAvatar(): void {\n    this.currentSource = 0;\n    if (this.sources.length > 0 && this.sources[this.currentSource]) {\n      this.sortAvatarSources();\n      this.fetchAvatarSource();\n      this.hostStyle = {\n        width: this.size + 'px',\n        height: this.size + 'px'\n      };\n    }\n  }\n\n  private sortAvatarSources(): void {\n    this.sources.sort((source1, source2) =>\n      this.avatarService.copmareSources(source1.sourceType, source2.sourceType)\n    );\n  }\n\n  private buildTextAvatar(avatarSource: Source): void {\n    this.avatarText = avatarSource.getAvatar(this.initialsSize);\n    this.avatarStyle = this.getInitialsStyle(avatarSource.sourceId);\n  }\n\n  private buildImageAvatar(avatarSource: Source): void {\n    this.avatarStyle = this.getImageStyle();\n    if (avatarSource instanceof AsyncSource) {\n      this.fetchAndProcessAsyncAvatar(avatarSource);\n    } else {\n      this.avatarSrc = avatarSource.getAvatar(this.size);\n    }\n  }\n\n  /**\n   *\n   * returns initials style\n   *\n   * memberOf AvatarComponent\n   */\n  private getInitialsStyle(avatarValue: string): void {\n    return {\n      textAlign: 'center',\n      borderRadius: this.round ? '100%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      textTransform: 'uppercase',\n      color: this.fgColor,\n      backgroundColor: this.bgColor\n        ? this.bgColor\n        : this.avatarService.getRandomColor(avatarValue),\n      font:\n        Math.floor(this.size / this.textSizeRatio) +\n        'px Helvetica, Arial, sans-serif',\n      lineHeight: this.size + 'px',\n      ...this.style\n    };\n  }\n\n  /**\n   *\n   * returns image style\n   *\n   * memberOf AvatarComponent\n   */\n  private getImageStyle(): void {\n    return {\n      maxWidth: '100%',\n      borderRadius: this.round ? '50%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      width: this.size,\n      height: this.size,\n      ...this.style\n    };\n  }\n  /**\n   * Fetch avatar image asynchrounsly.\n   *\n   * param {Source} source represents avatar source\n   * memberof AvatarComponent\n   */\n  private fetchAndProcessAsyncAvatar(source: AsyncSource): void {\n    this.avatarService\n      .fetchAvatar(source.getAvatar())\n      .pipe(\n        takeWhile(() => !this.isAlive),\n        map(response => source.processResponse(response, this.size))\n      )\n      .subscribe(\n        avatarSrc => (this.avatarSrc = avatarSrc),\n        err => {\n          console.error(\n            `ngx-avatar: error while fetching ${source.sourceType} avatar `\n          );\n        }\n      );\n  }\n\n  /**\n   * Add avatar source\n   *\n   * param sourceType avatar source type e.g facebook,twitter, etc.\n   * param sourceValue  source value e.g facebookId value, etc.\n   */\n  private addSource(sourceType: AvatarSource, sourceValue: string): void {\n    if (!this.isSourceExist(sourceType)) {\n      this.sources.push(\n        this.sourceFactory.newInstance(sourceType, sourceValue)\n      );\n    } else {\n      const index = this.sources.findIndex(\n        source => source.sourceType === sourceType\n      );\n      this.sources[index].sourceId = sourceValue;\n    }\n  }\n\n  private isSourceExist(avatarSource: AvatarSource): boolean {\n    return this.sources.map(source => source.sourceType).includes(avatarSource);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"ng://ngx-avatar/","sources":["lib/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  SimpleChange,\n  OnDestroy\n} from '@angular/core';\n\nimport { Source } from './sources/source';\nimport { AsyncSource } from './sources/async-source';\nimport { SourceFactory } from './sources/source.factory';\nimport { AvatarService } from './avatar.service';\nimport { AvatarSource } from './sources/avatar-source.enum';\nimport { takeWhile, map } from 'rxjs/operators';\n\n/**\n * Universal avatar component that\n * generates avatar from different sources\n *\n * export\n * class AvatarComponent\n * implements {OnChanges}\n */\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'ngx-avatar',\n  styles: [\n    `\n      :host {\n        border-radius: '50%';\n      }\n    `\n  ],\n  template: `\n    <div\n      (click)=\"onAvatarClicked()\"\n      class=\"avatar-container\"\n      [ngStyle]=\"hostStyle\"\n    >\n      <img\n        *ngIf=\"avatarSrc; else textAvatar\"\n        [src]=\"avatarSrc\"\n        [width]=\"size\"\n        [height]=\"size\"\n        [ngStyle]=\"avatarStyle\"\n        (error)=\"fetchAvatarSource($event)\"\n        class=\"avatar-content\"\n      />\n      <ng-template #textAvatar>\n        <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n          {{ avatarText }}\n        </div>\n      </ng-template>\n    </div>\n  `\n})\nexport class AvatarComponent implements OnChanges, OnDestroy {\n  @Input()\n  public round = true;\n  @Input()\n  public size = 50;\n  @Input()\n  public textSizeRatio = 3;\n  @Input()\n  public bgColor: string;\n  @Input()\n  public fgColor = '#FFF';\n  @Input()\n  public borderColor: string;\n  @Input()\n  public style: any = {};\n  @Input()\n  public cornerRadius = 0;\n  @Input('facebookId')\n  public facebook: string;\n  @Input('twitterId')\n  public twitter: string;\n  @Input('googleId')\n  public google: string;\n  @Input('vkontakteId')\n  public vkontakte: string;\n  @Input('skypeId')\n  public skype: string;\n  @Input('gravatarId')\n  public gravatar: string;\n  @Input('githubId')\n  public github: string;\n  @Input('src')\n  public custom: string;\n  @Input('name')\n  public initials: string;\n  @Input('value')\n  public value: string;\n  @Input('placeholder')\n  public placeholder: string;\n  @Input('initialsSize')\n  public initialsSize: number;\n\n  @Output()\n  public clickOnAvatar: EventEmitter<any> = new EventEmitter<any>();\n\n  public isAlive = true;\n  public avatarSrc: string;\n  public avatarText: string;\n  public avatarStyle: any = {};\n  public hostStyle: any = {};\n\n  private currentSource = 0;\n  private sources: Source[] = Array();\n\n  constructor(\n    public elementRef: ElementRef,\n    public sourceFactory: SourceFactory,\n    private avatarService: AvatarService\n  ) {}\n\n  public onAvatarClicked(): void {\n    this.clickOnAvatar.emit(this.sources[this.currentSource - 1]);\n  }\n\n  /**\n   * Detect inputs change\n   *\n   * param {{ [propKey: string]: SimpleChange }} changes\n   *\n   * memberof AvatarComponent\n   */\n  public ngOnChanges(changes: { [propKey: string]: SimpleChange }): void {\n    for (const propName in changes) {\n      if (\n        this.avatarService.isSource(propName) &&\n        changes[propName].currentValue\n      ) {\n        const currentValue = changes[propName].currentValue;\n        this.addSource(AvatarSource[propName.toUpperCase()], currentValue);\n      }\n    }\n    // reintialize the avatar component when a source property value has changed\n    // the fallback system must be re-invoked with the new values.\n    this.initializeAvatar();\n  }\n\n  /**\n   * Fetch avatar source\n   *\n   * param {any} event\n   *\n   * memberOf AvatarComponent\n   */\n  public fetchAvatarSource(event?: any): void {\n    const avatarSource = this.sources[this.currentSource];\n    if (!avatarSource) {\n      return;\n    }\n    if (this.avatarService.isTextAvatar(avatarSource.sourceType)) {\n      this.buildTextAvatar(avatarSource);\n      // TODO: check if this is needed\n      this.avatarSrc = undefined;\n    } else {\n      this.buildImageAvatar(avatarSource);\n    }\n    this.currentSource++;\n  }\n\n  public ngOnDestroy(): void {\n    this.isAlive = false;\n  }\n\n  /**\n   * Initialize the avatar component and its fallback system\n   */\n  private initializeAvatar(): void {\n    this.currentSource = 0;\n    if (this.sources.length > 0 && this.sources[this.currentSource]) {\n      this.sortAvatarSources();\n      this.fetchAvatarSource();\n      this.hostStyle = {\n        width: this.size + 'px',\n        height: this.size + 'px'\n      };\n    }\n  }\n\n  private sortAvatarSources(): void {\n    this.sources.sort((source1, source2) =>\n      this.avatarService.copmareSources(source1.sourceType, source2.sourceType)\n    );\n  }\n\n  private buildTextAvatar(avatarSource: Source): void {\n    this.avatarText = avatarSource.getAvatar(this.initialsSize);\n    this.avatarStyle = this.getInitialsStyle(avatarSource.sourceId);\n  }\n\n  private buildImageAvatar(avatarSource: Source): void {\n    this.avatarStyle = this.getImageStyle();\n    if (avatarSource instanceof AsyncSource) {\n      this.fetchAndProcessAsyncAvatar(avatarSource);\n    } else {\n      this.avatarSrc = avatarSource.getAvatar(this.size);\n    }\n  }\n\n  /**\n   *\n   * returns initials style\n   *\n   * memberOf AvatarComponent\n   */\n  private getInitialsStyle(avatarValue: string): void {\n    return {\n      textAlign: 'center',\n      borderRadius: this.round ? '100%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      textTransform: 'uppercase',\n      color: this.fgColor,\n      backgroundColor: this.bgColor\n        ? this.bgColor\n        : this.avatarService.getRandomColor(avatarValue),\n      font:\n        Math.floor(this.size / this.textSizeRatio) +\n        'px Helvetica, Arial, sans-serif',\n      lineHeight: this.size + 'px',\n      ...this.style\n    };\n  }\n\n  /**\n   *\n   * returns image style\n   *\n   * memberOf AvatarComponent\n   */\n  private getImageStyle(): void {\n    return {\n      maxWidth: '100%',\n      borderRadius: this.round ? '50%' : this.cornerRadius + 'px',\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\n      width: this.size,\n      height: this.size,\n      ...this.style\n    };\n  }\n  /**\n   * Fetch avatar image asynchrounsly.\n   *\n   * param {Source} source represents avatar source\n   * memberof AvatarComponent\n   */\n  private fetchAndProcessAsyncAvatar(source: AsyncSource): void {\n    this.avatarService\n      .fetchAvatar(source.getAvatar())\n      .pipe(\n        takeWhile(() => this.isAlive),\n        map(response => source.processResponse(response, this.size))\n      )\n      .subscribe(\n        avatarSrc => (this.avatarSrc = avatarSrc),\n        err => {\n          console.error(\n            `ngx-avatar: error while fetching ${source.sourceType} avatar `\n          );\n        }\n      );\n  }\n\n  /**\n   * Add avatar source\n   *\n   * param sourceType avatar source type e.g facebook,twitter, etc.\n   * param sourceValue  source value e.g facebookId value, etc.\n   */\n  private addSource(sourceType: AvatarSource, sourceValue: string): void {\n    if (!this.isSourceExist(sourceType)) {\n      this.sources.push(\n        this.sourceFactory.newInstance(sourceType, sourceValue)\n      );\n    } else {\n      const index = this.sources.findIndex(\n        source => source.sourceType === sourceType\n      );\n      this.sources[index].sourceId = sourceValue;\n    }\n  }\n\n  private isSourceExist(avatarSource: AvatarSource): boolean {\n    return this.sources.map(source => source.sourceType).includes(avatarSource);\n  }\n}\n"]}
{
"name": "ngx-avatar",
"description": "A universal avatar component for Angular 4+ applications that fetches / generates avatar based on the information you have about the user.",
"version": "3.3.2",
"version": "3.3.3",
"keywords": [

@@ -6,0 +6,0 @@ "angular",

@@ -270,3 +270,3 @@ ## &lt;ngx-avatar&gt;

## Release Notes & History
* 3.3.1 : Bug fixes
* 3.3.x : Bug fixes
* 3.3.0 : Override Source priority order when importing AvatarModule

@@ -273,0 +273,0 @@ * 3.2.0 : Add support to Angular 7

Sorry, the diff of this file is too big to display

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 too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc