ng-cloudimage-responsive
Advanced tools
Comparing version 0.0.4 to 1.0.0
@@ -7,2 +7,58 @@ (function (global, factory) { | ||
/*! ***************************************************************************** | ||
Copyright (c) Microsoft Corporation. All rights reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use | ||
this file except in compliance with the License. You may obtain a copy of the | ||
License at http://www.apache.org/licenses/LICENSE-2.0 | ||
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED | ||
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, | ||
MERCHANTABLITY OR NON-INFRINGEMENT. | ||
See the Apache Version 2.0 License for specific language governing permissions | ||
and limitations under the License. | ||
***************************************************************************** */ | ||
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]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
function __read(o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
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); | ||
} | ||
catch (error) { | ||
e = { error: error }; | ||
} | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) | ||
m.call(i); | ||
} | ||
finally { | ||
if (e) | ||
throw e.error; | ||
} | ||
} | ||
return ar; | ||
} | ||
function __spread() { | ||
for (var ar = [], i = 0; i < arguments.length; i++) | ||
ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
} | ||
/** | ||
@@ -39,15 +95,14 @@ * @fileoverview added by tsickle | ||
baseUrl: baseUrl, | ||
presets: presets ? this.getPresets(presets, 'presets') : | ||
presets: presets ? presets : | ||
{ | ||
xs: 575, | ||
// up to 576 PHONE | ||
sm: 767, | ||
// 577 - 768 PHABLET | ||
md: 991, | ||
// 769 - 992 TABLET | ||
lg: 1199, | ||
// 993 - 1200 SMALL_LAPTOP_SCREEN | ||
xl: 3000 // from 1200 USUALSCREEN | ||
xs: '(max-width: 575px)', | ||
// to 575 PHONE | ||
sm: '(min-width: 576px)', | ||
// 576 - 767 PHABLET | ||
md: '(min-width: 768px)', | ||
// 768 - 991 TABLET | ||
lg: '(min-width: 992px)', | ||
// 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
}, | ||
order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'], | ||
queryString: queryString, | ||
@@ -58,34 +113,2 @@ innerWidth: window.innerWidth, | ||
/** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getPresets = /** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
function (value, type) { | ||
if (value === void 0) { | ||
value = ''; | ||
} | ||
/** @type {?} */ | ||
var splittedValues = value.split('|'); | ||
/** @type {?} */ | ||
var result = { presets: {}, order: [] }; | ||
for (var i = 0; i < splittedValues.length; i++) { | ||
/** @type {?} */ | ||
var splittedParam = splittedValues[i] && splittedValues[i].split(':'); | ||
/** @type {?} */ | ||
var prop = splittedParam[0] && splittedParam[0].trim(); | ||
/** @type {?} */ | ||
var val = splittedParam[1] && splittedParam[1].trim(); | ||
if (prop && val) { | ||
result.presets[prop] = val; | ||
result.order.unshift(prop); | ||
} | ||
} | ||
return result[type]; | ||
}; | ||
/** | ||
* @param {?} img | ||
@@ -137,3 +160,7 @@ * @param {?} config | ||
} while (parentNode && !width); | ||
return 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); | ||
}; | ||
@@ -149,26 +176,9 @@ /** | ||
function (currentSize) { | ||
return currentSize <= 25 ? '25' : | ||
currentSize <= 50 ? '50' : | ||
currentSize <= 100 ? '100' | ||
: currentSize <= 200 ? '200' | ||
: currentSize <= 300 ? '300' | ||
: currentSize <= 400 ? '400' | ||
: currentSize <= 500 ? '500' | ||
: currentSize <= 600 ? '600' | ||
: currentSize <= 700 ? '700' | ||
: currentSize <= 800 ? '800' | ||
: currentSize <= 900 ? '900' | ||
: currentSize <= 1000 ? '1000' | ||
: currentSize <= 1100 ? '1100' | ||
: currentSize <= 1200 ? '1200' | ||
: currentSize <= 1300 ? '1300' | ||
: currentSize <= 1400 ? '1400' | ||
: currentSize <= 1500 ? '1500' | ||
: currentSize <= 1600 ? '1600' | ||
: currentSize <= 1700 ? '1700' | ||
: currentSize <= 1800 ? '1800' | ||
: currentSize <= 1900 ? '1900' | ||
: currentSize <= 2400 ? '2400' | ||
: currentSize <= 2800 ? '2800' | ||
: '3600'; | ||
if (currentSize <= 25) { | ||
return '25'; | ||
} | ||
if (currentSize <= 50) { | ||
return '50'; | ||
} | ||
return (Math.ceil(currentSize / 100) * 100).toString(); | ||
}; | ||
@@ -184,3 +194,10 @@ /** | ||
function (size) { | ||
return size && typeof size === 'object'; | ||
try { | ||
/** @type {?} */ | ||
var array = size.split(','); | ||
return array.length > 1; | ||
} | ||
catch (e) { | ||
return false; | ||
} | ||
}; | ||
@@ -288,34 +305,22 @@ /** | ||
function (operation, size, filters, imgSrc, isAdaptive, config, isPreview) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var sources = []; | ||
if (isAdaptive) { | ||
/** @type {?} */ | ||
var orderFiltered = []; | ||
for (var i = 0; i < config.order.length; i++) { | ||
/** @type {?} */ | ||
var nextSize = size[config.order[i]]; | ||
if (nextSize) { | ||
orderFiltered.unshift(config.order[i]); | ||
} | ||
} | ||
for (var i = 0; i < orderFiltered.length; i++) { | ||
/** @type {?} */ | ||
var isLast = !(i < orderFiltered.length - 1); | ||
/** @type {?} */ | ||
var nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i]; | ||
/** @type {?} */ | ||
var nextSize = size[orderFiltered[i]]; | ||
size.forEach(function (_a) { | ||
var nextSize = _a.size, mediaQuery = _a.media; | ||
if (isPreview) { | ||
nextSize = nextSize.split('x').map(function (item) { return item / 5; }).join('x'); | ||
nextSize = nextSize.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
/** @type {?} */ | ||
var srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config); | ||
/** @type {?} */ | ||
var mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)'; | ||
sources.push({ mediaQuery: mediaQuery, srcSet: srcSet }); | ||
} | ||
sources.push({ mediaQuery: mediaQuery, srcSet: _this.generateSrcset(operation, nextSize, filters, imgSrc, config) }); | ||
}); | ||
} | ||
else { | ||
if (isPreview) { | ||
size = size.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
sources.push({ | ||
srcSet: this.generateSrcset(operation, size.split('x').map(function (item) { return item / 5; }).join('x'), 'q10.foil1', imgSrc, config) | ||
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config) | ||
}); | ||
@@ -326,2 +331,26 @@ } | ||
/** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getAdaptiveSize = /** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
function (size, config) { | ||
/** @type {?} */ | ||
var arrayOfSizes = size.split(','); | ||
/** @type {?} */ | ||
var sizes = []; | ||
arrayOfSizes.forEach(function (string) { | ||
/** @type {?} */ | ||
var groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups; | ||
/** @type {?} */ | ||
var media = groups.media ? groups.media : config.presets[groups.variable]; | ||
sizes.push({ media: media, size: groups.size }); | ||
}); | ||
return sizes; | ||
}; | ||
/** | ||
* @param {?} operation | ||
@@ -343,6 +372,3 @@ * @param {?} size | ||
function (operation, size, filters, imgSrc, config) { | ||
/** @type {?} */ | ||
var imgWidth = size.toString().split('x')[0]; | ||
/** @type {?} */ | ||
var imgHeight = size.toString().split('x')[1]; | ||
var _a = __read(size.toString().split('x'), 2), imgWidth = _a[0], imgHeight = _a[1]; | ||
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config); | ||
@@ -393,2 +419,3 @@ }; | ||
function (size, config) { | ||
var _a, _b; | ||
/** @type {?} */ | ||
@@ -400,29 +427,9 @@ var width; | ||
/** @type {?} */ | ||
var breakPoint = this.getBreakPoint(config); | ||
var breakPointSource = this.getBreakPoint(size); | ||
/** @type {?} */ | ||
var orderIndex = config.order.indexOf(breakPoint); | ||
/** @type {?} */ | ||
var breakPointSize = null; | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndex]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndex--; | ||
} while (!breakPointSize && orderIndex >= 0); | ||
if (!breakPointSize) { | ||
/** @type {?} */ | ||
var orderIndexStepTwo = config.order.indexOf(breakPoint); | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndexStepTwo]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndexStepTwo++; | ||
} while (!breakPointSize && orderIndexStepTwo <= config.order.length); | ||
} | ||
width = breakPointSize.toString().split('x')[0]; | ||
height = breakPointSize.toString().split('x')[1]; | ||
var breakPointSize = breakPointSource ? breakPointSource.size : size[0].size; | ||
_a = __read(breakPointSize.toString().split('x'), 2), width = _a[0], height = _a[1]; | ||
} | ||
else { | ||
width = size.toString().split('x')[0]; | ||
height = size.toString().split('x')[1]; | ||
_b = __read(size.toString().split('x'), 2), width = _b[0], height = _b[1]; | ||
} | ||
@@ -435,16 +442,11 @@ if (width && height) { | ||
/** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getBreakPoint = /** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
function (config) { | ||
var presets = config.presets, order = config.order; | ||
/** @type {?} */ | ||
var innerWidth = window.innerWidth; | ||
/** @type {?} */ | ||
var prevBreakPointLimit = order.findIndex(function (item) { return presets[item] < innerWidth; }); | ||
return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1]; | ||
function (size) { | ||
return __spread(size).reverse().find(function (item) { return matchMedia(item.media).matches; }); | ||
}; | ||
@@ -466,29 +468,2 @@ CIService.decorators = [ | ||
/*! ***************************************************************************** | ||
Copyright (c) Microsoft Corporation. All rights reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use | ||
this file except in compliance with the License. You may obtain a copy of the | ||
License at http://www.apache.org/licenses/LICENSE-2.0 | ||
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED | ||
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, | ||
MERCHANTABLITY OR NON-INFRINGEMENT. | ||
See the Apache Version 2.0 License for specific language governing permissions | ||
and limitations under the License. | ||
***************************************************************************** */ | ||
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]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
/** | ||
@@ -502,5 +477,8 @@ * @fileoverview added by tsickle | ||
this._sanitizer = _sanitizer; | ||
this.class = ''; | ||
this.offset = 100; | ||
this.cloudimageUrl = ''; | ||
this.sources = []; | ||
this.firstSource = null; | ||
this.restSources = []; | ||
this.isLoaded = false; | ||
@@ -530,8 +508,5 @@ this.isProcessed = false; | ||
this.resizeSubscription$ = this.resizeObservable$.subscribe(function () { | ||
if (_this.isAdaptive) { | ||
if (_this.isAdaptive || _this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
else if (_this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
_this.windowInnerWidth = window.innerWidth; | ||
@@ -570,2 +545,3 @@ }); | ||
var isAdaptive = this.ciService.checkOnMedia(size); | ||
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size; | ||
/** @type {?} */ | ||
@@ -579,3 +555,3 @@ var isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src); | ||
this.cloudimageUrl = isAdaptive ? | ||
this.ciService.generateUrl('width', parentContainerWidth, filters, imgSrc, config) : | ||
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) : | ||
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config); | ||
@@ -632,2 +608,25 @@ this.sources = isAdaptive ? | ||
*/ | ||
ImgComponent.prototype.getRestSources = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
return resultSources.slice(1).reverse(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getFirstSource = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
this.firstSource = resultSources[0]; | ||
return resultSources[0]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getPositionStyle = /** | ||
@@ -646,3 +645,5 @@ * @return {?} | ||
function () { | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
// todo check if we need 100% height | ||
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto'); | ||
}; | ||
@@ -724,3 +725,3 @@ /** | ||
var result = 'transparent'; | ||
if (this.isRatio) { | ||
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) { | ||
result = config.placeholderBackground; | ||
@@ -733,3 +734,3 @@ } | ||
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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\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 [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"firstSource\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n " | ||
}] } | ||
@@ -736,0 +737,0 @@ ]; |
@@ -1,2 +0,2 @@ | ||
!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,i,r,n,o,s){"use strict";var a=function u(){},c=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,g=void 0===u?100:u,p=e.width,h=void 0===p?"400":p,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?"n":S,I=e.placeholderBackground,P=void 0===I?"#f4f4f4":I,x=e.baseUrl,L=void 0===x?"/":x,b=e.presets,z=e.queryString,k=void 0===z?"":z;this.config={token:i,container:n,ultraFast:s,lazyLoading:c,imgLoadingAnimation:d,lazyLoadOffset:g,width:h,height:y,operation:v,filters:w,placeholderBackground:P,baseUrl:L,presets:b?this.getPresets(b,"presets"):{xs:575,sm:767,md:991,lg:1199,xl:3e3},order:b?this.getPresets(b,"order"):["xl","lg","md","sm","xs"],queryString:k,innerWidth:window.innerWidth}}return e.prototype.getPresets=function(e,t){void 0===e&&(e="");for(var i=e.split("|"),r={presets:{},order:[]},n=0;n<i.length;n++){var o=i[n]&&i[n].split(":"),s=o[0]&&o[0].trim(),a=o[1]&&o[1].trim();s&&a&&(r.presets[s]=a,r.order.unshift(s))}return r[t]},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&&15<n||!r?this.getSizeLimit(n):r?this.getSizeLimit(r):e.width||t.width},e.prototype.getParentContainerWithWidth=function(e){for(var t=null,i=0;i=(t=t&&t.parentNode||e.parentNode).getBoundingClientRect().width,t&&!i;);return i},e.prototype.getSizeLimit=function(e){return e<=25?"25":e<=50?"50":e<=100?"100":e<=200?"200":e<=300?"300":e<=400?"400":e<=500?"500":e<=600?"600":e<=700?"700":e<=800?"800":e<=900?"900":e<=1e3?"1000":e<=1100?"1100":e<=1200?"1200":e<=1300?"1300":e<=1400?"1400":e<=1500?"1500":e<=1600?"1600":e<=1700?"1700":e<=1800?"1800":e<=1900?"1900":e<=2400?"2400":e<=2800?"2800":"3600"},e.prototype.checkOnMedia=function(e){return e&&"object"==typeof e},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=[];if(n){for(var c=[],l=0;l<o.order.length;l++){(g=t[o.order[l]])&&c.unshift(o.order[l])}for(l=0;l<c.length;l++){var d=!(l<c.length-1),u=d?c[l-1]:c[l],g=t[c[l]];s&&(g=g.split("x").map(function(e){return e/5}).join("x"));var p=this.generateSrcset(e,g,i,r,o),h="("+(d?"min":"max")+"-width: "+(o.presets[u]+(d?1:0))+"px)";a.push({mediaQuery:h,srcSet:p})}}else a.push({srcSet:this.generateSrcset(e,t.split("x").map(function(e){return e/5}).join("x"),"q10.foil1",r,o)});return a},e.prototype.generateSrcset=function(e,t,i,r,n){var o=t.toString().split("x")[0],s=t.toString().split("x")[1];return this.generateImgSrc(e,i,r,o,s,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;if("object"==typeof e){var n=this.getBreakPoint(t),o=t.order.indexOf(n),s=null;do{s=e[t.order[o]],o--}while(!s&&0<=o);if(!s){var a=t.order.indexOf(n);do{s=e[t.order[a]],a++}while(!s&&a<=t.order.length)}i=s.toString().split("x")[0],r=s.toString().split("x")[1]}else i=e.toString().split("x")[0],r=e.toString().split("x")[1];return i&&r?i/r:null},e.prototype.getBreakPoint=function(e){var t=e.presets,i=e.order,r=window.innerWidth,n=i.findIndex(function(e){return t[e]<r});return i[n-1]||i[n]||i[i.length-1]},e.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:a}]},e.ngInjectableDef=i.defineInjectable({factory:function(){return new e(i.inject(a))},token:e,providedIn:"root"}),e}(),f=function(){return(f=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)},l=function(){function e(e,t){this.ciService=e,this._sanitizer=t,this.offset=100,this.cloudimageUrl="",this.sources=[],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.processImage():e.windowInnerWidth<window.innerWidth&&e.processImage(),e.windowInnerWidth=window.innerWidth})},e.prototype.ngAfterViewInit=function(){this.processImage()},e.prototype.processImage=function(){var e,t,i=this,r=(this.imgElem||this.pictureElem).nativeElement,n=this.ciService.config,o=this.operation||this.o||n.operation,s=this.ciService.getParentWidth(r,n),a=this.size||this.s||n.size||s,c=this.filters||this.f||n.filters,l=this.ciService.checkOnMedia(a),d=this.ciService.checkIfRelativeUrlPath(this.src),u=this.ciService.getImgSrc(this.src,d,n.baseUrl),g=l?a:this.ciService.getSizeAccordingToPixelRatio(a);if(this.isPreview=!n.isChrome&&400<s&&n.lazyLoading,this.cloudimageUrl=l?this.ciService.generateUrl("width",s,c,u,n):this.ciService.generateUrl(o,g,c,u,n),this.sources=l?this.ciService.generateSources(o,g,c,u,l,n,!1):[],this.isPreview){var p=f({},n,{queryString:""});e=l?this.ciService.generateUrl("width",s/5,"q10.foil1",u,p):this.ciService.generateUrl(o,g.split("x").map(function(e){return e/5}).join("x"),"q10.foil1",u,p),t=l?this.ciService.generateSources(o,g,"q10.foil1",u,l,p,!0):[]}this.previewCloudimageUrl=e,this.previewSources=t,this.isAdaptive=l,this.actualSize=a,this.parentContainerWidth=s;var h=this.ciService.getRatioBySize(a,n);this.imageHeight=Math.floor(s/(h||this.ratio||1.5)),this.isRatio=!(!h&&!this.ratio),this.ratioBySize=h,setTimeout(function(){i.isProcessed=!0})},e.prototype.onImageLoad=function(){this.isPreview?this.isPreviewLoaded?this.isLoaded=!0:this.isPreviewLoaded=!0:(this.isPreviewLoaded=!0,this.isLoaded=!0)},e.prototype.getPositionStyle=function(){return this._sanitizer.bypassSecurityTrustStyle(this.isRatio?"absolute":"relative")},e.prototype.getImgHeight=function(){return this._sanitizer.bypassSecurityTrustStyle(this.isRatio?"100%":"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&&(t=e.placeholderBackground),this._sanitizer.bypassSecurityTrustStyle(t)},e.decorators=[{type:i.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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))"\n [media]="source.mediaQuery || \'\'"\n [attr.lazyLoad]="source.srcSet || \'\'"\n [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad()"\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()"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))"\n [media]="source.mediaQuery || \'\'"\n [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad()"\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()"\n [src]="!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)"\n [alt]="">\n </picture>\n </div>\n </ng-container>\n '}]}],e.ctorParameters=function(){return[{type:c},{type:r.DomSanitizer}]},e.propDecorators={imgElem:[{type:i.ViewChild,args:["imgElem"]}],pictureElem:[{type:i.ViewChild,args:["pictureElem"]}],src:[{type:i.Input}],"class":[{type:i.Input}],alt:[{type:i.Input}],operation:[{type:i.Input}],o:[{type:i.Input}],size:[{type:i.Input}],s:[{type:i.Input}],filters:[{type:i.Input}],f:[{type:i.Input}],ratio:[{type:i.Input}],offset:[{type:i.Input}],ngSwitch:[{type:i.Input}]},e}(),d=function(){function e(){}return e.decorators=[{type:i.NgModule,args:[{declarations:[l],imports:[t.CommonModule,s.LazyLoadImageModule],exports:[l],providers:[]}]}],e}();e.CIService=c,e.CIConfig=a,e.CIModule=d,e.ImgComponent=l,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,i,r,n,o,s){"use strict";var f=function(){return(f=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}var l=function g(){},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,u=void 0===l||l,d=e.lazyLoadOffset,p=void 0===d?100:d,g=e.width,h=void 0===g?"400":g,f=e.height,y=void 0===f?"300":f,m=e.operation,S=void 0===m?"width":m,v=e.filters,w=void 0===v?"n":v,z=e.placeholderBackground,I=void 0===z?"#f4f4f4":z,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:u,lazyLoadOffset:p,width:h,height:y,operation:S,filters:w,placeholderBackground:I,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}}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&&15<n||!r?this.getSizeLimit(n):r?this.getSizeLimit(r):e.width||t.width},e.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)},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 1<e.split(",").length}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(r,e,n,o,t,s,a){var c=this,l=[];return t?e.forEach(function(e){var t=e.size,i=e.media;a&&(t=t.split("x").map(function(e){return e/5}).join("x"),n="q10.foil1"),l.push({mediaQuery:i,srcSet:c.generateSrcset(r,t,n,o,s)})}):(a&&(e=e.split("x").map(function(e){return e/5}).join("x"),n="q10.foil1"),l.push({srcSet:this.generateSrcset(r,e,n,o,s)})),l},e.prototype.getAdaptiveSize=function(e,r){var t=e.split(","),n=[];return t.forEach(function(e){var t=e.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups,i=t.media?t.media:r.presets[t.variable];n.push({media:i,size:t.size})}),n},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 a(e).reverse().find(function(e){return matchMedia(e.media).matches})},e.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:l}]},e.ngInjectableDef=i.defineInjectable({factory:function(){return new e(i.inject(l))},token:e,providedIn:"root"}),e}(),d=function(){function e(e,t){this.ciService=e,this._sanitizer=t,this["class"]="",this.offset=100,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,t=(this.imgElem||this.pictureElem).nativeElement,i=this.ciService.config,r=this.operation||this.o||i.operation,n=this.ciService.getParentWidth(t,i),o=this.size||this.s||i.size||n,s=this.filters||this.f||i.filters,a=this.ciService.checkOnMedia(o);o=a?this.ciService.getAdaptiveSize(o,i):o;var c,l,u=this.ciService.checkIfRelativeUrlPath(this.src),d=this.ciService.getImgSrc(this.src,u,i.baseUrl),p=a?o:this.ciService.getSizeAccordingToPixelRatio(o);if(this.isPreview=!i.isChrome&&400<n&&i.lazyLoading,this.cloudimageUrl=a?this.ciService.generateUrl("width",this.ciService.getSizeAccordingToPixelRatio(n),s,d,i):this.ciService.generateUrl(r,p,s,d,i),this.sources=a?this.ciService.generateSources(r,p,s,d,a,i,!1):[],this.isPreview){var g=f({},i,{queryString:""});c=a?this.ciService.generateUrl("width",n/5,"q10.foil1",d,g):this.ciService.generateUrl(r,p.split("x").map(function(e){return e/5}).join("x"),"q10.foil1",d,g),l=a?this.ciService.generateSources(r,p,"q10.foil1",d,a,g,!0):[]}this.previewCloudimageUrl=c,this.previewSources=l,this.isAdaptive=a,this.actualSize=o,this.parentContainerWidth=n;var h=this.ciService.getRatioBySize(o,i);this.imageHeight=Math.floor(n/(h||this.ratio||1.5)),this.isRatio=!(!h&&!this.ratio),this.ratioBySize=h,setTimeout(function(){e.isProcessed=!0})},e.prototype.onImageLoad=function(){this.isPreview?this.isPreviewLoaded?this.isLoaded=!0:this.isPreviewLoaded=!0:(this.isPreviewLoaded=!0,this.isLoaded=!0)},e.prototype.getRestSources=function(){return a(this.isPreview?this.isPreviewLoaded?this.sources:this.previewSources:this.sources).slice(1).reverse()},e.prototype.getFirstSource=function(){var e=a(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:i.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 [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad()"\n />\n <source\n *ngIf="getFirstSource()"\n [attr.lazyLoad]="firstSource.srcSet || \'\'"\n [srcset]="firstSource.srcSet || \'\'"\n (load)="onImageLoad()"\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()"\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 [attr.lazyLoad]="source.srcSet || \'\'"\n [srcset]="source.srcSet || \'\'"\n (load)="onImageLoad()"\n />\n <source\n *ngIf="firstSource"\n [attr.lazyLoad]="firstSource.srcSet || \'\'"\n [srcset]="firstSource.srcSet || \'\'"\n (load)="onImageLoad()"\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()"\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}]},e.propDecorators={imgElem:[{type:i.ViewChild,args:["imgElem"]}],pictureElem:[{type:i.ViewChild,args:["pictureElem"]}],src:[{type:i.Input}],"class":[{type:i.Input}],alt:[{type:i.Input}],operation:[{type:i.Input}],o:[{type:i.Input}],size:[{type:i.Input}],s:[{type:i.Input}],filters:[{type:i.Input}],f:[{type:i.Input}],ratio:[{type:i.Input}],offset:[{type:i.Input}],ngSwitch:[{type:i.Input}]},e}(),p=function(){function e(){}return e.decorators=[{type:i.NgModule,args:[{declarations:[d],imports:[t.CommonModule,s.LazyLoadImageModule],exports:[d],providers:[]}]}],e}();e.CIService=u,e.CIConfig=l,e.CIModule=p,e.ImgComponent=d,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ng-cloudimage-responsive.umd.min.js.map |
@@ -18,5 +18,8 @@ /** | ||
this._sanitizer = _sanitizer; | ||
this.class = ''; | ||
this.offset = 100; | ||
this.cloudimageUrl = ''; | ||
this.sources = []; | ||
this.firstSource = null; | ||
this.restSources = []; | ||
this.isLoaded = false; | ||
@@ -39,8 +42,5 @@ this.isProcessed = false; | ||
this.resizeSubscription$ = this.resizeObservable$.subscribe(() => { | ||
if (this.isAdaptive) { | ||
if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) { | ||
this.processImage(); | ||
} | ||
else if (this.windowInnerWidth < window.innerWidth) { | ||
this.processImage(); | ||
} | ||
this.windowInnerWidth = window.innerWidth; | ||
@@ -67,3 +67,3 @@ }); | ||
/** @type {?} */ | ||
const size = this.size || this.s || config.size || parentContainerWidth; | ||
let size = this.size || this.s || config.size || parentContainerWidth; | ||
/** @type {?} */ | ||
@@ -73,2 +73,3 @@ const filters = this.filters || this.f || config.filters; | ||
const isAdaptive = this.ciService.checkOnMedia(size); | ||
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size; | ||
/** @type {?} */ | ||
@@ -82,3 +83,3 @@ const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src); | ||
this.cloudimageUrl = isAdaptive ? | ||
this.ciService.generateUrl('width', parentContainerWidth, filters, imgSrc, config) : | ||
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) : | ||
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config); | ||
@@ -132,2 +133,19 @@ this.sources = isAdaptive ? | ||
*/ | ||
getRestSources() { | ||
/** @type {?} */ | ||
const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))]; | ||
return resultSources.slice(1).reverse(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getFirstSource() { | ||
/** @type {?} */ | ||
const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))]; | ||
this.firstSource = resultSources[0]; | ||
return resultSources[0]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getPositionStyle() { | ||
@@ -140,3 +158,5 @@ return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative'); | ||
getImgHeight() { | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
// todo check if we need 100% height | ||
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto'); | ||
} | ||
@@ -203,3 +223,3 @@ /** | ||
let result = 'transparent'; | ||
if (this.isRatio) { | ||
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) { | ||
result = config.placeholderBackground; | ||
@@ -219,3 +239,3 @@ } | ||
<picture | ||
class="{{class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')}}" | ||
[class]="class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')" | ||
style="display:block;width:100%;overflow:hidden;position:relative;" | ||
@@ -227,3 +247,3 @@ [style.paddingBottom]="getPicturePaddingBottom()" | ||
<source | ||
*ngFor="let source of (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))" | ||
*ngFor="let source of getRestSources()" | ||
[media]="source.mediaQuery || ''" | ||
@@ -234,2 +254,8 @@ [attr.lazyLoad]="source.srcSet || ''" | ||
/> | ||
<source | ||
*ngIf="getFirstSource()" | ||
[attr.lazyLoad]="firstSource.srcSet || ''" | ||
[srcset]="firstSource.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<img | ||
@@ -250,3 +276,3 @@ style="display:block;width:100%;opacity:1;top:0;left:0;" | ||
<picture | ||
class="{{class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')}}" | ||
[class]="class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')" | ||
style="display:block;width:100%;overflow:hidden;position:relative;" | ||
@@ -258,7 +284,14 @@ [style.paddingBottom]="getPicturePaddingBottom()" | ||
<source | ||
*ngFor="let source of (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))" | ||
*ngFor="let source of restSources" | ||
[media]="source.mediaQuery || ''" | ||
[attr.lazyLoad]="source.srcSet || ''" | ||
[srcset]="source.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<source | ||
*ngIf="firstSource" | ||
[attr.lazyLoad]="firstSource.srcSet || ''" | ||
[srcset]="firstSource.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<img | ||
@@ -339,2 +372,6 @@ style="display:block;width:100%;opacity:1;top:0;left:0;" | ||
/** @type {?} */ | ||
ImgComponent.prototype.firstSource; | ||
/** @type {?} */ | ||
ImgComponent.prototype.restSources; | ||
/** @type {?} */ | ||
ImgComponent.prototype.isLoaded; | ||
@@ -378,2 +415,2 @@ /** @type {?} */ | ||
} | ||
//# 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 {Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy} 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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\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(private ciService: CIService, private _sanitizer: DomSanitizer) {\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) {\n        this.processImage();\n      } else if (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 operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    const 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    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', 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', (parentContainerWidth / 5), 'q10.foil1', imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, 'q10.foil1', 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    setTimeout(() => {\n      this.isProcessed = true;\n    });\n  }\n\n  onImageLoad() {\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  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : '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) {\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 {Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy} 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            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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            [attr.lazyLoad]=\"source.srcSet || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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\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(private ciService: CIService, private _sanitizer: DomSanitizer) {\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 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', (parentContainerWidth / 5), 'q10.foil1', imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, 'q10.foil1', 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    setTimeout(() => {\n      this.isProcessed = true;\n    });\n  }\n\n  onImageLoad() {\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  }\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"]} |
@@ -6,5 +6,5 @@ /** | ||
import { Injectable } from '@angular/core'; | ||
import { CIConfig } from './config.service'; | ||
import { CIConfig } from './config.model'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "./config.service"; | ||
import * as i1 from "./config.model"; | ||
export class CIService { | ||
@@ -30,15 +30,14 @@ /** | ||
baseUrl, | ||
presets: presets ? this.getPresets(presets, 'presets') : | ||
presets: presets ? presets : | ||
{ | ||
xs: 575, | ||
// up to 576 PHONE | ||
sm: 767, | ||
// 577 - 768 PHABLET | ||
md: 991, | ||
// 769 - 992 TABLET | ||
lg: 1199, | ||
// 993 - 1200 SMALL_LAPTOP_SCREEN | ||
xl: 3000 // from 1200 USUALSCREEN | ||
xs: '(max-width: 575px)', | ||
// to 575 PHONE | ||
sm: '(min-width: 576px)', | ||
// 576 - 767 PHABLET | ||
md: '(min-width: 768px)', | ||
// 768 - 991 TABLET | ||
lg: '(min-width: 992px)', | ||
// 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
}, | ||
order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'], | ||
queryString, | ||
@@ -49,26 +48,2 @@ innerWidth: window.innerWidth, | ||
/** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
getPresets(value = '', type) { | ||
/** @type {?} */ | ||
const splittedValues = value.split('|'); | ||
/** @type {?} */ | ||
const result = { presets: {}, order: [] }; | ||
for (let i = 0; i < splittedValues.length; i++) { | ||
/** @type {?} */ | ||
const splittedParam = splittedValues[i] && splittedValues[i].split(':'); | ||
/** @type {?} */ | ||
const prop = splittedParam[0] && splittedParam[0].trim(); | ||
/** @type {?} */ | ||
const val = splittedParam[1] && splittedParam[1].trim(); | ||
if (prop && val) { | ||
result.presets[prop] = val; | ||
result.order.unshift(prop); | ||
} | ||
} | ||
return result[type]; | ||
} | ||
/** | ||
* @param {?} img | ||
@@ -111,3 +86,7 @@ * @param {?} config | ||
} while (parentNode && !width); | ||
return width; | ||
/** @type {?} */ | ||
const letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10); | ||
/** @type {?} */ | ||
const rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10); | ||
return width + (width ? (-letPadding - rightPadding) : 0); | ||
} | ||
@@ -119,26 +98,9 @@ /** | ||
getSizeLimit(currentSize) { | ||
return currentSize <= 25 ? '25' : | ||
currentSize <= 50 ? '50' : | ||
currentSize <= 100 ? '100' | ||
: currentSize <= 200 ? '200' | ||
: currentSize <= 300 ? '300' | ||
: currentSize <= 400 ? '400' | ||
: currentSize <= 500 ? '500' | ||
: currentSize <= 600 ? '600' | ||
: currentSize <= 700 ? '700' | ||
: currentSize <= 800 ? '800' | ||
: currentSize <= 900 ? '900' | ||
: currentSize <= 1000 ? '1000' | ||
: currentSize <= 1100 ? '1100' | ||
: currentSize <= 1200 ? '1200' | ||
: currentSize <= 1300 ? '1300' | ||
: currentSize <= 1400 ? '1400' | ||
: currentSize <= 1500 ? '1500' | ||
: currentSize <= 1600 ? '1600' | ||
: currentSize <= 1700 ? '1700' | ||
: currentSize <= 1800 ? '1800' | ||
: currentSize <= 1900 ? '1900' | ||
: currentSize <= 2400 ? '2400' | ||
: currentSize <= 2800 ? '2800' | ||
: '3600'; | ||
if (currentSize <= 25) { | ||
return '25'; | ||
} | ||
if (currentSize <= 50) { | ||
return '50'; | ||
} | ||
return (Math.ceil(currentSize / 100) * 100).toString(); | ||
} | ||
@@ -150,3 +112,10 @@ /** | ||
checkOnMedia(size) { | ||
return size && typeof size === 'object'; | ||
try { | ||
/** @type {?} */ | ||
const array = size.split(','); | ||
return array.length > 1; | ||
} | ||
catch (e) { | ||
return false; | ||
} | ||
} | ||
@@ -219,31 +188,17 @@ /** | ||
if (isAdaptive) { | ||
/** @type {?} */ | ||
const orderFiltered = []; | ||
for (let i = 0; i < config.order.length; i++) { | ||
/** @type {?} */ | ||
const nextSize = size[config.order[i]]; | ||
if (nextSize) { | ||
orderFiltered.unshift(config.order[i]); | ||
} | ||
} | ||
for (let i = 0; i < orderFiltered.length; i++) { | ||
/** @type {?} */ | ||
const isLast = !(i < orderFiltered.length - 1); | ||
/** @type {?} */ | ||
const nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i]; | ||
/** @type {?} */ | ||
let nextSize = size[orderFiltered[i]]; | ||
size.forEach(({ size: nextSize, media: mediaQuery }) => { | ||
if (isPreview) { | ||
nextSize = nextSize.split('x').map(item => item / 5).join('x'); | ||
nextSize = nextSize.split('x').map(sizeNext => sizeNext / 5).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
/** @type {?} */ | ||
const srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config); | ||
/** @type {?} */ | ||
const mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)'; | ||
sources.push({ mediaQuery, srcSet }); | ||
} | ||
sources.push({ mediaQuery, srcSet: this.generateSrcset(operation, nextSize, filters, imgSrc, config) }); | ||
}); | ||
} | ||
else { | ||
if (isPreview) { | ||
size = size.split('x').map(sizeNext => sizeNext / 5).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
sources.push({ | ||
srcSet: this.generateSrcset(operation, size.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, config) | ||
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config) | ||
}); | ||
@@ -254,2 +209,21 @@ } | ||
/** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
getAdaptiveSize(size, config) { | ||
/** @type {?} */ | ||
const arrayOfSizes = size.split(','); | ||
/** @type {?} */ | ||
const sizes = []; | ||
arrayOfSizes.forEach(string => { | ||
/** @type {?} */ | ||
const groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups; | ||
/** @type {?} */ | ||
const media = groups.media ? groups.media : config.presets[groups.variable]; | ||
sizes.push({ media, size: groups.size }); | ||
}); | ||
return sizes; | ||
} | ||
/** | ||
* @param {?} operation | ||
@@ -263,6 +237,3 @@ * @param {?} size | ||
generateSrcset(operation, size, filters, imgSrc, config) { | ||
/** @type {?} */ | ||
const imgWidth = size.toString().split('x')[0]; | ||
/** @type {?} */ | ||
const imgHeight = size.toString().split('x')[1]; | ||
const [imgWidth, imgHeight] = size.toString().split('x'); | ||
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config); | ||
@@ -304,29 +275,9 @@ } | ||
/** @type {?} */ | ||
const breakPoint = this.getBreakPoint(config); | ||
const breakPointSource = this.getBreakPoint(size); | ||
/** @type {?} */ | ||
let orderIndex = config.order.indexOf(breakPoint); | ||
/** @type {?} */ | ||
let breakPointSize = null; | ||
do { | ||
/** @type {?} */ | ||
const nextBreakpoint = config.order[orderIndex]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndex--; | ||
} while (!breakPointSize && orderIndex >= 0); | ||
if (!breakPointSize) { | ||
/** @type {?} */ | ||
let orderIndexStepTwo = config.order.indexOf(breakPoint); | ||
do { | ||
/** @type {?} */ | ||
const nextBreakpoint = config.order[orderIndexStepTwo]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndexStepTwo++; | ||
} while (!breakPointSize && orderIndexStepTwo <= config.order.length); | ||
} | ||
width = breakPointSize.toString().split('x')[0]; | ||
height = breakPointSize.toString().split('x')[1]; | ||
const breakPointSize = breakPointSource ? breakPointSource.size : size[0].size; | ||
[width, height] = breakPointSize.toString().split('x'); | ||
} | ||
else { | ||
width = size.toString().split('x')[0]; | ||
height = size.toString().split('x')[1]; | ||
[width, height] = size.toString().split('x'); | ||
} | ||
@@ -339,12 +290,7 @@ if (width && height) { | ||
/** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
getBreakPoint(config) { | ||
const { presets, order } = config; | ||
/** @type {?} */ | ||
const innerWidth = window.innerWidth; | ||
/** @type {?} */ | ||
const prevBreakPointLimit = order.findIndex(item => presets[item] < innerWidth); | ||
return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1]; | ||
getBreakPoint(size) { | ||
return [...size].reverse().find(item => matchMedia(item.media).matches); | ||
} | ||
@@ -366,2 +312,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib.service.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/lib.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {CIConfig} from './config.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CIService {\n  public config: any = {};\n\n  constructor(ciConfig: CIConfig) {\n    const {\n      token = '',\n      container = 'cloudimg.io',\n      ultraFast = false,\n      lazyLoading = true,\n      imgLoadingAnimation = true,\n      lazyLoadOffset = 100,\n      width = '400',\n      height = '300',\n      operation = 'width',\n      filters = 'n',\n      placeholderBackground = '#f4f4f4',\n      baseUrl = '/',\n      presets,\n      queryString = ''\n    } = ciConfig;\n\n    this.config = {\n      token,\n      container,\n      ultraFast,\n      lazyLoading,\n      imgLoadingAnimation,\n      lazyLoadOffset,\n      width,\n      height,\n      operation,\n      filters,\n      placeholderBackground,\n      baseUrl,\n      presets: presets ? this.getPresets(presets, 'presets') :\n        {\n          xs: 575,  // up to 576    PHONE\n          sm: 767,  // 577 - 768    PHABLET\n          md: 991,  // 769 - 992    TABLET\n          lg: 1199, // 993 - 1200   SMALL_LAPTOP_SCREEN\n          xl: 3000  // from 1200    USUALSCREEN\n        },\n      order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'],\n      queryString,\n      innerWidth: window.innerWidth,\n      // isChrome: /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor)\n    };\n  }\n\n  getPresets(value = '', type) {\n    const splittedValues = value.split('|');\n    const result = {presets: {}, order: []};\n\n    for (let i = 0; i < splittedValues.length; i++) {\n      const splittedParam = splittedValues[i] && splittedValues[i].split(':');\n      const prop = splittedParam[0] && splittedParam[0].trim();\n      const val = splittedParam[1] && splittedParam[1].trim();\n\n      if (prop && val) {\n        result.presets[prop] = val;\n        result.order.unshift(prop);\n      }\n    }\n\n    return result[type];\n  }\n\n  public getParentWidth(img, config) {\n    if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {\n      return config.width;\n    }\n\n    const parentContainer = this.getParentContainerWithWidth(img);\n    const currentWidth = parseInt('' + parentContainer, 10);\n    const computedWidth = Number(window.getComputedStyle(img).width);\n\n    if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {\n      return this.getSizeLimit(computedWidth);\n    } else {\n      if (!currentWidth) {\n        return img.width || config.width;\n      }\n\n      return this.getSizeLimit(currentWidth);\n    }\n  }\n\n  getParentContainerWithWidth(img) {\n    let parentNode = null;\n    let width = 0;\n\n    do {\n      parentNode = (parentNode && parentNode.parentNode) || img.parentNode;\n      width = parentNode.getBoundingClientRect().width;\n    } while (parentNode && !width);\n\n    return width;\n  }\n\n  getSizeLimit(currentSize) {\n    return currentSize <= 25 ? '25' :\n      currentSize <= 50 ? '50' :\n        currentSize <= 100 ? '100'\n          : currentSize <= 200 ? '200'\n          : currentSize <= 300 ? '300'\n            : currentSize <= 400 ? '400'\n              : currentSize <= 500 ? '500'\n                : currentSize <= 600 ? '600'\n                  : currentSize <= 700 ? '700'\n                    : currentSize <= 800 ? '800'\n                      : currentSize <= 900 ? '900'\n                        : currentSize <= 1000 ? '1000'\n                          : currentSize <= 1100 ? '1100'\n                            : currentSize <= 1200 ? '1200'\n                              : currentSize <= 1300 ? '1300'\n                                : currentSize <= 1400 ? '1400'\n                                  : currentSize <= 1500 ? '1500'\n                                    : currentSize <= 1600 ? '1600'\n                                      : currentSize <= 1700 ? '1700'\n                                        : currentSize <= 1800 ? '1800'\n                                          : currentSize <= 1900 ? '1900'\n                                            : currentSize <= 2400 ? '2400'\n                                              : currentSize <= 2800 ? '2800'\n                                                : '3600';\n  }\n\n  public checkOnMedia(size) {\n    return size && typeof size === 'object';\n  }\n\n  public checkIfRelativeUrlPath(src) {\n    if (src.indexOf('//') === 0) {\n      src = window.location.protocol + src;\n    }\n    return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);\n  }\n\n  public getImgSrc(src, isRelativeUrlPath = false, baseUrl = '') {\n    if (isRelativeUrlPath) {\n      return baseUrl + src;\n    }\n\n    return src;\n  }\n\n  public getSizeAccordingToPixelRatio(size) {\n    const splittedSizes = size.toString().split('x');\n    const result = [];\n\n    [].forEach.call(splittedSizes, item => {\n      result.push(item * Math.round(window.devicePixelRatio || 1));\n    });\n\n    return result.join('x');\n  }\n\n  public generateUrl(operation, size, filters, imgSrc, config) {\n    const {ultraFast, token, container, queryString} = config;\n    const isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';\n    const cloudUrl = isUltraFast + token + '.' + container + '/';\n\n    return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;\n  }\n\n  public generateSources(operation, size, filters, imgSrc, isAdaptive, config, isPreview) {\n    const sources = [];\n\n    if (isAdaptive) {\n      const orderFiltered = [];\n\n      for (let i = 0; i < config.order.length; i++) {\n        const nextSize = size[config.order[i]];\n\n        if (nextSize) {\n          orderFiltered.unshift(config.order[i]);\n        }\n      }\n\n      for (let i = 0; i < orderFiltered.length; i++) {\n        const isLast = !(i < orderFiltered.length - 1);\n        const nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i];\n        let nextSize = size[orderFiltered[i]];\n\n        if (isPreview) {\n          nextSize = nextSize.split('x').map(item => item / 5).join('x');\n        }\n\n        const srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config);\n        const mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)';\n\n        sources.push({mediaQuery, srcSet});\n      }\n    } else {\n      sources.push({\n        srcSet: this.generateSrcset(operation, size.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, config)\n      });\n    }\n\n    return sources;\n  }\n\n  generateSrcset(operation, size, filters, imgSrc, config) {\n    const imgWidth = size.toString().split('x')[0];\n    const imgHeight = size.toString().split('x')[1];\n\n    return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);\n  }\n\n  generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {\n    let imgSize = '' + Math.trunc(imgWidth * factor);\n\n    if (imgHeight) {\n      imgSize += 'x' + Math.trunc(imgHeight * factor);\n    }\n\n    return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)\n      .replace('http://scaleflex.ultrafast.io/', '')\n      .replace('https://scaleflex.ultrafast.io/', '')\n      .replace('//scaleflex.ultrafast.io/', '')\n      .replace('///', '/');\n  }\n\n  public getRatioBySize(size, config) {\n    let width, height;\n\n    if (typeof size === 'object') {\n      const breakPoint = this.getBreakPoint(config);\n      let orderIndex = config.order.indexOf(breakPoint);\n      let breakPointSize = null;\n\n      do {\n        const nextBreakpoint = config.order[orderIndex];\n        breakPointSize = size[nextBreakpoint];\n        orderIndex--;\n      } while (!breakPointSize && orderIndex >= 0);\n\n      if (!breakPointSize) {\n        let orderIndexStepTwo = config.order.indexOf(breakPoint);\n\n        do {\n          const nextBreakpoint = config.order[orderIndexStepTwo];\n          breakPointSize = size[nextBreakpoint];\n          orderIndexStepTwo++;\n        } while (!breakPointSize && orderIndexStepTwo <= config.order.length);\n      }\n\n      width = breakPointSize.toString().split('x')[0];\n      height = breakPointSize.toString().split('x')[1];\n    } else {\n      width = size.toString().split('x')[0];\n      height = size.toString().split('x')[1];\n    }\n\n    if (width && height) {\n      return width / height;\n    }\n\n    return null;\n  }\n\n  getBreakPoint(config) {\n    const {presets, order} = config;\n    const innerWidth = window.innerWidth;\n    const prevBreakPointLimit = order.findIndex(item => presets[item] < innerWidth);\n\n    return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1];\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib.service.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/lib.service.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,eAAe,CAAC;AACzC,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;;;AAKxC,MAAM,OAAO,SAAS;;;;IAGpB,YAAY,QAAkB;QAF9B,WAAM,GAAQ,EAAE,CAAC;cAGT,EACJ,KAAK,GAAG,EAAE,EACV,SAAS,GAAG,aAAa,EACzB,SAAS,GAAG,KAAK,EACjB,WAAW,GAAG,IAAI,EAClB,mBAAmB,GAAG,IAAI,EAC1B,cAAc,GAAG,GAAG,EACpB,KAAK,GAAG,KAAK,EACb,MAAM,GAAG,KAAK,EACd,SAAS,GAAG,OAAO,EACnB,OAAO,GAAG,GAAG,EACb,qBAAqB,GAAG,SAAS,EACjC,OAAO,GAAG,GAAG,EACb,OAAO,EACP,WAAW,GAAG,EAAE,EACjB,GAAG,QAAQ;QAEZ,IAAI,CAAC,MAAM,GAAG;YACZ,KAAK;YACL,SAAS;YACT,SAAS;YACT,WAAW;YACX,mBAAmB;YACnB,cAAc;YACd,KAAK;YACL,MAAM;YACN,SAAS;YACT,OAAO;YACP,qBAAqB;YACrB,OAAO;YACP,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;gBAC1B;oBACE,EAAE,EAAE,oBAAoB;;oBACxB,EAAE,EAAE,oBAAoB;;oBACxB,EAAE,EAAE,oBAAoB;;oBACxB,EAAE,EAAE,oBAAoB;;oBACxB,EAAE,EAAE,qBAAqB,CAAE,2BAA2B;iBACvD;YACH,WAAW;YACX,UAAU,EAAE,MAAM,CAAC,UAAU;SAE9B,CAAC;IACJ,CAAC;;;;;;IAED,cAAc,CAAC,GAAG,EAAE,MAAM;QACxB,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,aAAa,IAAI,GAAG,CAAC,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,EAAE;YACjG,OAAO,MAAM,CAAC,KAAK,CAAC;SACrB;;cAEK,eAAe,GAAG,IAAI,CAAC,2BAA2B,CAAC,GAAG,CAAC;;cACvD,YAAY,GAAG,QAAQ,CAAC,EAAE,GAAG,eAAe,EAAE,EAAE,CAAC;;cACjD,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;QAEhE,IAAI,CAAC,aAAa,IAAI,CAAC,aAAa,GAAG,YAAY,IAAI,aAAa,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;YAC5F,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;SACzC;aAAM;YACL,IAAI,CAAC,YAAY,EAAE;gBACjB,OAAO,GAAG,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC;aAClC;YAED,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;SACxC;IACH,CAAC;;;;;IAED,2BAA2B,CAAC,GAAG;;YACzB,UAAU,GAAG,IAAI;;YACjB,KAAK,GAAG,CAAC;QAEb,GAAG;YACD,UAAU,GAAG,CAAC,UAAU,IAAI,UAAU,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC;YACrE,KAAK,GAAG,UAAU,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;SAClD,QAAQ,UAAU,IAAI,CAAC,KAAK,EAAE;;cAEzB,UAAU,GAAG,KAAK,IAAI,UAAU,IAAI,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;;cACjG,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC;QAEnF,OAAO,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC;;;;;IAED,YAAY,CAAC,WAAW;QACtB,IAAI,WAAW,IAAI,EAAE,EAAE;YACrB,OAAO,IAAI,CAAC;SACb;QACD,IAAI,WAAW,IAAI,EAAE,EAAE;YACrB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;IACzD,CAAC;;;;;IAED,YAAY,CAAC,IAAI;QACf,IAAI;;kBACI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;YAE7B,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;SACzB;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;IACH,CAAC;;;;;IAED,sBAAsB,CAAC,GAAG;QACxB,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,GAAG,GAAG,CAAC;SACtC;QAED,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IACpG,CAAC;;;;;;;IAED,SAAS,CAAC,GAAG,EAAE,iBAAiB,GAAG,KAAK,EAAE,OAAO,GAAG,EAAE;QACpD,IAAI,iBAAiB,EAAE;YACrB,OAAO,OAAO,GAAG,GAAG,CAAC;SACtB;QAED,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAED,4BAA4B,CAAC,IAAI;;cACzB,aAAa,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC;;cAC1C,MAAM,GAAG,EAAE;QAEjB,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,EAAE;YACpC,MAAM,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,gBAAgB,IAAI,CAAC,CAAC,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;;;;;;;;;IAED,WAAW,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM;cAC5C,EAAC,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,WAAW,EAAC,GAAG,MAAM;;cACnD,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,UAAU;;cACxE,QAAQ,GAAG,WAAW,GAAG,KAAK,GAAG,GAAG,GAAG,SAAS,GAAG,GAAG;QAE5D,OAAO,QAAQ,GAAG,SAAS,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,OAAO,GAAG,GAAG,GAAG,MAAM,GAAG,WAAW,CAAC;IACxF,CAAC;;;;;;;;;;;IAED,eAAe,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS;;cACvE,OAAO,GAAG,EAAE;QAElB,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAC,EAAE,EAAE;gBACpD,IAAI,SAAS,EAAE;oBACb,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACvE,OAAO,GAAG,WAAW,CAAC;iBACvB;gBAED,OAAO,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;YAC1G,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,SAAS,EAAE;gBACb,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC/D,OAAO,GAAG,WAAW,CAAC;aACvB;YAED,OAAO,CAAC,IAAI,CAAC;gBACX,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC;aACtE,CAAC,CAAC;SACJ;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;;;;;;IAED,eAAe,CAAC,IAAI,EAAE,MAAM;;cACpB,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;;cAC9B,KAAK,GAAG,EAAE;QAEhB,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;;kBACtB,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,wEAAwE,CAAC,CAAC,MAAM;;kBACtG,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC;YAE3E,KAAK,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;;;;;;;;;IAED,cAAc,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM;cAC/C,CAAC,QAAQ,EAAE,SAAS,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC;QAExD,OAAO,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;IACzF,CAAC;;;;;;;;;;;IAED,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM;;YACxE,OAAO,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC;QAEhD,IAAI,SAAS,EAAE;YACb,OAAO,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC;SACjD;QAED,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC;aACpG,OAAO,CAAC,gCAAgC,EAAE,EAAE,CAAC;aAC7C,OAAO,CAAC,iCAAiC,EAAE,EAAE,CAAC;aAC9C,OAAO,CAAC,2BAA2B,EAAE,EAAE,CAAC;aACxC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;;;;;;IAED,cAAc,CAAC,IAAI,EAAE,MAAM;;YACrB,KAAK;;YAAE,MAAM;QAEjB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;;kBACtB,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;;kBAC3C,cAAc,GAAG,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;YAE9E,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SACxD;aAAM;YACL,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SAC9C;QAED,IAAI,KAAK,IAAI,MAAM,EAAE;YACnB,OAAO,KAAK,GAAG,MAAM,CAAC;SACvB;QAED,OAAO,IAAI,CAAC;IACd,CAAC;;;;;IAED,aAAa,CAAC,IAAI;QAChB,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;IAC1E,CAAC;;;YA9NF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;;YAJO,QAAQ;;;;;IAMd,2BAAiB","sourcesContent":["import {Injectable} from '@angular/core';\nimport {CIConfig} from './config.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CIService {\n  config: any = {};\n\n  constructor(ciConfig: CIConfig) {\n    const {\n      token = '',\n      container = 'cloudimg.io',\n      ultraFast = false,\n      lazyLoading = true,\n      imgLoadingAnimation = true,\n      lazyLoadOffset = 100,\n      width = '400',\n      height = '300',\n      operation = 'width',\n      filters = 'n',\n      placeholderBackground = '#f4f4f4',\n      baseUrl = '/',\n      presets,\n      queryString = ''\n    } = ciConfig;\n\n    this.config = {\n      token,\n      container,\n      ultraFast,\n      lazyLoading,\n      imgLoadingAnimation,\n      lazyLoadOffset,\n      width,\n      height,\n      operation,\n      filters,\n      placeholderBackground,\n      baseUrl,\n      presets: presets ? presets :\n        {\n          xs: '(max-width: 575px)',  // to 575       PHONE\n          sm: '(min-width: 576px)',  // 576 - 767    PHABLET\n          md: '(min-width: 768px)',  // 768 - 991    TABLET\n          lg: '(min-width: 992px)',  // 992 - 1199   SMALL_LAPTOP_SCREEN\n          xl: '(min-width: 1200px)'  // from 1200    USUALSCREEN\n        },\n      queryString,\n      innerWidth: window.innerWidth,\n      // isChrome: /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor)\n    };\n  }\n\n  getParentWidth(img, config) {\n    if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {\n      return config.width;\n    }\n\n    const parentContainer = this.getParentContainerWithWidth(img);\n    const currentWidth = parseInt('' + parentContainer, 10);\n    const computedWidth = Number(window.getComputedStyle(img).width);\n\n    if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {\n      return this.getSizeLimit(computedWidth);\n    } else {\n      if (!currentWidth) {\n        return img.width || config.width;\n      }\n\n      return this.getSizeLimit(currentWidth);\n    }\n  }\n\n  getParentContainerWithWidth(img) {\n    let parentNode = null;\n    let width = 0;\n\n    do {\n      parentNode = (parentNode && parentNode.parentNode) || img.parentNode;\n      width = parentNode.getBoundingClientRect().width;\n    } while (parentNode && !width);\n\n    const letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10);\n    const rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10);\n\n    return width + (width ? (-letPadding - rightPadding) : 0);\n  }\n\n  getSizeLimit(currentSize) {\n    if (currentSize <= 25) {\n      return '25';\n    }\n    if (currentSize <= 50) {\n      return '50';\n    }\n\n    return (Math.ceil(currentSize / 100) * 100).toString();\n  }\n\n  checkOnMedia(size) {\n    try {\n      const array = size.split(',');\n\n      return array.length > 1;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  checkIfRelativeUrlPath(src) {\n    if (src.indexOf('//') === 0) {\n      src = window.location.protocol + src;\n    }\n\n    return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);\n  }\n\n  getImgSrc(src, isRelativeUrlPath = false, baseUrl = '') {\n    if (isRelativeUrlPath) {\n      return baseUrl + src;\n    }\n\n    return src;\n  }\n\n  getSizeAccordingToPixelRatio(size) {\n    const splittedSizes = size.toString().split('x');\n    const result = [];\n\n    [].forEach.call(splittedSizes, item => {\n      result.push(item * Math.round(window.devicePixelRatio || 1));\n    });\n\n    return result.join('x');\n  }\n\n  generateUrl(operation, size, filters, imgSrc, config) {\n    const {ultraFast, token, container, queryString} = config;\n    const isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';\n    const cloudUrl = isUltraFast + token + '.' + container + '/';\n\n    return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;\n  }\n\n  generateSources(operation, size, filters, imgSrc, isAdaptive, config, isPreview) {\n    const sources = [];\n\n    if (isAdaptive) {\n      size.forEach(({ size: nextSize, media: mediaQuery}) => {\n        if (isPreview) {\n          nextSize = nextSize.split('x').map(sizeNext => sizeNext / 5).join('x');\n          filters = 'q10.foil1';\n        }\n\n        sources.push({ mediaQuery, srcSet: this.generateSrcset(operation, nextSize, filters, imgSrc, config) });\n      });\n    } else {\n      if (isPreview) {\n        size = size.split('x').map(sizeNext => sizeNext / 5).join('x');\n        filters = 'q10.foil1';\n      }\n\n      sources.push({\n        srcSet: this.generateSrcset(operation, size, filters, imgSrc, config)\n      });\n    }\n    return sources;\n  }\n\n  getAdaptiveSize(size, config) {\n    const arrayOfSizes = size.split(',');\n    const sizes = [];\n\n    arrayOfSizes.forEach(string => {\n      const groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\\([\\S\\s]*\\)))\\s*(?<size>[0-9xp]*)/).groups;\n      const media = groups.media ? groups.media : config.presets[groups.variable];\n\n      sizes.push({ media, size: groups.size });\n    });\n\n    return sizes;\n  }\n\n  generateSrcset(operation, size, filters, imgSrc, config) {\n    const [imgWidth, imgHeight] = size.toString().split('x');\n\n    return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);\n  }\n\n  generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {\n    let imgSize = '' + Math.trunc(imgWidth * factor);\n\n    if (imgHeight) {\n      imgSize += 'x' + Math.trunc(imgHeight * factor);\n    }\n\n    return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)\n      .replace('http://scaleflex.ultrafast.io/', '')\n      .replace('https://scaleflex.ultrafast.io/', '')\n      .replace('//scaleflex.ultrafast.io/', '')\n      .replace('///', '/');\n  }\n\n  getRatioBySize(size, config) {\n    let width, height;\n\n    if (typeof size === 'object') {\n      const breakPointSource = this.getBreakPoint(size);\n      const breakPointSize = breakPointSource ? breakPointSource.size : size[0].size;\n\n      [width, height] = breakPointSize.toString().split('x');\n    } else {\n      [width, height] = size.toString().split('x');\n    }\n\n    if (width && height) {\n      return width / height;\n    }\n\n    return null;\n  }\n\n  getBreakPoint(size) {\n    return [...size].reverse().find(item => matchMedia(item.media).matches);\n  }\n}\n"]} |
@@ -9,5 +9,5 @@ /** | ||
export { CIService } from './lib/lib.service'; | ||
export { CIConfig } from './lib/config.service'; | ||
export { CIConfig } from './lib/config.model'; | ||
export { CIModule } from './lib/lib.module'; | ||
export { ImgComponent } from './lib/img/img.component'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nLWNsb3VkaW1hZ2UtcmVzcG9uc2l2ZS8iLCJzb3VyY2VzIjpbInB1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBLDBCQUFjLG1CQUFtQixDQUFDO0FBQ2xDLHlCQUFjLHNCQUFzQixDQUFDO0FBQ3JDLHlCQUFjLGtCQUFrQixDQUFDO0FBQ2pDLDZCQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsaWJcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maWcuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltZy9pbWcuY29tcG9uZW50JztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nLWNsb3VkaW1hZ2UtcmVzcG9uc2l2ZS8iLCJzb3VyY2VzIjpbInB1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBLDBCQUFjLG1CQUFtQixDQUFDO0FBQ2xDLHlCQUFjLG9CQUFvQixDQUFDO0FBQ25DLHlCQUFjLGtCQUFrQixDQUFDO0FBQ2pDLDZCQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsaWJcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWcvaW1nLmNvbXBvbmVudCc7XG4iXX0= |
@@ -15,5 +15,8 @@ /** | ||
this._sanitizer = _sanitizer; | ||
this.class = ''; | ||
this.offset = 100; | ||
this.cloudimageUrl = ''; | ||
this.sources = []; | ||
this.firstSource = null; | ||
this.restSources = []; | ||
this.isLoaded = false; | ||
@@ -43,8 +46,5 @@ this.isProcessed = false; | ||
this.resizeSubscription$ = this.resizeObservable$.subscribe(function () { | ||
if (_this.isAdaptive) { | ||
if (_this.isAdaptive || _this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
else if (_this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
_this.windowInnerWidth = window.innerWidth; | ||
@@ -83,2 +83,3 @@ }); | ||
var isAdaptive = this.ciService.checkOnMedia(size); | ||
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size; | ||
/** @type {?} */ | ||
@@ -92,3 +93,3 @@ var isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src); | ||
this.cloudimageUrl = isAdaptive ? | ||
this.ciService.generateUrl('width', parentContainerWidth, filters, imgSrc, config) : | ||
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) : | ||
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config); | ||
@@ -145,2 +146,25 @@ this.sources = isAdaptive ? | ||
*/ | ||
ImgComponent.prototype.getRestSources = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = tslib_1.__spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
return resultSources.slice(1).reverse(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getFirstSource = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = tslib_1.__spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
this.firstSource = resultSources[0]; | ||
return resultSources[0]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getPositionStyle = /** | ||
@@ -159,3 +183,5 @@ * @return {?} | ||
function () { | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
// todo check if we need 100% height | ||
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto'); | ||
}; | ||
@@ -237,3 +263,3 @@ /** | ||
var result = 'transparent'; | ||
if (this.isRatio) { | ||
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) { | ||
result = config.placeholderBackground; | ||
@@ -246,3 +272,3 @@ } | ||
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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\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 [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"firstSource\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n " | ||
}] } | ||
@@ -312,2 +338,6 @@ ]; | ||
/** @type {?} */ | ||
ImgComponent.prototype.firstSource; | ||
/** @type {?} */ | ||
ImgComponent.prototype.restSources; | ||
/** @type {?} */ | ||
ImgComponent.prototype.isLoaded; | ||
@@ -351,2 +381,2 @@ /** @type {?} */ | ||
} | ||
//# 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 {Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy} 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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n            [media]=\"source.mediaQuery || ''\"\n            [attr.lazyLoad]=\"source.srcSet || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n            [media]=\"source.mediaQuery || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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\n  resizeObservable$: Observable<Event>;\n  resizeSubscription$: Subscription;\n  cloudimageUrl = '';\n  sources = [];\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(private ciService: CIService, private _sanitizer: DomSanitizer) {\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) {\n        this.processImage();\n      } else if (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 operation = this.operation || this.o || config.operation;\n    const parentContainerWidth = this.ciService.getParentWidth(imgNode, config);\n    const 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    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', 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', (parentContainerWidth / 5), 'q10.foil1', imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, 'q10.foil1', 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    setTimeout(() => {\n      this.isProcessed = true;\n    });\n  }\n\n  onImageLoad() {\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  }\n\n  getPositionStyle() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative');\n  }\n\n  getImgHeight() {\n    return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : '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) {\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 {Component, OnInit, AfterViewInit, Input, ViewChild, ElementRef, OnDestroy} 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            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\n          />\n          <source\n            *ngIf=\"getFirstSource()\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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            [attr.lazyLoad]=\"source.srcSet || ''\"\n            [srcset]=\"source.srcSet || ''\"\n            (load)=\"onImageLoad()\"\n          />\n          <source\n            *ngIf=\"firstSource\"\n            [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n            [srcset]=\"firstSource.srcSet || ''\"\n            (load)=\"onImageLoad()\"\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()\"\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\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(private ciService: CIService, private _sanitizer: DomSanitizer) {\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 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', (parentContainerWidth / 5), 'q10.foil1', imgSrc, previewConfig) :\n        this.ciService.generateUrl(operation, resultSize.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, previewConfig);\n      previewSources = isAdaptive ?\n        this.ciService.generateSources(operation, resultSize, 'q10.foil1', 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    setTimeout(() => {\n      this.isProcessed = true;\n    });\n  }\n\n  onImageLoad() {\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  }\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"]} |
@@ -5,6 +5,7 @@ /** | ||
*/ | ||
import * as tslib_1 from "tslib"; | ||
import { Injectable } from '@angular/core'; | ||
import { CIConfig } from './config.service'; | ||
import { CIConfig } from './config.model'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "./config.service"; | ||
import * as i1 from "./config.model"; | ||
var CIService = /** @class */ (function () { | ||
@@ -27,15 +28,14 @@ function CIService(ciConfig) { | ||
baseUrl: baseUrl, | ||
presets: presets ? this.getPresets(presets, 'presets') : | ||
presets: presets ? presets : | ||
{ | ||
xs: 575, | ||
// up to 576 PHONE | ||
sm: 767, | ||
// 577 - 768 PHABLET | ||
md: 991, | ||
// 769 - 992 TABLET | ||
lg: 1199, | ||
// 993 - 1200 SMALL_LAPTOP_SCREEN | ||
xl: 3000 // from 1200 USUALSCREEN | ||
xs: '(max-width: 575px)', | ||
// to 575 PHONE | ||
sm: '(min-width: 576px)', | ||
// 576 - 767 PHABLET | ||
md: '(min-width: 768px)', | ||
// 768 - 991 TABLET | ||
lg: '(min-width: 992px)', | ||
// 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
}, | ||
order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'], | ||
queryString: queryString, | ||
@@ -46,32 +46,2 @@ innerWidth: window.innerWidth, | ||
/** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getPresets = /** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
function (value, type) { | ||
if (value === void 0) { value = ''; } | ||
/** @type {?} */ | ||
var splittedValues = value.split('|'); | ||
/** @type {?} */ | ||
var result = { presets: {}, order: [] }; | ||
for (var i = 0; i < splittedValues.length; i++) { | ||
/** @type {?} */ | ||
var splittedParam = splittedValues[i] && splittedValues[i].split(':'); | ||
/** @type {?} */ | ||
var prop = splittedParam[0] && splittedParam[0].trim(); | ||
/** @type {?} */ | ||
var val = splittedParam[1] && splittedParam[1].trim(); | ||
if (prop && val) { | ||
result.presets[prop] = val; | ||
result.order.unshift(prop); | ||
} | ||
} | ||
return result[type]; | ||
}; | ||
/** | ||
* @param {?} img | ||
@@ -123,3 +93,7 @@ * @param {?} config | ||
} while (parentNode && !width); | ||
return 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); | ||
}; | ||
@@ -135,26 +109,9 @@ /** | ||
function (currentSize) { | ||
return currentSize <= 25 ? '25' : | ||
currentSize <= 50 ? '50' : | ||
currentSize <= 100 ? '100' | ||
: currentSize <= 200 ? '200' | ||
: currentSize <= 300 ? '300' | ||
: currentSize <= 400 ? '400' | ||
: currentSize <= 500 ? '500' | ||
: currentSize <= 600 ? '600' | ||
: currentSize <= 700 ? '700' | ||
: currentSize <= 800 ? '800' | ||
: currentSize <= 900 ? '900' | ||
: currentSize <= 1000 ? '1000' | ||
: currentSize <= 1100 ? '1100' | ||
: currentSize <= 1200 ? '1200' | ||
: currentSize <= 1300 ? '1300' | ||
: currentSize <= 1400 ? '1400' | ||
: currentSize <= 1500 ? '1500' | ||
: currentSize <= 1600 ? '1600' | ||
: currentSize <= 1700 ? '1700' | ||
: currentSize <= 1800 ? '1800' | ||
: currentSize <= 1900 ? '1900' | ||
: currentSize <= 2400 ? '2400' | ||
: currentSize <= 2800 ? '2800' | ||
: '3600'; | ||
if (currentSize <= 25) { | ||
return '25'; | ||
} | ||
if (currentSize <= 50) { | ||
return '50'; | ||
} | ||
return (Math.ceil(currentSize / 100) * 100).toString(); | ||
}; | ||
@@ -170,3 +127,10 @@ /** | ||
function (size) { | ||
return size && typeof size === 'object'; | ||
try { | ||
/** @type {?} */ | ||
var array = size.split(','); | ||
return array.length > 1; | ||
} | ||
catch (e) { | ||
return false; | ||
} | ||
}; | ||
@@ -270,34 +234,22 @@ /** | ||
function (operation, size, filters, imgSrc, isAdaptive, config, isPreview) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var sources = []; | ||
if (isAdaptive) { | ||
/** @type {?} */ | ||
var orderFiltered = []; | ||
for (var i = 0; i < config.order.length; i++) { | ||
/** @type {?} */ | ||
var nextSize = size[config.order[i]]; | ||
if (nextSize) { | ||
orderFiltered.unshift(config.order[i]); | ||
} | ||
} | ||
for (var i = 0; i < orderFiltered.length; i++) { | ||
/** @type {?} */ | ||
var isLast = !(i < orderFiltered.length - 1); | ||
/** @type {?} */ | ||
var nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i]; | ||
/** @type {?} */ | ||
var nextSize = size[orderFiltered[i]]; | ||
size.forEach(function (_a) { | ||
var nextSize = _a.size, mediaQuery = _a.media; | ||
if (isPreview) { | ||
nextSize = nextSize.split('x').map(function (item) { return item / 5; }).join('x'); | ||
nextSize = nextSize.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
/** @type {?} */ | ||
var srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config); | ||
/** @type {?} */ | ||
var mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)'; | ||
sources.push({ mediaQuery: mediaQuery, srcSet: srcSet }); | ||
} | ||
sources.push({ mediaQuery: mediaQuery, srcSet: _this.generateSrcset(operation, nextSize, filters, imgSrc, config) }); | ||
}); | ||
} | ||
else { | ||
if (isPreview) { | ||
size = size.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
sources.push({ | ||
srcSet: this.generateSrcset(operation, size.split('x').map(function (item) { return item / 5; }).join('x'), 'q10.foil1', imgSrc, config) | ||
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config) | ||
}); | ||
@@ -308,2 +260,26 @@ } | ||
/** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getAdaptiveSize = /** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
function (size, config) { | ||
/** @type {?} */ | ||
var arrayOfSizes = size.split(','); | ||
/** @type {?} */ | ||
var sizes = []; | ||
arrayOfSizes.forEach(function (string) { | ||
/** @type {?} */ | ||
var groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups; | ||
/** @type {?} */ | ||
var media = groups.media ? groups.media : config.presets[groups.variable]; | ||
sizes.push({ media: media, size: groups.size }); | ||
}); | ||
return sizes; | ||
}; | ||
/** | ||
* @param {?} operation | ||
@@ -325,6 +301,3 @@ * @param {?} size | ||
function (operation, size, filters, imgSrc, config) { | ||
/** @type {?} */ | ||
var imgWidth = size.toString().split('x')[0]; | ||
/** @type {?} */ | ||
var imgHeight = size.toString().split('x')[1]; | ||
var _a = tslib_1.__read(size.toString().split('x'), 2), imgWidth = _a[0], imgHeight = _a[1]; | ||
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config); | ||
@@ -375,2 +348,3 @@ }; | ||
function (size, config) { | ||
var _a, _b; | ||
/** @type {?} */ | ||
@@ -382,29 +356,9 @@ var width; | ||
/** @type {?} */ | ||
var breakPoint = this.getBreakPoint(config); | ||
var breakPointSource = this.getBreakPoint(size); | ||
/** @type {?} */ | ||
var orderIndex = config.order.indexOf(breakPoint); | ||
/** @type {?} */ | ||
var breakPointSize = null; | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndex]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndex--; | ||
} while (!breakPointSize && orderIndex >= 0); | ||
if (!breakPointSize) { | ||
/** @type {?} */ | ||
var orderIndexStepTwo = config.order.indexOf(breakPoint); | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndexStepTwo]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndexStepTwo++; | ||
} while (!breakPointSize && orderIndexStepTwo <= config.order.length); | ||
} | ||
width = breakPointSize.toString().split('x')[0]; | ||
height = breakPointSize.toString().split('x')[1]; | ||
var breakPointSize = breakPointSource ? breakPointSource.size : size[0].size; | ||
_a = tslib_1.__read(breakPointSize.toString().split('x'), 2), width = _a[0], height = _a[1]; | ||
} | ||
else { | ||
width = size.toString().split('x')[0]; | ||
height = size.toString().split('x')[1]; | ||
_b = tslib_1.__read(size.toString().split('x'), 2), width = _b[0], height = _b[1]; | ||
} | ||
@@ -417,16 +371,11 @@ if (width && height) { | ||
/** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getBreakPoint = /** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
function (config) { | ||
var presets = config.presets, order = config.order; | ||
/** @type {?} */ | ||
var innerWidth = window.innerWidth; | ||
/** @type {?} */ | ||
var prevBreakPointLimit = order.findIndex(function (item) { return presets[item] < innerWidth; }); | ||
return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1]; | ||
function (size) { | ||
return tslib_1.__spread(size).reverse().find(function (item) { return matchMedia(item.media).matches; }); | ||
}; | ||
@@ -450,2 +399,2 @@ CIService.decorators = [ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib.service.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/lib.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {CIConfig} from './config.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CIService {\n  public config: any = {};\n\n  constructor(ciConfig: CIConfig) {\n    const {\n      token = '',\n      container = 'cloudimg.io',\n      ultraFast = false,\n      lazyLoading = true,\n      imgLoadingAnimation = true,\n      lazyLoadOffset = 100,\n      width = '400',\n      height = '300',\n      operation = 'width',\n      filters = 'n',\n      placeholderBackground = '#f4f4f4',\n      baseUrl = '/',\n      presets,\n      queryString = ''\n    } = ciConfig;\n\n    this.config = {\n      token,\n      container,\n      ultraFast,\n      lazyLoading,\n      imgLoadingAnimation,\n      lazyLoadOffset,\n      width,\n      height,\n      operation,\n      filters,\n      placeholderBackground,\n      baseUrl,\n      presets: presets ? this.getPresets(presets, 'presets') :\n        {\n          xs: 575,  // up to 576    PHONE\n          sm: 767,  // 577 - 768    PHABLET\n          md: 991,  // 769 - 992    TABLET\n          lg: 1199, // 993 - 1200   SMALL_LAPTOP_SCREEN\n          xl: 3000  // from 1200    USUALSCREEN\n        },\n      order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'],\n      queryString,\n      innerWidth: window.innerWidth,\n      // isChrome: /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor)\n    };\n  }\n\n  getPresets(value = '', type) {\n    const splittedValues = value.split('|');\n    const result = {presets: {}, order: []};\n\n    for (let i = 0; i < splittedValues.length; i++) {\n      const splittedParam = splittedValues[i] && splittedValues[i].split(':');\n      const prop = splittedParam[0] && splittedParam[0].trim();\n      const val = splittedParam[1] && splittedParam[1].trim();\n\n      if (prop && val) {\n        result.presets[prop] = val;\n        result.order.unshift(prop);\n      }\n    }\n\n    return result[type];\n  }\n\n  public getParentWidth(img, config) {\n    if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {\n      return config.width;\n    }\n\n    const parentContainer = this.getParentContainerWithWidth(img);\n    const currentWidth = parseInt('' + parentContainer, 10);\n    const computedWidth = Number(window.getComputedStyle(img).width);\n\n    if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {\n      return this.getSizeLimit(computedWidth);\n    } else {\n      if (!currentWidth) {\n        return img.width || config.width;\n      }\n\n      return this.getSizeLimit(currentWidth);\n    }\n  }\n\n  getParentContainerWithWidth(img) {\n    let parentNode = null;\n    let width = 0;\n\n    do {\n      parentNode = (parentNode && parentNode.parentNode) || img.parentNode;\n      width = parentNode.getBoundingClientRect().width;\n    } while (parentNode && !width);\n\n    return width;\n  }\n\n  getSizeLimit(currentSize) {\n    return currentSize <= 25 ? '25' :\n      currentSize <= 50 ? '50' :\n        currentSize <= 100 ? '100'\n          : currentSize <= 200 ? '200'\n          : currentSize <= 300 ? '300'\n            : currentSize <= 400 ? '400'\n              : currentSize <= 500 ? '500'\n                : currentSize <= 600 ? '600'\n                  : currentSize <= 700 ? '700'\n                    : currentSize <= 800 ? '800'\n                      : currentSize <= 900 ? '900'\n                        : currentSize <= 1000 ? '1000'\n                          : currentSize <= 1100 ? '1100'\n                            : currentSize <= 1200 ? '1200'\n                              : currentSize <= 1300 ? '1300'\n                                : currentSize <= 1400 ? '1400'\n                                  : currentSize <= 1500 ? '1500'\n                                    : currentSize <= 1600 ? '1600'\n                                      : currentSize <= 1700 ? '1700'\n                                        : currentSize <= 1800 ? '1800'\n                                          : currentSize <= 1900 ? '1900'\n                                            : currentSize <= 2400 ? '2400'\n                                              : currentSize <= 2800 ? '2800'\n                                                : '3600';\n  }\n\n  public checkOnMedia(size) {\n    return size && typeof size === 'object';\n  }\n\n  public checkIfRelativeUrlPath(src) {\n    if (src.indexOf('//') === 0) {\n      src = window.location.protocol + src;\n    }\n    return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);\n  }\n\n  public getImgSrc(src, isRelativeUrlPath = false, baseUrl = '') {\n    if (isRelativeUrlPath) {\n      return baseUrl + src;\n    }\n\n    return src;\n  }\n\n  public getSizeAccordingToPixelRatio(size) {\n    const splittedSizes = size.toString().split('x');\n    const result = [];\n\n    [].forEach.call(splittedSizes, item => {\n      result.push(item * Math.round(window.devicePixelRatio || 1));\n    });\n\n    return result.join('x');\n  }\n\n  public generateUrl(operation, size, filters, imgSrc, config) {\n    const {ultraFast, token, container, queryString} = config;\n    const isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';\n    const cloudUrl = isUltraFast + token + '.' + container + '/';\n\n    return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;\n  }\n\n  public generateSources(operation, size, filters, imgSrc, isAdaptive, config, isPreview) {\n    const sources = [];\n\n    if (isAdaptive) {\n      const orderFiltered = [];\n\n      for (let i = 0; i < config.order.length; i++) {\n        const nextSize = size[config.order[i]];\n\n        if (nextSize) {\n          orderFiltered.unshift(config.order[i]);\n        }\n      }\n\n      for (let i = 0; i < orderFiltered.length; i++) {\n        const isLast = !(i < orderFiltered.length - 1);\n        const nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i];\n        let nextSize = size[orderFiltered[i]];\n\n        if (isPreview) {\n          nextSize = nextSize.split('x').map(item => item / 5).join('x');\n        }\n\n        const srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config);\n        const mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)';\n\n        sources.push({mediaQuery, srcSet});\n      }\n    } else {\n      sources.push({\n        srcSet: this.generateSrcset(operation, size.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, config)\n      });\n    }\n\n    return sources;\n  }\n\n  generateSrcset(operation, size, filters, imgSrc, config) {\n    const imgWidth = size.toString().split('x')[0];\n    const imgHeight = size.toString().split('x')[1];\n\n    return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);\n  }\n\n  generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {\n    let imgSize = '' + Math.trunc(imgWidth * factor);\n\n    if (imgHeight) {\n      imgSize += 'x' + Math.trunc(imgHeight * factor);\n    }\n\n    return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)\n      .replace('http://scaleflex.ultrafast.io/', '')\n      .replace('https://scaleflex.ultrafast.io/', '')\n      .replace('//scaleflex.ultrafast.io/', '')\n      .replace('///', '/');\n  }\n\n  public getRatioBySize(size, config) {\n    let width, height;\n\n    if (typeof size === 'object') {\n      const breakPoint = this.getBreakPoint(config);\n      let orderIndex = config.order.indexOf(breakPoint);\n      let breakPointSize = null;\n\n      do {\n        const nextBreakpoint = config.order[orderIndex];\n        breakPointSize = size[nextBreakpoint];\n        orderIndex--;\n      } while (!breakPointSize && orderIndex >= 0);\n\n      if (!breakPointSize) {\n        let orderIndexStepTwo = config.order.indexOf(breakPoint);\n\n        do {\n          const nextBreakpoint = config.order[orderIndexStepTwo];\n          breakPointSize = size[nextBreakpoint];\n          orderIndexStepTwo++;\n        } while (!breakPointSize && orderIndexStepTwo <= config.order.length);\n      }\n\n      width = breakPointSize.toString().split('x')[0];\n      height = breakPointSize.toString().split('x')[1];\n    } else {\n      width = size.toString().split('x')[0];\n      height = size.toString().split('x')[1];\n    }\n\n    if (width && height) {\n      return width / height;\n    }\n\n    return null;\n  }\n\n  getBreakPoint(config) {\n    const {presets, order} = config;\n    const innerWidth = window.innerWidth;\n    const prevBreakPointLimit = order.findIndex(item => presets[item] < innerWidth);\n\n    return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1];\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib.service.js","sourceRoot":"ng://ng-cloudimage-responsive/","sources":["lib/lib.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {CIConfig} from './config.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CIService {\n  config: any = {};\n\n  constructor(ciConfig: CIConfig) {\n    const {\n      token = '',\n      container = 'cloudimg.io',\n      ultraFast = false,\n      lazyLoading = true,\n      imgLoadingAnimation = true,\n      lazyLoadOffset = 100,\n      width = '400',\n      height = '300',\n      operation = 'width',\n      filters = 'n',\n      placeholderBackground = '#f4f4f4',\n      baseUrl = '/',\n      presets,\n      queryString = ''\n    } = ciConfig;\n\n    this.config = {\n      token,\n      container,\n      ultraFast,\n      lazyLoading,\n      imgLoadingAnimation,\n      lazyLoadOffset,\n      width,\n      height,\n      operation,\n      filters,\n      placeholderBackground,\n      baseUrl,\n      presets: presets ? presets :\n        {\n          xs: '(max-width: 575px)',  // to 575       PHONE\n          sm: '(min-width: 576px)',  // 576 - 767    PHABLET\n          md: '(min-width: 768px)',  // 768 - 991    TABLET\n          lg: '(min-width: 992px)',  // 992 - 1199   SMALL_LAPTOP_SCREEN\n          xl: '(min-width: 1200px)'  // from 1200    USUALSCREEN\n        },\n      queryString,\n      innerWidth: window.innerWidth,\n      // isChrome: /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor)\n    };\n  }\n\n  getParentWidth(img, config) {\n    if (!(img && img.parentElement && img.parentElement.getBoundingClientRect) && !(img && img.width)) {\n      return config.width;\n    }\n\n    const parentContainer = this.getParentContainerWithWidth(img);\n    const currentWidth = parseInt('' + parentContainer, 10);\n    const computedWidth = Number(window.getComputedStyle(img).width);\n\n    if ((computedWidth && (computedWidth < currentWidth && computedWidth > 15) || !currentWidth)) {\n      return this.getSizeLimit(computedWidth);\n    } else {\n      if (!currentWidth) {\n        return img.width || config.width;\n      }\n\n      return this.getSizeLimit(currentWidth);\n    }\n  }\n\n  getParentContainerWithWidth(img) {\n    let parentNode = null;\n    let width = 0;\n\n    do {\n      parentNode = (parentNode && parentNode.parentNode) || img.parentNode;\n      width = parentNode.getBoundingClientRect().width;\n    } while (parentNode && !width);\n\n    const letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10);\n    const rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10);\n\n    return width + (width ? (-letPadding - rightPadding) : 0);\n  }\n\n  getSizeLimit(currentSize) {\n    if (currentSize <= 25) {\n      return '25';\n    }\n    if (currentSize <= 50) {\n      return '50';\n    }\n\n    return (Math.ceil(currentSize / 100) * 100).toString();\n  }\n\n  checkOnMedia(size) {\n    try {\n      const array = size.split(',');\n\n      return array.length > 1;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  checkIfRelativeUrlPath(src) {\n    if (src.indexOf('//') === 0) {\n      src = window.location.protocol + src;\n    }\n\n    return (src.indexOf('http://') !== 0 && src.indexOf('https://') !== 0 && src.indexOf('//') !== 0);\n  }\n\n  getImgSrc(src, isRelativeUrlPath = false, baseUrl = '') {\n    if (isRelativeUrlPath) {\n      return baseUrl + src;\n    }\n\n    return src;\n  }\n\n  getSizeAccordingToPixelRatio(size) {\n    const splittedSizes = size.toString().split('x');\n    const result = [];\n\n    [].forEach.call(splittedSizes, item => {\n      result.push(item * Math.round(window.devicePixelRatio || 1));\n    });\n\n    return result.join('x');\n  }\n\n  generateUrl(operation, size, filters, imgSrc, config) {\n    const {ultraFast, token, container, queryString} = config;\n    const isUltraFast = ultraFast ? 'https://scaleflex.ultrafast.io/' : 'https://';\n    const cloudUrl = isUltraFast + token + '.' + container + '/';\n\n    return cloudUrl + operation + '/' + size + '/' + filters + '/' + imgSrc + queryString;\n  }\n\n  generateSources(operation, size, filters, imgSrc, isAdaptive, config, isPreview) {\n    const sources = [];\n\n    if (isAdaptive) {\n      size.forEach(({ size: nextSize, media: mediaQuery}) => {\n        if (isPreview) {\n          nextSize = nextSize.split('x').map(sizeNext => sizeNext / 5).join('x');\n          filters = 'q10.foil1';\n        }\n\n        sources.push({ mediaQuery, srcSet: this.generateSrcset(operation, nextSize, filters, imgSrc, config) });\n      });\n    } else {\n      if (isPreview) {\n        size = size.split('x').map(sizeNext => sizeNext / 5).join('x');\n        filters = 'q10.foil1';\n      }\n\n      sources.push({\n        srcSet: this.generateSrcset(operation, size, filters, imgSrc, config)\n      });\n    }\n    return sources;\n  }\n\n  getAdaptiveSize(size, config) {\n    const arrayOfSizes = size.split(',');\n    const sizes = [];\n\n    arrayOfSizes.forEach(string => {\n      const groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\\([\\S\\s]*\\)))\\s*(?<size>[0-9xp]*)/).groups;\n      const media = groups.media ? groups.media : config.presets[groups.variable];\n\n      sizes.push({ media, size: groups.size });\n    });\n\n    return sizes;\n  }\n\n  generateSrcset(operation, size, filters, imgSrc, config) {\n    const [imgWidth, imgHeight] = size.toString().split('x');\n\n    return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config);\n  }\n\n  generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, factor, config) {\n    let imgSize = '' + Math.trunc(imgWidth * factor);\n\n    if (imgHeight) {\n      imgSize += 'x' + Math.trunc(imgHeight * factor);\n    }\n\n    return this.generateUrl(operation, this.getSizeAccordingToPixelRatio(imgSize), filters, imgSrc, config)\n      .replace('http://scaleflex.ultrafast.io/', '')\n      .replace('https://scaleflex.ultrafast.io/', '')\n      .replace('//scaleflex.ultrafast.io/', '')\n      .replace('///', '/');\n  }\n\n  getRatioBySize(size, config) {\n    let width, height;\n\n    if (typeof size === 'object') {\n      const breakPointSource = this.getBreakPoint(size);\n      const breakPointSize = breakPointSource ? breakPointSource.size : size[0].size;\n\n      [width, height] = breakPointSize.toString().split('x');\n    } else {\n      [width, height] = size.toString().split('x');\n    }\n\n    if (width && height) {\n      return width / height;\n    }\n\n    return null;\n  }\n\n  getBreakPoint(size) {\n    return [...size].reverse().find(item => matchMedia(item.media).matches);\n  }\n}\n"]} |
@@ -9,5 +9,5 @@ /** | ||
export { CIService } from './lib/lib.service'; | ||
export { CIConfig } from './lib/config.service'; | ||
export { CIConfig } from './lib/config.model'; | ||
export { CIModule } from './lib/lib.module'; | ||
export { ImgComponent } from './lib/img/img.component'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nLWNsb3VkaW1hZ2UtcmVzcG9uc2l2ZS8iLCJzb3VyY2VzIjpbInB1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBLDBCQUFjLG1CQUFtQixDQUFDO0FBQ2xDLHlCQUFjLHNCQUFzQixDQUFDO0FBQ3JDLHlCQUFjLGtCQUFrQixDQUFDO0FBQ2pDLDZCQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsaWJcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maWcuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltZy9pbWcuY29tcG9uZW50JztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nLWNsb3VkaW1hZ2UtcmVzcG9uc2l2ZS8iLCJzb3VyY2VzIjpbInB1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBLDBCQUFjLG1CQUFtQixDQUFDO0FBQ2xDLHlCQUFjLG9CQUFvQixDQUFDO0FBQ25DLHlCQUFjLGtCQUFrQixDQUFDO0FBQ2pDLDZCQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsaWJcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWcvaW1nLmNvbXBvbmVudCc7XG4iXX0= |
@@ -39,15 +39,14 @@ import { CommonModule } from '@angular/common'; | ||
baseUrl, | ||
presets: presets ? this.getPresets(presets, 'presets') : | ||
presets: presets ? presets : | ||
{ | ||
xs: 575, | ||
// up to 576 PHONE | ||
sm: 767, | ||
// 577 - 768 PHABLET | ||
md: 991, | ||
// 769 - 992 TABLET | ||
lg: 1199, | ||
// 993 - 1200 SMALL_LAPTOP_SCREEN | ||
xl: 3000 // from 1200 USUALSCREEN | ||
xs: '(max-width: 575px)', | ||
// to 575 PHONE | ||
sm: '(min-width: 576px)', | ||
// 576 - 767 PHABLET | ||
md: '(min-width: 768px)', | ||
// 768 - 991 TABLET | ||
lg: '(min-width: 992px)', | ||
// 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
}, | ||
order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'], | ||
queryString, | ||
@@ -58,26 +57,2 @@ innerWidth: window.innerWidth, | ||
/** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
getPresets(value = '', type) { | ||
/** @type {?} */ | ||
const splittedValues = value.split('|'); | ||
/** @type {?} */ | ||
const result = { presets: {}, order: [] }; | ||
for (let i = 0; i < splittedValues.length; i++) { | ||
/** @type {?} */ | ||
const splittedParam = splittedValues[i] && splittedValues[i].split(':'); | ||
/** @type {?} */ | ||
const prop = splittedParam[0] && splittedParam[0].trim(); | ||
/** @type {?} */ | ||
const val = splittedParam[1] && splittedParam[1].trim(); | ||
if (prop && val) { | ||
result.presets[prop] = val; | ||
result.order.unshift(prop); | ||
} | ||
} | ||
return result[type]; | ||
} | ||
/** | ||
* @param {?} img | ||
@@ -120,3 +95,7 @@ * @param {?} config | ||
} while (parentNode && !width); | ||
return width; | ||
/** @type {?} */ | ||
const letPadding = width && parentNode && parseInt(window.getComputedStyle(parentNode).paddingLeft, 10); | ||
/** @type {?} */ | ||
const rightPadding = parseInt(window.getComputedStyle(parentNode).paddingRight, 10); | ||
return width + (width ? (-letPadding - rightPadding) : 0); | ||
} | ||
@@ -128,26 +107,9 @@ /** | ||
getSizeLimit(currentSize) { | ||
return currentSize <= 25 ? '25' : | ||
currentSize <= 50 ? '50' : | ||
currentSize <= 100 ? '100' | ||
: currentSize <= 200 ? '200' | ||
: currentSize <= 300 ? '300' | ||
: currentSize <= 400 ? '400' | ||
: currentSize <= 500 ? '500' | ||
: currentSize <= 600 ? '600' | ||
: currentSize <= 700 ? '700' | ||
: currentSize <= 800 ? '800' | ||
: currentSize <= 900 ? '900' | ||
: currentSize <= 1000 ? '1000' | ||
: currentSize <= 1100 ? '1100' | ||
: currentSize <= 1200 ? '1200' | ||
: currentSize <= 1300 ? '1300' | ||
: currentSize <= 1400 ? '1400' | ||
: currentSize <= 1500 ? '1500' | ||
: currentSize <= 1600 ? '1600' | ||
: currentSize <= 1700 ? '1700' | ||
: currentSize <= 1800 ? '1800' | ||
: currentSize <= 1900 ? '1900' | ||
: currentSize <= 2400 ? '2400' | ||
: currentSize <= 2800 ? '2800' | ||
: '3600'; | ||
if (currentSize <= 25) { | ||
return '25'; | ||
} | ||
if (currentSize <= 50) { | ||
return '50'; | ||
} | ||
return (Math.ceil(currentSize / 100) * 100).toString(); | ||
} | ||
@@ -159,3 +121,10 @@ /** | ||
checkOnMedia(size) { | ||
return size && typeof size === 'object'; | ||
try { | ||
/** @type {?} */ | ||
const array = size.split(','); | ||
return array.length > 1; | ||
} | ||
catch (e) { | ||
return false; | ||
} | ||
} | ||
@@ -228,31 +197,17 @@ /** | ||
if (isAdaptive) { | ||
/** @type {?} */ | ||
const orderFiltered = []; | ||
for (let i = 0; i < config.order.length; i++) { | ||
/** @type {?} */ | ||
const nextSize = size[config.order[i]]; | ||
if (nextSize) { | ||
orderFiltered.unshift(config.order[i]); | ||
} | ||
} | ||
for (let i = 0; i < orderFiltered.length; i++) { | ||
/** @type {?} */ | ||
const isLast = !(i < orderFiltered.length - 1); | ||
/** @type {?} */ | ||
const nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i]; | ||
/** @type {?} */ | ||
let nextSize = size[orderFiltered[i]]; | ||
size.forEach(({ size: nextSize, media: mediaQuery }) => { | ||
if (isPreview) { | ||
nextSize = nextSize.split('x').map(item => item / 5).join('x'); | ||
nextSize = nextSize.split('x').map(sizeNext => sizeNext / 5).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
/** @type {?} */ | ||
const srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config); | ||
/** @type {?} */ | ||
const mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)'; | ||
sources.push({ mediaQuery, srcSet }); | ||
} | ||
sources.push({ mediaQuery, srcSet: this.generateSrcset(operation, nextSize, filters, imgSrc, config) }); | ||
}); | ||
} | ||
else { | ||
if (isPreview) { | ||
size = size.split('x').map(sizeNext => sizeNext / 5).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
sources.push({ | ||
srcSet: this.generateSrcset(operation, size.split('x').map(item => item / 5).join('x'), 'q10.foil1', imgSrc, config) | ||
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config) | ||
}); | ||
@@ -263,2 +218,21 @@ } | ||
/** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
getAdaptiveSize(size, config) { | ||
/** @type {?} */ | ||
const arrayOfSizes = size.split(','); | ||
/** @type {?} */ | ||
const sizes = []; | ||
arrayOfSizes.forEach(string => { | ||
/** @type {?} */ | ||
const groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups; | ||
/** @type {?} */ | ||
const media = groups.media ? groups.media : config.presets[groups.variable]; | ||
sizes.push({ media, size: groups.size }); | ||
}); | ||
return sizes; | ||
} | ||
/** | ||
* @param {?} operation | ||
@@ -272,6 +246,3 @@ * @param {?} size | ||
generateSrcset(operation, size, filters, imgSrc, config) { | ||
/** @type {?} */ | ||
const imgWidth = size.toString().split('x')[0]; | ||
/** @type {?} */ | ||
const imgHeight = size.toString().split('x')[1]; | ||
const [imgWidth, imgHeight] = size.toString().split('x'); | ||
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config); | ||
@@ -313,29 +284,9 @@ } | ||
/** @type {?} */ | ||
const breakPoint = this.getBreakPoint(config); | ||
const breakPointSource = this.getBreakPoint(size); | ||
/** @type {?} */ | ||
let orderIndex = config.order.indexOf(breakPoint); | ||
/** @type {?} */ | ||
let breakPointSize = null; | ||
do { | ||
/** @type {?} */ | ||
const nextBreakpoint = config.order[orderIndex]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndex--; | ||
} while (!breakPointSize && orderIndex >= 0); | ||
if (!breakPointSize) { | ||
/** @type {?} */ | ||
let orderIndexStepTwo = config.order.indexOf(breakPoint); | ||
do { | ||
/** @type {?} */ | ||
const nextBreakpoint = config.order[orderIndexStepTwo]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndexStepTwo++; | ||
} while (!breakPointSize && orderIndexStepTwo <= config.order.length); | ||
} | ||
width = breakPointSize.toString().split('x')[0]; | ||
height = breakPointSize.toString().split('x')[1]; | ||
const breakPointSize = breakPointSource ? breakPointSource.size : size[0].size; | ||
[width, height] = breakPointSize.toString().split('x'); | ||
} | ||
else { | ||
width = size.toString().split('x')[0]; | ||
height = size.toString().split('x')[1]; | ||
[width, height] = size.toString().split('x'); | ||
} | ||
@@ -348,12 +299,7 @@ if (width && height) { | ||
/** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
getBreakPoint(config) { | ||
const { presets, order } = config; | ||
/** @type {?} */ | ||
const innerWidth = window.innerWidth; | ||
/** @type {?} */ | ||
const prevBreakPointLimit = order.findIndex(item => presets[item] < innerWidth); | ||
return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1]; | ||
getBreakPoint(size) { | ||
return [...size].reverse().find(item => matchMedia(item.media).matches); | ||
} | ||
@@ -384,5 +330,8 @@ } | ||
this._sanitizer = _sanitizer; | ||
this.class = ''; | ||
this.offset = 100; | ||
this.cloudimageUrl = ''; | ||
this.sources = []; | ||
this.firstSource = null; | ||
this.restSources = []; | ||
this.isLoaded = false; | ||
@@ -405,8 +354,5 @@ this.isProcessed = false; | ||
this.resizeSubscription$ = this.resizeObservable$.subscribe(() => { | ||
if (this.isAdaptive) { | ||
if (this.isAdaptive || this.windowInnerWidth < window.innerWidth) { | ||
this.processImage(); | ||
} | ||
else if (this.windowInnerWidth < window.innerWidth) { | ||
this.processImage(); | ||
} | ||
this.windowInnerWidth = window.innerWidth; | ||
@@ -433,3 +379,3 @@ }); | ||
/** @type {?} */ | ||
const size = this.size || this.s || config.size || parentContainerWidth; | ||
let size = this.size || this.s || config.size || parentContainerWidth; | ||
/** @type {?} */ | ||
@@ -439,2 +385,3 @@ const filters = this.filters || this.f || config.filters; | ||
const isAdaptive = this.ciService.checkOnMedia(size); | ||
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size; | ||
/** @type {?} */ | ||
@@ -448,3 +395,3 @@ const isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src); | ||
this.cloudimageUrl = isAdaptive ? | ||
this.ciService.generateUrl('width', parentContainerWidth, filters, imgSrc, config) : | ||
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) : | ||
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config); | ||
@@ -498,2 +445,19 @@ this.sources = isAdaptive ? | ||
*/ | ||
getRestSources() { | ||
/** @type {?} */ | ||
const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))]; | ||
return resultSources.slice(1).reverse(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getFirstSource() { | ||
/** @type {?} */ | ||
const resultSources = [...(!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))]; | ||
this.firstSource = resultSources[0]; | ||
return resultSources[0]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getPositionStyle() { | ||
@@ -506,3 +470,5 @@ return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'absolute' : 'relative'); | ||
getImgHeight() { | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
// todo check if we need 100% height | ||
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto'); | ||
} | ||
@@ -569,3 +535,3 @@ /** | ||
let result = 'transparent'; | ||
if (this.isRatio) { | ||
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) { | ||
result = config.placeholderBackground; | ||
@@ -585,3 +551,3 @@ } | ||
<picture | ||
class="{{class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')}}" | ||
[class]="class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')" | ||
style="display:block;width:100%;overflow:hidden;position:relative;" | ||
@@ -593,3 +559,3 @@ [style.paddingBottom]="getPicturePaddingBottom()" | ||
<source | ||
*ngFor="let source of (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))" | ||
*ngFor="let source of getRestSources()" | ||
[media]="source.mediaQuery || ''" | ||
@@ -600,2 +566,8 @@ [attr.lazyLoad]="source.srcSet || ''" | ||
/> | ||
<source | ||
*ngIf="getFirstSource()" | ||
[attr.lazyLoad]="firstSource.srcSet || ''" | ||
[srcset]="firstSource.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<img | ||
@@ -616,3 +588,3 @@ style="display:block;width:100%;opacity:1;top:0;left:0;" | ||
<picture | ||
class="{{class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')}}" | ||
[class]="class + ' cloudimage-image-picture cloudimage-image-' + (isLoaded ? 'loaded' : 'loading')" | ||
style="display:block;width:100%;overflow:hidden;position:relative;" | ||
@@ -624,7 +596,14 @@ [style.paddingBottom]="getPicturePaddingBottom()" | ||
<source | ||
*ngFor="let source of (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))" | ||
*ngFor="let source of restSources" | ||
[media]="source.mediaQuery || ''" | ||
[attr.lazyLoad]="source.srcSet || ''" | ||
[srcset]="source.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<source | ||
*ngIf="firstSource" | ||
[attr.lazyLoad]="firstSource.srcSet || ''" | ||
[srcset]="firstSource.srcSet || ''" | ||
(load)="onImageLoad()" | ||
/> | ||
<img | ||
@@ -631,0 +610,0 @@ style="display:block;width:100%;opacity:1;top:0;left:0;" |
import { CommonModule } from '@angular/common'; | ||
import { __assign } from 'tslib'; | ||
import { __read, __spread, __assign } from 'tslib'; | ||
import { Injectable, NgModule, defineInjectable, inject, Component, ViewChild, Input } from '@angular/core'; | ||
@@ -40,15 +40,14 @@ import { DomSanitizer } from '@angular/platform-browser'; | ||
baseUrl: baseUrl, | ||
presets: presets ? this.getPresets(presets, 'presets') : | ||
presets: presets ? presets : | ||
{ | ||
xs: 575, | ||
// up to 576 PHONE | ||
sm: 767, | ||
// 577 - 768 PHABLET | ||
md: 991, | ||
// 769 - 992 TABLET | ||
lg: 1199, | ||
// 993 - 1200 SMALL_LAPTOP_SCREEN | ||
xl: 3000 // from 1200 USUALSCREEN | ||
xs: '(max-width: 575px)', | ||
// to 575 PHONE | ||
sm: '(min-width: 576px)', | ||
// 576 - 767 PHABLET | ||
md: '(min-width: 768px)', | ||
// 768 - 991 TABLET | ||
lg: '(min-width: 992px)', | ||
// 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
}, | ||
order: presets ? this.getPresets(presets, 'order') : ['xl', 'lg', 'md', 'sm', 'xs'], | ||
queryString: queryString, | ||
@@ -59,32 +58,2 @@ innerWidth: window.innerWidth, | ||
/** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getPresets = /** | ||
* @param {?=} value | ||
* @param {?=} type | ||
* @return {?} | ||
*/ | ||
function (value, type) { | ||
if (value === void 0) { value = ''; } | ||
/** @type {?} */ | ||
var splittedValues = value.split('|'); | ||
/** @type {?} */ | ||
var result = { presets: {}, order: [] }; | ||
for (var i = 0; i < splittedValues.length; i++) { | ||
/** @type {?} */ | ||
var splittedParam = splittedValues[i] && splittedValues[i].split(':'); | ||
/** @type {?} */ | ||
var prop = splittedParam[0] && splittedParam[0].trim(); | ||
/** @type {?} */ | ||
var val = splittedParam[1] && splittedParam[1].trim(); | ||
if (prop && val) { | ||
result.presets[prop] = val; | ||
result.order.unshift(prop); | ||
} | ||
} | ||
return result[type]; | ||
}; | ||
/** | ||
* @param {?} img | ||
@@ -136,3 +105,7 @@ * @param {?} config | ||
} while (parentNode && !width); | ||
return 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); | ||
}; | ||
@@ -148,26 +121,9 @@ /** | ||
function (currentSize) { | ||
return currentSize <= 25 ? '25' : | ||
currentSize <= 50 ? '50' : | ||
currentSize <= 100 ? '100' | ||
: currentSize <= 200 ? '200' | ||
: currentSize <= 300 ? '300' | ||
: currentSize <= 400 ? '400' | ||
: currentSize <= 500 ? '500' | ||
: currentSize <= 600 ? '600' | ||
: currentSize <= 700 ? '700' | ||
: currentSize <= 800 ? '800' | ||
: currentSize <= 900 ? '900' | ||
: currentSize <= 1000 ? '1000' | ||
: currentSize <= 1100 ? '1100' | ||
: currentSize <= 1200 ? '1200' | ||
: currentSize <= 1300 ? '1300' | ||
: currentSize <= 1400 ? '1400' | ||
: currentSize <= 1500 ? '1500' | ||
: currentSize <= 1600 ? '1600' | ||
: currentSize <= 1700 ? '1700' | ||
: currentSize <= 1800 ? '1800' | ||
: currentSize <= 1900 ? '1900' | ||
: currentSize <= 2400 ? '2400' | ||
: currentSize <= 2800 ? '2800' | ||
: '3600'; | ||
if (currentSize <= 25) { | ||
return '25'; | ||
} | ||
if (currentSize <= 50) { | ||
return '50'; | ||
} | ||
return (Math.ceil(currentSize / 100) * 100).toString(); | ||
}; | ||
@@ -183,3 +139,10 @@ /** | ||
function (size) { | ||
return size && typeof size === 'object'; | ||
try { | ||
/** @type {?} */ | ||
var array = size.split(','); | ||
return array.length > 1; | ||
} | ||
catch (e) { | ||
return false; | ||
} | ||
}; | ||
@@ -283,34 +246,22 @@ /** | ||
function (operation, size, filters, imgSrc, isAdaptive, config, isPreview) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var sources = []; | ||
if (isAdaptive) { | ||
/** @type {?} */ | ||
var orderFiltered = []; | ||
for (var i = 0; i < config.order.length; i++) { | ||
/** @type {?} */ | ||
var nextSize = size[config.order[i]]; | ||
if (nextSize) { | ||
orderFiltered.unshift(config.order[i]); | ||
} | ||
} | ||
for (var i = 0; i < orderFiltered.length; i++) { | ||
/** @type {?} */ | ||
var isLast = !(i < orderFiltered.length - 1); | ||
/** @type {?} */ | ||
var nextSizeType = isLast ? orderFiltered[i - 1] : orderFiltered[i]; | ||
/** @type {?} */ | ||
var nextSize = size[orderFiltered[i]]; | ||
size.forEach(function (_a) { | ||
var nextSize = _a.size, mediaQuery = _a.media; | ||
if (isPreview) { | ||
nextSize = nextSize.split('x').map(function (item) { return item / 5; }).join('x'); | ||
nextSize = nextSize.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
/** @type {?} */ | ||
var srcSet = this.generateSrcset(operation, nextSize, filters, imgSrc, config); | ||
/** @type {?} */ | ||
var mediaQuery = '(' + (isLast ? 'min' : 'max') + '-width: ' + (config.presets[nextSizeType] + (isLast ? 1 : 0)) + 'px)'; | ||
sources.push({ mediaQuery: mediaQuery, srcSet: srcSet }); | ||
} | ||
sources.push({ mediaQuery: mediaQuery, srcSet: _this.generateSrcset(operation, nextSize, filters, imgSrc, config) }); | ||
}); | ||
} | ||
else { | ||
if (isPreview) { | ||
size = size.split('x').map(function (sizeNext) { return sizeNext / 5; }).join('x'); | ||
filters = 'q10.foil1'; | ||
} | ||
sources.push({ | ||
srcSet: this.generateSrcset(operation, size.split('x').map(function (item) { return item / 5; }).join('x'), 'q10.foil1', imgSrc, config) | ||
srcSet: this.generateSrcset(operation, size, filters, imgSrc, config) | ||
}); | ||
@@ -321,2 +272,26 @@ } | ||
/** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getAdaptiveSize = /** | ||
* @param {?} size | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
function (size, config) { | ||
/** @type {?} */ | ||
var arrayOfSizes = size.split(','); | ||
/** @type {?} */ | ||
var sizes = []; | ||
arrayOfSizes.forEach(function (string) { | ||
/** @type {?} */ | ||
var groups = string.match(/((?<variable>[a-z_][a-z_]*)|(?<media>\([\S\s]*\)))\s*(?<size>[0-9xp]*)/).groups; | ||
/** @type {?} */ | ||
var media = groups.media ? groups.media : config.presets[groups.variable]; | ||
sizes.push({ media: media, size: groups.size }); | ||
}); | ||
return sizes; | ||
}; | ||
/** | ||
* @param {?} operation | ||
@@ -338,6 +313,3 @@ * @param {?} size | ||
function (operation, size, filters, imgSrc, config) { | ||
/** @type {?} */ | ||
var imgWidth = size.toString().split('x')[0]; | ||
/** @type {?} */ | ||
var imgHeight = size.toString().split('x')[1]; | ||
var _a = __read(size.toString().split('x'), 2), imgWidth = _a[0], imgHeight = _a[1]; | ||
return this.generateImgSrc(operation, filters, imgSrc, imgWidth, imgHeight, 1, config); | ||
@@ -388,2 +360,3 @@ }; | ||
function (size, config) { | ||
var _a, _b; | ||
/** @type {?} */ | ||
@@ -395,29 +368,9 @@ var width; | ||
/** @type {?} */ | ||
var breakPoint = this.getBreakPoint(config); | ||
var breakPointSource = this.getBreakPoint(size); | ||
/** @type {?} */ | ||
var orderIndex = config.order.indexOf(breakPoint); | ||
/** @type {?} */ | ||
var breakPointSize = null; | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndex]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndex--; | ||
} while (!breakPointSize && orderIndex >= 0); | ||
if (!breakPointSize) { | ||
/** @type {?} */ | ||
var orderIndexStepTwo = config.order.indexOf(breakPoint); | ||
do { | ||
/** @type {?} */ | ||
var nextBreakpoint = config.order[orderIndexStepTwo]; | ||
breakPointSize = size[nextBreakpoint]; | ||
orderIndexStepTwo++; | ||
} while (!breakPointSize && orderIndexStepTwo <= config.order.length); | ||
} | ||
width = breakPointSize.toString().split('x')[0]; | ||
height = breakPointSize.toString().split('x')[1]; | ||
var breakPointSize = breakPointSource ? breakPointSource.size : size[0].size; | ||
_a = __read(breakPointSize.toString().split('x'), 2), width = _a[0], height = _a[1]; | ||
} | ||
else { | ||
width = size.toString().split('x')[0]; | ||
height = size.toString().split('x')[1]; | ||
_b = __read(size.toString().split('x'), 2), width = _b[0], height = _b[1]; | ||
} | ||
@@ -430,16 +383,11 @@ if (width && height) { | ||
/** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
CIService.prototype.getBreakPoint = /** | ||
* @param {?} config | ||
* @param {?} size | ||
* @return {?} | ||
*/ | ||
function (config) { | ||
var presets = config.presets, order = config.order; | ||
/** @type {?} */ | ||
var innerWidth = window.innerWidth; | ||
/** @type {?} */ | ||
var prevBreakPointLimit = order.findIndex(function (item) { return presets[item] < innerWidth; }); | ||
return order[prevBreakPointLimit - 1] || order[prevBreakPointLimit] || order[order.length - 1]; | ||
function (size) { | ||
return __spread(size).reverse().find(function (item) { return matchMedia(item.media).matches; }); | ||
}; | ||
@@ -467,5 +415,8 @@ CIService.decorators = [ | ||
this._sanitizer = _sanitizer; | ||
this.class = ''; | ||
this.offset = 100; | ||
this.cloudimageUrl = ''; | ||
this.sources = []; | ||
this.firstSource = null; | ||
this.restSources = []; | ||
this.isLoaded = false; | ||
@@ -495,8 +446,5 @@ this.isProcessed = false; | ||
this.resizeSubscription$ = this.resizeObservable$.subscribe(function () { | ||
if (_this.isAdaptive) { | ||
if (_this.isAdaptive || _this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
else if (_this.windowInnerWidth < window.innerWidth) { | ||
_this.processImage(); | ||
} | ||
_this.windowInnerWidth = window.innerWidth; | ||
@@ -535,2 +483,3 @@ }); | ||
var isAdaptive = this.ciService.checkOnMedia(size); | ||
size = isAdaptive ? this.ciService.getAdaptiveSize(size, config) : size; | ||
/** @type {?} */ | ||
@@ -544,3 +493,3 @@ var isRelativeUrlPath = this.ciService.checkIfRelativeUrlPath(this.src); | ||
this.cloudimageUrl = isAdaptive ? | ||
this.ciService.generateUrl('width', parentContainerWidth, filters, imgSrc, config) : | ||
this.ciService.generateUrl('width', this.ciService.getSizeAccordingToPixelRatio(parentContainerWidth), filters, imgSrc, config) : | ||
this.ciService.generateUrl(operation, resultSize, filters, imgSrc, config); | ||
@@ -597,2 +546,25 @@ this.sources = isAdaptive ? | ||
*/ | ||
ImgComponent.prototype.getRestSources = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
return resultSources.slice(1).reverse(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getFirstSource = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var resultSources = __spread((!this.isPreview ? this.sources : (this.isPreviewLoaded ? this.sources : this.previewSources))); | ||
this.firstSource = resultSources[0]; | ||
return resultSources[0]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ImgComponent.prototype.getPositionStyle = /** | ||
@@ -611,3 +583,5 @@ * @return {?} | ||
function () { | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
// todo check if we need 100% height | ||
// return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? '100%' : 'auto'); | ||
return this._sanitizer.bypassSecurityTrustStyle(this.isRatio ? 'auto' : 'auto'); | ||
}; | ||
@@ -689,3 +663,3 @@ /** | ||
var result = 'transparent'; | ||
if (this.isRatio) { | ||
if (this.isRatio && !this.isPreviewLoaded && !this.isLoaded) { | ||
result = config.placeholderBackground; | ||
@@ -698,3 +672,3 @@ } | ||
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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\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 [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"firstSource\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\n [src]=\"!isPreview ? cloudimageUrl : (isPreviewLoaded ? cloudimageUrl : previewCloudimageUrl)\"\n [alt]=\"\">\n </picture>\n </div>\n </ng-container>\n " | ||
}] } | ||
@@ -701,0 +675,0 @@ ]; |
@@ -26,2 +26,4 @@ import { OnInit, AfterViewInit, ElementRef, OnDestroy } from '@angular/core'; | ||
sources: any[]; | ||
firstSource: any; | ||
restSources: any[]; | ||
isLoaded: boolean; | ||
@@ -47,2 +49,4 @@ isProcessed: boolean; | ||
onImageLoad(): void; | ||
getRestSources(): any[]; | ||
getFirstSource(): any; | ||
getPositionStyle(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle; | ||
@@ -49,0 +53,0 @@ getImgHeight(): import("@angular/platform-browser/src/security/dom_sanitization_service").SafeStyle; |
@@ -1,9 +0,8 @@ | ||
import { CIConfig } from './config.service'; | ||
import { CIConfig } from './config.model'; | ||
export declare class CIService { | ||
config: any; | ||
constructor(ciConfig: CIConfig); | ||
getPresets(value: string, type: any): any; | ||
getParentWidth(img: any, config: any): any; | ||
getParentContainerWithWidth(img: any): number; | ||
getSizeLimit(currentSize: any): "400" | "300" | "25" | "50" | "100" | "200" | "500" | "600" | "700" | "800" | "900" | "1000" | "1100" | "1200" | "1300" | "1400" | "1500" | "1600" | "1700" | "1800" | "1900" | "2400" | "2800" | "3600"; | ||
getSizeLimit(currentSize: any): string; | ||
checkOnMedia(size: any): boolean; | ||
@@ -15,6 +14,7 @@ checkIfRelativeUrlPath(src: any): boolean; | ||
generateSources(operation: any, size: any, filters: any, imgSrc: any, isAdaptive: any, config: any, isPreview: any): any[]; | ||
getAdaptiveSize(size: any, config: any): any[]; | ||
generateSrcset(operation: any, size: any, filters: any, imgSrc: any, config: any): string; | ||
generateImgSrc(operation: any, filters: any, imgSrc: any, imgWidth: any, imgHeight: any, factor: any, config: any): string; | ||
getRatioBySize(size: any, config: any): number; | ||
getBreakPoint(config: any): any; | ||
getBreakPoint(size: any): any; | ||
} |
@@ -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"}]}],"getPresets":[{"__symbolic":"method"}],"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"}],"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":6,"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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 (!isPreview ? sources : (isPreviewLoaded ? sources : previewSources))\"\n [media]=\"source.mediaQuery || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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":70,"character":3},"arguments":["imgElem"]}]}],"pictureElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":71,"character":3},"arguments":["pictureElem"]}]}],"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"class":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":73,"character":3}}]}],"alt":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3}}]}],"operation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"o":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":77,"character":3}}]}],"s":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"filters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":79,"character":3}}]}],"f":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3}}]}],"offset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3}}]}],"ngSwitch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":104,"character":64}]}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"processImage":[{"__symbolic":"method"}],"onImageLoad":[{"__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.service","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":6,"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 [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"getFirstSource()\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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 [attr.lazyLoad]=\"source.srcSet || ''\"\n [srcset]=\"source.srcSet || ''\"\n (load)=\"onImageLoad()\"\n />\n <source\n *ngIf=\"firstSource\"\n [attr.lazyLoad]=\"firstSource.srcSet || ''\"\n [srcset]=\"firstSource.srcSet || ''\"\n (load)=\"onImageLoad()\"\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()\"\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":83,"character":3},"arguments":["imgElem"]}]}],"pictureElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":84,"character":3},"arguments":["pictureElem"]}]}],"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"class":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":86,"character":3}}]}],"alt":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"operation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"o":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"s":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"filters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"f":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"ratio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3}}]}],"offset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":95,"character":3}}]}],"ngSwitch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":96,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CIService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":119,"character":64}]}],"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": "0.0.4", | ||
"description": "Cloudimage responsive plugin will make your website load the exact image size you need depending on your user's screen size. Multiple pixel ratios are supported.", | ||
"peerDependencies": { | ||
"@angular/common": "^7.0.0", | ||
"@angular/core": "^7.0.0", | ||
"rxjs": "^6.0.0" | ||
}, | ||
"version": "1.0.0", | ||
"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.", | ||
"author": "scaleflex", | ||
"license": "MIT", | ||
"repository": { | ||
@@ -15,6 +12,2 @@ "type": "git", | ||
"homepage": "https://github.com/scaleflex/ng-cloudimage-responsive#readme", | ||
"dependencies": { | ||
"ng-lazyload-image": "^5.0.0", | ||
"tslib": "^1.9.0" | ||
}, | ||
"keywords": [ | ||
@@ -41,4 +34,11 @@ "angular", | ||
], | ||
"author": "scaleflex", | ||
"license": "MIT", | ||
"peerDependencies": { | ||
"@angular/common": "^7.0.0", | ||
"@angular/core": "^7.0.0", | ||
"rxjs": "^6.0.0" | ||
}, | ||
"dependencies": { | ||
"ng-lazyload-image": "^5.0.0", | ||
"tslib": "^1.9.0" | ||
}, | ||
"main": "bundles/ng-cloudimage-responsive.umd.js", | ||
@@ -45,0 +45,0 @@ "module": "fesm5/ng-cloudimage-responsive.js", |
export * from './lib/lib.service'; | ||
export * from './lib/config.service'; | ||
export * from './lib/config.model'; | ||
export * from './lib/lib.module'; | ||
export * from './lib/img/img.component'; |
282
README.md
@@ -1,19 +0,93 @@ | ||
![](https://demo.cloudimg.io/width/800/none/sample.li/Cloudimage_diagram.jpeg) | ||
[![Release](https://img.shields.io/badge/release-v1.0.0-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) | ||
[![Contributions welcome](https://img.shields.io/badge/contributions-welcome-orange.svg)](#contributing) | ||
[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://opensource.org/licenses/MIT) | ||
[![Scaleflex team](https://img.shields.io/badge/%3C%2F%3E%20with%20%E2%99%A5%20by-the%20Scaleflex%20team-6986fa.svg)](https://www.scaleflex.it/en/home) | ||
[![Tweet](https://img.shields.io/twitter/url/http/shields.io.svg?style=social)](https://twitter.com/intent/tweet?text=Responsive%20images,%20now%20easier%20than%20ever&url=https://scaleflex.github.io/ng-cloudimage-responsive/&via=cloudimage&hashtags=react,images,cloudimage,responsive_images,lazy_loading,web_acceleration,image_optimization,image_CDN,image_CDNwebp,jpeg_xr,jpg_optimization,image_resizing_and_CDN,angular) | ||
<p align="center"> | ||
<img | ||
height="175" | ||
alt="The Lounge" | ||
src="https://demo.cloudimg.io/height/350/n/https://scaleflex.airstore.io/filerobot/filerobot-cloudimage.png?sanitize=true"> | ||
</p> | ||
<h1 align="center"> | ||
Angular Cloudimage Responsive | ||
</h1> | ||
<p align="center"> | ||
<strong> | ||
<a href="#table_of_contents">Docs</a> | ||
• | ||
<a href="https://scaleflex.github.io/ng-cloudimage-responsive/" target="_blank">Demo</a> | ||
• | ||
<a href="#" target="_blank">Why?</a> | ||
</strong> | ||
</p> | ||
This plugin detects the width of any image container as well as the device pixel ratio | ||
density to load the optimal image size needed. | ||
Images are resized on-the-fly via the <a href="https://cloudimage.io" target="_blank">Cloudimage service</a>, thus offering a comprehensive | ||
automated image optimization service. | ||
When an image is first loaded on your website or mobile app, | ||
Cloudimage's resizing servers will download the origin image from | ||
the source, resize it for the client's screen size and deliver to your users through one or multiple | ||
Content Delivery Networks (CDNs). The generated image formats are cached in the CDN and will be delivered rocket fast on any subsequent request. | ||
**NOTE:** Your original (master) images should be stored on a server | ||
or storage bucket (S3, Google Cloud, Azure Blob...) reachable over | ||
HTTP or HTTPS by Cloudimage. If you want to upload your master images to | ||
Cloudimage, contact us at | ||
[hello@cloudimage.io](mailto:hello@cloudimage.io). | ||
<p align="center"> | ||
<img | ||
alt="The Lounge" | ||
src="https://demo.cloudimg.io/width/1400/n/https://demo.cloudimg.io/width/800/none/sample.li/Cloudimage_diagram.jpeg?sanitize=true"> | ||
</p> | ||
powered by [Cloudimage](https://www.cloudimage.io/) | ||
([Watch the video here](https://www.youtube.com/watch?time_continue=2&v=JFZSE1vYb0k)) | ||
## Cloudimage Angular Plugin | ||
## Table of contents | ||
Cloudimage Responsive plugin will resize, compress and accelerate images across the World in your Angular application. It leverages the HTML5 `<picture>` and `srcset` elements to deliver the right image size based on the client's screen size and pixel ratio (retina or non-retina). | ||
* [Demo](#demo) | ||
* [Requirements](#requirements) | ||
* [Step 1: Installation](#installation) | ||
* [Step 2: Initialize](#initialize) | ||
* [Step 3: Implement](#implement) | ||
* [Configuration](#configuration) | ||
* [Image properties](#image_properties) | ||
* [Lazy loading](#lazy_loading) | ||
* [Browser support](#browser_support) | ||
* [Filerobot UI Family](#ui_family) | ||
* [Contributing](#contributing) | ||
* [License](#license) | ||
**NOTE:** Your original (master) images should be stored on a server or storage bucket (S3, Google Cloud, Azure Blob...) reachable over HTTP or HTTPS by Cloudimage. If you want to upload your master images to Cloudimage, contact us at [hello@cloudimage.io](mailto:hello@cloudimage.io). | ||
## <a name="demo"></a> Demo | ||
## Demo | ||
To see the Cloudimage Responsive plugin in action, please check out the | ||
[Demo page](https://scaleflex.github.io/ng-cloudimage-responsive/). | ||
Play with your browser's window size and observe your | ||
Inspector's Network tab to see how Cloudimage delivers the optimal | ||
image size to your browser, hence accelerating the overall page | ||
loading time. | ||
To see the Cloudimage Responsive plugin in action, please check out the [Demo page](https://scaleflex.github.io/ng-cloudimage-responsive/). Play with your browser's viewport size and observe your Inspector's Network tab to see how Cloudimage delivers the optimal image size to your browser, hence accelerating the overall page loading time. | ||
## <a name="requirements"/> Requirements | ||
## Installation | ||
To use the Cloudimage Responsive plugin, you will need a | ||
Cloudimage token to deliver your images over CDN. Don't worry, it only takes seconds to get one by | ||
registering [here](https://www.cloudimage.io/en/register_page). | ||
Once your token is created, you can configure it as described below. | ||
This token allows you to use 25GB of image cache and 25GB of worldwide | ||
CDN traffic per month for free. | ||
## <a name="installation"></a>Step 1: Installation | ||
using npm | ||
``` | ||
@@ -23,8 +97,11 @@ $ npm install --save ng-cloudimage-responsive | ||
And then include it in your module (see app.module.ts): | ||
## <a name="initialize"></a>Step 2: Initialize | ||
After installing the ng-cloudimage-responsive lib, simply initialize it with your **token** and the **baseUrl** | ||
of your image storage: | ||
```javascript | ||
import { NgModule } from '@angular/core'; | ||
import { BrowserModule } from '@angular/platform-browser'; | ||
import { CIModule, CIService, CIConfig } from 'ng-cloudimage-responsive'; | ||
import { CIModule, CIConfig } from 'ng-cloudimage-responsive'; | ||
import { AppComponent } from './app.component'; | ||
@@ -41,4 +118,3 @@ | ||
providers: [ | ||
{provide: CIConfig, useValue: ciConfig}, | ||
CIService | ||
{provide: CIConfig, useValue: ciConfig} | ||
], | ||
@@ -50,15 +126,15 @@ bootstrap: [ AppComponent ] | ||
## Simple Usage | ||
## <a name="implement"></a>Step 3: Implement it | ||
Finally, just use the ci-img component: | ||
```html | ||
<ci-img src="img.jpg" alt="Demo image" ratio="1.5"></ci-img> | ||
``` | ||
Note: as you see, using the Cloudimage plugin is very easy - just use the `ci-img` instead of the `img` tag. | ||
## Requirements | ||
NOTE: "ratio" is recommended to prevent page layout jumping. The parameter is used to calculate image height to hold | ||
the image position while image is loading. | ||
To use the Cloudimage Responsive plugin, you will need a Cloudimage token. Don't worry, it only takes seconds to get one by registering [here](https://www.cloudimage.io/en/register_page). Once your token is created, you can configure it as described below. This token allows you to use 25GB of image cache and 25GB of worldwide CDN traffic per month for free. | ||
## <a name="configuration"></a> Config | ||
## Config | ||
### token | ||
@@ -68,15 +144,19 @@ | ||
Your Cloudimage customer token. [Subscribe](https://www.cloudimage.io/en/register_page) for a Cloudimage account to get one. The subscription takes less than a minute and is totally free | ||
Your Cloudimage customer token. | ||
[Subscribe](https://www.cloudimage.io/en/register_page) for a | ||
Cloudimage account to get one. The subscription takes less than a | ||
minute and is totally free. | ||
### lazyLoading | ||
### baseUrl | ||
###### Type: **Bool** | Default: **true** | _required_ | ||
###### Type: **String** | Default: **"/"** | _optional_ | ||
Only load images close to the viewport | ||
Your image folder on server, this alows to shorten your origin image URLs. | ||
### imgLoadingAnimation | ||
### lazyLoading | ||
###### Type: **Bool** | Default: **true** | _required_ | ||
###### Type: **Bool** | Default: **true** | _optional_ | ||
Nice effect for preview transition | ||
Only images close to the client's viewport will be loaded, hence accelerating the page loading time. The plugin uses | ||
[ng-lazyload-image](https://github.com/tjoskar/ng-lazyload-image) library to achieve it. | ||
@@ -90,2 +170,8 @@ ### lazyLoadOffset | ||
### imgLoadingAnimation | ||
###### Type: **Bool** | Default: **true** | _optional_ | ||
Applies a nice interlacing effect for preview transition | ||
### filters | ||
@@ -95,5 +181,8 @@ | ||
Parameters like fcontrast, fpixelate, fgaussian, backtransparent, | ||
rotation to apply filters on your image by default | ||
Applies default Cloudimage filters to your image, e.g. fcontrast, fpixelate, fgaussian, backtransparent, | ||
rotation... Multiple filters can be applied, separated by "```.```" (dot). | ||
[Full documentaiton here.](https://docs.cloudimage.io/go/cloudimage-documentation/en/filters/) | ||
### placeholderBackground | ||
@@ -103,32 +192,53 @@ | ||
Parameters like fcontrast, fpixelate, fgaussian, backtransparent, | ||
rotation to apply filters on your image by default | ||
Placeholder colored background while the image is loading | ||
### baseUrl | ||
### presets | ||
###### Type: **String** | Default: **"/"** | _optional_ | ||
###### Type: **Object** | ||
Your image folder on server. | ||
Default: | ||
```javascript | ||
const ciConfig = { | ||
token: 'demo', | ||
baseUrl: 'https://jolipage.airstore.io/', | ||
... | ||
presets: { | ||
xs: '(max-width: 575px)', // up to 575 PHONE | ||
sm: '(min-width: 576px)', // 576 - 767 PHABLET | ||
md: '(min-width: 768px)', // 768 - 991 TABLET | ||
lg: '(min-width: 992px)', // 992 - 1199 SMALL_LAPTOP_SCREEN | ||
xl: '(min-width: 1200px)' // from 1200 USUALSCREEN | ||
} | ||
}; | ||
``` | ||
## Image properties | ||
Breakpoints shortcuts to use in image size property, can be overwridden. | ||
## <a name="image_properties"></a> Image properties | ||
### src | ||
###### Type: **String** | _required_ | ||
###### Type: **String** | Default: **undefined** | _required_ | ||
Original image hosted on your web server. | ||
Original image hosted on your web server. You can use absolute path or | ||
relative to baseUrl in your config. | ||
### operation/o | ||
**NOTES:** | ||
[see doc](https://docs.cloudimage.io/go/cloudimage-documentation/en/operations/) | ||
The plugin uses a special algorithm to detect the width of image container and set the image size accordingly. | ||
This is the recommended way of using the Cloudimage Responsive plugin. | ||
### operation (or o) | ||
###### Type: **String** | Default: **width** | _optional_ | ||
**width** - to resize with a specific width | ||
Operation allows to customize the behaviour of the plugin for specific images: | ||
**height** - to resize with a specific height | ||
**width** - to resize with a specific width. This is useful when you want to have a fixed width, regardless of screen size. | ||
**crop** - to crop the image at the center | ||
**height** - to resize with a specific height. This is useful when you want to have a fixed height, regardless of screen size. | ||
**crop** - to crop the image around the center | ||
**fit** - to resize the image in a box and keeping the proportions of the source image | ||
@@ -138,6 +248,12 @@ | ||
### size/s | ||
**NOTES:** | ||
###### Type: **String/Object** | _optional_ | ||
When you use an operation, you must specify the size for each screen size, see below | ||
Full documentation of all operations available [here](https://docs.cloudimage.io/go/cloudimage-documentation/en/operations/) | ||
### size (or s) | ||
###### Type: **String** | Default: **undefined** | _optional_ but _required_ when using operation | ||
Size of an image which is used as a base for creating retina ready and responsive image element. | ||
@@ -147,20 +263,59 @@ | ||
**[width]**: s="250" => width: 250 * PR (px); height: auto; | ||
**[width]**: | ||
**[width x height]**: s="125x200" => width: 125 * PR (px); height: 200 * PR (px); | ||
```html | ||
<ci-img | ||
src="dino-reichmuth-1.jpg" | ||
operation="width" | ||
size="250"/> | ||
``` | ||
=> width: 250 * PR (px); height: auto; | ||
**[width x height]**: | ||
```html | ||
<ci-img | ||
src="dino-reichmuth-1.jpg" | ||
operation="width" | ||
size="125x200"/> | ||
``` | ||
=> width: 125 * PR (px); height: 200 * PR (px); | ||
**[Width and height for different screen resolutions]**: | ||
s={{ xs: '50x100', sm:'100x125', md: '150x150', lg:'200x175', xl:'300x200' }} | ||
```html | ||
<ci-img | ||
src="dino-reichmuth-1.jpg" | ||
operation="crop" | ||
size=" | ||
sm 800x400, | ||
(min-width: 620px) 200x20, | ||
md 1000x1350, | ||
lg 1400x1200, | ||
xl 1600x1000 | ||
"/> | ||
``` | ||
*You can drop some breakpoints, for example s={{ sm:'100x125', xl:'300x200' }} | ||
You can drop some breakpoints, for example: | ||
**NOTE:** if size is set to **undefined**, Cloudimage uses a special | ||
algorithm to detect the width of image container and set the image size | ||
accordingly. | ||
```html | ||
<ci-img | ||
src="dino-reichmuth-1.jpg" | ||
operation="crop" | ||
size="md 1000x1350, lg 1400x1200"/> | ||
``` | ||
### filters/f | ||
**NOTE:** if size is not set, the plugin uses a special algorithm to | ||
detect the width of image container and set the image size accordingly. This is the recommended way of using | ||
the Cloudimage Responsive plugin. | ||
[see doc](https://docs.cloudimage.io/go/cloudimage-documentation/en/filters/) | ||
For example: | ||
```html | ||
<ci-img src="dino-reichmuth-1.jpg"/> | ||
``` | ||
### filters (or f) | ||
###### Type: **String** | Default: **none** | _optional_ | ||
@@ -182,5 +337,30 @@ | ||
Full documentation of all filters available [here](https://docs.cloudimage.io/go/cloudimage-documentation/en/filters/) | ||
*** | ||
### ratio (or r) | ||
###### Type: **Number** | _optional_ | ||
It is recommended to prevent page layout jumping. The parameter is used to calculate image height to hold | ||
the image position while image is loading. | ||
To see the full cloudimage documentation [click here](https://docs.cloudimage.io/go/cloudimage-documentation) | ||
## <a name="browser_support"></a>Browser support | ||
Tested in all modern browsers and IE 11. | ||
## <a name="ui_family"></a>Filerobot UI Familiy | ||
* [JS Cloudimage Responsive](https://github.com/scaleflex/js-cloudimage-responsive) | ||
* [React Cloudimage Responsive](https://github.com/scaleflex/react-cloudimage-responsive) | ||
* [Image Editor](https://github.com/scaleflex/filerobot-image-editor) | ||
* [Uploader](https://github.com/scaleflex/filerobot-uploader) | ||
## <a name="contributing"></a>Contributing! | ||
All contributions are super welcome! | ||
## <a name="license"></a>License | ||
Angular Cloudimage Responsive is provided under the [MIT License](https://opensource.org/licenses/MIT) |
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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Mixed license
License(Experimental) Package contains multiple licenses.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
1
357
410489
1
3901