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

ng-cloudimage-responsive

Package Overview
Dependencies
Maintainers
1
Versions
32
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ng-cloudimage-responsive - npm Package Compare versions

Comparing version 2.0.1 to 2.0.2

786

bundles/ng-cloudimage-responsive.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/platform-browser'), require('rxjs'), require('rxjs/operators'), require('ng-lazyload-image')) :
typeof define === 'function' && define.amd ? define('ng-cloudimage-responsive', ['exports', '@angular/core', '@angular/common', '@angular/platform-browser', 'rxjs', 'rxjs/operators', 'ng-lazyload-image'], factory) :
(global = global || self, factory(global['ng-cloudimage-responsive'] = {}, global.ng.core, global.ng.common, global.ng.platformBrowser, global.rxjs, global.rxjs.operators, global.ngLazyloadImage));
}(this, function (exports, core, common, platformBrowser, rxjs, operators, ngLazyloadImage) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/common'), require('@angular/core'), require('@angular/platform-browser'), require('rxjs'), require('rxjs/operators'), require('ng-lazyload-image')) :
typeof define === 'function' && define.amd ? define('ng-cloudimage-responsive', ['exports', '@angular/common', '@angular/core', '@angular/platform-browser', 'rxjs', 'rxjs/operators', 'ng-lazyload-image'], factory) :
(factory((global['ng-cloudimage-responsive'] = {}),global.ng.common,global.ng.core,global.ng.platformBrowser,global.rxjs,global.rxjs.operators,global.ngLazyloadImage));
}(this, (function (exports,common,i0,platformBrowser,rxjs,operators,ngLazyloadImage) { 'use strict';

@@ -21,8 +21,9 @@ /*! *****************************************************************************

***************************************************************************** */
var __assign = function() {
var __assign = function () {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}

@@ -33,20 +34,26 @@ return t;

};
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
if (!m)
return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
while ((n === void 0 || n-- > 0) && !(r = i.next()).done)
ar.push(r.value);
}
catch (error) { e = { error: error }; }
catch (error) {
e = { error: error };
}
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
if (r && !r.done && (m = i["return"]))
m.call(i);
}
finally { if (e) throw e.error; }
finally {
if (e)
throw e.error;
}
}
return ar;
}
function __spread() {

@@ -60,3 +67,3 @@ for (var ar = [], i = 0; i < arguments.length; i++)

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -71,3 +78,3 @@ var CIConfig = /** @class */ (function () {

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -119,22 +126,22 @@ var CIService = /** @class */ (function () {

*/
function (img, config) {
if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {
return config.width;
}
/** @type {?} */
var parentContainer = this.getParentContainerWithWidth(img);
/** @type {?} */
var currentWidth = parseInt('' + parentContainer, 10);
/** @type {?} */
var computedWidth = Number(window.getComputedStyle(img).width);
if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {
return this.getSizeLimit(computedWidth);
}
else {
if (!currentWidth) {
return img.width || config.width;
function (img, config) {
if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {
return config.width;
}
return this.getSizeLimit(currentWidth);
}
};
/** @type {?} */
var parentContainer = this.getParentContainerWithWidth(img);
/** @type {?} */
var currentWidth = parseInt('' + parentContainer, 10);
/** @type {?} */
var computedWidth = Number(window.getComputedStyle(img).width);
if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {
return this.getSizeLimit(computedWidth);
}
else {
if (!currentWidth) {
return img.width || config.width;
}
return this.getSizeLimit(currentWidth);
}
};
/**

@@ -148,17 +155,17 @@ * @param {?} img

*/
function (img) {
/** @type {?} */
var parentNode = null;
/** @type {?} */
var width = 0;
do {
parentNode = (parentNode && parentNode.parentNode) || img.parentNode;
width = parentNode.getBoundingClientRect().width;
} while (parentNode && !width);
/** @type {?} */
var letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10);
/** @type {?} */
var rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10);
return width + (width ? (-letPadding - rightPadding) : 0);
};
function (img) {
/** @type {?} */
var parentNode = null;
/** @type {?} */
var width = 0;
do {
parentNode = (parentNode && parentNode.parentNode) || img.parentNode;
width = parentNode.getBoundingClientRect().width;
} while (parentNode && !width);
/** @type {?} */
var letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10);
/** @type {?} */
var rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10);
return width + (width ? (-letPadding - rightPadding) : 0);
};
/**

@@ -172,11 +179,11 @@ * @param {?} currentSize

*/
function (currentSize) {
if (currentSize <= 25) {
return '25';
}
if (currentSize <= 50) {
return '50';
}
return (Math.ceil(currentSize / 100) * 100).toString();
};
function (currentSize) {
if (currentSize <= 25) {
return '25';
}
if (currentSize <= 50) {
return '50';
}
return (Math.ceil(currentSize / 100) * 100).toString();
};
/**

@@ -190,12 +197,12 @@ * @param {?} size

*/
function (size) {
try {
/** @type {?} */
var array = size.split(',');
return array.length > 1;
}
catch (e) {
return false;
}
};
function (size) {
try {
/** @type {?} */
var array = size.split(',');
return array.length > 1;
}
catch (e) {
return false;
}
};
/**

@@ -209,8 +216,8 @@ * @param {?} src

*/
function (src) {
if (src.indexOf('//') === 0) {
src = window.location.protocol + src;
}
return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);
};
function (src) {
if (src.indexOf('//') === 0) {
src = window.location.protocol + src;
}
return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);
};
/**

@@ -228,10 +235,14 @@ * @param {?} src

*/
function (src, isRelativeUrlPath, baseUrl) {
if (isRelativeUrlPath === void 0) { isRelativeUrlPath = false; }
if (baseUrl === void 0) { baseUrl = ''; }
if (isRelativeUrlPath) {
return baseUrl + src;
}
return src;
};
function (src, isRelativeUrlPath, baseUrl) {
if (isRelativeUrlPath === void 0) {
isRelativeUrlPath = false;
}
if (baseUrl === void 0) {
baseUrl = '';
}
if (isRelativeUrlPath) {
return baseUrl + src;
}
return src;
};
/**

@@ -245,16 +256,15 @@ * @param {?} size

*/
function (size) {
/** @type {?} */
var splittedSizes = size.toString().split('x');
/** @type {?} */
var result = [];
[].forEach.call(splittedSizes, (/**
* @param {?} item
* @return {?}
*/
function (item) {
result.push(item * Math.round(window.devicePixelRatio || 1));
}));
return result.join('x');
};
function (size) {
/** @type {?} */
var splittedSizes = size.toString().split('x');
/** @type {?} */
var result = [];
[].forEach.call(splittedSizes, ( /**
* @param {?} item
* @return {?}
*/function (item) {
result.push(item * Math.round(window.devicePixelRatio || 1));
}));
return result.join('x');
};
/**

@@ -276,10 +286,10 @@ * @param {?} operation

*/
function (operation, size, filters, imgSrc, config) {
var ultraFast = config.ultraFast, token = config.token, container = config.container, queryString = config.queryString;
/** @type {?} */
var isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';
/** @type {?} */
var cloudUrl = isUltraFast + token + '.' + container + '/';
return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;
};
function (operation, size, filters, imgSrc, config) {
var ultraFast = config.ultraFast, token = config.token, container = config.container, queryString = config.queryString;
/** @type {?} */
var isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';
/** @type {?} */
var cloudUrl = isUltraFast + token + '.' + container + '/';
return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;
};
/**

@@ -305,38 +315,35 @@ * @param {?} operation

*/
function (operation, size, filters, imgSrc, isAdaptive, config, isPreview) {
var _this = this;
var previewQualityFactor = config.previewQualityFactor;
/** @type {?} */
var sources = [];
if (isAdaptive) {
size.forEach((/**
* @param {?} __0
* @return {?}
*/
function (_a) {
var nextSize = _a.size, mediaQuery = _a.media;
function (operation, size, filters, imgSrc, isAdaptive, config, isPreview) {
var _this = this;
var previewQualityFactor = config.previewQualityFactor;
/** @type {?} */
var sources = [];
if (isAdaptive) {
size.forEach(( /**
* @param {?} __0
* @return {?}
*/function (_a) {
var nextSize = _a.size, mediaQuery = _a.media;
if (isPreview) {
nextSize = nextSize.split('x').map(( /**
* @param {?} sizeNext
* @return {?}
*/function (sizeNext) { return Math.floor(sizeNext / previewQualityFactor); })).join('x');
}
sources.push({ mediaQuery: mediaQuery, srcSet: _this.generateSrcset(operation, nextSize, filters, imgSrc, config) });
}));
}
else {
if (isPreview) {
nextSize = nextSize.split('x').map((/**
size = size.split('x').map(( /**
* @param {?} sizeNext
* @return {?}
*/
function (sizeNext) { return Math.floor(sizeNext / previewQualityFactor); })).join('x');
*/function (sizeNext) { return Math.floor(sizeNext / previewQualityFactor); })).join('x');
}
sources.push({ mediaQuery: mediaQuery, srcSet: _this.generateSrcset(operation, nextSize, filters, imgSrc, config) });
}));
}
else {
if (isPreview) {
size = size.split('x').map((/**
* @param {?} sizeNext
* @return {?}
*/
function (sizeNext) { return Math.floor(sizeNext / previewQualityFactor); })).join('x');
sources.push({
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config)
});
}
sources.push({
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config)
});
}
return sources;
};
return sources;
};
/**

@@ -352,20 +359,19 @@ * @param {?} size

*/
function (size, config) {
/** @type {?} */
var arrayOfSizes = size.split(',');
/** @type {?} */
var sizes = [];
arrayOfSizes.forEach((/**
* @param {?} string
* @return {?}
*/
function (string) {
function (size, config) {
/** @type {?} */
var groups = string.match(/(([a-z_][a-z_]*)|(\([\S\s]*\)))\s*([0-9xp]*)/);
var arrayOfSizes = size.split(',');
/** @type {?} */
var media = groups[3] ? groups[3] : config.presets[groups[2]];
sizes.push({ media: media, size: groups[4] });
}));
return sizes;
};
var sizes = [];
arrayOfSizes.forEach(( /**
* @param {?} string
* @return {?}
*/function (string) {
/** @type {?} */
var groups = string.match(/(([a-z_][a-z_]*)|(\([\S\s]*\)))\s*([0-9xp]*)/);
/** @type {?} */
var media = groups[3] ? groups[3] : config.presets[groups[2]];
sizes.push({ media: media, size: groups[4] });
}));
return sizes;
};
/**

@@ -387,6 +393,6 @@ * @param {?} operation

*/
function (operation, size, filters, imgSrc, config) {
var _a = __read(size.toString().split('x'), 2), imgWidth = _a[0], imgHeight = _a[1];
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);
};
function (operation, size, filters, imgSrc, config) {
var _a = __read(size.toString().split('x'), 2), imgWidth = _a[0], imgHeight = _a[1];
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);
};
/**

@@ -412,14 +418,14 @@ * @param {?} operation

*/
function (operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {
/** @type {?} */
var imgSize = '' + Math.trunc(imgWidth * factor);
if (imgHeight) {
imgSize += 'x' + Math.trunc(imgHeight * factor);
}
return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)
.replace('http://scaleflex.ultrafast.io/', '')
.replace('https://scaleflex.ultrafast.io/', '')
.replace('//scaleflex.ultrafast.io/', '')
.replace('///', '/');
};
function (operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {
/** @type {?} */
var imgSize = '' + Math.trunc(imgWidth * factor);
if (imgHeight) {
imgSize += 'x' + Math.trunc(imgHeight * factor);
}
return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)
.replace('http://scaleflex.ultrafast.io/', '')
.replace('https://scaleflex.ultrafast.io/', '')
.replace('//scaleflex.ultrafast.io/', '')
.replace('///', '/');
};
/**

@@ -435,23 +441,23 @@ * @param {?} size

*/
function (size, config) {
var _a, _b;
/** @type {?} */
var width;
/** @type {?} */
var height;
if (typeof size === 'object') {
function (size, config) {
var _a, _b;
/** @type {?} */
var breakPointSource = this.getBreakPoint(size);
var width;
/** @type {?} */
var breakPointSize = breakPointSource ? breakPointSource.size : size[0].size;
_a = __read(breakPointSize.toString().split('x'), 2), width = _a[0], height = _a[1];
}
else {
_b = __read(size.toString().split('x'), 2), width = _b[0], height = _b[1];
}
if (width && height) {
return width / height;
}
return null;
};
var height;
if (typeof size === 'object') {
/** @type {?} */
var breakPointSource = this.getBreakPoint(size);
/** @type {?} */
var breakPointSize = breakPointSource ? breakPointSource.size : size[0].size;
_a = __read(breakPointSize.toString().split('x'), 2), width = _a[0], height = _a[1];
}
else {
_b = __read(size.toString().split('x'), 2), width = _b[0], height = _b[1];
}
if (width && height) {
return width / height;
}
return null;
};
/**

@@ -465,11 +471,10 @@ * @param {?} size

*/
function (size) {
return __spread(size).reverse().find((/**
* @param {?} item
* @return {?}
*/
function (item) { return matchMedia(item.media).matches; }));
};
function (size) {
return __spread(size).reverse().find(( /**
* @param {?} item
* @return {?}
*/function (item) { return matchMedia(item.media).matches; }));
};
CIService.decorators = [
{ type: core.Injectable, args: [{
{ type: i0.Injectable, args: [{
providedIn: 'root'

@@ -479,6 +484,8 @@ },] }

/** @nocollapse */
CIService.ctorParameters = function () { return [
{ type: CIConfig }
]; };
/** @nocollapse */ CIService.ngInjectableDef = core.ɵɵdefineInjectable({ factory: function CIService_Factory() { return new CIService(core.ɵɵinject(CIConfig)); }, token: CIService, providedIn: "root" });
CIService.ctorParameters = function () {
return [
{ type: CIConfig }
];
};
/** @nocollapse */ CIService.ngInjectableDef = i0.defineInjectable({ factory: function CIService_Factory() { return new CIService(i0.inject(CIConfig)); }, token: CIService, providedIn: "root" });
return CIService;

@@ -489,3 +496,3 @@ }());

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -499,3 +506,3 @@ var ImgComponent = /** @class */ (function () {

this.offset = 100;
this.imageLoaded = new core.EventEmitter();
this.imageLoaded = new i0.EventEmitter();
this.cloudimageUrl = '';

@@ -516,5 +523,5 @@ this.sources = [];

*/
function () {
this.resizeSubscription$.unsubscribe();
};
function () {
this.resizeSubscription$.unsubscribe();
};
/**

@@ -526,15 +533,14 @@ * @return {?}

*/
function () {
var _this = this;
this.resizeObservable$ = rxjs.fromEvent(window, 'resize').pipe(operators.debounceTime(500));
this.resizeSubscription$ = this.resizeObservable$.subscribe((/**
* @return {?}
*/
function () {
if (_this.isAdaptive || _this.windowInnerWidth < window.innerWidth) {
_this.processImage();
}
_this.windowInnerWidth = window.innerWidth;
}));
};
var _this = this;
this.resizeObservable$ = rxjs.fromEvent(window, 'resize').pipe(operators.debounceTime(500));
this.resizeSubscription$ = this.resizeObservable$.subscribe(( /**
* @return {?}
*/function () {
if (_this.isAdaptive || _this.windowInnerWidth < window.innerWidth) {
_this.processImage();
}
_this.windowInnerWidth = window.innerWidth;
}));
};
/**

@@ -546,5 +552,5 @@ * @return {?}

*/
function () {
this.processImage();
};
function () {
this.processImage();
};
/**

@@ -556,60 +562,59 @@ * @return {?}

*/
function () {
/** @type {?} */
var imgNode = (this.imgElem || this.pictureElem).nativeElement;
var _a = this.ciService.config, config = _a === void 0 ? {} : _a;
var previewQualityFactor = config.previewQualityFactor;
/** @type {?} */
var operation = this.operation || this.o || config.operation;
/** @type {?} */
var parentContainerWidth = this.ciService.getParentWidth(imgNode, config);
/** @type {?} */
var size = this.size || this.s || config.size || parentContainerWidth;
/** @type {?} */
var filters = this.filters || this.f || config.filters;
/** @type {?} */
var isAdaptive = this.ciService.checkOnMedia(size);
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;
/** @type {?} */
var isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);
/** @type {?} */
var imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);
/** @type {?} */
var resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);
this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;
this.cloudimageUrl = isAdaptive ?
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);
this.sources = isAdaptive ?
this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];
/** @type {?} */
var previewCloudimageUrl;
/** @type {?} */
var previewSources;
if (this.isPreview) {
function () {
/** @type {?} */
var previewConfig = __assign({}, config, { queryString: '' });
previewCloudimageUrl = isAdaptive ?
this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :
this.ciService.generateUrl(operation, resultSize.split('x').map((/**
* @param {?} item
* @return {?}
*/
function (item) { return Math.floor(item / previewQualityFactor); })).join('x'), filters, imgSrc, previewConfig);
previewSources = isAdaptive ?
this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];
}
this.previewCloudimageUrl = previewCloudimageUrl;
this.previewSources = previewSources;
this.isAdaptive = isAdaptive;
this.actualSize = size;
this.parentContainerWidth = parentContainerWidth;
/** @type {?} */
var ratioBySize = this.ciService.getRatioBySize(size, config);
this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));
this.isRatio = !!(ratioBySize || this.ratio);
this.ratioBySize = ratioBySize;
this.isProcessed = true;
this.cd.detectChanges();
};
var imgNode = (this.imgElem || this.pictureElem).nativeElement;
var _a = this.ciService.config, config = _a === void 0 ? {} : _a;
var previewQualityFactor = config.previewQualityFactor;
/** @type {?} */
var operation = this.operation || this.o || config.operation;
/** @type {?} */
var parentContainerWidth = this.ciService.getParentWidth(imgNode, config);
/** @type {?} */
var size = this.size || this.s || config.size || parentContainerWidth;
/** @type {?} */
var filters = this.filters || this.f || config.filters;
/** @type {?} */
var isAdaptive = this.ciService.checkOnMedia(size);
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;
/** @type {?} */
var isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);
/** @type {?} */
var imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);
/** @type {?} */
var resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);
this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;
this.cloudimageUrl = isAdaptive ?
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);
this.sources = isAdaptive ?
this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];
/** @type {?} */
var previewCloudimageUrl;
/** @type {?} */
var previewSources;
if (this.isPreview) {
/** @type {?} */
var previewConfig = __assign({}, config, { queryString: '' });
previewCloudimageUrl = isAdaptive ?
this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :
this.ciService.generateUrl(operation, resultSize.split('x').map(( /**
* @param {?} item
* @return {?}
*/function (item) { return Math.floor(item / previewQualityFactor); })).join('x'), filters, imgSrc, previewConfig);
previewSources = isAdaptive ?
this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];
}
this.previewCloudimageUrl = previewCloudimageUrl;
this.previewSources = previewSources;
this.isAdaptive = isAdaptive;
this.actualSize = size;
this.parentContainerWidth = parentContainerWidth;
/** @type {?} */
var ratioBySize = this.ciService.getRatioBySize(size, config);
this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));
this.isRatio = !!(ratioBySize || this.ratio);
this.ratioBySize = ratioBySize;
this.isProcessed = true;
this.cd.detectChanges();
};
/**

@@ -623,15 +628,15 @@ * @param {?} $event

*/
function ($event) {
if (!this.isPreview) {
this.isPreviewLoaded = true;
this.isLoaded = true;
}
else if (this.isPreviewLoaded) {
this.isLoaded = true;
}
else {
this.isPreviewLoaded = true;
}
this.imageLoaded.emit($event);
};
function ($event) {
if (!this.isPreview) {
this.isPreviewLoaded = true;
this.isLoaded = true;
}
else if (this.isPreviewLoaded) {
this.isLoaded = true;
}
else {
this.isPreviewLoaded = true;
}
this.imageLoaded.emit($event);
};
/**

@@ -643,7 +648,7 @@ * @return {?}

*/
function () {
/** @type {?} */
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources)));
return resultSources.slice(1).reverse();
};
function () {
/** @type {?} */
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources)));
return resultSources.slice(1).reverse();
};
/**

@@ -655,8 +660,8 @@ * @return {?}

*/
function () {
/** @type {?} */
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources)));
this.firstSource = resultSources[0];
return resultSources[0];
};
function () {
/** @type {?} */
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources)));
this.firstSource = resultSources[0];
return resultSources[0];
};
/**

@@ -668,5 +673,5 @@ * @return {?}

*/
function () {
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');
};
function () {
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');
};
/**

@@ -678,7 +683,7 @@ * @return {?}

*/
function () {
// todo check if we need 100% height
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');
};
function () {
// todo check if we need 100% height
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');
};
/**

@@ -690,14 +695,14 @@ * @return {?}

*/
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (config.imgLoadingAnimation) {
result = 'scale3d(1.1, 1.1, 1)';
}
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'translateZ(0) scale3d(1, 1, 1)';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (config.imgLoadingAnimation) {
result = 'scale3d(1.1, 1.1, 1)';
}
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'translateZ(0) scale3d(1, 1, 1)';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
/**

@@ -709,11 +714,11 @@ * @return {?}

*/
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'all 0.3s ease-in-out';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'all 0.3s ease-in-out';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
/**

@@ -725,14 +730,14 @@ * @return {?}

*/
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (config.imgLoadingAnimation) {
result = "blur(" + Math.floor(parseInt(this.parentContainerWidth, 10) / 100) + "px)";
}
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'blur(0px)';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'none';
if (config.imgLoadingAnimation) {
result = "blur(" + Math.floor(parseInt(this.parentContainerWidth, 10) / 100) + "px)";
}
if (this.isLoaded && config.imgLoadingAnimation) {
result = 'blur(0px)';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
/**

@@ -744,10 +749,10 @@ * @return {?}

*/
function () {
/** @type {?} */
var result = '';
if (this.isRatio) {
result = (100 / (this.ratioBySize || this.ratio)) + '%';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
function () {
/** @type {?} */
var result = '';
if (this.isRatio) {
result = (100 / (this.ratioBySize || this.ratio)) + '%';
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
/**

@@ -759,13 +764,13 @@ * @return {?}

*/
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'transparent';
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {
result = config.placeholderBackground;
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
function () {
var config = this.ciService.config;
/** @type {?} */
var result = 'transparent';
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {
result = config.placeholderBackground;
}
return this._sanitizer.bypassSecurityTrustStyle(result);
};
ImgComponent.decorators = [
{ type: core.Component, args: [{
{ type: i0.Component, args: [{
selector: 'ci-img',

@@ -776,23 +781,25 @@ template: "\n <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n <ng-container [ngSwitch]=\"lazyLoading\">\n <ng-container *ngSwitchCase=\"true\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of getRestSources()\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [offset]=\"offset\"\n [alt]=\"\">\n </picture>\n </ng-container>\n <div *ngSwitchCase=\"false\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of restSources\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"firstSource\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n "

/** @nocollapse */
ImgComponent.ctorParameters = function () { return [
{ type: CIService },
{ type: platformBrowser.DomSanitizer },
{ type: core.ChangeDetectorRef }
]; };
ImgComponent.ctorParameters = function () {
return [
{ type: CIService },
{ type: platformBrowser.DomSanitizer },
{ type: i0.ChangeDetectorRef }
];
};
ImgComponent.propDecorators = {
imgElem: [{ type: core.ViewChild, args: ['imgElem', { static: false },] }],
pictureElem: [{ type: core.ViewChild, args: ['pictureElem', { static: false },] }],
src: [{ type: core.Input }],
class: [{ type: core.Input }],
alt: [{ type: core.Input }],
operation: [{ type: core.Input }],
o: [{ type: core.Input }],
size: [{ type: core.Input }],
s: [{ type: core.Input }],
filters: [{ type: core.Input }],
f: [{ type: core.Input }],
ratio: [{ type: core.Input }],
offset: [{ type: core.Input }],
ngSwitch: [{ type: core.Input }],
imageLoaded: [{ type: core.Output }]
imgElem: [{ type: i0.ViewChild, args: ['imgElem',] }],
pictureElem: [{ type: i0.ViewChild, args: ['pictureElem',] }],
src: [{ type: i0.Input }],
class: [{ type: i0.Input }],
alt: [{ type: i0.Input }],
operation: [{ type: i0.Input }],
o: [{ type: i0.Input }],
size: [{ type: i0.Input }],
s: [{ type: i0.Input }],
filters: [{ type: i0.Input }],
f: [{ type: i0.Input }],
ratio: [{ type: i0.Input }],
offset: [{ type: i0.Input }],
ngSwitch: [{ type: i0.Input }],
imageLoaded: [{ type: i0.Output }]
};

@@ -804,3 +811,3 @@ return ImgComponent;

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -811,3 +818,3 @@ var CIModule = /** @class */ (function () {

CIModule.decorators = [
{ type: core.NgModule, args: [{
{ type: i0.NgModule, args: [{
declarations: [ImgComponent],

@@ -822,5 +829,15 @@ imports: [common.CommonModule, ngLazyloadImage.LazyLoadImageModule],

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
exports.CIService = CIService;
exports.CIConfig = CIConfig;
exports.CIModule = CIModule;
exports.CIService = CIService;
exports.ImgComponent = ImgComponent;

@@ -830,3 +847,4 @@

}));
//# sourceMappingURL=ng-cloudimage-responsive.umd.js.map
})));
//# sourceMappingURL=ng-cloudimage-responsive.umd.js.map

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/platform-browser"),require("rxjs"),require("rxjs/operators"),require("ng-lazyload-image")):"function"==typeof define&&define.amd?define("ng-cloudimage-responsive",["exports","@angular/core","@angular/common","@angular/platform-browser","rxjs","rxjs/operators","ng-lazyload-image"],t):t((e=e||self)["ng-cloudimage-responsive"]={},e.ng.core,e.ng.common,e.ng.platformBrowser,e.rxjs,e.rxjs.operators,e.ngLazyloadImage)}(this,function(e,t,i,r,n,o,s){"use strict";var a=function(){return(a=Object.assign||function(e){for(var t,i=1,r=arguments.length;i<r;i++)for(var n in t=arguments[i])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)};function c(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var r,n,o=i.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=o.next()).done;)s.push(r.value)}catch(a){n={error:a}}finally{try{r&&!r.done&&(i=o["return"])&&i.call(o)}finally{if(n)throw n.error}}return s}function l(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(c(arguments[t]));return e}var d=function(){},u=function(){function e(e){this.config={};var t=e.token,i=void 0===t?"":t,r=e.container,n=void 0===r?"cloudimg.io":r,o=e.ultraFast,s=void 0!==o&&o,a=e.lazyLoading,c=void 0===a||a,l=e.imgLoadingAnimation,d=void 0===l||l,u=e.lazyLoadOffset,p=void 0===u?100:u,g=e.width,h=void 0===g?"400":g,f=e.height,y=void 0===f?"300":f,m=e.operation,v=void 0===m?"width":m,S=e.filters,w=void 0===S?"foil1":S,I=e.placeholderBackground,z=void 0===I?"#f4f4f4":I,L=e.baseUrl,P=void 0===L?"/":L,x=e.presets,b=e.queryString,C=void 0===b?"":b;this.config={token:i,container:n,ultraFast:s,lazyLoading:c,imgLoadingAnimation:d,lazyLoadOffset:p,width:h,height:y,operation:v,filters:w,placeholderBackground:z,baseUrl:P,presets:x||{xs:"(max-width: 575px)",sm:"(min-width: 576px)",md:"(min-width: 768px)",lg:"(min-width: 992px)",xl:"(min-width: 1200px)"},queryString:C,innerWidth:window.innerWidth,previewQualityFactor:10}}return e.prototype.getParentWidth=function(e,t){if(!(e&&e.parentElement&&e.parentElement.getBoundingClientRect||e&&e.width))return t.width;var i=this.getParentContainerWithWidth(e),r=parseInt(""+i,10),n=Number(window.getComputedStyle(e).width);return n&&n<r&&n>15||!r?this.getSizeLimit(n):r?this.getSizeLimit(r):e.width||t.width},e.prototype.getParentContainerWithWidth=function(e){var t=null,i=0;do{i=(t=t&&t.parentNode||e.parentNode).getBoundingClientRect().width}while(t&&!i);var r=i&&t&&parseInt(window.getComputedStyle(t).paddingLeft,10),n=parseInt(window.getComputedStyle(t).paddingRight,10);return i+(i?-r-n:0)},e.prototype.getSizeLimit=function(e){return e<=25?"25":e<=50?"50":(100*Math.ceil(e/100)).toString()},e.prototype.checkOnMedia=function(e){try{return e.split(",").length>1}catch(t){return!1}},e.prototype.checkIfRelativeUrlPath=function(e){return 0===e.indexOf("//")&&(e=window.location.protocol+e),0!==e.indexOf("http://")&&0!==e.indexOf("https://")&&0!==e.indexOf("//")},e.prototype.getImgSrc=function(e,t,i){return void 0===t&&(t=!1),void 0===i&&(i=""),t?i+e:e},e.prototype.getSizeAccordingToPixelRatio=function(e){var t=e.toString().split("x"),i=[];return[].forEach.call(t,function(e){i.push(e*Math.round(window.devicePixelRatio||1))}),i.join("x")},e.prototype.generateUrl=function(e,t,i,r,n){return(n.ultraFast?"https://scaleflex.ultrafast.io/":"https://")+n.token+"."+n.container+"/"+e+"/"+t+"/"+i+"/"+r+n.queryString},e.prototype.generateSources=function(e,t,i,r,n,o,s){var a=this,c=o.previewQualityFactor,l=[];return n?t.forEach(function(t){var n=t.size,d=t.media;s&&(n=n.split("x").map(function(e){return Math.floor(e/c)}).join("x")),l.push({mediaQuery:d,srcSet:a.generateSrcset(e,n,i,r,o)})}):(s&&(t=t.split("x").map(function(e){return Math.floor(e/c)}).join("x")),l.push({srcSet:this.generateSrcset(e,t,i,r,o)})),l},e.prototype.getAdaptiveSize=function(e,t){var i=e.split(","),r=[];return i.forEach(function(e){var i=e.match(/(([a-z_][a-z_]*)|(\([\S\s]*\)))\s*([0-9xp]*)/),n=i[3]?i[3]:t.presets[i[2]];r.push({media:n,size:i[4]})}),r},e.prototype.generateSrcset=function(e,t,i,r,n){var o=c(t.toString().split("x"),2),s=o[0],a=o[1];return this.generateImgSrc(e,i,r,s,a,1,n)},e.prototype.generateImgSrc=function(e,t,i,r,n,o,s){var a=""+Math.trunc(r*o);return n&&(a+="x"+Math.trunc(n*o)),this.generateUrl(e,this.getSizeAccordingToPixelRatio(a),t,i,s).replace("http://scaleflex.ultrafast.io/","").replace("https://scaleflex.ultrafast.io/","").replace("//scaleflex.ultrafast.io/","").replace("///","/")},e.prototype.getRatioBySize=function(e,t){var i,r,n,o;if("object"==typeof e){var s=this.getBreakPoint(e);n=(i=c((s?s.size:e[0].size).toString().split("x"),2))[0],o=i[1]}else n=(r=c(e.toString().split("x"),2))[0],o=r[1];return n&&o?n/o:null},e.prototype.getBreakPoint=function(e){return l(e).reverse().find(function(e){return matchMedia(e.media).matches})},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:d}]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e(t.ɵɵinject(d))},token:e,providedIn:"root"}),e}(),p=function(){function e(e,i,r){this.ciService=e,this._sanitizer=i,this.cd=r,this["class"]="",this.offset=100,this.imageLoaded=new t.EventEmitter,this.cloudimageUrl="",this.sources=[],this.firstSource=null,this.restSources=[],this.isLoaded=!1,this.isProcessed=!1,this.windowInnerWidth=window.innerWidth,this.lazyLoading=e.config.lazyLoading}return e.prototype.ngOnDestroy=function(){this.resizeSubscription$.unsubscribe()},e.prototype.ngOnInit=function(){var e=this;this.resizeObservable$=n.fromEvent(window,"resize").pipe(o.debounceTime(500)),this.resizeSubscription$=this.resizeObservable$.subscribe(function(){(e.isAdaptive||e.windowInnerWidth<window.innerWidth)&&e.processImage(),e.windowInnerWidth=window.innerWidth})},e.prototype.ngAfterViewInit=function(){this.processImage()},e.prototype.processImage=function(){var e=(this.imgElem||this.pictureElem).nativeElement,t=this.ciService.config,i=void 0===t?{}:t,r=i.previewQualityFactor,n=this.operation||this.o||i.operation,o=this.ciService.getParentWidth(e,i),s=this.size||this.s||i.size||o,c=this.filters||this.f||i.filters,l=this.ciService.checkOnMedia(s);s=l?this.ciService.getAdaptiveSize(s,i):s;var d,u,p=this.ciService.checkIfRelativeUrlPath(this.src),g=this.ciService.getImgSrc(this.src,p,i.baseUrl),h=l?s:this.ciService.getSizeAccordingToPixelRatio(s);if(this.isPreview=!i.isChrome&&o>400&&i.lazyLoading,this.cloudimageUrl=l?this.ciService.generateUrl("width",this.ciService.getSizeAccordingToPixelRatio(o),c,g,i):this.ciService.generateUrl(n,h,c,g,i),this.sources=l?this.ciService.generateSources(n,h,c,g,l,i,!1):[],this.isPreview){var f=a({},i,{queryString:""});d=l?this.ciService.generateUrl("width",Math.floor(o/r),c,g,f):this.ciService.generateUrl(n,h.split("x").map(function(e){return Math.floor(e/r)}).join("x"),c,g,f),u=l?this.ciService.generateSources(n,h,c,g,l,f,!0):[]}this.previewCloudimageUrl=d,this.previewSources=u,this.isAdaptive=l,this.actualSize=s,this.parentContainerWidth=o;var y=this.ciService.getRatioBySize(s,i);this.imageHeight=Math.floor(o/(y||this.ratio||1.5)),this.isRatio=!(!y&&!this.ratio),this.ratioBySize=y,this.isProcessed=!0,this.cd.detectChanges()},e.prototype.onImageLoad=function(e){this.isPreview?this.isPreviewLoaded?this.isLoaded=!0:this.isPreviewLoaded=!0:(this.isPreviewLoaded=!0,this.isLoaded=!0),this.imageLoaded.emit(e)},e.prototype.getRestSources=function(){return l(this.isPreview?this.isPreviewLoaded?this.sources:this.previewSources:this.sources).slice(1).reverse()},e.prototype.getFirstSource=function(){var e=l(this.isPreview?this.isPreviewLoaded?this.sources:this.previewSources:this.sources);return this.firstSource=e[0],e[0]},e.prototype.getPositionStyle=function(){return this._sanitizer.bypassSecurityTrustStyle(this.isRatio?"absolute":"relative")},e.prototype.getImgHeight=function(){return this._sanitizer.bypassSecurityTrustStyle((this.isRatio,"auto"))},e.prototype.getTransformStyle=function(){var e=this.ciService.config,t="none";return e.imgLoadingAnimation&&(t="scale3d(1.1, 1.1, 1)"),this.isLoaded&&e.imgLoadingAnimation&&(t="translateZ(0) scale3d(1, 1, 1)"),this._sanitizer.bypassSecurityTrustStyle(t)},e.prototype.getTransitionStyle=function(){var e=this.ciService.config,t="none";return this.isLoaded&&e.imgLoadingAnimation&&(t="all 0.3s ease-in-out"),this._sanitizer.bypassSecurityTrustStyle(t)},e.prototype.getFilterStyle=function(){var e=this.ciService.config,t="none";return e.imgLoadingAnimation&&(t="blur("+Math.floor(parseInt(this.parentContainerWidth,10)/100)+"px)"),this.isLoaded&&e.imgLoadingAnimation&&(t="blur(0px)"),this._sanitizer.bypassSecurityTrustStyle(t)},e.prototype.getPicturePaddingBottom=function(){var e="";return this.isRatio&&(e=100/(this.ratioBySize||this.ratio)+"%"),this._sanitizer.bypassSecurityTrustStyle(e)},e.prototype.getPictureBackground=function(){var e=this.ciService.config,t="transparent";return!this.isRatio||this.isPreviewLoaded||this.isLoaded||(t=e.placeholderBackground),this._sanitizer.bypassSecurityTrustStyle(t)},e.decorators=[{type:t.Component,args:[{selector:"ci-img",template:'\n <picture #pictureElem *ngIf="!isProcessed"></picture>\n\n <ng-container [ngSwitch]="lazyLoading">\n <ng-container *ngSwitchCase="true">\n <picture\n [class]="class + \' cloudimage-image-picture cloudimage-image-\' + (isLoaded ? \'loaded\' : \'loading\')"\n style="display:block;width:100%;overflow:hidden;position:relative;"\n [style.paddingBottom]="getPicturePaddingBottom()"\n [style.background]="getPictureBackground()"\n #imgElem\n *ngIf="isProcessed">\n <source\n *ngFor="let source of getRestSources()"\n [media]="source.mediaQuery || \'\'"\n [attr.lazyLoad]="source.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <source\n *ngIf="getFirstSource()"\n [attr.lazyLoad]="firstSource.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <img\n style="display:block;width:100%;opacity:1;top:0;left:0;"\n [style.position]="getPositionStyle()"\n [style.height]="getImgHeight()"\n [style.transform]="getTransformStyle()"\n [style.transition]="getTransitionStyle()"\n [style.filter]="getFilterStyle()"\n (load)="onImageLoad($event)"\n [lazyLoad]="!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)"\n [offset]="offset"\n [alt]="">\n </picture>\n </ng-container>\n <div *ngSwitchCase="false">\n <picture\n [class]="class + \' cloudimage-image-picture cloudimage-image-\' + (isLoaded ? \'loaded\' : \'loading\')"\n style="display:block;width:100%;overflow:hidden;position:relative;"\n [style.paddingBottom]="getPicturePaddingBottom()"\n [style.background]="getPictureBackground()"\n #imgElem\n *ngIf="isProcessed">\n <source\n *ngFor="let source of restSources"\n [media]="source.mediaQuery || \'\'"\n [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <source\n *ngIf="firstSource"\n [srcset]="firstSource.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <img\n style="display:block;width:100%;opacity:1;top:0;left:0;"\n [style.position]="getPositionStyle()"\n [style.height]="getImgHeight()"\n [style.transform]="getTransformStyle()"\n [style.transition]="getTransitionStyle()"\n [style.filter]="getFilterStyle()"\n (load)="onImageLoad($event)"\n [src]="!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)"\n [alt]="">\n </picture>\n </div>\n </ng-container>\n '}]}],e.ctorParameters=function(){return[{type:u},{type:r.DomSanitizer},{type:t.ChangeDetectorRef}]},e.propDecorators={imgElem:[{type:t.ViewChild,args:["imgElem",{"static":!1}]}],pictureElem:[{type:t.ViewChild,args:["pictureElem",{"static":!1}]}],src:[{type:t.Input}],"class":[{type:t.Input}],alt:[{type:t.Input}],operation:[{type:t.Input}],o:[{type:t.Input}],size:[{type:t.Input}],s:[{type:t.Input}],filters:[{type:t.Input}],f:[{type:t.Input}],ratio:[{type:t.Input}],offset:[{type:t.Input}],ngSwitch:[{type:t.Input}],imageLoaded:[{type:t.Output}]},e}(),g=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[p],imports:[i.CommonModule,s.LazyLoadImageModule],exports:[p],providers:[]}]}],e}();e.CIConfig=d,e.CIModule=g,e.CIService=u,e.ImgComponent=p,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/common"),require("@angular/core"),require("@angular/platform-browser"),require("rxjs"),require("rxjs/operators"),require("ng-lazyload-image")):"function"==typeof define&&define.amd?define("ng-cloudimage-responsive",["exports","@angular/common","@angular/core","@angular/platform-browser","rxjs","rxjs/operators","ng-lazyload-image"],t):t(e["ng-cloudimage-responsive"]={},e.ng.common,e.ng.core,e.ng.platformBrowser,e.rxjs,e.rxjs.operators,e.ngLazyloadImage)}(this,function(e,t,r,i,n,o,s){"use strict";var y=function(){return(y=Object.assign||function(e){for(var t,i=1,r=arguments.length;i<r;i++)for(var n in t=arguments[i])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)};function c(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var r,n,o=i.call(e),s=[];try{for(;(void 0===t||0<t--)&&!(r=o.next()).done;)s.push(r.value)}catch(a){n={error:a}}finally{try{r&&!r.done&&(i=o["return"])&&i.call(o)}finally{if(n)throw n.error}}return s}function a(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(c(arguments[t]));return e}function l(){}var d=(u.prototype.getParentWidth=function(e,t){if(!(e&&e.parentElement&&e.parentElement.getBoundingClientRect||e&&e.width))return t.width;var i=this.getParentContainerWithWidth(e),r=parseInt(""+i,10),n=Number(window.getComputedStyle(e).width);return n&&n<r&&15<n||!r?this.getSizeLimit(n):r?this.getSizeLimit(r):e.width||t.width},u.prototype.getParentContainerWithWidth=function(e){for(var t=null,i=0;i=(t=t&&t.parentNode||e.parentNode).getBoundingClientRect().width,t&&!i;);var r=i&&t&&parseInt(window.getComputedStyle(t).paddingLeft,10),n=parseInt(window.getComputedStyle(t).paddingRight,10);return i+(i?-r-n:0)},u.prototype.getSizeLimit=function(e){return e<=25?"25":e<=50?"50":(100*Math.ceil(e/100)).toString()},u.prototype.checkOnMedia=function(e){try{return 1<e.split(",").length}catch(t){return!1}},u.prototype.checkIfRelativeUrlPath=function(e){return 0===e.indexOf("//")&&(e=window.location.protocol+e),0!==e.indexOf("http://")&&0!==e.indexOf("https://")&&0!==e.indexOf("//")},u.prototype.getImgSrc=function(e,t,i){return void 0===t&&(t=!1),void 0===i&&(i=""),t?i+e:e},u.prototype.getSizeAccordingToPixelRatio=function(e){var t=e.toString().split("x"),i=[];return[].forEach.call(t,function(e){i.push(e*Math.round(window.devicePixelRatio||1))}),i.join("x")},u.prototype.generateUrl=function(e,t,i,r,n){return(n.ultraFast?"https://scaleflex.ultrafast.io/":"https://")+n.token+"."+n.container+"/"+e+"/"+t+"/"+i+"/"+r+n.queryString},u.prototype.generateSources=function(r,e,n,o,t,s,a){var c=this,l=s.previewQualityFactor,d=[];return t?e.forEach(function(e){var t=e.size,i=e.media;a&&(t=t.split("x").map(function(e){return Math.floor(e/l)}).join("x")),d.push({mediaQuery:i,srcSet:c.generateSrcset(r,t,n,o,s)})}):(a&&(e=e.split("x").map(function(e){return Math.floor(e/l)}).join("x")),d.push({srcSet:this.generateSrcset(r,e,n,o,s)})),d},u.prototype.getAdaptiveSize=function(e,r){var t=e.split(","),n=[];return t.forEach(function(e){var t=e.match(/(([a-z_][a-z_]*)|(\([\S\s]*\)))\s*([0-9xp]*)/),i=t[3]?t[3]:r.presets[t[2]];n.push({media:i,size:t[4]})}),n},u.prototype.generateSrcset=function(e,t,i,r,n){var o=c(t.toString().split("x"),2),s=o[0],a=o[1];return this.generateImgSrc(e,i,r,s,a,1,n)},u.prototype.generateImgSrc=function(e,t,i,r,n,o,s){var a=""+Math.trunc(r*o);return n&&(a+="x"+Math.trunc(n*o)),this.generateUrl(e,this.getSizeAccordingToPixelRatio(a),t,i,s).replace("http://scaleflex.ultrafast.io/","").replace("https://scaleflex.ultrafast.io/","").replace("//scaleflex.ultrafast.io/","").replace("///","/")},u.prototype.getRatioBySize=function(e,t){var i,r,n,o;if("object"==typeof e){var s=this.getBreakPoint(e);n=(i=c((s?s.size:e[0].size).toString().split("x"),2))[0],o=i[1]}else n=(r=c(e.toString().split("x"),2))[0],o=r[1];return n&&o?n/o:null},u.prototype.getBreakPoint=function(e){return a(e).reverse().find(function(e){return matchMedia(e.media).matches})},u.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],u.ctorParameters=function(){return[{type:l}]},u.ngInjectableDef=r.defineInjectable({factory:function(){return new u(r.inject(l))},token:u,providedIn:"root"}),u);function u(e){this.config={};var t=e.token,i=void 0===t?"":t,r=e.container,n=void 0===r?"cloudimg.io":r,o=e.ultraFast,s=void 0!==o&&o,a=e.lazyLoading,c=void 0===a||a,l=e.imgLoadingAnimation,d=void 0===l||l,u=e.lazyLoadOffset,p=void 0===u?100:u,g=e.width,h=void 0===g?"400":g,f=e.height,y=void 0===f?"300":f,m=e.operation,v=void 0===m?"width":m,S=e.filters,w=void 0===S?"foil1":S,I=e.placeholderBackground,z=void 0===I?"#f4f4f4":I,L=e.baseUrl,P=void 0===L?"/":L,x=e.presets,b=e.queryString,C=void 0===b?"":b;this.config={token:i,container:n,ultraFast:s,lazyLoading:c,imgLoadingAnimation:d,lazyLoadOffset:p,width:h,height:y,operation:v,filters:w,placeholderBackground:z,baseUrl:P,presets:x||{xs:"(max-width: 575px)",sm:"(min-width: 576px)",md:"(min-width: 768px)",lg:"(min-width: 992px)",xl:"(min-width: 1200px)"},queryString:C,innerWidth:window.innerWidth,previewQualityFactor:10}}var p=(g.prototype.ngOnDestroy=function(){this.resizeSubscription$.unsubscribe()},g.prototype.ngOnInit=function(){var e=this;this.resizeObservable$=n.fromEvent(window,"resize").pipe(o.debounceTime(500)),this.resizeSubscription$=this.resizeObservable$.subscribe(function(){(e.isAdaptive||e.windowInnerWidth<window.innerWidth)&&e.processImage(),e.windowInnerWidth=window.innerWidth})},g.prototype.ngAfterViewInit=function(){this.processImage()},g.prototype.processImage=function(){var e=(this.imgElem||this.pictureElem).nativeElement,t=this.ciService.config,i=void 0===t?{}:t,r=i.previewQualityFactor,n=this.operation||this.o||i.operation,o=this.ciService.getParentWidth(e,i),s=this.size||this.s||i.size||o,a=this.filters||this.f||i.filters,c=this.ciService.checkOnMedia(s);s=c?this.ciService.getAdaptiveSize(s,i):s;var l,d,u=this.ciService.checkIfRelativeUrlPath(this.src),p=this.ciService.getImgSrc(this.src,u,i.baseUrl),g=c?s:this.ciService.getSizeAccordingToPixelRatio(s);if(this.isPreview=!i.isChrome&&400<o&&i.lazyLoading,this.cloudimageUrl=c?this.ciService.generateUrl("width",this.ciService.getSizeAccordingToPixelRatio(o),a,p,i):this.ciService.generateUrl(n,g,a,p,i),this.sources=c?this.ciService.generateSources(n,g,a,p,c,i,!1):[],this.isPreview){var h=y({},i,{queryString:""});l=c?this.ciService.generateUrl("width",Math.floor(o/r),a,p,h):this.ciService.generateUrl(n,g.split("x").map(function(e){return Math.floor(e/r)}).join("x"),a,p,h),d=c?this.ciService.generateSources(n,g,a,p,c,h,!0):[]}this.previewCloudimageUrl=l,this.previewSources=d,this.isAdaptive=c,this.actualSize=s,this.parentContainerWidth=o;var f=this.ciService.getRatioBySize(s,i);this.imageHeight=Math.floor(o/(f||this.ratio||1.5)),this.isRatio=!(!f&&!this.ratio),this.ratioBySize=f,this.isProcessed=!0,this.cd.detectChanges()},g.prototype.onImageLoad=function(e){this.isPreview?this.isPreviewLoaded?this.isLoaded=!0:this.isPreviewLoaded=!0:(this.isPreviewLoaded=!0,this.isLoaded=!0),this.imageLoaded.emit(e)},g.prototype.getRestSources=function(){return a(this.isPreview?this.isPreviewLoaded?this.sources:this.previewSources:this.sources).slice(1).reverse()},g.prototype.getFirstSource=function(){var e=a(this.isPreview?this.isPreviewLoaded?this.sources:this.previewSources:this.sources);return this.firstSource=e[0],e[0]},g.prototype.getPositionStyle=function(){return this._sanitizer.bypassSecurityTrustStyle(this.isRatio?"absolute":"relative")},g.prototype.getImgHeight=function(){return this._sanitizer.bypassSecurityTrustStyle((this.isRatio,"auto"))},g.prototype.getTransformStyle=function(){var e=this.ciService.config,t="none";return e.imgLoadingAnimation&&(t="scale3d(1.1, 1.1, 1)"),this.isLoaded&&e.imgLoadingAnimation&&(t="translateZ(0) scale3d(1, 1, 1)"),this._sanitizer.bypassSecurityTrustStyle(t)},g.prototype.getTransitionStyle=function(){var e=this.ciService.config,t="none";return this.isLoaded&&e.imgLoadingAnimation&&(t="all 0.3s ease-in-out"),this._sanitizer.bypassSecurityTrustStyle(t)},g.prototype.getFilterStyle=function(){var e=this.ciService.config,t="none";return e.imgLoadingAnimation&&(t="blur("+Math.floor(parseInt(this.parentContainerWidth,10)/100)+"px)"),this.isLoaded&&e.imgLoadingAnimation&&(t="blur(0px)"),this._sanitizer.bypassSecurityTrustStyle(t)},g.prototype.getPicturePaddingBottom=function(){var e="";return this.isRatio&&(e=100/(this.ratioBySize||this.ratio)+"%"),this._sanitizer.bypassSecurityTrustStyle(e)},g.prototype.getPictureBackground=function(){var e=this.ciService.config,t="transparent";return!this.isRatio||this.isPreviewLoaded||this.isLoaded||(t=e.placeholderBackground),this._sanitizer.bypassSecurityTrustStyle(t)},g.decorators=[{type:r.Component,args:[{selector:"ci-img",template:'\n <picture #pictureElem *ngIf="!isProcessed"></picture>\n\n <ng-container [ngSwitch]="lazyLoading">\n <ng-container *ngSwitchCase="true">\n <picture\n [class]="class + \' cloudimage-image-picture cloudimage-image-\' + (isLoaded ? \'loaded\' : \'loading\')"\n style="display:block;width:100%;overflow:hidden;position:relative;"\n [style.paddingBottom]="getPicturePaddingBottom()"\n [style.background]="getPictureBackground()"\n #imgElem\n *ngIf="isProcessed">\n <source\n *ngFor="let source of getRestSources()"\n [media]="source.mediaQuery || \'\'"\n [attr.lazyLoad]="source.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <source\n *ngIf="getFirstSource()"\n [attr.lazyLoad]="firstSource.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <img\n style="display:block;width:100%;opacity:1;top:0;left:0;"\n [style.position]="getPositionStyle()"\n [style.height]="getImgHeight()"\n [style.transform]="getTransformStyle()"\n [style.transition]="getTransitionStyle()"\n [style.filter]="getFilterStyle()"\n (load)="onImageLoad($event)"\n [lazyLoad]="!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)"\n [offset]="offset"\n [alt]="">\n </picture>\n </ng-container>\n <div *ngSwitchCase="false">\n <picture\n [class]="class + \' cloudimage-image-picture cloudimage-image-\' + (isLoaded ? \'loaded\' : \'loading\')"\n style="display:block;width:100%;overflow:hidden;position:relative;"\n [style.paddingBottom]="getPicturePaddingBottom()"\n [style.background]="getPictureBackground()"\n #imgElem\n *ngIf="isProcessed">\n <source\n *ngFor="let source of restSources"\n [media]="source.mediaQuery || \'\'"\n [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <source\n *ngIf="firstSource"\n [srcset]="firstSource.srcSet || \'\'"\n (load)="onImageLoad($event)"\n />\n <img\n style="display:block;width:100%;opacity:1;top:0;left:0;"\n [style.position]="getPositionStyle()"\n [style.height]="getImgHeight()"\n [style.transform]="getTransformStyle()"\n [style.transition]="getTransitionStyle()"\n [style.filter]="getFilterStyle()"\n (load)="onImageLoad($event)"\n [src]="!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)"\n [alt]="">\n </picture>\n </div>\n </ng-container>\n '}]}],g.ctorParameters=function(){return[{type:d},{type:i.DomSanitizer},{type:r.ChangeDetectorRef}]},g.propDecorators={imgElem:[{type:r.ViewChild,args:["imgElem"]}],pictureElem:[{type:r.ViewChild,args:["pictureElem"]}],src:[{type:r.Input}],"class":[{type:r.Input}],alt:[{type:r.Input}],operation:[{type:r.Input}],o:[{type:r.Input}],size:[{type:r.Input}],s:[{type:r.Input}],filters:[{type:r.Input}],f:[{type:r.Input}],ratio:[{type:r.Input}],offset:[{type:r.Input}],ngSwitch:[{type:r.Input}],imageLoaded:[{type:r.Output}]},g);function g(e,t,i){this.ciService=e,this._sanitizer=t,this.cd=i,this["class"]="",this.offset=100,this.imageLoaded=new r.EventEmitter,this.cloudimageUrl="",this.sources=[],this.firstSource=null,this.restSources=[],this.isLoaded=!1,this.isProcessed=!1,this.windowInnerWidth=window.innerWidth,this.lazyLoading=e.config.lazyLoading}var h=(f.decorators=[{type:r.NgModule,args:[{declarations:[p],imports:[t.CommonModule,s.LazyLoadImageModule],exports:[p],providers:[]}]}],f);function f(){}e.CIService=d,e.CIConfig=l,e.CIModule=h,e.ImgComponent=p,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=ng-cloudimage-responsive.umd.min.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ export class CIConfig {

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -315,4 +315,4 @@ import { Component, Input, ViewChild, ElementRef, EventEmitter, Output, ChangeDetectorRef } from '@angular/core';

ImgComponent.propDecorators = {
imgElem: [{ type: ViewChild, args: ['imgElem', { static: false },] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem', { static: false },] }],
imgElem: [{ type: ViewChild, args: ['imgElem',] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem',] }],
src: [{ type: Input }],

@@ -419,2 +419,2 @@ class: [{ type: Input }],

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img.component.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/img/img.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy, EventEmitter, Output, ChangeDetectorRef\n} from '@angular/core';\nimport {CIService} from '../lib.service';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {fromEvent, Observable, Subscription} from 'rxjs';\nimport {debounceTime} from 'rxjs/operators';\n\n@Component({\n  selector: 'ci-img',\n  template: `\n    <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n    <ng-container [ngSwitch]=\"lazyLoading\">\n      <ng-container *ngSwitchCase=\"true\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of getRestSources()\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [offset]=\"offset\"\n            [alt]=\"\">\n        </picture>\n      </ng-container>\n      <div *ngSwitchCase=\"false\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of restSources\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [alt]=\"\">\n        </picture>\n      </div>\n    </ng-container>\n  `\n})\nexport class ImgComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('imgElem', {static: false}) imgElem: ElementRef;\n  @ViewChild('pictureElem', {static: false}) pictureElem: ElementRef;\n  @Input() src: string;\n  @Input() class: string = '';\n  @Input() alt: string;\n  @Input() operation: string;\n  @Input() o: string;\n  @Input() size: string | {};\n  @Input() s: string | {};\n  @Input() filters: string;\n  @Input() f: string;\n  @Input() ratio: number;\n  @Input() offset = 100;\n  @Input() ngSwitch: any;\n  @Output() imageLoaded: EventEmitter<any> = new EventEmitter<any>();\n\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\n  firstSource = null;\n  restSources = [];\n  isLoaded = false;\n  isProcessed = false;\n  isPreview: boolean;\n  previewCloudimageUrl: string;\n  previewSources: string;\n  isAdaptive: boolean;\n  actualSize: string;\n  parentContainerWidth: string;\n  isPreviewLoaded: boolean;\n  isRatio: boolean;\n  ratioBySize: number;\n  lazyLoading: boolean;\n  imageHeight: number;\n  windowInnerWidth: number = window.innerWidth;\n\n  constructor(\n    private ciService: CIService,\n    private _sanitizer: DomSanitizer,\n    private cd: ChangeDetectorRef,\n  ) {\n    this.lazyLoading = ciService.config.lazyLoading;\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription$.unsubscribe();\n  }\n\n  ngOnInit() {\n    this.resizeObservable$ = fromEvent(window, 'resize').pipe(debounceTime(500));\n    this.resizeSubscription$ = this.resizeObservable$.subscribe(() => {\n      if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) {\n        this.processImage();\n      }\n      this.windowInnerWidth = window.innerWidth;\n    });\n  }\n\n  ngAfterViewInit() {\n    this.processImage();\n  }\n\n  processImage() {\n    const imgNode = (this.imgElem || this.pictureElem).nativeElement;\n    const {config = {}} = this.ciService;\n    const {previewQualityFactor} = config;\n    const operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    let size = this.size || this.s || config.size || parentContainerWidth;\n    const filters = this.filters || this.f || config.filters;\n    const isAdaptive = this.ciService.checkOnMedia(size);\n\n    size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;\n\n    const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);\n    const imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);\n    const resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);\n    this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;\n    this.cloudimageUrl = isAdaptive ?\n      this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :\n      this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);\n    this.sources = isAdaptive ?\n      this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];\n    let previewCloudimageUrl, previewSources;\n\n    if (this.isPreview) {\n      const previewConfig = {...config, queryString: ''};\n      previewCloudimageUrl = isAdaptive ?\n        this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :\n        this.ciService.generateUrl(\n          operation,\n          resultSize.split('x').map(item => Math.floor(item / previewQualityFactor)).join('x'),\n          filters,\n          imgSrc,\n          previewConfig\n        );\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];\n    }\n\n    this.previewCloudimageUrl = previewCloudimageUrl;\n    this.previewSources = previewSources;\n    this.isAdaptive = isAdaptive;\n    this.actualSize = size;\n    this.parentContainerWidth = parentContainerWidth;\n    const ratioBySize = this.ciService.getRatioBySize(size, config);\n    this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));\n    this.isRatio = !!(ratioBySize || this.ratio);\n    this.ratioBySize = ratioBySize;\n\n    this.isProcessed = true;\n    this.cd.detectChanges();\n  }\n\n  onImageLoad($event) {\n    if (!this.isPreview) {\n      this.isPreviewLoaded = true;\n      this.isLoaded = true;\n    } else if (this.isPreviewLoaded) {\n      this.isLoaded = true;\n    } else {\n      this.isPreviewLoaded = true;\n    }\n    this.imageLoaded.emit($event);\n  }\n\n  getRestSources() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n\n    return resultSources.slice(1).reverse();\n  }\n\n  getFirstSource() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n    this.firstSource = resultSources[0];\n\n    return resultSources[0];\n  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    // todo check if we need 100% height\n    // return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');\n  }\n\n  getTransformStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = 'scale3d(1.1, 1.1, 1)';\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'translateZ(0) scale3d(1, 1, 1)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getTransitionStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'all 0.3s ease-in-out';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getFilterStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = `blur(${Math.floor(parseInt(this.parentContainerWidth, 10) / 100)}px)`;\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'blur(0px)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPicturePaddingBottom() {\n    let result = '';\n\n    if (this.isRatio) {\n      result = (100 / (this.ratioBySize || this.ratio)) + '%';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPictureBackground() {\n    const {config} = this.ciService;\n    let result = 'transparent';\n\n    if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {\n      result = config.placeholderBackground;\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img.component.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/img/img.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAAyB,KAAK,EAAE,SAAS,EAAE,UAAU,EAAa,YAAY,EAAE,MAAM,EAAE,iBAAiB,EACnH,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,YAAY,EAAC,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAC,SAAS,EAA2B,MAAM,MAAM,CAAC;AACzD,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AA0E5C,MAAM,OAAO,YAAY;;;;;;IAsCvB,YACU,SAAoB,EACpB,UAAwB,EACxB,EAAqB;QAFrB,cAAS,GAAT,SAAS,CAAW;QACpB,eAAU,GAAV,UAAU,CAAc;QACxB,OAAE,GAAF,EAAE,CAAmB;QArCtB,UAAK,GAAW,EAAE,CAAC;QASnB,WAAM,GAAG,GAAG,CAAC;QAEZ,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAA;QAIlE,kBAAa,GAAG,EAAE,CAAC;QACnB,YAAO,GAAG,EAAE,CAAC;QACb,gBAAW,GAAG,IAAI,CAAC;QACnB,gBAAW,GAAG,EAAE,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,gBAAW,GAAG,KAAK,CAAC;QAYpB,qBAAgB,GAAW,MAAM,CAAC,UAAU,CAAC;QAO3C,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAClD,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS;;;QAAC,GAAG,EAAE;YAC/D,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,UAAU,EAAE;gBAChE,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;YACD,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,UAAU,CAAC;QAC5C,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;;;;IAED,YAAY;;cACJ,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,aAAa;cAC1D,EAAC,MAAM,GAAG,EAAE,EAAC,GAAG,IAAI,CAAC,SAAS;cAC9B,EAAE,oBAAoB,EAAE,GAAG,MAAM;;cACjC,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC,IAAI,MAAM,CAAC,SAAS;;cACxD,oBAAoB,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC;;YACvE,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,IAAI,MAAM,CAAC,IAAI,IAAI,oBAAoB;;cAC/D,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO;;cAClD,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC;QAEpD,IAAI,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;;cAElE,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,GAAG,CAAC;;cACnE,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,EAAE,MAAM,CAAC,OAAO,CAAC;;cAC9E,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,4BAA4B,CAAC,IAAI,CAAC;QACxF,IAAI,CAAC,SAAS,GAAG,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC;QACxF,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,CAAC;YAC/B,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,4BAA4B,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;YACjI,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;QAC7E,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,CAAC;YACzB,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;;YACrG,oBAAoB;;YAAE,cAAc;QAExC,IAAI,IAAI,CAAC,SAAS,EAAE;;kBACZ,aAAa,qBAAO,MAAM,IAAE,WAAW,EAAE,EAAE,GAAC;YAClD,oBAAoB,GAAG,UAAU,CAAC,CAAC;gBACjC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,oBAAoB,GAAG,oBAAoB,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;gBAChI,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG;;;;gBAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,oBAAoB,CAAC,EAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC;YAC9J,cAAc,GAAG,UAAU,CAAC,CAAC;gBAC3B,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;SAChH;QAED,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;QACjD,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;;cAC3C,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC;QAC/D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,oBAAoB,GAAG,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC;QACzF,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAE/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;;;;;IAED,WAAW,CAAC,MAAM;QAChB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;aAAM,IAAI,IAAI,CAAC,eAAe,EAAE;YAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;;;;IAED,cAAc;;cACN,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QAEzH,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IAC1C,CAAC;;;;IAED,cAAc;;cACN,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QACzH,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;QAEpC,OAAO,aAAa,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;;;;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAC1F,CAAC;;;;IAED,YAAY;QACV,oCAAoC;QACpC,mFAAmF;QACnF,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAClF,CAAC;;;;IAED,iBAAiB;cACT,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,SAAS;;YAC3B,MAAM,GAAG,MAAM;QAEnB,IAAI,MAAM,CAAC,mBAAmB,EAAE;YAC9B,MAAM,GAAG,sBAAsB,CAAC;SACjC;QAED,IAAI,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,mBAAmB,EAAE;YAC/C,MAAM,GAAG,gCAAgC,CAAC;SAC3C;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;;;;IAED,kBAAkB;cACV,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,SAAS;;YAC3B,MAAM,GAAG,MAAM;QAEnB,IAAI,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,mBAAmB,EAAE;YAC/C,MAAM,GAAG,sBAAsB,CAAC;SACjC;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;;;;IAED,cAAc;cACN,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,SAAS;;YAC3B,MAAM,GAAG,MAAM;QAEnB,IAAI,MAAM,CAAC,mBAAmB,EAAE;YAC9B,MAAM,GAAG,QAAQ,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC;SACjF;QAED,IAAI,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,mBAAmB,EAAE;YAC/C,MAAM,GAAG,WAAW,CAAC;SACtB;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;;;;IAED,uBAAuB;;YACjB,MAAM,GAAG,EAAE;QAEf,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,MAAM,GAAG,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC;SACzD;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;;;;IAED,oBAAoB;cACZ,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC,SAAS;;YAC3B,MAAM,GAAG,aAAa;QAE1B,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC3D,MAAM,GAAG,MAAM,CAAC,qBAAqB,CAAC;SACvC;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;;;YArRF,SAAS,SAAC;gBACT,QAAQ,EAAE,QAAQ;gBAClB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoET;aACF;;;;YA5EO,SAAS;YACT,YAAY;YAH+E,iBAAiB;;;sBAgFjH,SAAS,SAAC,SAAS;0BACnB,SAAS,SAAC,aAAa;kBACvB,KAAK;oBACL,KAAK;kBACL,KAAK;wBACL,KAAK;gBACL,KAAK;mBACL,KAAK;gBACL,KAAK;sBACL,KAAK;gBACL,KAAK;oBACL,KAAK;qBACL,KAAK;uBACL,KAAK;0BACL,MAAM;;;;IAdP,+BAA0C;;IAC1C,mCAAkD;;IAClD,2BAAqB;;IACrB,6BAA4B;;IAC5B,2BAAqB;;IACrB,iCAA2B;;IAC3B,yBAAmB;;IACnB,4BAA2B;;IAC3B,yBAAwB;;IACxB,+BAAyB;;IACzB,yBAAmB;;IACnB,6BAAuB;;IACvB,8BAAsB;;IACtB,gCAAuB;;IACvB,mCAAkE;;IAElE,yCAAqC;;IACrC,2CAAkC;;IAClC,qCAAmB;;IACnB,+BAAa;;IACb,mCAAmB;;IACnB,mCAAiB;;IACjB,gCAAiB;;IACjB,mCAAoB;;IACpB,iCAAmB;;IACnB,4CAA6B;;IAC7B,sCAAuB;;IACvB,kCAAoB;;IACpB,kCAAmB;;IACnB,4CAA6B;;IAC7B,uCAAyB;;IACzB,+BAAiB;;IACjB,mCAAoB;;IACpB,mCAAqB;;IACrB,mCAAoB;;IACpB,wCAA6C;;;;;IAG3C,iCAA4B;;;;;IAC5B,kCAAgC;;;;;IAChC,0BAA6B","sourcesContent":["import {\n  Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy, EventEmitter, Output, ChangeDetectorRef\n} from '@angular/core';\nimport {CIService} from '../lib.service';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {fromEvent, Observable, Subscription} from 'rxjs';\nimport {debounceTime} from 'rxjs/operators';\n\n@Component({\n  selector: 'ci-img',\n  template: `\n    <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n    <ng-container [ngSwitch]=\"lazyLoading\">\n      <ng-container *ngSwitchCase=\"true\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of getRestSources()\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [offset]=\"offset\"\n            [alt]=\"\">\n        </picture>\n      </ng-container>\n      <div *ngSwitchCase=\"false\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of restSources\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [alt]=\"\">\n        </picture>\n      </div>\n    </ng-container>\n  `\n})\nexport class ImgComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('imgElem') imgElem: ElementRef;\n  @ViewChild('pictureElem') pictureElem: ElementRef;\n  @Input() src: string;\n  @Input() class: string = '';\n  @Input() alt: string;\n  @Input() operation: string;\n  @Input() o: string;\n  @Input() size: string | {};\n  @Input() s: string | {};\n  @Input() filters: string;\n  @Input() f: string;\n  @Input() ratio: number;\n  @Input() offset = 100;\n  @Input() ngSwitch: any;\n  @Output() imageLoaded: EventEmitter<any> = new EventEmitter<any>()\n\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\n  firstSource = null;\n  restSources = [];\n  isLoaded = false;\n  isProcessed = false;\n  isPreview: boolean;\n  previewCloudimageUrl: string;\n  previewSources: string;\n  isAdaptive: boolean;\n  actualSize: string;\n  parentContainerWidth: string;\n  isPreviewLoaded: boolean;\n  isRatio: boolean;\n  ratioBySize: number;\n  lazyLoading: boolean;\n  imageHeight: number;\n  windowInnerWidth: number = window.innerWidth;\n\n  constructor(\n    private ciService: CIService,\n    private _sanitizer: DomSanitizer,\n    private cd: ChangeDetectorRef,\n  ) {\n    this.lazyLoading = ciService.config.lazyLoading;\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription$.unsubscribe();\n  }\n\n  ngOnInit() {\n    this.resizeObservable$ = fromEvent(window, 'resize').pipe(debounceTime(500));\n    this.resizeSubscription$ = this.resizeObservable$.subscribe(() => {\n      if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) {\n        this.processImage();\n      }\n      this.windowInnerWidth = window.innerWidth;\n    });\n  }\n\n  ngAfterViewInit() {\n    this.processImage();\n  }\n\n  processImage() {\n    const imgNode = (this.imgElem || this.pictureElem).nativeElement;\n    const {config = {}} = this.ciService;\n    const { previewQualityFactor } = config;\n    const operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    let size = this.size || this.s || config.size || parentContainerWidth;\n    const filters = this.filters || this.f || config.filters;\n    const isAdaptive = this.ciService.checkOnMedia(size);\n\n    size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;\n\n    const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);\n    const imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);\n    const resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);\n    this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;\n    this.cloudimageUrl = isAdaptive ?\n      this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :\n      this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);\n    this.sources = isAdaptive ?\n      this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];\n    let previewCloudimageUrl, previewSources;\n\n    if (this.isPreview) {\n      const previewConfig = {...config, queryString: ''};\n      previewCloudimageUrl = isAdaptive ?\n        this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => Math.floor(item / previewQualityFactor)).join('x'), filters, imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];\n    }\n\n    this.previewCloudimageUrl = previewCloudimageUrl;\n    this.previewSources = previewSources;\n    this.isAdaptive = isAdaptive;\n    this.actualSize = size;\n    this.parentContainerWidth = parentContainerWidth;\n    const ratioBySize = this.ciService.getRatioBySize(size, config);\n    this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));\n    this.isRatio = !!(ratioBySize || this.ratio);\n    this.ratioBySize = ratioBySize;\n\n    this.isProcessed = true;\n    this.cd.detectChanges();\n  }\n\n  onImageLoad($event) {\n    if (!this.isPreview) {\n      this.isPreviewLoaded = true;\n      this.isLoaded = true;\n    } else if (this.isPreviewLoaded) {\n      this.isLoaded = true;\n    } else {\n      this.isPreviewLoaded = true;\n    }\n    this.imageLoaded.emit($event);\n  }\n\n  getRestSources() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n\n    return resultSources.slice(1).reverse();\n  }\n\n  getFirstSource() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n    this.firstSource = resultSources[0];\n\n    return resultSources[0];\n  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    // todo check if we need 100% height\n    // return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');\n  }\n\n  getTransformStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = 'scale3d(1.1, 1.1, 1)';\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'translateZ(0) scale3d(1, 1, 1)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getTransitionStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'all 0.3s ease-in-out';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getFilterStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = `blur(${Math.floor(parseInt(this.parentContainerWidth, 10) / 100)}px)`;\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'blur(0px)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPicturePaddingBottom() {\n    let result = '';\n\n    if (this.isRatio) {\n      result = (100 / (this.ratioBySize || this.ratio)) + '%';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPictureBackground() {\n    const {config} = this.ciService;\n    let result = 'transparent';\n\n    if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {\n      result = config.placeholderBackground;\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n}\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core';

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -321,3 +321,3 @@ import { Injectable } from '@angular/core';

];
/** @nocollapse */ CIService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function CIService_Factory() { return new CIService(i0.ɵɵinject(i1.CIConfig)); }, token: CIService, providedIn: "root" });
/** @nocollapse */ CIService.ngInjectableDef = i0.defineInjectable({ factory: function CIService_Factory() { return new CIService(i0.inject(i1.CIConfig)); }, token: CIService, providedIn: "root" });
if (false) {

@@ -324,0 +324,0 @@ /** @type {?} */

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /*

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ var CIConfig = /** @class */ (function () {

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -286,4 +286,4 @@ import * as tslib_1 from "tslib";

ImgComponent.propDecorators = {
imgElem: [{ type: ViewChild, args: ['imgElem', { static: false },] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem', { static: false },] }],
imgElem: [{ type: ViewChild, args: ['imgElem',] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem',] }],
src: [{ type: Input }],

@@ -393,2 +393,2 @@ class: [{ type: Input }],

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img.component.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/img/img.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy, EventEmitter, Output, ChangeDetectorRef\n} from '@angular/core';\nimport {CIService} from '../lib.service';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {fromEvent, Observable, Subscription} from 'rxjs';\nimport {debounceTime} from 'rxjs/operators';\n\n@Component({\n  selector: 'ci-img',\n  template: `\n    <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n    <ng-container [ngSwitch]=\"lazyLoading\">\n      <ng-container *ngSwitchCase=\"true\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of getRestSources()\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [offset]=\"offset\"\n            [alt]=\"\">\n        </picture>\n      </ng-container>\n      <div *ngSwitchCase=\"false\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of restSources\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [alt]=\"\">\n        </picture>\n      </div>\n    </ng-container>\n  `\n})\nexport class ImgComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('imgElem', {static: false}) imgElem: ElementRef;\n  @ViewChild('pictureElem', {static: false}) pictureElem: ElementRef;\n  @Input() src: string;\n  @Input() class: string = '';\n  @Input() alt: string;\n  @Input() operation: string;\n  @Input() o: string;\n  @Input() size: string | {};\n  @Input() s: string | {};\n  @Input() filters: string;\n  @Input() f: string;\n  @Input() ratio: number;\n  @Input() offset = 100;\n  @Input() ngSwitch: any;\n  @Output() imageLoaded: EventEmitter<any> = new EventEmitter<any>();\n\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\n  firstSource = null;\n  restSources = [];\n  isLoaded = false;\n  isProcessed = false;\n  isPreview: boolean;\n  previewCloudimageUrl: string;\n  previewSources: string;\n  isAdaptive: boolean;\n  actualSize: string;\n  parentContainerWidth: string;\n  isPreviewLoaded: boolean;\n  isRatio: boolean;\n  ratioBySize: number;\n  lazyLoading: boolean;\n  imageHeight: number;\n  windowInnerWidth: number = window.innerWidth;\n\n  constructor(\n    private ciService: CIService,\n    private _sanitizer: DomSanitizer,\n    private cd: ChangeDetectorRef,\n  ) {\n    this.lazyLoading = ciService.config.lazyLoading;\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription$.unsubscribe();\n  }\n\n  ngOnInit() {\n    this.resizeObservable$ = fromEvent(window, 'resize').pipe(debounceTime(500));\n    this.resizeSubscription$ = this.resizeObservable$.subscribe(() => {\n      if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) {\n        this.processImage();\n      }\n      this.windowInnerWidth = window.innerWidth;\n    });\n  }\n\n  ngAfterViewInit() {\n    this.processImage();\n  }\n\n  processImage() {\n    const imgNode = (this.imgElem || this.pictureElem).nativeElement;\n    const {config = {}} = this.ciService;\n    const {previewQualityFactor} = config;\n    const operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    let size = this.size || this.s || config.size || parentContainerWidth;\n    const filters = this.filters || this.f || config.filters;\n    const isAdaptive = this.ciService.checkOnMedia(size);\n\n    size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;\n\n    const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);\n    const imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);\n    const resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);\n    this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;\n    this.cloudimageUrl = isAdaptive ?\n      this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :\n      this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);\n    this.sources = isAdaptive ?\n      this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];\n    let previewCloudimageUrl, previewSources;\n\n    if (this.isPreview) {\n      const previewConfig = {...config, queryString: ''};\n      previewCloudimageUrl = isAdaptive ?\n        this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :\n        this.ciService.generateUrl(\n          operation,\n          resultSize.split('x').map(item => Math.floor(item / previewQualityFactor)).join('x'),\n          filters,\n          imgSrc,\n          previewConfig\n        );\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];\n    }\n\n    this.previewCloudimageUrl = previewCloudimageUrl;\n    this.previewSources = previewSources;\n    this.isAdaptive = isAdaptive;\n    this.actualSize = size;\n    this.parentContainerWidth = parentContainerWidth;\n    const ratioBySize = this.ciService.getRatioBySize(size, config);\n    this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));\n    this.isRatio = !!(ratioBySize || this.ratio);\n    this.ratioBySize = ratioBySize;\n\n    this.isProcessed = true;\n    this.cd.detectChanges();\n  }\n\n  onImageLoad($event) {\n    if (!this.isPreview) {\n      this.isPreviewLoaded = true;\n      this.isLoaded = true;\n    } else if (this.isPreviewLoaded) {\n      this.isLoaded = true;\n    } else {\n      this.isPreviewLoaded = true;\n    }\n    this.imageLoaded.emit($event);\n  }\n\n  getRestSources() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n\n    return resultSources.slice(1).reverse();\n  }\n\n  getFirstSource() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n    this.firstSource = resultSources[0];\n\n    return resultSources[0];\n  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    // todo check if we need 100% height\n    // return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');\n  }\n\n  getTransformStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = 'scale3d(1.1, 1.1, 1)';\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'translateZ(0) scale3d(1, 1, 1)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getTransitionStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'all 0.3s ease-in-out';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getFilterStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = `blur(${Math.floor(parseInt(this.parentContainerWidth, 10) / 100)}px)`;\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'blur(0px)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPicturePaddingBottom() {\n    let result = '';\n\n    if (this.isRatio) {\n      result = (100 / (this.ratioBySize || this.ratio)) + '%';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPictureBackground() {\n    const {config} = this.ciService;\n    let result = 'transparent';\n\n    if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {\n      result = config.placeholderBackground;\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img.component.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/img/img.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy, EventEmitter, Output, ChangeDetectorRef\n} from '@angular/core';\nimport {CIService} from '../lib.service';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {fromEvent, Observable, Subscription} from 'rxjs';\nimport {debounceTime} from 'rxjs/operators';\n\n@Component({\n  selector: 'ci-img',\n  template: `\n    <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n    <ng-container [ngSwitch]=\"lazyLoading\">\n      <ng-container *ngSwitchCase=\"true\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of getRestSources()\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [offset]=\"offset\"\n            [alt]=\"\">\n        </picture>\n      </ng-container>\n      <div *ngSwitchCase=\"false\">\n        <picture\n          [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n          style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n          [style.paddingBottom]=\"getPicturePaddingBottom()\"\n          [style.background]=\"getPictureBackground()\"\n          #imgElem\n          *ngIf=\"isProcessed\">\n          <source\n            *ngFor=\"let source of restSources\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad($event)\"\n          />\n          <img\n            style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n            [style.position]=\"getPositionStyle()\"\n            [style.height]=\"getImgHeight()\"\n            [style.transform]=\"getTransformStyle()\"\n            [style.transition]=\"getTransitionStyle()\"\n            [style.filter]=\"getFilterStyle()\"\n            (load)=\"onImageLoad($event)\"\n            [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n            [alt]=\"\">\n        </picture>\n      </div>\n    </ng-container>\n  `\n})\nexport class ImgComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('imgElem') imgElem: ElementRef;\n  @ViewChild('pictureElem') pictureElem: ElementRef;\n  @Input() src: string;\n  @Input() class: string = '';\n  @Input() alt: string;\n  @Input() operation: string;\n  @Input() o: string;\n  @Input() size: string | {};\n  @Input() s: string | {};\n  @Input() filters: string;\n  @Input() f: string;\n  @Input() ratio: number;\n  @Input() offset = 100;\n  @Input() ngSwitch: any;\n  @Output() imageLoaded: EventEmitter<any> = new EventEmitter<any>()\n\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\n  firstSource = null;\n  restSources = [];\n  isLoaded = false;\n  isProcessed = false;\n  isPreview: boolean;\n  previewCloudimageUrl: string;\n  previewSources: string;\n  isAdaptive: boolean;\n  actualSize: string;\n  parentContainerWidth: string;\n  isPreviewLoaded: boolean;\n  isRatio: boolean;\n  ratioBySize: number;\n  lazyLoading: boolean;\n  imageHeight: number;\n  windowInnerWidth: number = window.innerWidth;\n\n  constructor(\n    private ciService: CIService,\n    private _sanitizer: DomSanitizer,\n    private cd: ChangeDetectorRef,\n  ) {\n    this.lazyLoading = ciService.config.lazyLoading;\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription$.unsubscribe();\n  }\n\n  ngOnInit() {\n    this.resizeObservable$ = fromEvent(window, 'resize').pipe(debounceTime(500));\n    this.resizeSubscription$ = this.resizeObservable$.subscribe(() => {\n      if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) {\n        this.processImage();\n      }\n      this.windowInnerWidth = window.innerWidth;\n    });\n  }\n\n  ngAfterViewInit() {\n    this.processImage();\n  }\n\n  processImage() {\n    const imgNode = (this.imgElem || this.pictureElem).nativeElement;\n    const {config = {}} = this.ciService;\n    const { previewQualityFactor } = config;\n    const operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    let size = this.size || this.s || config.size || parentContainerWidth;\n    const filters = this.filters || this.f || config.filters;\n    const isAdaptive = this.ciService.checkOnMedia(size);\n\n    size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size;\n\n    const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src);\n    const imgSrc = this.ciService.getImgSrc(this.src, isRelativeUrlPath, config.baseUrl);\n    const resultSize = isAdaptive ? size : this.ciService.getSizeAccordingToPixelRatio(size);\n    this.isPreview = !config.isChrome && (parentContainerWidth > 400) && config.lazyLoading;\n    this.cloudimageUrl = isAdaptive ?\n      this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) :\n      this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config);\n    this.sources = isAdaptive ?\n      this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, config, false) : [];\n    let previewCloudimageUrl, previewSources;\n\n    if (this.isPreview) {\n      const previewConfig = {...config, queryString: ''};\n      previewCloudimageUrl = isAdaptive ?\n        this.ciService.generateUrl('width', (Math.floor(parentContainerWidth / previewQualityFactor)), filters, imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => Math.floor(item / previewQualityFactor)).join('x'), filters, imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, filters, imgSrc, isAdaptive, previewConfig, true) : [];\n    }\n\n    this.previewCloudimageUrl = previewCloudimageUrl;\n    this.previewSources = previewSources;\n    this.isAdaptive = isAdaptive;\n    this.actualSize = size;\n    this.parentContainerWidth = parentContainerWidth;\n    const ratioBySize = this.ciService.getRatioBySize(size, config);\n    this.imageHeight = Math.floor(parentContainerWidth / (ratioBySize || this.ratio || 1.5));\n    this.isRatio = !!(ratioBySize || this.ratio);\n    this.ratioBySize = ratioBySize;\n\n    this.isProcessed = true;\n    this.cd.detectChanges();\n  }\n\n  onImageLoad($event) {\n    if (!this.isPreview) {\n      this.isPreviewLoaded = true;\n      this.isLoaded = true;\n    } else if (this.isPreviewLoaded) {\n      this.isLoaded = true;\n    } else {\n      this.isPreviewLoaded = true;\n    }\n    this.imageLoaded.emit($event);\n  }\n\n  getRestSources() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n\n    return resultSources.slice(1).reverse();\n  }\n\n  getFirstSource() {\n    const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))];\n    this.firstSource = resultSources[0];\n\n    return resultSources[0];\n  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    // todo check if we need 100% height\n    // return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto');\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto');\n  }\n\n  getTransformStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = 'scale3d(1.1, 1.1, 1)';\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'translateZ(0) scale3d(1, 1, 1)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getTransitionStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'all 0.3s ease-in-out';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getFilterStyle() {\n    const {config} = this.ciService;\n    let result = 'none';\n\n    if (config.imgLoadingAnimation) {\n      result = `blur(${Math.floor(parseInt(this.parentContainerWidth, 10) / 100)}px)`;\n    }\n\n    if (this.isLoaded && config.imgLoadingAnimation) {\n      result = 'blur(0px)';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPicturePaddingBottom() {\n    let result = '';\n\n    if (this.isRatio) {\n      result = (100 / (this.ratioBySize || this.ratio)) + '%';\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n\n  getPictureBackground() {\n    const {config} = this.ciService;\n    let result = 'transparent';\n\n    if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) {\n      result = config.placeholderBackground;\n    }\n\n    return this._sanitizer.bypassSecurityTrustStyle(result);\n  }\n}\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core';

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -404,3 +404,3 @@ import * as tslib_1 from "tslib";

]; };
/** @nocollapse */ CIService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function CIService_Factory() { return new CIService(i0.ɵɵinject(i1.CIConfig)); }, token: CIService, providedIn: "root" });
/** @nocollapse */ CIService.ngInjectableDef = i0.defineInjectable({ factory: function CIService_Factory() { return new CIService(i0.inject(i1.CIConfig)); }, token: CIService, providedIn: "root" });
return CIService;

@@ -407,0 +407,0 @@ }());

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /*

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

import { Injectable, ɵɵdefineInjectable, ɵɵinject, EventEmitter, Component, ChangeDetectorRef, ViewChild, Input, Output, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Injectable, NgModule, Component, Input, ViewChild, EventEmitter, Output, ChangeDetectorRef, defineInjectable, inject } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';

@@ -10,3 +10,3 @@ import { fromEvent } from 'rxjs';

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -18,3 +18,3 @@ class CIConfig {

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -333,7 +333,7 @@ class CIService {

];
/** @nocollapse */ CIService.ngInjectableDef = ɵɵdefineInjectable({ factory: function CIService_Factory() { return new CIService(ɵɵinject(CIConfig)); }, token: CIService, providedIn: "root" });
/** @nocollapse */ CIService.ngInjectableDef = defineInjectable({ factory: function CIService_Factory() { return new CIService(inject(CIConfig)); }, token: CIService, providedIn: "root" });
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -645,4 +645,4 @@ class ImgComponent {

ImgComponent.propDecorators = {
imgElem: [{ type: ViewChild, args: ['imgElem', { static: false },] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem', { static: false },] }],
imgElem: [{ type: ViewChild, args: ['imgElem',] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem',] }],
src: [{ type: Input }],

@@ -665,3 +665,3 @@ class: [{ type: Input }],

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -679,3 +679,14 @@ class CIModule {

export { CIConfig, CIModule, CIService, ImgComponent };
//# sourceMappingURL=ng-cloudimage-responsive.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { CIService, CIConfig, CIModule, ImgComponent };
//# sourceMappingURL=ng-cloudimage-responsive.js.map

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

import { CommonModule } from '@angular/common';
import { __read, __spread, __assign } from 'tslib';
import { Injectable, ɵɵdefineInjectable, ɵɵinject, Component, ChangeDetectorRef, ViewChild, Input, Output, EventEmitter, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Injectable, NgModule, defineInjectable, inject, EventEmitter, Component, ChangeDetectorRef, ViewChild, Input, Output } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';

@@ -11,3 +11,3 @@ import { fromEvent } from 'rxjs';

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -22,3 +22,3 @@ var CIConfig = /** @class */ (function () {

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -419,3 +419,3 @@ var CIService = /** @class */ (function () {

]; };
/** @nocollapse */ CIService.ngInjectableDef = ɵɵdefineInjectable({ factory: function CIService_Factory() { return new CIService(ɵɵinject(CIConfig)); }, token: CIService, providedIn: "root" });
/** @nocollapse */ CIService.ngInjectableDef = defineInjectable({ factory: function CIService_Factory() { return new CIService(inject(CIConfig)); }, token: CIService, providedIn: "root" });
return CIService;

@@ -426,3 +426,3 @@ }());

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -704,4 +704,4 @@ var ImgComponent = /** @class */ (function () {

ImgComponent.propDecorators = {
imgElem: [{ type: ViewChild, args: ['imgElem', { static: false },] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem', { static: false },] }],
imgElem: [{ type: ViewChild, args: ['imgElem',] }],
pictureElem: [{ type: ViewChild, args: ['pictureElem',] }],
src: [{ type: Input }],

@@ -726,3 +726,3 @@ class: [{ type: Input }],

* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -743,3 +743,14 @@ var CIModule = /** @class */ (function () {

export { CIConfig, CIModule, CIService, ImgComponent };
//# sourceMappingURL=ng-cloudimage-responsive.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { CIService, CIConfig, CIModule, ImgComponent };
//# sourceMappingURL=ng-cloudimage-responsive.js.map

@@ -52,9 +52,9 @@ import { OnInit, AfterViewInit, ElementRef, OnDestroy, EventEmitter, ChangeDetectorRef } from '@angular/core';

getFirstSource(): any;
getPositionStyle(): import("@angular/platform-browser").SafeStyle;
getImgHeight(): import("@angular/platform-browser").SafeStyle;
getTransformStyle(): import("@angular/platform-browser").SafeStyle;
getTransitionStyle(): import("@angular/platform-browser").SafeStyle;
getFilterStyle(): import("@angular/platform-browser").SafeStyle;
getPicturePaddingBottom(): import("@angular/platform-browser").SafeStyle;
getPictureBackground(): import("@angular/platform-browser").SafeStyle;
getPositionStyle(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getImgHeight(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getTransformStyle(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getTransitionStyle(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getFilterStyle(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getPicturePaddingBottom(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
getPictureBackground(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle;
}

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

{"__symbolic":"module","version":4,"metadata":{"CIService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIConfig"}]}],"getParentWidth":[{"__symbolic":"method"}],"getParentContainerWithWidth":[{"__symbolic":"method"}],"getSizeLimit":[{"__symbolic":"method"}],"checkOnMedia":[{"__symbolic":"method"}],"checkIfRelativeUrlPath":[{"__symbolic":"method"}],"getImgSrc":[{"__symbolic":"method"}],"getSizeAccordingToPixelRatio":[{"__symbolic":"method"}],"generateUrl":[{"__symbolic":"method"}],"generateSources":[{"__symbolic":"method"}],"getAdaptiveSize":[{"__symbolic":"method"}],"generateSrcset":[{"__symbolic":"method"}],"generateImgSrc":[{"__symbolic":"method"}],"getRatioBySize":[{"__symbolic":"method"}],"getBreakPoint":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"CIConfig":{"__symbolic":"class","members":{}},"CIModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ImgComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":12},{"__symbolic":"reference","module":"ng-lazyload-image","name":"LazyLoadImageModule","line":7,"character":26}],"exports":[{"__symbolic":"reference","name":"ImgComponent"}],"providers":[]}]}],"members":{}},"ImgComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"ci-img","template":"\n <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n <ng-container [ngSwitch]=\"lazyLoading\">\n <ng-container *ngSwitchCase=\"true\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of getRestSources()\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [offset]=\"offset\"\n [alt]=\"\">\n </picture>\n </ng-container>\n <div *ngSwitchCase=\"false\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of restSources\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"firstSource\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n "}]}],"members":{"imgElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":81,"character":3},"arguments":["imgElem",{"static":false}]}]}],"pictureElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":82,"character":3},"arguments":["pictureElem",{"static":false}]}]}],"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":3}}]}],"class":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"alt":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"operation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":86,"character":3}}]}],"o":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"s":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"filters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"f":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"offset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"ngSwitch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3}}]}],"imageLoaded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":95,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":120,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":121,"character":16}]}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"processImage":[{"__symbolic":"method"}],"onImageLoad":[{"__symbolic":"method"}],"getRestSources":[{"__symbolic":"method"}],"getFirstSource":[{"__symbolic":"method"}],"getPositionStyle":[{"__symbolic":"method"}],"getImgHeight":[{"__symbolic":"method"}],"getTransformStyle":[{"__symbolic":"method"}],"getTransitionStyle":[{"__symbolic":"method"}],"getFilterStyle":[{"__symbolic":"method"}],"getPicturePaddingBottom":[{"__symbolic":"method"}],"getPictureBackground":[{"__symbolic":"method"}]}}},"origins":{"CIService":"./lib/lib.service","CIConfig":"./lib/config.model","CIModule":"./lib/lib.module","ImgComponent":"./lib/img/img.component"},"importAs":"ng-cloudimage-responsive"}
{"__symbolic":"module","version":4,"metadata":{"CIService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIConfig"}]}],"getParentWidth":[{"__symbolic":"method"}],"getParentContainerWithWidth":[{"__symbolic":"method"}],"getSizeLimit":[{"__symbolic":"method"}],"checkOnMedia":[{"__symbolic":"method"}],"checkIfRelativeUrlPath":[{"__symbolic":"method"}],"getImgSrc":[{"__symbolic":"method"}],"getSizeAccordingToPixelRatio":[{"__symbolic":"method"}],"generateUrl":[{"__symbolic":"method"}],"generateSources":[{"__symbolic":"method"}],"getAdaptiveSize":[{"__symbolic":"method"}],"generateSrcset":[{"__symbolic":"method"}],"generateImgSrc":[{"__symbolic":"method"}],"getRatioBySize":[{"__symbolic":"method"}],"getBreakPoint":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"CIConfig":{"__symbolic":"class","members":{}},"CIModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ImgComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":12},{"__symbolic":"reference","module":"ng-lazyload-image","name":"LazyLoadImageModule","line":7,"character":26}],"exports":[{"__symbolic":"reference","name":"ImgComponent"}],"providers":[]}]}],"members":{}},"ImgComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"ci-img","template":"\n <picture #pictureElem *ngIf=\"!isProcessed\"></picture>\n\n <ng-container [ngSwitch]=\"lazyLoading\">\n <ng-container *ngSwitchCase=\"true\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of getRestSources()\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [lazyLoad]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [offset]=\"offset\"\n [alt]=\"\">\n </picture>\n </ng-container>\n <div *ngSwitchCase=\"false\">\n <picture\n [class]=\"class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')\"\n style=\"display:block;width:100%;overflow:hidden;position:relative;\"\n [style.paddingBottom]=\"getPicturePaddingBottom()\"\n [style.background]=\"getPictureBackground()\"\n #imgElem\n *ngIf=\"isProcessed\">\n <source\n *ngFor=\"let source of restSources\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <source\n *ngIf=\"firstSource\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad($event)\"\n />\n <img\n style=\"display:block;width:100%;opacity:1;top:0;left:0;\"\n [style.position]=\"getPositionStyle()\"\n [style.height]=\"getImgHeight()\"\n [style.transform]=\"getTransformStyle()\"\n [style.transition]=\"getTransitionStyle()\"\n [style.filter]=\"getFilterStyle()\"\n (load)=\"onImageLoad($event)\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n "}]}],"members":{"imgElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":81,"character":3},"arguments":["imgElem"]}]}],"pictureElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":82,"character":3},"arguments":["pictureElem"]}]}],"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":3}}]}],"class":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"alt":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"operation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":86,"character":3}}]}],"o":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"s":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"filters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"f":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"offset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"ngSwitch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3}}]}],"imageLoaded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":95,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":120,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":121,"character":16}]}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"processImage":[{"__symbolic":"method"}],"onImageLoad":[{"__symbolic":"method"}],"getRestSources":[{"__symbolic":"method"}],"getFirstSource":[{"__symbolic":"method"}],"getPositionStyle":[{"__symbolic":"method"}],"getImgHeight":[{"__symbolic":"method"}],"getTransformStyle":[{"__symbolic":"method"}],"getTransitionStyle":[{"__symbolic":"method"}],"getFilterStyle":[{"__symbolic":"method"}],"getPicturePaddingBottom":[{"__symbolic":"method"}],"getPictureBackground":[{"__symbolic":"method"}]}}},"origins":{"CIService":"./lib/lib.service","CIConfig":"./lib/config.model","CIModule":"./lib/lib.module","ImgComponent":"./lib/img/img.component"},"importAs":"ng-cloudimage-responsive"}
{
"name": "ng-cloudimage-responsive",
"version": "2.0.1",
"version": "2.0.2",
"description": "Cloudimage Responsive will smartly resize, compress and accelerate images across the World in your site for all devices. The plugin supports lazy loading technique with fancy animation on image load.",

@@ -5,0 +5,0 @@ "author": "scaleflex",

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

[![Release](https://img.shields.io/badge/release-v2.0.1-blue.svg)](https://github.com/scaleflex/ng-cloudimage-responsive/releases)
[![Release](https://img.shields.io/badge/release-v2.0.2-blue.svg)](https://github.com/scaleflex/ng-cloudimage-responsive/releases)
[![Free plan](https://img.shields.io/badge/price-includes%20free%20plan-green.svg)](https://www.cloudimage.io/en/home#b38181a6-b9c8-4015-9742-7b1a1ad382d5)

@@ -3,0 +3,0 @@ [![Contributions welcome](https://img.shields.io/badge/contributions-welcome-orange.svg)](#contributing)

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