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

angular-pimg

Package Overview
Dependencies
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-pimg - npm Package Compare versions

Comparing version 0.0.3 to 0.0.4

14

bundles/angular-pimg.umd.js

@@ -85,2 +85,3 @@ (function (global, factory) {

var className = _a.className, dataSaver = _a.dataSaver, fetchOnDemand = _a.fetchOnDemand, placeholderClassName = _a.placeholderClassName;
console.log('setting config');
this._className = typeof className !== 'undefined' ? className : this.className;

@@ -96,5 +97,3 @@ this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;

}
else {
this._dataSaver = true; // dataSaver is true
}
this._dataSaver = true; // dataSaver is true
};

@@ -150,3 +149,2 @@ AngularPimgService.decorators = [

_this.isIntersecting = true;
console.log('Called by intersection API');
_this.delayed = false;

@@ -169,3 +167,2 @@ observer.disconnect();

.then(function (res) {
console.log(res);
_this.blob = _this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));

@@ -193,3 +190,2 @@ _this.loading = false;

if (props.findIndex(function (val) { return val === prop; }) > 0 && !this_1.isUndefined(changes[prop].currentValue)) {
console.log(prop + " is not undefined. It has changed");
this_1[prop] = changes[prop].currentValue;

@@ -225,3 +221,2 @@ }

// Called on initialization; Set the default configuration options if option is not present
console.log('Config options', this.options);
if (this.isUndefined(this.fetchOnDemand)) {

@@ -239,4 +234,6 @@ this.fetchOnDemand = this.options.fetchOnDemand;

}
console.log('datasaver', this.dataSaver, this.options.dataSaver);
if (this.isObject(this.dataSaver)) {
// set buttonClassName and wrapperClassName
this.dataSaver = true;
this.buttonClassName = this.dataSaver.buttonClassName;

@@ -266,3 +263,2 @@ this.wrapperClassName = this.dataSaver.wrapperClassName;

this.fetchImage();
console.log('Fetching image, due to config', this.dataSaver);
}

@@ -367,2 +363,2 @@ if (this.src && this.src.includes('cloudinary')) {

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.umd.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    } else {\n      this._dataSaver = true; // dataSaver is true\n    }\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        console.log('Called by intersection API');\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        console.log(res);\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        console.log(`${prop} is not undefined. It has changed`);\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    console.log('Config options', this.options);\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n      console.log('Fetching image, due to config', this.dataSaver);\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":["Injectable","Optional","Inject","EventEmitter","Component","ElementRef","DomSanitizer","Input","Output","NgModule","CommonModule","SkipSelf"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.umd.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    console.log('setting config');\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    }\n    this._dataSaver = true; // dataSaver is true\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    console.log('datasaver', this.dataSaver, this.options.dataSaver);\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.dataSaver = true;\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":["Injectable","Optional","Inject","EventEmitter","Component","ElementRef","DomSanitizer","Input","Output","NgModule","CommonModule","SkipSelf"],"mappings":"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"}

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/platform-browser"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-pimg",["exports","@angular/core","@angular/platform-browser","@angular/common"],t):t(e["angular-pimg"]={},e.ng.core,e.ng.platformBrowser,e.ng.common)}(this,function(e,a,t,n){"use strict";var s=function(){function e(e){this._placeholderClassName="pimg__placeholder",this._fetchOnDemand=!1,this._buttonClassName="pimg_btn",this._wrapperClassName="pimg_wrapper",e&&this.setConfig(e)}return Object.defineProperty(e.prototype,"wrapperClassName",{get:function(){return this._wrapperClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"buttonClassName",{get:function(){return this._buttonClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"className",{get:function(){return this._className},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"placeholderClassName",{get:function(){return this._placeholderClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dataSaver",{get:function(){return this._dataSaver},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fetchOnDemand",{get:function(){return this._fetchOnDemand},enumerable:!0,configurable:!0}),e.prototype.setConfig=function(e){var t=e.className,n=e.dataSaver,a=e.fetchOnDemand,s=e.placeholderClassName;this._className=void 0!==t?t:this.className,this._fetchOnDemand=void 0!==a?a:this.fetchOnDemand,this._placeholderClassName=void 0!==s?s:this.placeholderClassName,void 0!==n&&("object"==typeof n?(this._buttonClassName=n.buttonClassName,this._wrapperClassName=n.wrapperClassName):this._dataSaver=!0)},e.decorators=[{type:a.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:undefined,decorators:[{type:a.Optional},{type:a.Inject,args:["Options"]}]}]},e.ngInjectableDef=a.defineInjectable({factory:function(){return new e(a.inject("Options",8))},token:e,providedIn:"root"}),e}(),r=function(){function e(e,t,n){this.el=e,this.domSanitizer=t,this.options=n,this.style={display:"block"},this.fetched=new a.EventEmitter,this.error=new a.EventEmitter,this.wrapperClassName="",this.buttonClassName="",this.blob="",this.isIntersecting=!1,this.isObject=function(e){return"object"==typeof e},this.isUndefined=function(e){return void 0===e},this.insertInput(),this.setUp()}return e.prototype.setFetchOnDemand=function(){var t=this,n=new IntersectionObserver(function(e){e[0].isIntersecting&&!t.isIntersecting&&(t.fetchImage(),t.isIntersecting=!0,console.log("Called by intersection API"),t.delayed=!1,n.disconnect())});n.observe(this.el.nativeElement)},e.prototype.fetchImage=function(){var t=this;fetch(this.src).then(function(e){return e.blob()}).then(function(e){console.log(e),t.blob=t.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(e)),t.loading=!1,t.isIntersecting=!1,t.delayed=!1,t.fetched.emit()})["catch"](function(e){t.error.emit(e)})},e.prototype.ngOnChanges=function(e){var n=["src","fetchOnDemand","placeholder","placeholderClassName","className","style"],t=function(t){0<n.findIndex(function(e){return e===t})&&!a.isUndefined(e[t].currentValue)?(console.log(t+" is not undefined. It has changed"),a[t]=e[t].currentValue):"dataSaver"===t&&a.isObject(e[t])&&(a.buttonClassName=e[t].currentValue.buttonClassName,a.placeholderClassName=e[t].currentValue.placeholderClassName)},a=this;for(var s in e)t(s);this.setUp()},e.prototype.insertInput=function(){console.log("Config options",this.options),this.isUndefined(this.fetchOnDemand)&&(this.fetchOnDemand=this.options.fetchOnDemand),this.isUndefined(this.placeholderClassName)&&(this.placeholderClassName=this.options.placeholderClassName),this.isUndefined(this.dataSaver)&&(this.dataSaver=this.options.dataSaver),this.isUndefined(this.className)&&(this.className=this.options.className),this.isObject(this.dataSaver)?(this.buttonClassName=this.dataSaver.buttonClassName,this.wrapperClassName=this.dataSaver.wrapperClassName):(this.buttonClassName=this.options.buttonClassName,this.wrapperClassName=this.options.wrapperClassName)},e.prototype.setUp=function(){this.dataSaver?this.delayed=!0:this.fetchOnDemand?(this.loading=!0,this.setFetchOnDemand()):(this.fetchImage(),console.log("Fetching image, due to config",this.dataSaver)),this.src&&this.src.includes("cloudinary")&&(this.placeholder=this.placeholder||this.src.replace("/upload/","/upload/c_thumb,w_30/")),this.classes=this.className+" "+this.placeholderClassName},e.decorators=[{type:a.Component,args:[{selector:"angular-pimg",template:'<div [ngClass]="wrapperClassName" *ngIf="(dataSaver && loading) || delayed; else loadingContent">\n <img [ngClass]="classes" [ngStyle]="style" [src]="placeholder" />\n <button [ngClass]="buttonClassName" (click)="fetchImage()">\n Load image\n </button>\n</div>\n<ng-template #loadingContent>\n <img *ngIf="loading; else otherContent" [ngClass]="placeholderClassName" [ngStyle]="style" [src]="placeholder" />\n <ng-template #otherContent>\n <img [ngStyle]="style" [ngClass]="classes" [src]="blob" />\n </ng-template>\n</ng-template>',styles:[]}]}],e.ctorParameters=function(){return[{type:a.ElementRef},{type:t.DomSanitizer},{type:s}]},e.propDecorators={dataSaver:[{type:a.Input}],src:[{type:a.Input}],fetchOnDemand:[{type:a.Input}],placeholder:[{type:a.Input}],placeholderClassName:[{type:a.Input}],className:[{type:a.Input}],style:[{type:a.Input}],fetched:[{type:a.Output}],error:[{type:a.Output}]},e}(),o=function(){function t(e){if(e)throw new Error("The Angular Pimg Module is already loaded. Import it only in your AppModule")}return t.forRoot=function(e){return{ngModule:t,providers:[s,{provide:"Options",useValue:e}]}},t.decorators=[{type:a.NgModule,args:[{imports:[n.CommonModule],declarations:[r],exports:[r]}]}],t.ctorParameters=function(){return[{type:t,decorators:[{type:a.Optional},{type:a.SkipSelf}]}]},t}();e.AngularPimgService=s,e.AngularPimgComponent=r,e.AngularPimgModule=o,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/platform-browser"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-pimg",["exports","@angular/core","@angular/platform-browser","@angular/common"],t):t(e["angular-pimg"]={},e.ng.core,e.ng.platformBrowser,e.ng.common)}(this,function(e,n,t,a){"use strict";var s=function(){function e(e){this._placeholderClassName="pimg__placeholder",this._fetchOnDemand=!1,this._buttonClassName="pimg_btn",this._wrapperClassName="pimg_wrapper",e&&this.setConfig(e)}return Object.defineProperty(e.prototype,"wrapperClassName",{get:function(){return this._wrapperClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"buttonClassName",{get:function(){return this._buttonClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"className",{get:function(){return this._className},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"placeholderClassName",{get:function(){return this._placeholderClassName},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dataSaver",{get:function(){return this._dataSaver},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fetchOnDemand",{get:function(){return this._fetchOnDemand},enumerable:!0,configurable:!0}),e.prototype.setConfig=function(e){var t=e.className,a=e.dataSaver,n=e.fetchOnDemand,s=e.placeholderClassName;console.log("setting config"),this._className=void 0!==t?t:this.className,this._fetchOnDemand=void 0!==n?n:this.fetchOnDemand,this._placeholderClassName=void 0!==s?s:this.placeholderClassName,void 0!==a&&("object"==typeof a&&(this._buttonClassName=a.buttonClassName,this._wrapperClassName=a.wrapperClassName),this._dataSaver=!0)},e.decorators=[{type:n.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:undefined,decorators:[{type:n.Optional},{type:n.Inject,args:["Options"]}]}]},e.ngInjectableDef=n.defineInjectable({factory:function(){return new e(n.inject("Options",8))},token:e,providedIn:"root"}),e}(),r=function(){function e(e,t,a){this.el=e,this.domSanitizer=t,this.options=a,this.style={display:"block"},this.fetched=new n.EventEmitter,this.error=new n.EventEmitter,this.wrapperClassName="",this.buttonClassName="",this.blob="",this.isIntersecting=!1,this.isObject=function(e){return"object"==typeof e},this.isUndefined=function(e){return void 0===e},this.insertInput(),this.setUp()}return e.prototype.setFetchOnDemand=function(){var t=this,a=new IntersectionObserver(function(e){e[0].isIntersecting&&!t.isIntersecting&&(t.fetchImage(),t.isIntersecting=!0,t.delayed=!1,a.disconnect())});a.observe(this.el.nativeElement)},e.prototype.fetchImage=function(){var t=this;fetch(this.src).then(function(e){return e.blob()}).then(function(e){t.blob=t.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(e)),t.loading=!1,t.isIntersecting=!1,t.delayed=!1,t.fetched.emit()})["catch"](function(e){t.error.emit(e)})},e.prototype.ngOnChanges=function(e){var a=["src","fetchOnDemand","placeholder","placeholderClassName","className","style"],t=function(t){0<a.findIndex(function(e){return e===t})&&!n.isUndefined(e[t].currentValue)?n[t]=e[t].currentValue:"dataSaver"===t&&n.isObject(e[t])&&(n.buttonClassName=e[t].currentValue.buttonClassName,n.placeholderClassName=e[t].currentValue.placeholderClassName)},n=this;for(var s in e)t(s);this.setUp()},e.prototype.insertInput=function(){this.isUndefined(this.fetchOnDemand)&&(this.fetchOnDemand=this.options.fetchOnDemand),this.isUndefined(this.placeholderClassName)&&(this.placeholderClassName=this.options.placeholderClassName),this.isUndefined(this.dataSaver)&&(this.dataSaver=this.options.dataSaver),this.isUndefined(this.className)&&(this.className=this.options.className),console.log("datasaver",this.dataSaver,this.options.dataSaver),this.isObject(this.dataSaver)?(this.dataSaver=!0,this.buttonClassName=this.dataSaver.buttonClassName,this.wrapperClassName=this.dataSaver.wrapperClassName):(this.buttonClassName=this.options.buttonClassName,this.wrapperClassName=this.options.wrapperClassName)},e.prototype.setUp=function(){this.dataSaver?this.delayed=!0:this.fetchOnDemand?(this.loading=!0,this.setFetchOnDemand()):this.fetchImage(),this.src&&this.src.includes("cloudinary")&&(this.placeholder=this.placeholder||this.src.replace("/upload/","/upload/c_thumb,w_30/")),this.classes=this.className+" "+this.placeholderClassName},e.decorators=[{type:n.Component,args:[{selector:"angular-pimg",template:'<div [ngClass]="wrapperClassName" *ngIf="(dataSaver && loading) || delayed; else loadingContent">\n <img [ngClass]="classes" [ngStyle]="style" [src]="placeholder" />\n <button [ngClass]="buttonClassName" (click)="fetchImage()">\n Load image\n </button>\n</div>\n<ng-template #loadingContent>\n <img *ngIf="loading; else otherContent" [ngClass]="placeholderClassName" [ngStyle]="style" [src]="placeholder" />\n <ng-template #otherContent>\n <img [ngStyle]="style" [ngClass]="classes" [src]="blob" />\n </ng-template>\n</ng-template>',styles:[]}]}],e.ctorParameters=function(){return[{type:n.ElementRef},{type:t.DomSanitizer},{type:s}]},e.propDecorators={dataSaver:[{type:n.Input}],src:[{type:n.Input}],fetchOnDemand:[{type:n.Input}],placeholder:[{type:n.Input}],placeholderClassName:[{type:n.Input}],className:[{type:n.Input}],style:[{type:n.Input}],fetched:[{type:n.Output}],error:[{type:n.Output}]},e}(),o=function(){function t(e){if(e)throw new Error("The Angular Pimg Module is already loaded. Import it only in your AppModule")}return t.forRoot=function(e){return{ngModule:t,providers:[s,{provide:"Options",useValue:e}]}},t.decorators=[{type:n.NgModule,args:[{imports:[a.CommonModule],declarations:[r],exports:[r]}]}],t.ctorParameters=function(){return[{type:t,decorators:[{type:n.Optional},{type:n.SkipSelf}]}]},t}();e.AngularPimgService=s,e.AngularPimgComponent=r,e.AngularPimgModule=o,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-pimg.umd.min.js.map

@@ -39,3 +39,2 @@ /**

this.isIntersecting = true;
console.log('Called by intersection API');
this.delayed = false;

@@ -54,3 +53,2 @@ observer.disconnect();

.then(res => {
console.log(res);
this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));

@@ -75,3 +73,2 @@ this.loading = false;

if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {
console.log(`${prop} is not undefined. It has changed`);
this[prop] = changes[prop].currentValue;

@@ -100,3 +97,2 @@ }

// Called on initialization; Set the default configuration options if option is not present
console.log('Config options', this.options);
if (this.isUndefined(this.fetchOnDemand)) {

@@ -114,4 +110,6 @@ this.fetchOnDemand = this.options.fetchOnDemand;

}
console.log('datasaver', this.dataSaver, this.options.dataSaver);
if (this.isObject(this.dataSaver)) {
// set buttonClassName and wrapperClassName
this.dataSaver = true;
this.buttonClassName = this.dataSaver.buttonClassName;

@@ -138,3 +136,2 @@ this.wrapperClassName = this.dataSaver.wrapperClassName;

this.fetchImage();
console.log('Fetching image, due to config', this.dataSaver);
}

@@ -237,2 +234,2 @@ if (this.src && this.src.includes('cloudinary')) {

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-pimg.component.js","sourceRoot":"ng://angular-pimg/","sources":["lib/angular-pimg.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        console.log('Called by intersection API');\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        console.log(res);\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        console.log(`${prop} is not undefined. It has changed`);\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    console.log('Config options', this.options);\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n      console.log('Fetching image, due to config', this.dataSaver);\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-pimg.component.js","sourceRoot":"ng://angular-pimg/","sources":["lib/angular-pimg.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    console.log('datasaver', this.dataSaver, this.options.dataSaver);\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.dataSaver = true;\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n"]}

@@ -61,2 +61,3 @@ /**

setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }) {
console.log('setting config');
this._className = typeof className !== 'undefined' ? className : this.className;

@@ -72,5 +73,3 @@ this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;

}
else {
this._dataSaver = true; // dataSaver is true
}
this._dataSaver = true; // dataSaver is true
}

@@ -110,2 +109,2 @@ }

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1waW1nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvYW5ndWxhci1waW1nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFNN0QsTUFBTTs7OztJQVFKLFlBQTJDO3FDQU5YLG1CQUFtQjs4QkFDMUIsS0FBSztnQ0FFSCxVQUFVO2lDQUNULGNBQWM7UUFHeEMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztZQUNaLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDekI7S0FDRjs7OztJQUVELElBQUksZ0JBQWdCO1FBQ2xCLE1BQU0sQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUM7S0FDL0I7Ozs7SUFFRCxJQUFJLGVBQWU7UUFDakIsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztLQUM5Qjs7OztJQUVELElBQUksU0FBUztRQUNYLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0tBQ3hCOzs7O0lBRUQsSUFBSSxvQkFBb0I7UUFDdEIsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztLQUNuQzs7OztJQUVELElBQUksU0FBUztRQUNYLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0tBQ3hCOzs7O0lBRUQsSUFBSSxhQUFhO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7S0FDNUI7Ozs7O0lBRUQsU0FBUyxDQUFDLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsb0JBQW9CLEVBQStCO1FBQ2xHLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxTQUFTLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDaEYsSUFBSSxDQUFDLGNBQWMsR0FBRyxPQUFPLGFBQWEsS0FBSyxXQUFXLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUNoRyxJQUFJLENBQUMscUJBQXFCLEdBQUcsT0FBTyxvQkFBb0IsS0FBSyxXQUFXLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUM7UUFDNUgsRUFBRSxDQUFDLENBQUMsT0FBTyxTQUFTLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQztZQUNyQyxNQUFNLENBQUM7U0FDUjtRQUNELEVBQUUsQ0FBQyxDQUFDLE9BQU8sU0FBUyxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDbEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFNBQVMsQ0FBQyxlQUFlLENBQUM7WUFDbEQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQztTQUNyRDtRQUFDLElBQUksQ0FBQyxDQUFDO1lBQ04sSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7U0FDeEI7S0FDRjs7O1lBdERGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7Ozs0Q0FTYyxRQUFRLFlBQUksTUFBTSxTQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBbmd1bGFyUGltZ09wdGlvbnMgfSBmcm9tICcuL2NvbmZpZy1vcHRpb25zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQW5ndWxhclBpbWdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBfY2xhc3NOYW1lOiBzdHJpbmc7XG4gIHByaXZhdGUgX3BsYWNlaG9sZGVyQ2xhc3NOYW1lID0gJ3BpbWdfX3BsYWNlaG9sZGVyJztcbiAgcHJpdmF0ZSBfZmV0Y2hPbkRlbWFuZCA9IGZhbHNlO1xuICBwcml2YXRlIF9kYXRhU2F2ZXI6IGJvb2xlYW47XG4gIHByaXZhdGUgX2J1dHRvbkNsYXNzTmFtZSA9ICdwaW1nX2J0bic7XG4gIHByaXZhdGUgX3dyYXBwZXJDbGFzc05hbWUgPSAncGltZ193cmFwcGVyJztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBASW5qZWN0KCdPcHRpb25zJykgb3B0aW9uczogQW5ndWxhclBpbWdPcHRpb25zKSB7XG4gICAgaWYgKG9wdGlvbnMpIHtcbiAgICAgIHRoaXMuc2V0Q29uZmlnKG9wdGlvbnMpO1xuICAgIH1cbiAgfVxuXG4gIGdldCB3cmFwcGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3dyYXBwZXJDbGFzc05hbWU7XG4gIH1cblxuICBnZXQgYnV0dG9uQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2J1dHRvbkNsYXNzTmFtZTtcbiAgfVxuXG4gIGdldCBjbGFzc05hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fY2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IHBsYWNlaG9sZGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BsYWNlaG9sZGVyQ2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IGRhdGFTYXZlcigpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YVNhdmVyO1xuICB9XG5cbiAgZ2V0IGZldGNoT25EZW1hbmQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2ZldGNoT25EZW1hbmQ7XG4gIH1cblxuICBzZXRDb25maWcoeyBjbGFzc05hbWUsIGRhdGFTYXZlciwgZmV0Y2hPbkRlbWFuZCwgcGxhY2Vob2xkZXJDbGFzc05hbWUgfTogUGFydGlhbDxBbmd1bGFyUGltZ09wdGlvbnM+KSB7XG4gICAgdGhpcy5fY2xhc3NOYW1lID0gdHlwZW9mIGNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBjbGFzc05hbWUgOiB0aGlzLmNsYXNzTmFtZTtcbiAgICB0aGlzLl9mZXRjaE9uRGVtYW5kID0gdHlwZW9mIGZldGNoT25EZW1hbmQgIT09ICd1bmRlZmluZWQnID8gZmV0Y2hPbkRlbWFuZCA6IHRoaXMuZmV0Y2hPbkRlbWFuZDtcbiAgICB0aGlzLl9wbGFjZWhvbGRlckNsYXNzTmFtZSA9IHR5cGVvZiBwbGFjZWhvbGRlckNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBwbGFjZWhvbGRlckNsYXNzTmFtZSA6IHRoaXMucGxhY2Vob2xkZXJDbGFzc05hbWU7XG4gICAgaWYgKHR5cGVvZiBkYXRhU2F2ZXIgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0eXBlb2YgZGF0YVNhdmVyID09PSAnb2JqZWN0Jykge1xuICAgICAgdGhpcy5fYnV0dG9uQ2xhc3NOYW1lID0gZGF0YVNhdmVyLmJ1dHRvbkNsYXNzTmFtZTtcbiAgICAgIHRoaXMuX3dyYXBwZXJDbGFzc05hbWUgPSBkYXRhU2F2ZXIud3JhcHBlckNsYXNzTmFtZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fZGF0YVNhdmVyID0gdHJ1ZTsgLy8gZGF0YVNhdmVyIGlzIHRydWVcbiAgICB9XG4gIH1cblxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1waW1nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvYW5ndWxhci1waW1nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFNN0QsTUFBTTs7OztJQVFKLFlBQTJDO3FDQU5YLG1CQUFtQjs4QkFDMUIsS0FBSztnQ0FFSCxVQUFVO2lDQUNULGNBQWM7UUFHeEMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztZQUNaLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDekI7S0FDRjs7OztJQUVELElBQUksZ0JBQWdCO1FBQ2xCLE1BQU0sQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUM7S0FDL0I7Ozs7SUFFRCxJQUFJLGVBQWU7UUFDakIsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztLQUM5Qjs7OztJQUVELElBQUksU0FBUztRQUNYLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0tBQ3hCOzs7O0lBRUQsSUFBSSxvQkFBb0I7UUFDdEIsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztLQUNuQzs7OztJQUVELElBQUksU0FBUztRQUNYLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0tBQ3hCOzs7O0lBRUQsSUFBSSxhQUFhO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7S0FDNUI7Ozs7O0lBRUQsU0FBUyxDQUFDLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsb0JBQW9CLEVBQStCO1FBQ2xHLE9BQU8sQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsVUFBVSxHQUFHLE9BQU8sU0FBUyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ2hGLElBQUksQ0FBQyxjQUFjLEdBQUcsT0FBTyxhQUFhLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDaEcsSUFBSSxDQUFDLHFCQUFxQixHQUFHLE9BQU8sb0JBQW9CLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDO1FBQzVILEVBQUUsQ0FBQyxDQUFDLE9BQU8sU0FBUyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUM7WUFDckMsTUFBTSxDQUFDO1NBQ1I7UUFDRCxFQUFFLENBQUMsQ0FBQyxPQUFPLFNBQVMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxTQUFTLENBQUMsZUFBZSxDQUFDO1lBQ2xELElBQUksQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUMsZ0JBQWdCLENBQUM7U0FDckQ7UUFDRCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztLQUN4Qjs7O1lBdERGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7Ozs0Q0FTYyxRQUFRLFlBQUksTUFBTSxTQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBbmd1bGFyUGltZ09wdGlvbnMgfSBmcm9tICcuL2NvbmZpZy1vcHRpb25zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQW5ndWxhclBpbWdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBfY2xhc3NOYW1lOiBzdHJpbmc7XG4gIHByaXZhdGUgX3BsYWNlaG9sZGVyQ2xhc3NOYW1lID0gJ3BpbWdfX3BsYWNlaG9sZGVyJztcbiAgcHJpdmF0ZSBfZmV0Y2hPbkRlbWFuZCA9IGZhbHNlO1xuICBwcml2YXRlIF9kYXRhU2F2ZXI6IGJvb2xlYW47XG4gIHByaXZhdGUgX2J1dHRvbkNsYXNzTmFtZSA9ICdwaW1nX2J0bic7XG4gIHByaXZhdGUgX3dyYXBwZXJDbGFzc05hbWUgPSAncGltZ193cmFwcGVyJztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBASW5qZWN0KCdPcHRpb25zJykgb3B0aW9uczogQW5ndWxhclBpbWdPcHRpb25zKSB7XG4gICAgaWYgKG9wdGlvbnMpIHtcbiAgICAgIHRoaXMuc2V0Q29uZmlnKG9wdGlvbnMpO1xuICAgIH1cbiAgfVxuXG4gIGdldCB3cmFwcGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3dyYXBwZXJDbGFzc05hbWU7XG4gIH1cblxuICBnZXQgYnV0dG9uQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2J1dHRvbkNsYXNzTmFtZTtcbiAgfVxuXG4gIGdldCBjbGFzc05hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fY2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IHBsYWNlaG9sZGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BsYWNlaG9sZGVyQ2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IGRhdGFTYXZlcigpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YVNhdmVyO1xuICB9XG5cbiAgZ2V0IGZldGNoT25EZW1hbmQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2ZldGNoT25EZW1hbmQ7XG4gIH1cblxuICBzZXRDb25maWcoeyBjbGFzc05hbWUsIGRhdGFTYXZlciwgZmV0Y2hPbkRlbWFuZCwgcGxhY2Vob2xkZXJDbGFzc05hbWUgfTogUGFydGlhbDxBbmd1bGFyUGltZ09wdGlvbnM+KSB7XG4gICAgY29uc29sZS5sb2coJ3NldHRpbmcgY29uZmlnJyk7XG4gICAgdGhpcy5fY2xhc3NOYW1lID0gdHlwZW9mIGNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBjbGFzc05hbWUgOiB0aGlzLmNsYXNzTmFtZTtcbiAgICB0aGlzLl9mZXRjaE9uRGVtYW5kID0gdHlwZW9mIGZldGNoT25EZW1hbmQgIT09ICd1bmRlZmluZWQnID8gZmV0Y2hPbkRlbWFuZCA6IHRoaXMuZmV0Y2hPbkRlbWFuZDtcbiAgICB0aGlzLl9wbGFjZWhvbGRlckNsYXNzTmFtZSA9IHR5cGVvZiBwbGFjZWhvbGRlckNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBwbGFjZWhvbGRlckNsYXNzTmFtZSA6IHRoaXMucGxhY2Vob2xkZXJDbGFzc05hbWU7XG4gICAgaWYgKHR5cGVvZiBkYXRhU2F2ZXIgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0eXBlb2YgZGF0YVNhdmVyID09PSAnb2JqZWN0Jykge1xuICAgICAgdGhpcy5fYnV0dG9uQ2xhc3NOYW1lID0gZGF0YVNhdmVyLmJ1dHRvbkNsYXNzTmFtZTtcbiAgICAgIHRoaXMuX3dyYXBwZXJDbGFzc05hbWUgPSBkYXRhU2F2ZXIud3JhcHBlckNsYXNzTmFtZTtcbiAgICB9XG4gICAgdGhpcy5fZGF0YVNhdmVyID0gdHJ1ZTsgLy8gZGF0YVNhdmVyIGlzIHRydWVcbiAgfVxuXG59XG4iXX0=

@@ -21,3 +21,3 @@ /**

placeholderClassName: 'pimg__placeholder',
fetchOnDemand: true,
fetchOnDemand: false,
dataSaver: false,

@@ -28,2 +28,2 @@ buttonClassName: 'pimg_btn',

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLW9wdGlvbnMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvY29uZmlnLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBT0EsTUFBTSxDQUFDLHVCQUFNLGNBQWMsR0FBRztJQUM1QixvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsYUFBYSxFQUFFLElBQUk7SUFDbkIsU0FBUyxFQUFFLEtBQUs7SUFDaEIsZUFBZSxFQUFFLFVBQVU7SUFDM0IsZ0JBQWdCLEVBQUUsY0FBYztDQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBbmd1bGFyUGltZ09wdGlvbnMge1xuICBwbGFjZWhvbGRlckNsYXNzTmFtZTogc3RyaW5nO1xuICBjbGFzc05hbWU6IHN0cmluZztcbiAgZmV0Y2hPbkRlbWFuZDogYm9vbGVhbjtcbiAgZGF0YVNhdmVyOiBmYWxzZSB8IHsgd3JhcHBlckNsYXNzTmFtZTogc3RyaW5nLCBidXR0b25DbGFzc05hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdE9wdGlvbnMgPSB7XG4gIHBsYWNlaG9sZGVyQ2xhc3NOYW1lOiAncGltZ19fcGxhY2Vob2xkZXInLFxuICBmZXRjaE9uRGVtYW5kOiB0cnVlLFxuICBkYXRhU2F2ZXI6IGZhbHNlLFxuICBidXR0b25DbGFzc05hbWU6ICdwaW1nX2J0bicsXG4gIHdyYXBwZXJDbGFzc05hbWU6ICdwaW1nX3dyYXBwZXInLFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLW9wdGlvbnMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvY29uZmlnLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBT0EsTUFBTSxDQUFDLHVCQUFNLGNBQWMsR0FBRztJQUM1QixvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsYUFBYSxFQUFFLEtBQUs7SUFDcEIsU0FBUyxFQUFFLEtBQUs7SUFDaEIsZUFBZSxFQUFFLFVBQVU7SUFDM0IsZ0JBQWdCLEVBQUUsY0FBYztDQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBbmd1bGFyUGltZ09wdGlvbnMge1xuICBwbGFjZWhvbGRlckNsYXNzTmFtZTogc3RyaW5nO1xuICBjbGFzc05hbWU6IHN0cmluZztcbiAgZmV0Y2hPbkRlbWFuZDogYm9vbGVhbjtcbiAgZGF0YVNhdmVyOiBmYWxzZSB8IHsgd3JhcHBlckNsYXNzTmFtZTogc3RyaW5nLCBidXR0b25DbGFzc05hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdE9wdGlvbnMgPSB7XG4gIHBsYWNlaG9sZGVyQ2xhc3NOYW1lOiAncGltZ19fcGxhY2Vob2xkZXInLFxuICBmZXRjaE9uRGVtYW5kOiBmYWxzZSxcbiAgZGF0YVNhdmVyOiBmYWxzZSxcbiAgYnV0dG9uQ2xhc3NOYW1lOiAncGltZ19idG4nLFxuICB3cmFwcGVyQ2xhc3NOYW1lOiAncGltZ193cmFwcGVyJyxcbn07XG4iXX0=

@@ -38,3 +38,2 @@ /**

_this.isIntersecting = true;
console.log('Called by intersection API');
_this.delayed = false;

@@ -57,3 +56,2 @@ observer.disconnect();

.then(function (res) {
console.log(res);
_this.blob = _this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));

@@ -82,3 +80,2 @@ _this.loading = false;

if (props.findIndex(function (val) { return val === prop; }) > 0 && !this_1.isUndefined(changes[prop].currentValue)) {
console.log(prop + " is not undefined. It has changed");
this_1[prop] = changes[prop].currentValue;

@@ -114,3 +111,2 @@ }

// Called on initialization; Set the default configuration options if option is not present
console.log('Config options', this.options);
if (this.isUndefined(this.fetchOnDemand)) {

@@ -128,4 +124,6 @@ this.fetchOnDemand = this.options.fetchOnDemand;

}
console.log('datasaver', this.dataSaver, this.options.dataSaver);
if (this.isObject(this.dataSaver)) {
// set buttonClassName and wrapperClassName
this.dataSaver = true;
this.buttonClassName = this.dataSaver.buttonClassName;

@@ -155,3 +153,2 @@ this.wrapperClassName = this.dataSaver.wrapperClassName;

this.fetchImage();
console.log('Fetching image, due to config', this.dataSaver);
}

@@ -245,2 +242,2 @@ if (this.src && this.src.includes('cloudinary')) {

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-pimg.component.js","sourceRoot":"ng://angular-pimg/","sources":["lib/angular-pimg.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        console.log('Called by intersection API');\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        console.log(res);\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        console.log(`${prop} is not undefined. It has changed`);\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    console.log('Config options', this.options);\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n      console.log('Fetching image, due to config', this.dataSaver);\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-pimg.component.js","sourceRoot":"ng://angular-pimg/","sources":["lib/angular-pimg.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    console.log('datasaver', this.dataSaver, this.options.dataSaver);\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.dataSaver = true;\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n"]}

@@ -87,2 +87,3 @@ /**

var className = _a.className, dataSaver = _a.dataSaver, fetchOnDemand = _a.fetchOnDemand, placeholderClassName = _a.placeholderClassName;
console.log('setting config');
this._className = typeof className !== 'undefined' ? className : this.className;

@@ -98,5 +99,3 @@ this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;

}
else {
this._dataSaver = true; // dataSaver is true
}
this._dataSaver = true; // dataSaver is true
};

@@ -138,2 +137,2 @@ AngularPimgService.decorators = [

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1waW1nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvYW5ndWxhci1waW1nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0lBYzNELDRCQUEyQztxQ0FOWCxtQkFBbUI7OEJBQzFCLEtBQUs7Z0NBRUgsVUFBVTtpQ0FDVCxjQUFjO1FBR3hDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDWixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ3pCO0tBQ0Y7SUFFRCxzQkFBSSxnREFBZ0I7Ozs7UUFBcEI7WUFDRSxNQUFNLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1NBQy9COzs7T0FBQTtJQUVELHNCQUFJLCtDQUFlOzs7O1FBQW5CO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztTQUM5Qjs7O09BQUE7SUFFRCxzQkFBSSx5Q0FBUzs7OztRQUFiO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7U0FDeEI7OztPQUFBO0lBRUQsc0JBQUksb0RBQW9COzs7O1FBQXhCO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztTQUNuQzs7O09BQUE7SUFFRCxzQkFBSSx5Q0FBUzs7OztRQUFiO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7U0FDeEI7OztPQUFBO0lBRUQsc0JBQUksNkNBQWE7Ozs7UUFBakI7WUFDRSxNQUFNLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQztTQUM1Qjs7O09BQUE7Ozs7O0lBRUQsc0NBQVM7Ozs7SUFBVCxVQUFVLEVBQTBGO1lBQXhGLHdCQUFTLEVBQUUsd0JBQVMsRUFBRSxnQ0FBYSxFQUFFLDhDQUFvQjtRQUNuRSxJQUFJLENBQUMsVUFBVSxHQUFHLE9BQU8sU0FBUyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ2hGLElBQUksQ0FBQyxjQUFjLEdBQUcsT0FBTyxhQUFhLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDaEcsSUFBSSxDQUFDLHFCQUFxQixHQUFHLE9BQU8sb0JBQW9CLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDO1FBQzVILEVBQUUsQ0FBQyxDQUFDLE9BQU8sU0FBUyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUM7WUFDckMsTUFBTSxDQUFDO1NBQ1I7UUFDRCxFQUFFLENBQUMsQ0FBQyxPQUFPLFNBQVMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxTQUFTLENBQUMsZUFBZSxDQUFDO1lBQ2xELElBQUksQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUMsZ0JBQWdCLENBQUM7U0FDckQ7UUFBQyxJQUFJLENBQUMsQ0FBQztZQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1NBQ3hCO0tBQ0Y7O2dCQXRERixVQUFVLFNBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzs7O2dEQVNjLFFBQVEsWUFBSSxNQUFNLFNBQUMsU0FBUzs7OzZCQWQzQzs7U0FNYSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBbmd1bGFyUGltZ09wdGlvbnMgfSBmcm9tICcuL2NvbmZpZy1vcHRpb25zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQW5ndWxhclBpbWdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBfY2xhc3NOYW1lOiBzdHJpbmc7XG4gIHByaXZhdGUgX3BsYWNlaG9sZGVyQ2xhc3NOYW1lID0gJ3BpbWdfX3BsYWNlaG9sZGVyJztcbiAgcHJpdmF0ZSBfZmV0Y2hPbkRlbWFuZCA9IGZhbHNlO1xuICBwcml2YXRlIF9kYXRhU2F2ZXI6IGJvb2xlYW47XG4gIHByaXZhdGUgX2J1dHRvbkNsYXNzTmFtZSA9ICdwaW1nX2J0bic7XG4gIHByaXZhdGUgX3dyYXBwZXJDbGFzc05hbWUgPSAncGltZ193cmFwcGVyJztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBASW5qZWN0KCdPcHRpb25zJykgb3B0aW9uczogQW5ndWxhclBpbWdPcHRpb25zKSB7XG4gICAgaWYgKG9wdGlvbnMpIHtcbiAgICAgIHRoaXMuc2V0Q29uZmlnKG9wdGlvbnMpO1xuICAgIH1cbiAgfVxuXG4gIGdldCB3cmFwcGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3dyYXBwZXJDbGFzc05hbWU7XG4gIH1cblxuICBnZXQgYnV0dG9uQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2J1dHRvbkNsYXNzTmFtZTtcbiAgfVxuXG4gIGdldCBjbGFzc05hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fY2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IHBsYWNlaG9sZGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BsYWNlaG9sZGVyQ2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IGRhdGFTYXZlcigpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YVNhdmVyO1xuICB9XG5cbiAgZ2V0IGZldGNoT25EZW1hbmQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2ZldGNoT25EZW1hbmQ7XG4gIH1cblxuICBzZXRDb25maWcoeyBjbGFzc05hbWUsIGRhdGFTYXZlciwgZmV0Y2hPbkRlbWFuZCwgcGxhY2Vob2xkZXJDbGFzc05hbWUgfTogUGFydGlhbDxBbmd1bGFyUGltZ09wdGlvbnM+KSB7XG4gICAgdGhpcy5fY2xhc3NOYW1lID0gdHlwZW9mIGNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBjbGFzc05hbWUgOiB0aGlzLmNsYXNzTmFtZTtcbiAgICB0aGlzLl9mZXRjaE9uRGVtYW5kID0gdHlwZW9mIGZldGNoT25EZW1hbmQgIT09ICd1bmRlZmluZWQnID8gZmV0Y2hPbkRlbWFuZCA6IHRoaXMuZmV0Y2hPbkRlbWFuZDtcbiAgICB0aGlzLl9wbGFjZWhvbGRlckNsYXNzTmFtZSA9IHR5cGVvZiBwbGFjZWhvbGRlckNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBwbGFjZWhvbGRlckNsYXNzTmFtZSA6IHRoaXMucGxhY2Vob2xkZXJDbGFzc05hbWU7XG4gICAgaWYgKHR5cGVvZiBkYXRhU2F2ZXIgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0eXBlb2YgZGF0YVNhdmVyID09PSAnb2JqZWN0Jykge1xuICAgICAgdGhpcy5fYnV0dG9uQ2xhc3NOYW1lID0gZGF0YVNhdmVyLmJ1dHRvbkNsYXNzTmFtZTtcbiAgICAgIHRoaXMuX3dyYXBwZXJDbGFzc05hbWUgPSBkYXRhU2F2ZXIud3JhcHBlckNsYXNzTmFtZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fZGF0YVNhdmVyID0gdHJ1ZTsgLy8gZGF0YVNhdmVyIGlzIHRydWVcbiAgICB9XG4gIH1cblxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1waW1nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvYW5ndWxhci1waW1nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0lBYzNELDRCQUEyQztxQ0FOWCxtQkFBbUI7OEJBQzFCLEtBQUs7Z0NBRUgsVUFBVTtpQ0FDVCxjQUFjO1FBR3hDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDWixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ3pCO0tBQ0Y7SUFFRCxzQkFBSSxnREFBZ0I7Ozs7UUFBcEI7WUFDRSxNQUFNLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1NBQy9COzs7T0FBQTtJQUVELHNCQUFJLCtDQUFlOzs7O1FBQW5CO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztTQUM5Qjs7O09BQUE7SUFFRCxzQkFBSSx5Q0FBUzs7OztRQUFiO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7U0FDeEI7OztPQUFBO0lBRUQsc0JBQUksb0RBQW9COzs7O1FBQXhCO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztTQUNuQzs7O09BQUE7SUFFRCxzQkFBSSx5Q0FBUzs7OztRQUFiO1lBQ0UsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7U0FDeEI7OztPQUFBO0lBRUQsc0JBQUksNkNBQWE7Ozs7UUFBakI7WUFDRSxNQUFNLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQztTQUM1Qjs7O09BQUE7Ozs7O0lBRUQsc0NBQVM7Ozs7SUFBVCxVQUFVLEVBQTBGO1lBQXhGLHdCQUFTLEVBQUUsd0JBQVMsRUFBRSxnQ0FBYSxFQUFFLDhDQUFvQjtRQUNuRSxPQUFPLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLFNBQVMsS0FBSyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUNoRixJQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sYUFBYSxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQ2hHLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxPQUFPLG9CQUFvQixLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQztRQUM1SCxFQUFFLENBQUMsQ0FBQyxPQUFPLFNBQVMsS0FBSyxXQUFXLENBQUMsQ0FBQyxDQUFDO1lBQ3JDLE1BQU0sQ0FBQztTQUNSO1FBQ0QsRUFBRSxDQUFDLENBQUMsT0FBTyxTQUFTLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsU0FBUyxDQUFDLGVBQWUsQ0FBQztZQUNsRCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFDLGdCQUFnQixDQUFDO1NBQ3JEO1FBQ0QsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7S0FDeEI7O2dCQXRERixVQUFVLFNBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzs7O2dEQVNjLFFBQVEsWUFBSSxNQUFNLFNBQUMsU0FBUzs7OzZCQWQzQzs7U0FNYSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBbmd1bGFyUGltZ09wdGlvbnMgfSBmcm9tICcuL2NvbmZpZy1vcHRpb25zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQW5ndWxhclBpbWdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBfY2xhc3NOYW1lOiBzdHJpbmc7XG4gIHByaXZhdGUgX3BsYWNlaG9sZGVyQ2xhc3NOYW1lID0gJ3BpbWdfX3BsYWNlaG9sZGVyJztcbiAgcHJpdmF0ZSBfZmV0Y2hPbkRlbWFuZCA9IGZhbHNlO1xuICBwcml2YXRlIF9kYXRhU2F2ZXI6IGJvb2xlYW47XG4gIHByaXZhdGUgX2J1dHRvbkNsYXNzTmFtZSA9ICdwaW1nX2J0bic7XG4gIHByaXZhdGUgX3dyYXBwZXJDbGFzc05hbWUgPSAncGltZ193cmFwcGVyJztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBASW5qZWN0KCdPcHRpb25zJykgb3B0aW9uczogQW5ndWxhclBpbWdPcHRpb25zKSB7XG4gICAgaWYgKG9wdGlvbnMpIHtcbiAgICAgIHRoaXMuc2V0Q29uZmlnKG9wdGlvbnMpO1xuICAgIH1cbiAgfVxuXG4gIGdldCB3cmFwcGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3dyYXBwZXJDbGFzc05hbWU7XG4gIH1cblxuICBnZXQgYnV0dG9uQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2J1dHRvbkNsYXNzTmFtZTtcbiAgfVxuXG4gIGdldCBjbGFzc05hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fY2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IHBsYWNlaG9sZGVyQ2xhc3NOYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BsYWNlaG9sZGVyQ2xhc3NOYW1lO1xuICB9XG5cbiAgZ2V0IGRhdGFTYXZlcigpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YVNhdmVyO1xuICB9XG5cbiAgZ2V0IGZldGNoT25EZW1hbmQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2ZldGNoT25EZW1hbmQ7XG4gIH1cblxuICBzZXRDb25maWcoeyBjbGFzc05hbWUsIGRhdGFTYXZlciwgZmV0Y2hPbkRlbWFuZCwgcGxhY2Vob2xkZXJDbGFzc05hbWUgfTogUGFydGlhbDxBbmd1bGFyUGltZ09wdGlvbnM+KSB7XG4gICAgY29uc29sZS5sb2coJ3NldHRpbmcgY29uZmlnJyk7XG4gICAgdGhpcy5fY2xhc3NOYW1lID0gdHlwZW9mIGNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBjbGFzc05hbWUgOiB0aGlzLmNsYXNzTmFtZTtcbiAgICB0aGlzLl9mZXRjaE9uRGVtYW5kID0gdHlwZW9mIGZldGNoT25EZW1hbmQgIT09ICd1bmRlZmluZWQnID8gZmV0Y2hPbkRlbWFuZCA6IHRoaXMuZmV0Y2hPbkRlbWFuZDtcbiAgICB0aGlzLl9wbGFjZWhvbGRlckNsYXNzTmFtZSA9IHR5cGVvZiBwbGFjZWhvbGRlckNsYXNzTmFtZSAhPT0gJ3VuZGVmaW5lZCcgPyBwbGFjZWhvbGRlckNsYXNzTmFtZSA6IHRoaXMucGxhY2Vob2xkZXJDbGFzc05hbWU7XG4gICAgaWYgKHR5cGVvZiBkYXRhU2F2ZXIgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0eXBlb2YgZGF0YVNhdmVyID09PSAnb2JqZWN0Jykge1xuICAgICAgdGhpcy5fYnV0dG9uQ2xhc3NOYW1lID0gZGF0YVNhdmVyLmJ1dHRvbkNsYXNzTmFtZTtcbiAgICAgIHRoaXMuX3dyYXBwZXJDbGFzc05hbWUgPSBkYXRhU2F2ZXIud3JhcHBlckNsYXNzTmFtZTtcbiAgICB9XG4gICAgdGhpcy5fZGF0YVNhdmVyID0gdHJ1ZTsgLy8gZGF0YVNhdmVyIGlzIHRydWVcbiAgfVxuXG59XG4iXX0=

@@ -21,3 +21,3 @@ /**

placeholderClassName: 'pimg__placeholder',
fetchOnDemand: true,
fetchOnDemand: false,
dataSaver: false,

@@ -28,2 +28,2 @@ buttonClassName: 'pimg_btn',

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLW9wdGlvbnMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvY29uZmlnLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBT0EsTUFBTSxDQUFDLHFCQUFNLGNBQWMsR0FBRztJQUM1QixvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsYUFBYSxFQUFFLElBQUk7SUFDbkIsU0FBUyxFQUFFLEtBQUs7SUFDaEIsZUFBZSxFQUFFLFVBQVU7SUFDM0IsZ0JBQWdCLEVBQUUsY0FBYztDQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBbmd1bGFyUGltZ09wdGlvbnMge1xuICBwbGFjZWhvbGRlckNsYXNzTmFtZTogc3RyaW5nO1xuICBjbGFzc05hbWU6IHN0cmluZztcbiAgZmV0Y2hPbkRlbWFuZDogYm9vbGVhbjtcbiAgZGF0YVNhdmVyOiBmYWxzZSB8IHsgd3JhcHBlckNsYXNzTmFtZTogc3RyaW5nLCBidXR0b25DbGFzc05hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdE9wdGlvbnMgPSB7XG4gIHBsYWNlaG9sZGVyQ2xhc3NOYW1lOiAncGltZ19fcGxhY2Vob2xkZXInLFxuICBmZXRjaE9uRGVtYW5kOiB0cnVlLFxuICBkYXRhU2F2ZXI6IGZhbHNlLFxuICBidXR0b25DbGFzc05hbWU6ICdwaW1nX2J0bicsXG4gIHdyYXBwZXJDbGFzc05hbWU6ICdwaW1nX3dyYXBwZXInLFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLW9wdGlvbnMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBpbWcvIiwic291cmNlcyI6WyJsaWIvY29uZmlnLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBT0EsTUFBTSxDQUFDLHFCQUFNLGNBQWMsR0FBRztJQUM1QixvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsYUFBYSxFQUFFLEtBQUs7SUFDcEIsU0FBUyxFQUFFLEtBQUs7SUFDaEIsZUFBZSxFQUFFLFVBQVU7SUFDM0IsZ0JBQWdCLEVBQUUsY0FBYztDQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBbmd1bGFyUGltZ09wdGlvbnMge1xuICBwbGFjZWhvbGRlckNsYXNzTmFtZTogc3RyaW5nO1xuICBjbGFzc05hbWU6IHN0cmluZztcbiAgZmV0Y2hPbkRlbWFuZDogYm9vbGVhbjtcbiAgZGF0YVNhdmVyOiBmYWxzZSB8IHsgd3JhcHBlckNsYXNzTmFtZTogc3RyaW5nLCBidXR0b25DbGFzc05hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdE9wdGlvbnMgPSB7XG4gIHBsYWNlaG9sZGVyQ2xhc3NOYW1lOiAncGltZ19fcGxhY2Vob2xkZXInLFxuICBmZXRjaE9uRGVtYW5kOiBmYWxzZSxcbiAgZGF0YVNhdmVyOiBmYWxzZSxcbiAgYnV0dG9uQ2xhc3NOYW1lOiAncGltZ19idG4nLFxuICB3cmFwcGVyQ2xhc3NOYW1lOiAncGltZ193cmFwcGVyJyxcbn07XG4iXX0=

@@ -63,2 +63,3 @@ import { Injectable, Optional, Inject, NgModule, SkipSelf, Component, Input, Output, EventEmitter, ElementRef, defineInjectable, inject } from '@angular/core';

setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }) {
console.log('setting config');
this._className = typeof className !== 'undefined' ? className : this.className;

@@ -74,5 +75,3 @@ this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;

}
else {
this._dataSaver = true; // dataSaver is true
}
this._dataSaver = true; // dataSaver is true
}

@@ -126,3 +125,2 @@ }

this.isIntersecting = true;
console.log('Called by intersection API');
this.delayed = false;

@@ -141,3 +139,2 @@ observer.disconnect();

.then(res => {
console.log(res);
this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));

@@ -161,3 +158,2 @@ this.loading = false;

if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {
console.log(`${prop} is not undefined. It has changed`);
this[prop] = changes[prop].currentValue;

@@ -186,3 +182,2 @@ }

// Called on initialization; Set the default configuration options if option is not present
console.log('Config options', this.options);
if (this.isUndefined(this.fetchOnDemand)) {

@@ -200,4 +195,6 @@ this.fetchOnDemand = this.options.fetchOnDemand;

}
console.log('datasaver', this.dataSaver, this.options.dataSaver);
if (this.isObject(this.dataSaver)) {
// set buttonClassName and wrapperClassName
this.dataSaver = true;
this.buttonClassName = this.dataSaver.buttonClassName;

@@ -224,3 +221,2 @@ this.wrapperClassName = this.dataSaver.wrapperClassName;

this.fetchImage();
console.log('Fetching image, due to config', this.dataSaver);
}

@@ -323,2 +319,2 @@ if (this.src && this.src.includes('cloudinary')) {

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    } else {\n      this._dataSaver = true; // dataSaver is true\n    }\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        console.log('Called by intersection API');\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        console.log(res);\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        console.log(`${prop} is not undefined. It has changed`);\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    console.log('Config options', this.options);\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n      console.log('Fetching image, due to config', this.dataSaver);\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    console.log('setting config');\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    }\n    this._dataSaver = true; // dataSaver is true\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    console.log('datasaver', this.dataSaver, this.options.dataSaver);\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.dataSaver = true;\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":";;;;;;;;AAAA;;;;IAcE,YAA2C;qCANX,mBAAmB;8BAC1B,KAAK;gCAEH,UAAU;iCACT,cAAc;QAGxC,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;SACzB;KACF;;;;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;KAC/B;;;;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;KAC9B;;;;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;KACxB;;;;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC;KACnC;;;;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;KACxB;;;;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;KAC5B;;;;;IAED,SAAS,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,oBAAoB,EAA+B;QAClG,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,OAAO,SAAS,KAAK,WAAW,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAChF,IAAI,CAAC,cAAc,GAAG,OAAO,aAAa,KAAK,WAAW,GAAG,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QAChG,IAAI,CAAC,qBAAqB,GAAG,OAAO,oBAAoB,KAAK,WAAW,GAAG,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC;QAC5H,IAAI,OAAO,SAAS,KAAK,WAAW,EAAE;YACpC,OAAO;SACR;QACD,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;YACjC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,eAAe,CAAC;YAClD,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC,gBAAgB,CAAC;SACrD;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;KACxB;;;YAtDF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;;4CASc,QAAQ,YAAI,MAAM,SAAC,SAAS;;;;;;;;ACd3C;;;;;;IAuCE,YAAoB,EAAc,EAAU,YAA0B,EAAU,OAA2B;QAAvF,OAAE,GAAF,EAAE,CAAY;QAAU,iBAAY,GAAZ,YAAY,CAAc;QAAU,YAAO,GAAP,OAAO,CAAoB;qBAXrF,EAAE,OAAO,EAAE,OAAO,EAAE;uBACF,IAAI,YAAY,EAAE;qBACrB,IAAI,YAAY,EAAE;gCACpC,EAAE;+BACH,EAAE;oBACJ,EAAE;8BAIO,KAAK;wBAoGnB,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ;2BACvB,CAAC,IAAI,OAAO,CAAC,KAAK,WAAW;QAlGzC,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,KAAK,EAAE,CAAC;KACd;;;;IAED,gBAAgB;QACd,uBAAM,QAAQ,GAAG,IAAI,oBAAoB,CAAC,OAAO;YAC/C,uBAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,KAAK,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBAChD,IAAI,CAAC,UAAU,EAAE,CAAC;gBAClB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,QAAQ,CAAC,UAAU,EAAE,CAAC;aACvB;SACF,CAAC,CAAC;QACH,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;KACzC;;;;IAED,UAAU;QACR,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC;aACZ,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;aACvB,IAAI,CAAC,GAAG;YACP,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;YAC/E,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;SACrB,CAAC;aACD,KAAK,CAAC,GAAG;YACR,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACtB,CAAC,CAAC;KACN;;;;;IAED,WAAW,CAAC,OAAsB;QAEhC,uBAAM,KAAK,GAAG,CAAC,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,sBAAsB,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QACpG,KAAK,uBAAM,IAAI,IAAI,OAAO,EAAE;YAC1B,IAAI,KAAK,CAAC,SAAS,CAAC,GAAG,IAAI,GAAG,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,EAAE;gBAC7F,IAAI,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC;aACzC;iBAAM;gBACL,IAAI,IAAI,KAAK,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE;oBACxD,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC;oBAClE,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,oBAAoB,CAAC;iBAC7E;aACF;SACF;QACD,IAAI,CAAC,KAAK,EAAE,CAAC;;;;;;;;KAQd;;;;IAED,WAAW;;QAET,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;YACxC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;SACjD;QACD,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE;YAC/C,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC;SAC/D;QACD,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YACpC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;SACzC;QACD,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YACpC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;SACzC;QACD,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACjE,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;;YAEjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC;YACtD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;SACzD;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;YACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;SACvD;KACF;;;;IAED,KAAK;QACH,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;aAAM,IAAI,IAAI,CAAC,aAAa,EAAE;YAC7B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;aAAM;YACL,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;QACD,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;YAC/C,IAAI,CAAC,WAAW;gBACd,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,EAAE,uBAAuB,CAAC,CAAC;SAC7E;QACD,IAAI,CAAC,OAAO,GAAG,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;KACjE;;;YAlIF,SAAS,SAAC;gBACT,QAAQ,EAAE,cAAc;gBACxB,QAAQ,EAAE;;;;;;;;;;;eAWG;gBACb,MAAM,EAAE,EAAE;aACX;;;;YApB0E,UAAU;YAC5E,YAAY;YACZ,kBAAkB;;;0BAoBxB,KAAK;oBACL,KAAK;8BACL,KAAK;4BACL,KAAK;qCACL,KAAK;0BACL,KAAK;sBACL,KAAK;wBACL,MAAM;sBACN,MAAM;;;;;;;AC9BT;;;;IAcE,YAAoC;QAClC,IAAI,YAAY,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;SAChG;KACF;;;;;IACD,OAAO,OAAO,CAAC,OAAqC;QAClD,OAAO;YACL,QAAQ,EAAE,iBAAiB;YAC3B,SAAS,EAAE;gBACT,kBAAkB;gBAClB,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE;aAC1C;SACF,CAAC;KACH;;;YArBF,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;iBACb;gBACD,YAAY,EAAE,CAAC,oBAAoB,CAAC;gBACpC,OAAO,EAAE,CAAC,oBAAoB,CAAC;aAChC;;;;YACY,iBAAiB,uBACf,QAAQ,YAAI,QAAQ;;;;;;;;;;;;;;;"}

@@ -89,2 +89,3 @@ import { Injectable, Optional, Inject, NgModule, SkipSelf, Component, Input, Output, EventEmitter, ElementRef, defineInjectable, inject } from '@angular/core';

var className = _a.className, dataSaver = _a.dataSaver, fetchOnDemand = _a.fetchOnDemand, placeholderClassName = _a.placeholderClassName;
console.log('setting config');
this._className = typeof className !== 'undefined' ? className : this.className;

@@ -100,5 +101,3 @@ this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;

}
else {
this._dataSaver = true; // dataSaver is true
}
this._dataSaver = true; // dataSaver is true
};

@@ -152,3 +151,2 @@ AngularPimgService.decorators = [

_this.isIntersecting = true;
console.log('Called by intersection API');
_this.delayed = false;

@@ -171,3 +169,2 @@ observer.disconnect();

.then(function (res) {
console.log(res);
_this.blob = _this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));

@@ -195,3 +192,2 @@ _this.loading = false;

if (props.findIndex(function (val) { return val === prop; }) > 0 && !this_1.isUndefined(changes[prop].currentValue)) {
console.log(prop + " is not undefined. It has changed");
this_1[prop] = changes[prop].currentValue;

@@ -227,3 +223,2 @@ }

// Called on initialization; Set the default configuration options if option is not present
console.log('Config options', this.options);
if (this.isUndefined(this.fetchOnDemand)) {

@@ -241,4 +236,6 @@ this.fetchOnDemand = this.options.fetchOnDemand;

}
console.log('datasaver', this.dataSaver, this.options.dataSaver);
if (this.isObject(this.dataSaver)) {
// set buttonClassName and wrapperClassName
this.dataSaver = true;
this.buttonClassName = this.dataSaver.buttonClassName;

@@ -268,3 +265,2 @@ this.wrapperClassName = this.dataSaver.wrapperClassName;

this.fetchImage();
console.log('Fetching image, due to config', this.dataSaver);
}

@@ -359,2 +355,2 @@ if (this.src && this.src.includes('cloudinary')) {

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    } else {\n      this._dataSaver = true; // dataSaver is true\n    }\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        console.log('Called by intersection API');\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        console.log(res);\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        console.log(`${prop} is not undefined. It has changed`);\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    console.log('Config options', this.options);\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n      console.log('Fetching image, due to config', this.dataSaver);\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-pimg.js.map","sources":["ng://angular-pimg/lib/angular-pimg.service.ts","ng://angular-pimg/lib/angular-pimg.component.ts","ng://angular-pimg/lib/angular-pimg.module.ts"],"sourcesContent":["import { Injectable, Optional, Inject } from '@angular/core';\nimport { AngularPimgOptions } from './config-options';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularPimgService {\n  private _className: string;\n  private _placeholderClassName = 'pimg__placeholder';\n  private _fetchOnDemand = false;\n  private _dataSaver: boolean;\n  private _buttonClassName = 'pimg_btn';\n  private _wrapperClassName = 'pimg_wrapper';\n\n  constructor(@Optional() @Inject('Options') options: AngularPimgOptions) {\n    if (options) {\n      this.setConfig(options);\n    }\n  }\n\n  get wrapperClassName(): string {\n    return this._wrapperClassName;\n  }\n\n  get buttonClassName(): string {\n    return this._buttonClassName;\n  }\n\n  get className(): string {\n    return this._className;\n  }\n\n  get placeholderClassName(): string {\n    return this._placeholderClassName;\n  }\n\n  get dataSaver(): boolean {\n    return this._dataSaver;\n  }\n\n  get fetchOnDemand(): boolean {\n    return this._fetchOnDemand;\n  }\n\n  setConfig({ className, dataSaver, fetchOnDemand, placeholderClassName }: Partial<AngularPimgOptions>) {\n    console.log('setting config');\n    this._className = typeof className !== 'undefined' ? className : this.className;\n    this._fetchOnDemand = typeof fetchOnDemand !== 'undefined' ? fetchOnDemand : this.fetchOnDemand;\n    this._placeholderClassName = typeof placeholderClassName !== 'undefined' ? placeholderClassName : this.placeholderClassName;\n    if (typeof dataSaver === 'undefined') {\n      return;\n    }\n    if (typeof dataSaver === 'object') {\n      this._buttonClassName = dataSaver.buttonClassName;\n      this._wrapperClassName = dataSaver.wrapperClassName;\n    }\n    this._dataSaver = true; // dataSaver is true\n  }\n\n}\n","import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, ElementRef } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\n\n@Component({\n  selector: 'angular-pimg',\n  template: `<div [ngClass]=\"wrapperClassName\" *ngIf=\"(dataSaver && loading) || delayed; else loadingContent\">\n  <img [ngClass]=\"classes\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <button [ngClass]=\"buttonClassName\" (click)=\"fetchImage()\">\n    Load image\n  </button>\n</div>\n<ng-template #loadingContent>\n  <img *ngIf=\"loading; else otherContent\" [ngClass]=\"placeholderClassName\" [ngStyle]=\"style\" [src]=\"placeholder\" />\n  <ng-template #otherContent>\n    <img [ngStyle]=\"style\" [ngClass]=\"classes\" [src]=\"blob\" />\n  </ng-template>\n</ng-template>`,\n  styles: []\n})\nexport class AngularPimgComponent implements OnChanges {\n  @Input() dataSaver: any;\n  @Input() src: string;\n  @Input() fetchOnDemand: boolean;\n  @Input() placeholder: string;\n  @Input() placeholderClassName: string;\n  @Input() className: string;\n  @Input() style: any = { display: 'block' };\n  @Output() fetched: EventEmitter<null> = new EventEmitter();\n  @Output() error: EventEmitter<any> = new EventEmitter();\n  wrapperClassName = '';\n  buttonClassName = '';\n  blob: SafeUrl = '';\n  delayed: boolean;\n  loading: boolean;\n  classes: string;\n  private isIntersecting = false;\n\n  constructor(private el: ElementRef, private domSanitizer: DomSanitizer, private options: AngularPimgService) {\n    this.insertInput();\n    this.setUp();\n  }\n\n  setFetchOnDemand() {\n    const observer = new IntersectionObserver(entries => {\n      const image = entries[0];\n      if (image.isIntersecting && !this.isIntersecting) {\n        this.fetchImage();\n        this.isIntersecting = true;\n        this.delayed = false;\n        observer.disconnect();\n      }\n    });\n    observer.observe(this.el.nativeElement);\n  }\n\n  fetchImage() {\n    fetch(this.src)\n      .then(res => res.blob())\n      .then(res => {\n        this.blob = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(res));\n        this.loading = false;\n        this.isIntersecting = false;\n        this.delayed = false;\n        this.fetched.emit();\n      })\n      .catch(err => {\n        this.error.emit(err);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const newValues: any = {};\n    const props = ['src', 'fetchOnDemand', 'placeholder', 'placeholderClassName', 'className', 'style'];\n    for (const prop in changes) {\n      if (props.findIndex(val => val === prop) > 0 && !this.isUndefined(changes[prop].currentValue)) {\n        this[prop] = changes[prop].currentValue;\n      } else {\n        if (prop === 'dataSaver' && this.isObject(changes[prop])) {\n          this.buttonClassName = changes[prop].currentValue.buttonClassName;\n          this.placeholderClassName = changes[prop].currentValue.placeholderClassName;\n        }\n      }\n    }\n    this.setUp();\n    // changes.dataSaver ? newValues.dataSaver = changes.dataSaver.currentValue : null;\n    // changes.src ? newValues.src = changes.src.currentValue : null;\n    // changes.fetchOnDemand ? newValues.fetchOnDemand = changes.fetchOnDemand.currentValue : null;\n    // changes.placeholder ? newValues.placeholder = changes.placeholder.currentValue : null;\n    // changes.placeholderClassName ? newValues.placeholderClassName = changes.placeholderClassName.currentValue : null;\n    // changes.class ? newValues.class = changes.class.currentValue : null;\n    // changes.style ? newValues.style = changes.style.currentValue : null;\n  }\n\n  insertInput() {\n    // Called on initialization; Set the default configuration options if option is not present\n    if (this.isUndefined(this.fetchOnDemand)) {\n      this.fetchOnDemand = this.options.fetchOnDemand;\n    }\n    if (this.isUndefined(this.placeholderClassName)) {\n      this.placeholderClassName = this.options.placeholderClassName;\n    }\n    if (this.isUndefined(this.dataSaver)) {\n      this.dataSaver = this.options.dataSaver;\n    }\n    if (this.isUndefined(this.className)) {\n      this.className = this.options.className;\n    }\n    console.log('datasaver', this.dataSaver, this.options.dataSaver);\n    if (this.isObject(this.dataSaver)) {\n      // set buttonClassName and wrapperClassName\n      this.dataSaver = true;\n      this.buttonClassName = this.dataSaver.buttonClassName;\n      this.wrapperClassName = this.dataSaver.wrapperClassName;\n    } else {\n      this.buttonClassName = this.options.buttonClassName;\n      this.wrapperClassName = this.options.wrapperClassName;\n    }\n  }\n\n  setUp() {\n    if (this.dataSaver) {\n      this.delayed = true;\n    } else if (this.fetchOnDemand) {\n      this.loading = true;\n      this.setFetchOnDemand();\n    } else {\n      this.fetchImage();\n    }\n    if (this.src && this.src.includes('cloudinary')) {\n      this.placeholder =\n        this.placeholder || this.src.replace('/upload/', '/upload/c_thumb,w_30/');\n    }\n    this.classes = `${this.className} ${this.placeholderClassName}`;\n  }\n\n  isObject = x => typeof x === 'object';\n  isUndefined = x => typeof x === 'undefined';\n\n}\n","import { NgModule, ModuleWithProviders, Optional, SkipSelf } from '@angular/core';\nimport { AngularPimgComponent } from './angular-pimg.component';\nimport { AngularPimgService } from './angular-pimg.service';\nimport { AngularPimgOptions } from './config-options';\nimport { CommonModule } from '@angular/common';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [AngularPimgComponent],\n  exports: [AngularPimgComponent]\n})\nexport class AngularPimgModule {\n  constructor(@Optional() @SkipSelf() parentModule: AngularPimgModule) {\n    if (parentModule) {\n      throw new Error('The Angular Pimg Module is already loaded. Import it only in your AppModule');\n    }\n  }\n  static forRoot(options?: Partial<AngularPimgOptions>): ModuleWithProviders {\n    return {\n      ngModule: AngularPimgModule,\n      providers: [\n        AngularPimgService,\n        { provide: 'Options', useValue: options }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
{
"name": "angular-pimg",
"version": "0.0.3",
"version": "0.0.4",
"peerDependencies": {

@@ -5,0 +5,0 @@ "@angular/common": "^6.0.0-rc.0 || ^6.0.0",

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