vanilla-lazyload
Advanced tools
Comparing version 17.8.4 to 17.8.5
@@ -88,3 +88,3 @@ define(function () { 'use strict'; | ||
}; | ||
/* Auto initialization of one or more instances of lazyload, depending on the | ||
/* Auto initialization of one or more instances of LazyLoad, depending on the | ||
options passed in (plain object or an array) */ | ||
@@ -165,3 +165,3 @@ | ||
var safeCallback = function safeCallback(callback, arg1, arg2, arg3) { | ||
if (!callback) { | ||
if (!callback || typeof callback !== 'function') { | ||
return; | ||
@@ -428,3 +428,3 @@ } | ||
if (element.style.backgroundImage === '') { | ||
if (element.style.backgroundImage === "") { | ||
bgImageValues = imgSetValues.map(function (value) { | ||
@@ -665,3 +665,3 @@ return "-webkit-image-set(".concat(value, ")"); | ||
var dontLoad = hadStartedLoading(element); | ||
/* Save status | ||
/* Save status | ||
before setting it, to prevent loading it again. Fixes #526. */ | ||
@@ -668,0 +668,0 @@ |
@@ -1,1 +0,1 @@ | ||
define((function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,o=t&&"classList"in document.createElement("p"),a=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",m="applied",p="error",h="native",E="data-",I="ll-status",k=function(n,t){return n.getAttribute(E+t)},w=function(n){return k(n,I)},y=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return y(n,null)},L=function(n){return null===w(n)},O=function(n){return w(n)===h},C=[v,b,m,p],x=function(n,t,e,i){n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},R=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},T=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},D=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},H=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&D(e).forEach(t)},V=function(n,t){D(n).forEach(t)},j=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),y(n,m),e&&(t.unobserve_completed&&R(n,t),x(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),y(n,v),e&&(T(e,1),x(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,k(n,t.data_sizes)),W(n,s,k(n,t.data_srcset)),W(n,u,k(n,t.data_src))},Y={IMG:function(n,t){H(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,j),W(n,u,k(n,t.data_src))},VIDEO:function(n,t){V(n,(function(n){$(n,j),W(n,u,k(n,t.data_src))})),$(n,F),W(n,f,k(n,t.data_poster)),W(n,u,k(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,k(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||x(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),T(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&R(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),y(t,b),x(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),y(t,p),x(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=k(n,t.data_bg),o=k(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_multi),o=k(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_set);if(i){var o=i.split("|"),a=o.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=a.join(),""===n.style.backgroundImage&&(a=o.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){H(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,j)},VIDEO:function(n){V(n,(function(n){q(n,j)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return C.indexOf(w(n))>=0}(n);y(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&R(n,e)}(n,e,i),x(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return w(n)===v}(n)&&"IMG"===n.tagName&&(an(n),function(n){H(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),T(i,-1),A(n),x(e.callback_cancel,n,t,i))}(n,t,e,i),x(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return w(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),y(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){R(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En})); | ||
define((function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,o=t&&"classList"in document.createElement("p"),a=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",m="applied",p="error",h="native",E="data-",I="ll-status",k=function(n,t){return n.getAttribute(E+t)},y=function(n){return k(n,I)},w=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===y(n)},O=function(n){return y(n)===h},C=[v,b,m,p],x=function(n,t,e,i){n&&"function"==typeof n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},R=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},T=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},D=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},H=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&D(e).forEach(t)},V=function(n,t){D(n).forEach(t)},j=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,m),e&&(t.unobserve_completed&&R(n,t),x(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(T(e,1),x(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,k(n,t.data_sizes)),W(n,s,k(n,t.data_srcset)),W(n,u,k(n,t.data_src))},Y={IMG:function(n,t){H(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,j),W(n,u,k(n,t.data_src))},VIDEO:function(n,t){V(n,(function(n){$(n,j),W(n,u,k(n,t.data_src))})),$(n,F),W(n,f,k(n,t.data_poster)),W(n,u,k(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,k(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||x(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),T(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&R(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),x(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),w(t,p),x(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=k(n,t.data_bg),o=k(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_multi),o=k(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_set);if(i){var o=i.split("|"),a=o.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=a.join(),""===n.style.backgroundImage&&(a=o.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){H(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,j)},VIDEO:function(n){V(n,(function(n){q(n,j)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return C.indexOf(y(n))>=0}(n);w(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&R(n,e)}(n,e,i),x(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return y(n)===v}(n)&&"IMG"===n.tagName&&(an(n),function(n){H(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),T(i,-1),A(n),x(e.callback_cancel,n,t,i))}(n,t,e,i),x(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return y(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){R(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En})); |
const runningOnBrowser = typeof window !== "undefined"; | ||
const isBot = | ||
(runningOnBrowser && !("onscroll" in window)) || | ||
(typeof navigator !== "undefined" && /(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent)); | ||
(runningOnBrowser && !("onscroll" in window)) || | ||
(typeof navigator !== "undefined" && /(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent)); | ||
@@ -14,38 +14,38 @@ const supportsIntersectionObserver = runningOnBrowser && "IntersectionObserver" in window; | ||
const defaultSettings = { | ||
elements_selector: ".lazy", | ||
container: isBot || runningOnBrowser ? document : null, | ||
threshold: 300, | ||
thresholds: null, | ||
data_src: "src", | ||
data_srcset: "srcset", | ||
data_sizes: "sizes", | ||
data_bg: "bg", | ||
data_bg_hidpi: "bg-hidpi", | ||
data_bg_multi: "bg-multi", | ||
data_bg_multi_hidpi: "bg-multi-hidpi", | ||
data_bg_set: "bg-set", | ||
data_poster: "poster", | ||
class_applied: "applied", | ||
class_loading: "loading", | ||
class_loaded: "loaded", | ||
class_error: "error", | ||
class_entered: "entered", | ||
class_exited: "exited", | ||
unobserve_completed: true, | ||
unobserve_entered: false, | ||
cancel_on_exit: true, | ||
callback_enter: null, | ||
callback_exit: null, | ||
callback_applied: null, | ||
callback_loading: null, | ||
callback_loaded: null, | ||
callback_error: null, | ||
callback_finish: null, | ||
callback_cancel: null, | ||
use_native: false, | ||
restore_on_error: false, | ||
elements_selector: ".lazy", | ||
container: isBot || runningOnBrowser ? document : null, | ||
threshold: 300, | ||
thresholds: null, | ||
data_src: "src", | ||
data_srcset: "srcset", | ||
data_sizes: "sizes", | ||
data_bg: "bg", | ||
data_bg_hidpi: "bg-hidpi", | ||
data_bg_multi: "bg-multi", | ||
data_bg_multi_hidpi: "bg-multi-hidpi", | ||
data_bg_set: "bg-set", | ||
data_poster: "poster", | ||
class_applied: "applied", | ||
class_loading: "loading", | ||
class_loaded: "loaded", | ||
class_error: "error", | ||
class_entered: "entered", | ||
class_exited: "exited", | ||
unobserve_completed: true, | ||
unobserve_entered: false, | ||
cancel_on_exit: true, | ||
callback_enter: null, | ||
callback_exit: null, | ||
callback_applied: null, | ||
callback_loading: null, | ||
callback_loaded: null, | ||
callback_error: null, | ||
callback_finish: null, | ||
callback_cancel: null, | ||
use_native: false, | ||
restore_on_error: false | ||
}; | ||
const getExtendedSettings = (customSettings) => { | ||
return Object.assign({}, defaultSettings, customSettings); | ||
return Object.assign({}, defaultSettings, customSettings); | ||
}; | ||
@@ -55,31 +55,31 @@ | ||
const createInstance = function(classObj, options) { | ||
let event; | ||
const eventString = "LazyLoad::Initialized"; | ||
const instance = new classObj(options); | ||
try { | ||
// Works in modern browsers | ||
event = new CustomEvent(eventString, { detail: { instance } }); | ||
} catch (err) { | ||
// Works in Internet Explorer (all versions) | ||
event = document.createEvent("CustomEvent"); | ||
event.initCustomEvent(eventString, false, false, { instance }); | ||
} | ||
window.dispatchEvent(event); | ||
let event; | ||
const eventString = "LazyLoad::Initialized"; | ||
const instance = new classObj(options); | ||
try { | ||
// Works in modern browsers | ||
event = new CustomEvent(eventString, { detail: { instance } }); | ||
} catch (err) { | ||
// Works in Internet Explorer (all versions) | ||
event = document.createEvent("CustomEvent"); | ||
event.initCustomEvent(eventString, false, false, { instance }); | ||
} | ||
window.dispatchEvent(event); | ||
}; | ||
/* Auto initialization of one or more instances of lazyload, depending on the | ||
/* Auto initialization of one or more instances of LazyLoad, depending on the | ||
options passed in (plain object or an array) */ | ||
const autoInitialize = (classObj, options) => { | ||
if (!options) { | ||
return; | ||
if (!options) { | ||
return; | ||
} | ||
if (!options.length) { | ||
// Plain object | ||
createInstance(classObj, options); | ||
} else { | ||
// Array of objects | ||
for (let i = 0, optionsItem; (optionsItem = options[i]); i += 1) { | ||
createInstance(classObj, optionsItem); | ||
} | ||
if (!options.length) { | ||
// Plain object | ||
createInstance(classObj, options); | ||
} else { | ||
// Array of objects | ||
for (let i = 0, optionsItem; (optionsItem = options[i]); i += 1) { | ||
createInstance(classObj, optionsItem); | ||
} | ||
} | ||
} | ||
}; | ||
@@ -105,12 +105,12 @@ | ||
const getData = (element, attribute) => { | ||
return element.getAttribute(dataPrefix + attribute); | ||
return element.getAttribute(dataPrefix + attribute); | ||
}; | ||
const setData = (element, attribute, value) => { | ||
var attrName = dataPrefix + attribute; | ||
if (value === null) { | ||
element.removeAttribute(attrName); | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
const attrName = dataPrefix + attribute; | ||
if (value === null) { | ||
element.removeAttribute(attrName); | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
}; | ||
@@ -131,42 +131,38 @@ | ||
const safeCallback = (callback, arg1, arg2, arg3) => { | ||
if (!callback) { | ||
return; | ||
} | ||
if (arg3 !== undefined) { | ||
callback(arg1, arg2, arg3); | ||
return; | ||
} | ||
if (arg2 !== undefined) { | ||
callback(arg1, arg2); | ||
return; | ||
} | ||
callback(arg1); | ||
if (!callback || typeof callback !== 'function') { | ||
return; | ||
} | ||
if (arg3 !== undefined) { | ||
callback(arg1, arg2, arg3); | ||
return; | ||
} | ||
if (arg2 !== undefined) { | ||
callback(arg1, arg2); | ||
return; | ||
} | ||
callback(arg1); | ||
}; | ||
const addClass = (element, className) => { | ||
if (supportsClassList) { | ||
element.classList.add(className); | ||
return; | ||
} | ||
element.className += (element.className ? " " : "") + className; | ||
if (supportsClassList) { | ||
element.classList.add(className); | ||
return; | ||
} | ||
element.className += (element.className ? " " : "") + className; | ||
}; | ||
const removeClass = (element, className) => { | ||
if (supportsClassList) { | ||
element.classList.remove(className); | ||
return; | ||
} | ||
element.className = element.className. | ||
replace(new RegExp("(^|\\s+)" + className + "(\\s+|$)"), " "). | ||
replace(/^\s+/, ""). | ||
replace(/\s+$/, ""); | ||
if (supportsClassList) { | ||
element.classList.remove(className); | ||
return; | ||
} | ||
element.className = element.className.replace(new RegExp("(^|\\s+)" + className + "(\\s+|$)"), " ").replace(/^\s+/, "").replace(/\s+$/, ""); | ||
}; | ||
const addTempImage = (element) => { | ||
element.llTempImage = document.createElement("IMG"); | ||
element.llTempImage = document.createElement("IMG"); | ||
}; | ||
const deleteTempImage = (element) => { | ||
delete element.llTempImage; | ||
delete element.llTempImage; | ||
}; | ||
@@ -177,29 +173,29 @@ | ||
const unobserve = (element, instance) => { | ||
if (!instance) return; | ||
const observer = instance._observer; | ||
if (!observer) return; | ||
observer.unobserve(element); | ||
if (!instance) return; | ||
const observer = instance._observer; | ||
if (!observer) return; | ||
observer.unobserve(element); | ||
}; | ||
const resetObserver = (observer) => { | ||
observer.disconnect(); | ||
observer.disconnect(); | ||
}; | ||
const unobserveEntered = (element, settings, instance) => { | ||
if (settings.unobserve_entered) unobserve(element, instance); | ||
if (settings.unobserve_entered) unobserve(element, instance); | ||
}; | ||
const updateLoadingCount = (instance, delta) => { | ||
if (!instance) return; | ||
instance.loadingCount += delta; | ||
if (!instance) return; | ||
instance.loadingCount += delta; | ||
}; | ||
const decreaseToLoadCount = (instance) => { | ||
if (!instance) return; | ||
instance.toLoadCount -= 1; | ||
if (!instance) return; | ||
instance.toLoadCount -= 1; | ||
}; | ||
const setToLoadCount = (instance, value) => { | ||
if (!instance) return; | ||
instance.toLoadCount = value; | ||
if (!instance) return; | ||
instance.toLoadCount = value; | ||
}; | ||
@@ -214,5 +210,5 @@ | ||
for (let i = 0, childTag; (childTag = parentTag.children[i]); i += 1) { | ||
if (childTag.tagName === "SOURCE") { | ||
sourceTags.push(childTag); | ||
} | ||
if (childTag.tagName === "SOURCE") { | ||
sourceTags.push(childTag); | ||
} | ||
} | ||
@@ -225,3 +221,3 @@ return sourceTags; | ||
if (!parent || parent.tagName !== "PICTURE") { | ||
return; | ||
return; | ||
} | ||
@@ -249,17 +245,17 @@ let sourceTags = getSourceTags(parent); | ||
const setOriginalsObject = (element, attributes) => { | ||
if (hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = {}; | ||
attributes.forEach((attribute) => { | ||
originals[attribute] = element.getAttribute(attribute); | ||
}); | ||
element[ORIGINALS] = originals; | ||
if (hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = {}; | ||
attributes.forEach((attribute) => { | ||
originals[attribute] = element.getAttribute(attribute); | ||
}); | ||
element[ORIGINALS] = originals; | ||
}; | ||
const saveOriginalBackgroundStyle = (element) => { | ||
if (hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
element[ORIGINALS] = { backgroundImage: element.style.backgroundImage }; | ||
if (hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
element[ORIGINALS] = { backgroundImage: element.style.backgroundImage }; | ||
}; | ||
@@ -270,100 +266,100 @@ | ||
const setOrResetAttribute = (element, attrName, value) => { | ||
if (!value) { | ||
element.removeAttribute(attrName); | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
if (!value) { | ||
element.removeAttribute(attrName); | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
}; | ||
const restoreOriginalAttrs = (element, attributes) => { | ||
if (!hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = getOriginalAttrs(element); | ||
attributes.forEach((attribute) => { | ||
setOrResetAttribute(element, attribute, originals[attribute]); | ||
}); | ||
if (!hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = getOriginalAttrs(element); | ||
attributes.forEach((attribute) => { | ||
setOrResetAttribute(element, attribute, originals[attribute]); | ||
}); | ||
}; | ||
const restoreOriginalBgImage = (element) => { | ||
if (!hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = getOriginalAttrs(element); | ||
element.style.backgroundImage = originals.backgroundImage; | ||
if (!hasOriginalAttrs(element)) { | ||
return; | ||
} | ||
const originals = getOriginalAttrs(element); | ||
element.style.backgroundImage = originals.backgroundImage; | ||
}; | ||
const manageApplied = (element, settings, instance) => { | ||
addClass(element, settings.class_applied); | ||
setStatus(element, statusApplied); | ||
// Instance is not provided when loading is called from static class | ||
if (!instance) return; | ||
if (settings.unobserve_completed) { | ||
// Unobserve now because we can't do it on load | ||
unobserve(element, settings); | ||
} | ||
safeCallback(settings.callback_applied, element, instance); | ||
addClass(element, settings.class_applied); | ||
setStatus(element, statusApplied); | ||
// Instance is not provided when loading is called from static class | ||
if (!instance) return; | ||
if (settings.unobserve_completed) { | ||
// Unobserve now because we can't do it on load | ||
unobserve(element, settings); | ||
} | ||
safeCallback(settings.callback_applied, element, instance); | ||
}; | ||
const manageLoading = (element, settings, instance) => { | ||
addClass(element, settings.class_loading); | ||
setStatus(element, statusLoading); | ||
// Instance is not provided when loading is called from static class | ||
if (!instance) return; | ||
updateLoadingCount(instance, +1); | ||
safeCallback(settings.callback_loading, element, instance); | ||
addClass(element, settings.class_loading); | ||
setStatus(element, statusLoading); | ||
// Instance is not provided when loading is called from static class | ||
if (!instance) return; | ||
updateLoadingCount(instance, +1); | ||
safeCallback(settings.callback_loading, element, instance); | ||
}; | ||
const setAttributeIfValue = (element, attrName, value) => { | ||
if (!value) { | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
if (!value) { | ||
return; | ||
} | ||
element.setAttribute(attrName, value); | ||
}; | ||
const setImageAttributes = (element, settings) => { | ||
setAttributeIfValue(element, SIZES, getData(element, settings.data_sizes)); | ||
setAttributeIfValue(element, SRCSET, getData(element, settings.data_srcset)); | ||
setAttributeIfValue(element, SRC, getData(element, settings.data_src)); | ||
setAttributeIfValue(element, SIZES, getData(element, settings.data_sizes)); | ||
setAttributeIfValue(element, SRCSET, getData(element, settings.data_srcset)); | ||
setAttributeIfValue(element, SRC, getData(element, settings.data_src)); | ||
}; | ||
const setSourcesImg = (imgEl, settings) => { | ||
forEachPictureSource(imgEl, (sourceTag) => { | ||
setOriginalsObject(sourceTag, attrsSrcSrcsetSizes); | ||
setImageAttributes(sourceTag, settings); | ||
}); | ||
setOriginalsObject(imgEl, attrsSrcSrcsetSizes); | ||
setImageAttributes(imgEl, settings); | ||
forEachPictureSource(imgEl, (sourceTag) => { | ||
setOriginalsObject(sourceTag, attrsSrcSrcsetSizes); | ||
setImageAttributes(sourceTag, settings); | ||
}); | ||
setOriginalsObject(imgEl, attrsSrcSrcsetSizes); | ||
setImageAttributes(imgEl, settings); | ||
}; | ||
const setSourcesIframe = (iframe, settings) => { | ||
setOriginalsObject(iframe, attrsSrc); | ||
setAttributeIfValue(iframe, SRC, getData(iframe, settings.data_src)); | ||
setOriginalsObject(iframe, attrsSrc); | ||
setAttributeIfValue(iframe, SRC, getData(iframe, settings.data_src)); | ||
}; | ||
const setSourcesVideo = (videoEl, settings) => { | ||
forEachVideoSource(videoEl, (sourceEl) => { | ||
setOriginalsObject(sourceEl, attrsSrc); | ||
setAttributeIfValue(sourceEl, SRC, getData(sourceEl, settings.data_src)); | ||
}); | ||
setOriginalsObject(videoEl, attrsSrcPoster); | ||
forEachVideoSource(videoEl, (sourceEl) => { | ||
setOriginalsObject(sourceEl, attrsSrc); | ||
setAttributeIfValue(sourceEl, SRC, getData(sourceEl, settings.data_src)); | ||
}); | ||
setOriginalsObject(videoEl, attrsSrcPoster); | ||
setAttributeIfValue(videoEl, POSTER, getData(videoEl, settings.data_poster)); | ||
setAttributeIfValue(videoEl, SRC, getData(videoEl, settings.data_src)); | ||
videoEl.load(); | ||
setAttributeIfValue(videoEl, POSTER, getData(videoEl, settings.data_poster)); | ||
setAttributeIfValue(videoEl, SRC, getData(videoEl, settings.data_src)); | ||
videoEl.load(); | ||
}; | ||
const setSourcesObject = (object, settings) => { | ||
setOriginalsObject(object, attrsData); | ||
setAttributeIfValue(object, DATA, getData(object, settings.data_src)); | ||
setOriginalsObject(object, attrsData); | ||
setAttributeIfValue(object, DATA, getData(object, settings.data_src)); | ||
}; | ||
const setBackground = (element, settings, instance) => { | ||
const bg1xValue = getData(element, settings.data_bg); | ||
const bgHiDpiValue = getData(element, settings.data_bg_hidpi); | ||
const bgDataValue = isHiDpi && bgHiDpiValue ? bgHiDpiValue : bg1xValue; | ||
if (!bgDataValue) return; | ||
element.style.backgroundImage = `url("${bgDataValue}")`; | ||
getTempImage(element).setAttribute(SRC, bgDataValue); | ||
manageLoading(element, settings, instance); | ||
const bg1xValue = getData(element, settings.data_bg); | ||
const bgHiDpiValue = getData(element, settings.data_bg_hidpi); | ||
const bgDataValue = isHiDpi && bgHiDpiValue ? bgHiDpiValue : bg1xValue; | ||
if (!bgDataValue) return; | ||
element.style.backgroundImage = `url("${bgDataValue}")`; | ||
getTempImage(element).setAttribute(SRC, bgDataValue); | ||
manageLoading(element, settings, instance); | ||
}; | ||
@@ -375,50 +371,50 @@ | ||
const setMultiBackground = (element, settings, instance) => { | ||
const bg1xValue = getData(element, settings.data_bg_multi); | ||
const bgHiDpiValue = getData(element, settings.data_bg_multi_hidpi); | ||
const bgDataValue = isHiDpi && bgHiDpiValue ? bgHiDpiValue : bg1xValue; | ||
if (!bgDataValue) { | ||
return; | ||
} | ||
element.style.backgroundImage = bgDataValue; | ||
manageApplied(element, settings, instance); | ||
const bg1xValue = getData(element, settings.data_bg_multi); | ||
const bgHiDpiValue = getData(element, settings.data_bg_multi_hidpi); | ||
const bgDataValue = isHiDpi && bgHiDpiValue ? bgHiDpiValue : bg1xValue; | ||
if (!bgDataValue) { | ||
return; | ||
} | ||
element.style.backgroundImage = bgDataValue; | ||
manageApplied(element, settings, instance); | ||
}; | ||
const setImgsetBackground = (element, settings, instance) => { | ||
const bgImgSetDataValue = getData(element, settings.data_bg_set); | ||
if (!bgImgSetDataValue) { | ||
return; | ||
} | ||
const imgSetValues = bgImgSetDataValue.split("|"); | ||
let bgImageValues = imgSetValues.map((value) => `image-set(${value})`); | ||
const bgImgSetDataValue = getData(element, settings.data_bg_set); | ||
if (!bgImgSetDataValue) { | ||
return; | ||
} | ||
const imgSetValues = bgImgSetDataValue.split("|"); | ||
let bgImageValues = imgSetValues.map((value) => `image-set(${value})`); | ||
element.style.backgroundImage = bgImageValues.join(); | ||
// Temporary fix for Chromeium with the -webkit- prefix | ||
if (element.style.backgroundImage === "") { | ||
bgImageValues = imgSetValues.map((value) => `-webkit-image-set(${value})`); | ||
element.style.backgroundImage = bgImageValues.join(); | ||
// Temporary fix for Chromeium with the -webkit- prefix | ||
if (element.style.backgroundImage === '') { | ||
bgImageValues = imgSetValues.map((value) => `-webkit-image-set(${value})`); | ||
element.style.backgroundImage = bgImageValues.join(); | ||
} | ||
manageApplied(element, settings, instance); | ||
} | ||
manageApplied(element, settings, instance); | ||
}; | ||
const setSourcesFunctions = { | ||
IMG: setSourcesImg, | ||
IFRAME: setSourcesIframe, | ||
VIDEO: setSourcesVideo, | ||
OBJECT: setSourcesObject | ||
IMG: setSourcesImg, | ||
IFRAME: setSourcesIframe, | ||
VIDEO: setSourcesVideo, | ||
OBJECT: setSourcesObject | ||
}; | ||
const setSourcesNative = (element, settings) => { | ||
const setSourcesFunction = setSourcesFunctions[element.tagName]; | ||
if (!setSourcesFunction) { | ||
return; | ||
} | ||
setSourcesFunction(element, settings); | ||
const setSourcesFunction = setSourcesFunctions[element.tagName]; | ||
if (!setSourcesFunction) { | ||
return; | ||
} | ||
setSourcesFunction(element, settings); | ||
}; | ||
const setSources = (element, settings, instance) => { | ||
const setSourcesFunction = setSourcesFunctions[element.tagName]; | ||
if (!setSourcesFunction) { | ||
return; | ||
} | ||
setSourcesFunction(element, settings); | ||
manageLoading(element, settings, instance); | ||
const setSourcesFunction = setSourcesFunctions[element.tagName]; | ||
if (!setSourcesFunction) { | ||
return; | ||
} | ||
setSourcesFunction(element, settings); | ||
manageLoading(element, settings, instance); | ||
}; | ||
@@ -430,215 +426,215 @@ | ||
const checkFinish = (settings, instance) => { | ||
if (instance && !isSomethingLoading(instance) && !haveElementsToLoad(instance)) { | ||
safeCallback(settings.callback_finish, instance); | ||
} | ||
if (instance && !isSomethingLoading(instance) && !haveElementsToLoad(instance)) { | ||
safeCallback(settings.callback_finish, instance); | ||
} | ||
}; | ||
const addEventListener = (element, eventName, handler) => { | ||
element.addEventListener(eventName, handler); | ||
element.llEvLisnrs[eventName] = handler; | ||
element.addEventListener(eventName, handler); | ||
element.llEvLisnrs[eventName] = handler; | ||
}; | ||
const removeEventListener = (element, eventName, handler) => { | ||
element.removeEventListener(eventName, handler); | ||
element.removeEventListener(eventName, handler); | ||
}; | ||
const hasEventListeners = (element) => { | ||
return !!element.llEvLisnrs; | ||
return !!element.llEvLisnrs; | ||
}; | ||
const addEventListeners = (element, loadHandler, errorHandler) => { | ||
if (!hasEventListeners(element)) element.llEvLisnrs = {}; | ||
const loadEventName = element.tagName === "VIDEO" ? "loadeddata" : "load"; | ||
addEventListener(element, loadEventName, loadHandler); | ||
addEventListener(element, "error", errorHandler); | ||
if (!hasEventListeners(element)) element.llEvLisnrs = {}; | ||
const loadEventName = element.tagName === "VIDEO" ? "loadeddata" : "load"; | ||
addEventListener(element, loadEventName, loadHandler); | ||
addEventListener(element, "error", errorHandler); | ||
}; | ||
const removeEventListeners = (element) => { | ||
if (!hasEventListeners(element)) { | ||
return; | ||
} | ||
const eventListeners = element.llEvLisnrs; | ||
for (let eventName in eventListeners) { | ||
const handler = eventListeners[eventName]; | ||
removeEventListener(element, eventName, handler); | ||
} | ||
delete element.llEvLisnrs; | ||
if (!hasEventListeners(element)) { | ||
return; | ||
} | ||
const eventListeners = element.llEvLisnrs; | ||
for (let eventName in eventListeners) { | ||
const handler = eventListeners[eventName]; | ||
removeEventListener(element, eventName, handler); | ||
} | ||
delete element.llEvLisnrs; | ||
}; | ||
const doneHandler = (element, settings, instance) => { | ||
deleteTempImage(element); | ||
updateLoadingCount(instance, -1); | ||
decreaseToLoadCount(instance); | ||
removeClass(element, settings.class_loading); | ||
if (settings.unobserve_completed) { | ||
unobserve(element, instance); | ||
} | ||
deleteTempImage(element); | ||
updateLoadingCount(instance, -1); | ||
decreaseToLoadCount(instance); | ||
removeClass(element, settings.class_loading); | ||
if (settings.unobserve_completed) { | ||
unobserve(element, instance); | ||
} | ||
}; | ||
const loadHandler = (event, element, settings, instance) => { | ||
const goingNative = hasStatusNative(element); | ||
doneHandler(element, settings, instance); | ||
addClass(element, settings.class_loaded); | ||
setStatus(element, statusLoaded); | ||
safeCallback(settings.callback_loaded, element, instance); | ||
if (!goingNative) checkFinish(settings, instance); | ||
const goingNative = hasStatusNative(element); | ||
doneHandler(element, settings, instance); | ||
addClass(element, settings.class_loaded); | ||
setStatus(element, statusLoaded); | ||
safeCallback(settings.callback_loaded, element, instance); | ||
if (!goingNative) checkFinish(settings, instance); | ||
}; | ||
const errorHandler = (event, element, settings, instance) => { | ||
const goingNative = hasStatusNative(element); | ||
doneHandler(element, settings, instance); | ||
addClass(element, settings.class_error); | ||
setStatus(element, statusError); | ||
safeCallback(settings.callback_error, element, instance); | ||
if (settings.restore_on_error) restoreOriginalAttrs(element, attrsSrcSrcsetSizes); | ||
if (!goingNative) checkFinish(settings, instance); | ||
const goingNative = hasStatusNative(element); | ||
doneHandler(element, settings, instance); | ||
addClass(element, settings.class_error); | ||
setStatus(element, statusError); | ||
safeCallback(settings.callback_error, element, instance); | ||
if (settings.restore_on_error) restoreOriginalAttrs(element, attrsSrcSrcsetSizes); | ||
if (!goingNative) checkFinish(settings, instance); | ||
}; | ||
const addOneShotEventListeners = (element, settings, instance) => { | ||
const elementToListenTo = getTempImage(element) || element; | ||
if (hasEventListeners(elementToListenTo)) { | ||
// This happens when loading is retried twice | ||
return; | ||
} | ||
const _loadHandler = (event) => { | ||
loadHandler(event, element, settings, instance); | ||
removeEventListeners(elementToListenTo); | ||
}; | ||
const _errorHandler = (event) => { | ||
errorHandler(event, element, settings, instance); | ||
removeEventListeners(elementToListenTo); | ||
}; | ||
addEventListeners(elementToListenTo, _loadHandler, _errorHandler); | ||
const elementToListenTo = getTempImage(element) || element; | ||
if (hasEventListeners(elementToListenTo)) { | ||
// This happens when loading is retried twice | ||
return; | ||
} | ||
const _loadHandler = (event) => { | ||
loadHandler(event, element, settings, instance); | ||
removeEventListeners(elementToListenTo); | ||
}; | ||
const _errorHandler = (event) => { | ||
errorHandler(event, element, settings, instance); | ||
removeEventListeners(elementToListenTo); | ||
}; | ||
addEventListeners(elementToListenTo, _loadHandler, _errorHandler); | ||
}; | ||
const loadBackground = (element, settings, instance) => { | ||
addTempImage(element); | ||
addOneShotEventListeners(element, settings, instance); | ||
saveOriginalBackgroundStyle(element); | ||
setBackground(element, settings, instance); | ||
setMultiBackground(element, settings, instance); | ||
setImgsetBackground(element, settings, instance); | ||
addTempImage(element); | ||
addOneShotEventListeners(element, settings, instance); | ||
saveOriginalBackgroundStyle(element); | ||
setBackground(element, settings, instance); | ||
setMultiBackground(element, settings, instance); | ||
setImgsetBackground(element, settings, instance); | ||
}; | ||
const loadRegular = (element, settings, instance) => { | ||
addOneShotEventListeners(element, settings, instance); | ||
setSources(element, settings, instance); | ||
addOneShotEventListeners(element, settings, instance); | ||
setSources(element, settings, instance); | ||
}; | ||
const load = (element, settings, instance) => { | ||
if (hasLoadEvent(element)) { | ||
loadRegular(element, settings, instance); | ||
} else { | ||
loadBackground(element, settings, instance); | ||
} | ||
if (hasLoadEvent(element)) { | ||
loadRegular(element, settings, instance); | ||
} else { | ||
loadBackground(element, settings, instance); | ||
} | ||
}; | ||
const loadNative = (element, settings, instance) => { | ||
element.setAttribute("loading", "lazy"); | ||
addOneShotEventListeners(element, settings, instance); | ||
setSourcesNative(element, settings); | ||
setStatus(element, statusNative); | ||
element.setAttribute("loading", "lazy"); | ||
addOneShotEventListeners(element, settings, instance); | ||
setSourcesNative(element, settings); | ||
setStatus(element, statusNative); | ||
}; | ||
const removeImageAttributes = (element) => { | ||
element.removeAttribute(SRC); | ||
element.removeAttribute(SRCSET); | ||
element.removeAttribute(SIZES); | ||
element.removeAttribute(SRC); | ||
element.removeAttribute(SRCSET); | ||
element.removeAttribute(SIZES); | ||
}; | ||
const resetSourcesImg = (element) => { | ||
forEachPictureSource(element, (sourceTag) => { | ||
removeImageAttributes(sourceTag); | ||
}); | ||
removeImageAttributes(element); | ||
forEachPictureSource(element, (sourceTag) => { | ||
removeImageAttributes(sourceTag); | ||
}); | ||
removeImageAttributes(element); | ||
}; | ||
const restoreImg = (imgEl) => { | ||
forEachPictureSource(imgEl, (sourceEl) => { | ||
restoreOriginalAttrs(sourceEl, attrsSrcSrcsetSizes); | ||
}); | ||
restoreOriginalAttrs(imgEl, attrsSrcSrcsetSizes); | ||
forEachPictureSource(imgEl, (sourceEl) => { | ||
restoreOriginalAttrs(sourceEl, attrsSrcSrcsetSizes); | ||
}); | ||
restoreOriginalAttrs(imgEl, attrsSrcSrcsetSizes); | ||
}; | ||
const restoreVideo = (videoEl) => { | ||
forEachVideoSource(videoEl, (sourceEl) => { | ||
restoreOriginalAttrs(sourceEl, attrsSrc); | ||
}); | ||
restoreOriginalAttrs(videoEl, attrsSrcPoster); | ||
videoEl.load(); | ||
forEachVideoSource(videoEl, (sourceEl) => { | ||
restoreOriginalAttrs(sourceEl, attrsSrc); | ||
}); | ||
restoreOriginalAttrs(videoEl, attrsSrcPoster); | ||
videoEl.load(); | ||
}; | ||
const restoreIframe = (iframeEl) => { | ||
restoreOriginalAttrs(iframeEl, attrsSrc); | ||
restoreOriginalAttrs(iframeEl, attrsSrc); | ||
}; | ||
const restoreObject = (objectEl) => { | ||
restoreOriginalAttrs(objectEl, attrsData); | ||
restoreOriginalAttrs(objectEl, attrsData); | ||
}; | ||
const restoreFunctions = { | ||
IMG: restoreImg, | ||
IFRAME: restoreIframe, | ||
VIDEO: restoreVideo, | ||
OBJECT: restoreObject | ||
IMG: restoreImg, | ||
IFRAME: restoreIframe, | ||
VIDEO: restoreVideo, | ||
OBJECT: restoreObject | ||
}; | ||
const restoreAttributes = (element) => { | ||
const restoreFunction = restoreFunctions[element.tagName]; | ||
if (!restoreFunction) { | ||
restoreOriginalBgImage(element); | ||
return; | ||
} | ||
restoreFunction(element); | ||
const restoreFunction = restoreFunctions[element.tagName]; | ||
if (!restoreFunction) { | ||
restoreOriginalBgImage(element); | ||
return; | ||
} | ||
restoreFunction(element); | ||
}; | ||
const resetClasses = (element, settings) => { | ||
if (hasEmptyStatus(element) || hasStatusNative(element)) { | ||
return; | ||
} | ||
removeClass(element, settings.class_entered); | ||
removeClass(element, settings.class_exited); | ||
removeClass(element, settings.class_applied); | ||
removeClass(element, settings.class_loading); | ||
removeClass(element, settings.class_loaded); | ||
removeClass(element, settings.class_error); | ||
if (hasEmptyStatus(element) || hasStatusNative(element)) { | ||
return; | ||
} | ||
removeClass(element, settings.class_entered); | ||
removeClass(element, settings.class_exited); | ||
removeClass(element, settings.class_applied); | ||
removeClass(element, settings.class_loading); | ||
removeClass(element, settings.class_loaded); | ||
removeClass(element, settings.class_error); | ||
}; | ||
const restore = (element, settings) => { | ||
restoreAttributes(element); | ||
resetClasses(element, settings); | ||
resetStatus(element); | ||
deleteOriginalAttrs(element); | ||
restoreAttributes(element); | ||
resetClasses(element, settings); | ||
resetStatus(element); | ||
deleteOriginalAttrs(element); | ||
}; | ||
const cancelLoading = (element, entry, settings, instance) => { | ||
if (!settings.cancel_on_exit) return; | ||
if (!hasStatusLoading(element)) return; | ||
if (element.tagName !== "IMG") return; //Works only on images | ||
removeEventListeners(element); | ||
resetSourcesImg(element); | ||
restoreImg(element); | ||
removeClass(element, settings.class_loading); | ||
updateLoadingCount(instance, -1); | ||
resetStatus(element); | ||
safeCallback(settings.callback_cancel, element, entry, instance); | ||
if (!settings.cancel_on_exit) return; | ||
if (!hasStatusLoading(element)) return; | ||
if (element.tagName !== "IMG") return; //Works only on images | ||
removeEventListeners(element); | ||
resetSourcesImg(element); | ||
restoreImg(element); | ||
removeClass(element, settings.class_loading); | ||
updateLoadingCount(instance, -1); | ||
resetStatus(element); | ||
safeCallback(settings.callback_cancel, element, entry, instance); | ||
}; | ||
const onEnter = (element, entry, settings, instance) => { | ||
const dontLoad = hadStartedLoading(element); /* Save status | ||
const dontLoad = hadStartedLoading(element); /* Save status | ||
before setting it, to prevent loading it again. Fixes #526. */ | ||
setStatus(element, statusEntered); | ||
addClass(element, settings.class_entered); | ||
removeClass(element, settings.class_exited); | ||
unobserveEntered(element, settings, instance); | ||
safeCallback(settings.callback_enter, element, entry, instance); | ||
if (dontLoad) return; | ||
load(element, settings, instance); | ||
setStatus(element, statusEntered); | ||
addClass(element, settings.class_entered); | ||
removeClass(element, settings.class_exited); | ||
unobserveEntered(element, settings, instance); | ||
safeCallback(settings.callback_enter, element, entry, instance); | ||
if (dontLoad) return; | ||
load(element, settings, instance); | ||
}; | ||
const onExit = (element, entry, settings, instance) => { | ||
if (hasEmptyStatus(element)) return; //Ignore the first pass, at landing | ||
addClass(element, settings.class_exited); | ||
cancelLoading(element, entry, settings, instance); | ||
safeCallback(settings.callback_exit, element, entry, instance); | ||
if (hasEmptyStatus(element)) return; //Ignore the first pass, at landing | ||
addClass(element, settings.class_exited); | ||
cancelLoading(element, entry, settings, instance); | ||
safeCallback(settings.callback_exit, element, entry, instance); | ||
}; | ||
@@ -649,12 +645,12 @@ | ||
const shouldUseNative = (settings) => | ||
settings.use_native && "loading" in HTMLImageElement.prototype; | ||
settings.use_native && "loading" in HTMLImageElement.prototype; | ||
const loadAllNative = (elements, settings, instance) => { | ||
elements.forEach((element) => { | ||
if (tagsWithNativeLazy.indexOf(element.tagName) === -1) { | ||
return; | ||
} | ||
loadNative(element, settings, instance); | ||
}); | ||
setToLoadCount(instance, 0); | ||
elements.forEach((element) => { | ||
if (tagsWithNativeLazy.indexOf(element.tagName) === -1) { | ||
return; | ||
} | ||
loadNative(element, settings, instance); | ||
}); | ||
setToLoadCount(instance, 0); | ||
}; | ||
@@ -665,32 +661,32 @@ | ||
const getObserverSettings = (settings) => ({ | ||
root: settings.container === document ? null : settings.container, | ||
rootMargin: settings.thresholds || settings.threshold + "px" | ||
root: settings.container === document ? null : settings.container, | ||
rootMargin: settings.thresholds || settings.threshold + "px" | ||
}); | ||
const intersectionHandler = (entries, settings, instance) => { | ||
entries.forEach((entry) => | ||
isIntersecting(entry) | ||
? onEnter(entry.target, entry, settings, instance) | ||
: onExit(entry.target, entry, settings, instance) | ||
); | ||
entries.forEach((entry) => | ||
isIntersecting(entry) | ||
? onEnter(entry.target, entry, settings, instance) | ||
: onExit(entry.target, entry, settings, instance) | ||
); | ||
}; | ||
const observeElements = (observer, elements) => { | ||
elements.forEach((element) => { | ||
observer.observe(element); | ||
}); | ||
elements.forEach((element) => { | ||
observer.observe(element); | ||
}); | ||
}; | ||
const updateObserver = (observer, elementsToObserve) => { | ||
resetObserver(observer); | ||
observeElements(observer, elementsToObserve); | ||
resetObserver(observer); | ||
observeElements(observer, elementsToObserve); | ||
}; | ||
const setObserver = (settings, instance) => { | ||
if (!supportsIntersectionObserver || shouldUseNative(settings)) { | ||
return; | ||
} | ||
instance._observer = new IntersectionObserver((entries) => { | ||
intersectionHandler(entries, settings, instance); | ||
}, getObserverSettings(settings)); | ||
if (!supportsIntersectionObserver || shouldUseNative(settings)) { | ||
return; | ||
} | ||
instance._observer = new IntersectionObserver((entries) => { | ||
intersectionHandler(entries, settings, instance); | ||
}, getObserverSettings(settings)); | ||
}; | ||
@@ -701,3 +697,3 @@ | ||
const queryElements = (settings) => | ||
settings.container.querySelectorAll(settings.elements_selector); | ||
settings.container.querySelectorAll(settings.elements_selector); | ||
@@ -710,100 +706,100 @@ const excludeManagedElements = (elements) => toArray(elements).filter(hasEmptyStatus); | ||
const getElementsToLoad = (elements, settings) => | ||
excludeManagedElements(elements || queryElements(settings)); | ||
excludeManagedElements(elements || queryElements(settings)); | ||
const retryLazyLoad = (settings, instance) => { | ||
const errorElements = filterErrorElements(queryElements(settings)); | ||
errorElements.forEach((element) => { | ||
removeClass(element, settings.class_error); | ||
resetStatus(element); | ||
}); | ||
instance.update(); | ||
const errorElements = filterErrorElements(queryElements(settings)); | ||
errorElements.forEach((element) => { | ||
removeClass(element, settings.class_error); | ||
resetStatus(element); | ||
}); | ||
instance.update(); | ||
}; | ||
const setOnlineCheck = (settings, instance) => { | ||
if (!runningOnBrowser) { | ||
return; | ||
} | ||
instance._onlineHandler = () => { | ||
retryLazyLoad(settings, instance); | ||
}; | ||
window.addEventListener("online", instance._onlineHandler); | ||
if (!runningOnBrowser) { | ||
return; | ||
} | ||
instance._onlineHandler = () => { | ||
retryLazyLoad(settings, instance); | ||
}; | ||
window.addEventListener("online", instance._onlineHandler); | ||
}; | ||
const resetOnlineCheck = (instance) => { | ||
if (!runningOnBrowser) { | ||
return; | ||
} | ||
window.removeEventListener("online", instance._onlineHandler); | ||
if (!runningOnBrowser) { | ||
return; | ||
} | ||
window.removeEventListener("online", instance._onlineHandler); | ||
}; | ||
const LazyLoad = function (customSettings, elements) { | ||
const settings = getExtendedSettings(customSettings); | ||
this._settings = settings; | ||
this.loadingCount = 0; | ||
setObserver(settings, this); | ||
setOnlineCheck(settings, this); | ||
this.update(elements); | ||
const LazyLoad = function(customSettings, elements) { | ||
const settings = getExtendedSettings(customSettings); | ||
this._settings = settings; | ||
this.loadingCount = 0; | ||
setObserver(settings, this); | ||
setOnlineCheck(settings, this); | ||
this.update(elements); | ||
}; | ||
LazyLoad.prototype = { | ||
update: function (givenNodeset) { | ||
const settings = this._settings; | ||
const elementsToLoad = getElementsToLoad(givenNodeset, settings); | ||
setToLoadCount(this, elementsToLoad.length); | ||
update: function(givenNodeset) { | ||
const settings = this._settings; | ||
const elementsToLoad = getElementsToLoad(givenNodeset, settings); | ||
setToLoadCount(this, elementsToLoad.length); | ||
if (isBot || !supportsIntersectionObserver) { | ||
this.loadAll(elementsToLoad); | ||
return; | ||
} | ||
if (shouldUseNative(settings)) { | ||
loadAllNative(elementsToLoad, settings, this); | ||
return; | ||
} | ||
if (isBot || !supportsIntersectionObserver) { | ||
this.loadAll(elementsToLoad); | ||
return; | ||
} | ||
if (shouldUseNative(settings)) { | ||
loadAllNative(elementsToLoad, settings, this); | ||
return; | ||
} | ||
updateObserver(this._observer, elementsToLoad); | ||
}, | ||
updateObserver(this._observer, elementsToLoad); | ||
}, | ||
destroy: function () { | ||
// Observer | ||
if (this._observer) { | ||
this._observer.disconnect(); | ||
} | ||
// Clean handlers | ||
resetOnlineCheck(this); | ||
// Clean custom attributes on elements | ||
queryElements(this._settings).forEach((element) => { | ||
deleteOriginalAttrs(element); | ||
}); | ||
// Delete all internal props | ||
delete this._observer; | ||
delete this._settings; | ||
delete this._onlineHandler; | ||
delete this.loadingCount; | ||
delete this.toLoadCount; | ||
}, | ||
destroy: function() { | ||
// Observer | ||
if (this._observer) { | ||
this._observer.disconnect(); | ||
} | ||
// Clean handlers | ||
resetOnlineCheck(this); | ||
// Clean custom attributes on elements | ||
queryElements(this._settings).forEach((element) => { | ||
deleteOriginalAttrs(element); | ||
}); | ||
// Delete all internal props | ||
delete this._observer; | ||
delete this._settings; | ||
delete this._onlineHandler; | ||
delete this.loadingCount; | ||
delete this.toLoadCount; | ||
}, | ||
loadAll: function (elements) { | ||
const settings = this._settings; | ||
const elementsToLoad = getElementsToLoad(elements, settings); | ||
elementsToLoad.forEach((element) => { | ||
unobserve(element, this); | ||
load(element, settings, this); | ||
}); | ||
}, | ||
loadAll: function(elements) { | ||
const settings = this._settings; | ||
const elementsToLoad = getElementsToLoad(elements, settings); | ||
elementsToLoad.forEach((element) => { | ||
unobserve(element, this); | ||
load(element, settings, this); | ||
}); | ||
}, | ||
restoreAll: function() { | ||
const settings = this._settings; | ||
queryElements(settings).forEach((element) => { | ||
restore(element, settings); | ||
}); | ||
} | ||
restoreAll: function() { | ||
const settings = this._settings; | ||
queryElements(settings).forEach((element) => { | ||
restore(element, settings); | ||
}); | ||
} | ||
}; | ||
LazyLoad.load = (element, customSettings) => { | ||
const settings = getExtendedSettings(customSettings); | ||
load(element, settings); | ||
const settings = getExtendedSettings(customSettings); | ||
load(element, settings); | ||
}; | ||
LazyLoad.resetStatus = (element) => { | ||
resetStatus(element); | ||
resetStatus(element); | ||
}; | ||
@@ -813,5 +809,5 @@ | ||
if (runningOnBrowser) { | ||
autoInitialize(LazyLoad, window.lazyLoadOptions); | ||
autoInitialize(LazyLoad, window.lazyLoadOptions); | ||
} | ||
export { LazyLoad as default }; |
@@ -1,1 +0,1 @@ | ||
const e="undefined"!=typeof window,t=e&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),a=e&&"IntersectionObserver"in window,s=e&&"classList"in document.createElement("p"),l=e&&window.devicePixelRatio>1,n={elements_selector:".lazy",container:t||e?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},o=e=>Object.assign({},n,e),r=function(e,t){let a;const s="LazyLoad::Initialized",l=new e(t);try{a=new CustomEvent(s,{detail:{instance:l}})}catch(e){a=document.createEvent("CustomEvent"),a.initCustomEvent(s,!1,!1,{instance:l})}window.dispatchEvent(a)},i="src",c="llOriginalAttrs",d=(e,t)=>e.getAttribute("data-"+t),_=e=>d(e,"ll-status"),u=(e,t)=>((e,t,a)=>{var s="data-ll-status";null!==a?e.setAttribute(s,a):e.removeAttribute(s)})(e,0,t),g=e=>u(e,null),b=e=>null===_(e),m=e=>"native"===_(e),p=["loading","loaded","applied","error"],h=(e,t,a,s)=>{e&&(void 0===s?void 0===a?e(t):e(t,a):e(t,a,s))},v=(e,t)=>{s?e.classList.add(t):e.className+=(e.className?" ":"")+t},E=(e,t)=>{s?e.classList.remove(t):e.className=e.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},f=e=>e.llTempImage,I=(e,t)=>{if(!t)return;const a=t._observer;a&&a.unobserve(e)},k=(e,t)=>{e&&(e.loadingCount+=t)},A=(e,t)=>{e&&(e.toLoadCount=t)},w=e=>{let t=[];for(let a,s=0;a=e.children[s];s+=1)"SOURCE"===a.tagName&&t.push(a);return t},y=(e,t)=>{const a=e.parentNode;a&&"PICTURE"===a.tagName&&w(a).forEach(t)},L=(e,t)=>{w(e).forEach(t)},O=[i],x=[i,"poster"],C=[i,"srcset","sizes"],N=["data"],M=e=>!!e[c],z=e=>e[c],R=e=>delete e[c],T=(e,t)=>{if(M(e))return;const a={};t.forEach((t=>{a[t]=e.getAttribute(t)})),e[c]=a},G=(e,t)=>{if(!M(e))return;const a=z(e);t.forEach((t=>{((e,t,a)=>{a?e.setAttribute(t,a):e.removeAttribute(t)})(e,t,a[t])}))},D=(e,t,a)=>{v(e,t.class_applied),u(e,"applied"),a&&(t.unobserve_completed&&I(e,t),h(t.callback_applied,e,a))},H=(e,t,a)=>{v(e,t.class_loading),u(e,"loading"),a&&(k(a,1),h(t.callback_loading,e,a))},V=(e,t,a)=>{a&&e.setAttribute(t,a)},$=(e,t)=>{V(e,"sizes",d(e,t.data_sizes)),V(e,"srcset",d(e,t.data_srcset)),V(e,i,d(e,t.data_src))},F={IMG:(e,t)=>{y(e,(e=>{T(e,C),$(e,t)})),T(e,C),$(e,t)},IFRAME:(e,t)=>{T(e,O),V(e,i,d(e,t.data_src))},VIDEO:(e,t)=>{L(e,(e=>{T(e,O),V(e,i,d(e,t.data_src))})),T(e,x),V(e,"poster",d(e,t.data_poster)),V(e,i,d(e,t.data_src)),e.load()},OBJECT:(e,t)=>{T(e,N),V(e,"data",d(e,t.data_src))}},j=["IMG","IFRAME","VIDEO","OBJECT"],B=(e,t)=>{!t||(e=>e.loadingCount>0)(t)||(e=>e.toLoadCount>0)(t)||h(e.callback_finish,t)},J=(e,t,a)=>{e.addEventListener(t,a),e.llEvLisnrs[t]=a},S=(e,t,a)=>{e.removeEventListener(t,a)},P=e=>!!e.llEvLisnrs,U=e=>{if(!P(e))return;const t=e.llEvLisnrs;for(let a in t){const s=t[a];S(e,a,s)}delete e.llEvLisnrs},q=(e,t,a)=>{(e=>{delete e.llTempImage})(e),k(a,-1),(e=>{e&&(e.toLoadCount-=1)})(a),E(e,t.class_loading),t.unobserve_completed&&I(e,a)},K=(e,t,a)=>{const s=f(e)||e;P(s)||((e,t,a)=>{P(e)||(e.llEvLisnrs={});const s="VIDEO"===e.tagName?"loadeddata":"load";J(e,s,t),J(e,"error",a)})(s,(l=>{((e,t,a,s)=>{const l=m(t);q(t,a,s),v(t,a.class_loaded),u(t,"loaded"),h(a.callback_loaded,t,s),l||B(a,s)})(0,e,t,a),U(s)}),(l=>{((e,t,a,s)=>{const l=m(t);q(t,a,s),v(t,a.class_error),u(t,"error"),h(a.callback_error,t,s),a.restore_on_error&&G(t,C),l||B(a,s)})(0,e,t,a),U(s)}))},Q=(e,t,a)=>{(e=>j.indexOf(e.tagName)>-1)(e)?((e,t,a)=>{K(e,t,a),((e,t,a)=>{const s=F[e.tagName];s&&(s(e,t),H(e,t,a))})(e,t,a)})(e,t,a):((e,t,a)=>{(e=>{e.llTempImage=document.createElement("IMG")})(e),K(e,t,a),(e=>{M(e)||(e[c]={backgroundImage:e.style.backgroundImage})})(e),((e,t,a)=>{const s=d(e,t.data_bg),n=d(e,t.data_bg_hidpi),o=l&&n?n:s;o&&(e.style.backgroundImage=`url("${o}")`,f(e).setAttribute(i,o),H(e,t,a))})(e,t,a),((e,t,a)=>{const s=d(e,t.data_bg_multi),n=d(e,t.data_bg_multi_hidpi),o=l&&n?n:s;o&&(e.style.backgroundImage=o,D(e,t,a))})(e,t,a),((e,t,a)=>{const s=d(e,t.data_bg_set);if(!s)return;const l=s.split("|");let n=l.map((e=>`image-set(${e})`));e.style.backgroundImage=n.join(),""===e.style.backgroundImage&&(n=l.map((e=>`-webkit-image-set(${e})`)),e.style.backgroundImage=n.join()),D(e,t,a)})(e,t,a)})(e,t,a)},W=e=>{e.removeAttribute(i),e.removeAttribute("srcset"),e.removeAttribute("sizes")},X=e=>{y(e,(e=>{G(e,C)})),G(e,C)},Y={IMG:X,IFRAME:e=>{G(e,O)},VIDEO:e=>{L(e,(e=>{G(e,O)})),G(e,x),e.load()},OBJECT:e=>{G(e,N)}},Z=(e,t)=>{(e=>{const t=Y[e.tagName];t?t(e):(e=>{if(!M(e))return;const t=z(e);e.style.backgroundImage=t.backgroundImage})(e)})(e),((e,t)=>{b(e)||m(e)||(E(e,t.class_entered),E(e,t.class_exited),E(e,t.class_applied),E(e,t.class_loading),E(e,t.class_loaded),E(e,t.class_error))})(e,t),g(e),R(e)},ee=["IMG","IFRAME","VIDEO"],te=e=>e.use_native&&"loading"in HTMLImageElement.prototype,ae=(e,t,a)=>{e.forEach((e=>(e=>e.isIntersecting||e.intersectionRatio>0)(e)?((e,t,a,s)=>{const l=(e=>p.indexOf(_(e))>=0)(e);u(e,"entered"),v(e,a.class_entered),E(e,a.class_exited),((e,t,a)=>{t.unobserve_entered&&I(e,a)})(e,a,s),h(a.callback_enter,e,t,s),l||Q(e,a,s)})(e.target,e,t,a):((e,t,a,s)=>{b(e)||(v(e,a.class_exited),((e,t,a,s)=>{a.cancel_on_exit&&(e=>"loading"===_(e))(e)&&"IMG"===e.tagName&&(U(e),(e=>{y(e,(e=>{W(e)})),W(e)})(e),X(e),E(e,a.class_loading),k(s,-1),g(e),h(a.callback_cancel,e,t,s))})(e,t,a,s),h(a.callback_exit,e,t,s))})(e.target,e,t,a)))},se=e=>Array.prototype.slice.call(e),le=e=>e.container.querySelectorAll(e.elements_selector),ne=e=>(e=>"error"===_(e))(e),oe=(e,t)=>(e=>se(e).filter(b))(e||le(t)),re=function(t,s){const l=o(t);this._settings=l,this.loadingCount=0,((e,t)=>{a&&!te(e)&&(t._observer=new IntersectionObserver((a=>{ae(a,e,t)}),(e=>({root:e.container===document?null:e.container,rootMargin:e.thresholds||e.threshold+"px"}))(e)))})(l,this),((t,a)=>{e&&(a._onlineHandler=()=>{((e,t)=>{var a;(a=le(e),se(a).filter(ne)).forEach((t=>{E(t,e.class_error),g(t)})),t.update()})(t,a)},window.addEventListener("online",a._onlineHandler))})(l,this),this.update(s)};re.prototype={update:function(e){const s=this._settings,l=oe(e,s);var n,o;A(this,l.length),!t&&a?te(s)?((e,t,a)=>{e.forEach((e=>{-1!==ee.indexOf(e.tagName)&&((e,t,a)=>{e.setAttribute("loading","lazy"),K(e,t,a),((e,t)=>{const a=F[e.tagName];a&&a(e,t)})(e,t),u(e,"native")})(e,t,a)})),A(a,0)})(l,s,this):(o=l,(e=>{e.disconnect()})(n=this._observer),((e,t)=>{t.forEach((t=>{e.observe(t)}))})(n,o)):this.loadAll(l)},destroy:function(){this._observer&&this._observer.disconnect(),e&&window.removeEventListener("online",this._onlineHandler),le(this._settings).forEach((e=>{R(e)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(e){const t=this._settings;oe(e,t).forEach((e=>{I(e,this),Q(e,t,this)}))},restoreAll:function(){const e=this._settings;le(e).forEach((t=>{Z(t,e)}))}},re.load=(e,t)=>{const a=o(t);Q(e,a)},re.resetStatus=e=>{g(e)},e&&((e,t)=>{if(t)if(t.length)for(let a,s=0;a=t[s];s+=1)r(e,a);else r(e,t)})(re,window.lazyLoadOptions);export{re as default}; | ||
const e="undefined"!=typeof window,t=e&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),a=e&&"IntersectionObserver"in window,s=e&&"classList"in document.createElement("p"),l=e&&window.devicePixelRatio>1,n={elements_selector:".lazy",container:t||e?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},o=e=>Object.assign({},n,e),r=function(e,t){let a;const s="LazyLoad::Initialized",l=new e(t);try{a=new CustomEvent(s,{detail:{instance:l}})}catch(e){a=document.createEvent("CustomEvent"),a.initCustomEvent(s,!1,!1,{instance:l})}window.dispatchEvent(a)},i="src",c="llOriginalAttrs",d=(e,t)=>e.getAttribute("data-"+t),_=e=>d(e,"ll-status"),u=(e,t)=>((e,t,a)=>{const s="data-ll-status";null!==a?e.setAttribute(s,a):e.removeAttribute(s)})(e,0,t),g=e=>u(e,null),b=e=>null===_(e),m=e=>"native"===_(e),p=["loading","loaded","applied","error"],h=(e,t,a,s)=>{e&&"function"==typeof e&&(void 0===s?void 0===a?e(t):e(t,a):e(t,a,s))},v=(e,t)=>{s?e.classList.add(t):e.className+=(e.className?" ":"")+t},E=(e,t)=>{s?e.classList.remove(t):e.className=e.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},f=e=>e.llTempImage,I=(e,t)=>{if(!t)return;const a=t._observer;a&&a.unobserve(e)},k=(e,t)=>{e&&(e.loadingCount+=t)},A=(e,t)=>{e&&(e.toLoadCount=t)},w=e=>{let t=[];for(let a,s=0;a=e.children[s];s+=1)"SOURCE"===a.tagName&&t.push(a);return t},y=(e,t)=>{const a=e.parentNode;a&&"PICTURE"===a.tagName&&w(a).forEach(t)},L=(e,t)=>{w(e).forEach(t)},O=[i],x=[i,"poster"],C=[i,"srcset","sizes"],N=["data"],M=e=>!!e[c],z=e=>e[c],R=e=>delete e[c],T=(e,t)=>{if(M(e))return;const a={};t.forEach((t=>{a[t]=e.getAttribute(t)})),e[c]=a},G=(e,t)=>{if(!M(e))return;const a=z(e);t.forEach((t=>{((e,t,a)=>{a?e.setAttribute(t,a):e.removeAttribute(t)})(e,t,a[t])}))},D=(e,t,a)=>{v(e,t.class_applied),u(e,"applied"),a&&(t.unobserve_completed&&I(e,t),h(t.callback_applied,e,a))},H=(e,t,a)=>{v(e,t.class_loading),u(e,"loading"),a&&(k(a,1),h(t.callback_loading,e,a))},V=(e,t,a)=>{a&&e.setAttribute(t,a)},$=(e,t)=>{V(e,"sizes",d(e,t.data_sizes)),V(e,"srcset",d(e,t.data_srcset)),V(e,i,d(e,t.data_src))},F={IMG:(e,t)=>{y(e,(e=>{T(e,C),$(e,t)})),T(e,C),$(e,t)},IFRAME:(e,t)=>{T(e,O),V(e,i,d(e,t.data_src))},VIDEO:(e,t)=>{L(e,(e=>{T(e,O),V(e,i,d(e,t.data_src))})),T(e,x),V(e,"poster",d(e,t.data_poster)),V(e,i,d(e,t.data_src)),e.load()},OBJECT:(e,t)=>{T(e,N),V(e,"data",d(e,t.data_src))}},j=["IMG","IFRAME","VIDEO","OBJECT"],B=(e,t)=>{!t||(e=>e.loadingCount>0)(t)||(e=>e.toLoadCount>0)(t)||h(e.callback_finish,t)},J=(e,t,a)=>{e.addEventListener(t,a),e.llEvLisnrs[t]=a},S=(e,t,a)=>{e.removeEventListener(t,a)},P=e=>!!e.llEvLisnrs,U=e=>{if(!P(e))return;const t=e.llEvLisnrs;for(let a in t){const s=t[a];S(e,a,s)}delete e.llEvLisnrs},q=(e,t,a)=>{(e=>{delete e.llTempImage})(e),k(a,-1),(e=>{e&&(e.toLoadCount-=1)})(a),E(e,t.class_loading),t.unobserve_completed&&I(e,a)},K=(e,t,a)=>{const s=f(e)||e;P(s)||((e,t,a)=>{P(e)||(e.llEvLisnrs={});const s="VIDEO"===e.tagName?"loadeddata":"load";J(e,s,t),J(e,"error",a)})(s,(l=>{((e,t,a,s)=>{const l=m(t);q(t,a,s),v(t,a.class_loaded),u(t,"loaded"),h(a.callback_loaded,t,s),l||B(a,s)})(0,e,t,a),U(s)}),(l=>{((e,t,a,s)=>{const l=m(t);q(t,a,s),v(t,a.class_error),u(t,"error"),h(a.callback_error,t,s),a.restore_on_error&&G(t,C),l||B(a,s)})(0,e,t,a),U(s)}))},Q=(e,t,a)=>{(e=>j.indexOf(e.tagName)>-1)(e)?((e,t,a)=>{K(e,t,a),((e,t,a)=>{const s=F[e.tagName];s&&(s(e,t),H(e,t,a))})(e,t,a)})(e,t,a):((e,t,a)=>{(e=>{e.llTempImage=document.createElement("IMG")})(e),K(e,t,a),(e=>{M(e)||(e[c]={backgroundImage:e.style.backgroundImage})})(e),((e,t,a)=>{const s=d(e,t.data_bg),n=d(e,t.data_bg_hidpi),o=l&&n?n:s;o&&(e.style.backgroundImage=`url("${o}")`,f(e).setAttribute(i,o),H(e,t,a))})(e,t,a),((e,t,a)=>{const s=d(e,t.data_bg_multi),n=d(e,t.data_bg_multi_hidpi),o=l&&n?n:s;o&&(e.style.backgroundImage=o,D(e,t,a))})(e,t,a),((e,t,a)=>{const s=d(e,t.data_bg_set);if(!s)return;const l=s.split("|");let n=l.map((e=>`image-set(${e})`));e.style.backgroundImage=n.join(),""===e.style.backgroundImage&&(n=l.map((e=>`-webkit-image-set(${e})`)),e.style.backgroundImage=n.join()),D(e,t,a)})(e,t,a)})(e,t,a)},W=e=>{e.removeAttribute(i),e.removeAttribute("srcset"),e.removeAttribute("sizes")},X=e=>{y(e,(e=>{G(e,C)})),G(e,C)},Y={IMG:X,IFRAME:e=>{G(e,O)},VIDEO:e=>{L(e,(e=>{G(e,O)})),G(e,x),e.load()},OBJECT:e=>{G(e,N)}},Z=(e,t)=>{(e=>{const t=Y[e.tagName];t?t(e):(e=>{if(!M(e))return;const t=z(e);e.style.backgroundImage=t.backgroundImage})(e)})(e),((e,t)=>{b(e)||m(e)||(E(e,t.class_entered),E(e,t.class_exited),E(e,t.class_applied),E(e,t.class_loading),E(e,t.class_loaded),E(e,t.class_error))})(e,t),g(e),R(e)},ee=["IMG","IFRAME","VIDEO"],te=e=>e.use_native&&"loading"in HTMLImageElement.prototype,ae=(e,t,a)=>{e.forEach((e=>(e=>e.isIntersecting||e.intersectionRatio>0)(e)?((e,t,a,s)=>{const l=(e=>p.indexOf(_(e))>=0)(e);u(e,"entered"),v(e,a.class_entered),E(e,a.class_exited),((e,t,a)=>{t.unobserve_entered&&I(e,a)})(e,a,s),h(a.callback_enter,e,t,s),l||Q(e,a,s)})(e.target,e,t,a):((e,t,a,s)=>{b(e)||(v(e,a.class_exited),((e,t,a,s)=>{a.cancel_on_exit&&(e=>"loading"===_(e))(e)&&"IMG"===e.tagName&&(U(e),(e=>{y(e,(e=>{W(e)})),W(e)})(e),X(e),E(e,a.class_loading),k(s,-1),g(e),h(a.callback_cancel,e,t,s))})(e,t,a,s),h(a.callback_exit,e,t,s))})(e.target,e,t,a)))},se=e=>Array.prototype.slice.call(e),le=e=>e.container.querySelectorAll(e.elements_selector),ne=e=>(e=>"error"===_(e))(e),oe=(e,t)=>(e=>se(e).filter(b))(e||le(t)),re=function(t,s){const l=o(t);this._settings=l,this.loadingCount=0,((e,t)=>{a&&!te(e)&&(t._observer=new IntersectionObserver((a=>{ae(a,e,t)}),(e=>({root:e.container===document?null:e.container,rootMargin:e.thresholds||e.threshold+"px"}))(e)))})(l,this),((t,a)=>{e&&(a._onlineHandler=()=>{((e,t)=>{var a;(a=le(e),se(a).filter(ne)).forEach((t=>{E(t,e.class_error),g(t)})),t.update()})(t,a)},window.addEventListener("online",a._onlineHandler))})(l,this),this.update(s)};re.prototype={update:function(e){const s=this._settings,l=oe(e,s);var n,o;A(this,l.length),!t&&a?te(s)?((e,t,a)=>{e.forEach((e=>{-1!==ee.indexOf(e.tagName)&&((e,t,a)=>{e.setAttribute("loading","lazy"),K(e,t,a),((e,t)=>{const a=F[e.tagName];a&&a(e,t)})(e,t),u(e,"native")})(e,t,a)})),A(a,0)})(l,s,this):(o=l,(e=>{e.disconnect()})(n=this._observer),((e,t)=>{t.forEach((t=>{e.observe(t)}))})(n,o)):this.loadAll(l)},destroy:function(){this._observer&&this._observer.disconnect(),e&&window.removeEventListener("online",this._onlineHandler),le(this._settings).forEach((e=>{R(e)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(e){const t=this._settings;oe(e,t).forEach((e=>{I(e,this),Q(e,t,this)}))},restoreAll:function(){const e=this._settings;le(e).forEach((t=>{Z(t,e)}))}},re.load=(e,t)=>{const a=o(t);Q(e,a)},re.resetStatus=e=>{g(e)},e&&((e,t)=>{if(t)if(t.length)for(let a,s=0;a=t[s];s+=1)r(e,a);else r(e,t)})(re,window.lazyLoadOptions);export{re as default}; |
@@ -89,3 +89,3 @@ var LazyLoad = (function () { | ||
}; | ||
/* Auto initialization of one or more instances of lazyload, depending on the | ||
/* Auto initialization of one or more instances of LazyLoad, depending on the | ||
options passed in (plain object or an array) */ | ||
@@ -166,3 +166,3 @@ | ||
var safeCallback = function safeCallback(callback, arg1, arg2, arg3) { | ||
if (!callback) { | ||
if (!callback || typeof callback !== 'function') { | ||
return; | ||
@@ -429,3 +429,3 @@ } | ||
if (element.style.backgroundImage === '') { | ||
if (element.style.backgroundImage === "") { | ||
bgImageValues = imgSetValues.map(function (value) { | ||
@@ -666,3 +666,3 @@ return "-webkit-image-set(".concat(value, ")"); | ||
var dontLoad = hadStartedLoading(element); | ||
/* Save status | ||
/* Save status | ||
before setting it, to prevent loading it again. Fixes #526. */ | ||
@@ -669,0 +669,0 @@ |
@@ -1,1 +0,1 @@ | ||
var LazyLoad=function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,a=t&&"classList"in document.createElement("p"),o=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",a=new n(t);try{e=new CustomEvent(i,{detail:{instance:a}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:a})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",m="applied",p="error",h="native",E="data-",I="ll-status",k=function(n,t){return n.getAttribute(E+t)},y=function(n){return k(n,I)},w=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===y(n)},O=function(n){return y(n)===h},C=[v,b,m,p],x=function(n,t,e,i){n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){a?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){a?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},R=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},T=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},D=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},H=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&D(e).forEach(t)},V=function(n,t){D(n).forEach(t)},j=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,m),e&&(t.unobserve_completed&&R(n,t),x(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(T(e,1),x(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,k(n,t.data_sizes)),W(n,s,k(n,t.data_srcset)),W(n,u,k(n,t.data_src))},Y={IMG:function(n,t){H(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,j),W(n,u,k(n,t.data_src))},VIDEO:function(n,t){V(n,(function(n){$(n,j),W(n,u,k(n,t.data_src))})),$(n,F),W(n,f,k(n,t.data_poster)),W(n,u,k(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,k(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||x(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},an=function(n){return!!n.llEvLisnrs},on=function(n){if(an(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),T(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&R(n,e)},cn=function(n,t,e){var i=z(n)||n;an(i)||function(n,t,e){an(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(a){!function(n,t,e,i){var a=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),x(e.callback_loaded,t,i),a||nn(e,i)}(0,n,t,e),on(i)}),(function(a){!function(n,t,e,i){var a=O(t);rn(t,e,i),N(t,e.class_error),w(t,p),x(e.callback_error,t,i),e.restore_on_error&&q(t,B),a||nn(e,i)}(0,n,t,e),on(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=k(n,t.data_bg),a=k(n,t.data_bg_hidpi),r=o&&a?a:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_multi),a=k(n,t.data_bg_multi_hidpi),r=o&&a?a:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_set);if(i){var a=i.split("|"),o=a.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=o.join(),""===n.style.backgroundImage&&(o=a.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=o.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){H(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,j)},VIDEO:function(n){V(n,(function(n){q(n,j)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var a=function(n){return C.indexOf(y(n))>=0}(n);w(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&R(n,e)}(n,e,i),x(e.callback_enter,n,t,i),a||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return y(n)===v}(n)&&"IMG"===n.tagName&&(on(n),function(n){H(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),T(i,-1),A(n),x(e.callback_cancel,n,t,i))}(n,t,e,i),x(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return y(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var a=c(n);this._settings=a,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(a,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(a,this),this.update(e)};return En.prototype={update:function(n){var t,a,o=this._settings,r=hn(n,o);G(this,r.length),!e&&i?gn(o)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,o,this):(a=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,a)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){R(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En}(); | ||
var LazyLoad=function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,o=t&&"classList"in document.createElement("p"),a=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",m="applied",p="error",h="native",E="data-",I="ll-status",k=function(n,t){return n.getAttribute(E+t)},y=function(n){return k(n,I)},w=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===y(n)},O=function(n){return y(n)===h},C=[v,b,m,p],x=function(n,t,e,i){n&&"function"==typeof n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},R=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},T=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},D=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},H=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&D(e).forEach(t)},V=function(n,t){D(n).forEach(t)},j=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,m),e&&(t.unobserve_completed&&R(n,t),x(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(T(e,1),x(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,k(n,t.data_sizes)),W(n,s,k(n,t.data_srcset)),W(n,u,k(n,t.data_src))},Y={IMG:function(n,t){H(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,j),W(n,u,k(n,t.data_src))},VIDEO:function(n,t){V(n,(function(n){$(n,j),W(n,u,k(n,t.data_src))})),$(n,F),W(n,f,k(n,t.data_poster)),W(n,u,k(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,k(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||x(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),T(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&R(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),x(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),w(t,p),x(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=k(n,t.data_bg),o=k(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_multi),o=k(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=k(n,t.data_bg_set);if(i){var o=i.split("|"),a=o.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=a.join(),""===n.style.backgroundImage&&(a=o.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){H(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,j)},VIDEO:function(n){V(n,(function(n){q(n,j)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return C.indexOf(y(n))>=0}(n);w(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&R(n,e)}(n,e,i),x(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return y(n)===v}(n)&&"IMG"===n.tagName&&(an(n),function(n){H(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),T(i,-1),A(n),x(e.callback_cancel,n,t,i))}(n,t,e,i),x(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return y(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){R(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En}(); |
@@ -92,3 +92,3 @@ (function (global, factory) { | ||
}; | ||
/* Auto initialization of one or more instances of lazyload, depending on the | ||
/* Auto initialization of one or more instances of LazyLoad, depending on the | ||
options passed in (plain object or an array) */ | ||
@@ -169,3 +169,3 @@ | ||
var safeCallback = function safeCallback(callback, arg1, arg2, arg3) { | ||
if (!callback) { | ||
if (!callback || typeof callback !== 'function') { | ||
return; | ||
@@ -432,3 +432,3 @@ } | ||
if (element.style.backgroundImage === '') { | ||
if (element.style.backgroundImage === "") { | ||
bgImageValues = imgSetValues.map(function (value) { | ||
@@ -669,3 +669,3 @@ return "-webkit-image-set(".concat(value, ")"); | ||
var dontLoad = hadStartedLoading(element); | ||
/* Save status | ||
/* Save status | ||
before setting it, to prevent loading it again. Fixes #526. */ | ||
@@ -672,0 +672,0 @@ |
@@ -1,1 +0,1 @@ | ||
!function(n,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(n="undefined"!=typeof globalThis?globalThis:n||self).LazyLoad=t()}(this,(function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,o=t&&"classList"in document.createElement("p"),a=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",m="applied",p="error",h="native",E="data-",I="ll-status",y=function(n,t){return n.getAttribute(E+t)},k=function(n){return y(n,I)},w=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===k(n)},O=function(n){return k(n)===h},x=[v,b,m,p],C=function(n,t,e,i){n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},T=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},R=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},j=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},D=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&j(e).forEach(t)},H=function(n,t){j(n).forEach(t)},V=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,m),e&&(t.unobserve_completed&&T(n,t),C(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(R(e,1),C(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,y(n,t.data_sizes)),W(n,s,y(n,t.data_srcset)),W(n,u,y(n,t.data_src))},Y={IMG:function(n,t){D(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,V),W(n,u,y(n,t.data_src))},VIDEO:function(n,t){H(n,(function(n){$(n,V),W(n,u,y(n,t.data_src))})),$(n,F),W(n,f,y(n,t.data_poster)),W(n,u,y(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,y(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||C(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),R(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&T(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),C(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),w(t,p),C(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=y(n,t.data_bg),o=y(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_multi),o=y(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_set);if(i){var o=i.split("|"),a=o.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=a.join(),""===n.style.backgroundImage&&(a=o.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){D(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,V)},VIDEO:function(n){H(n,(function(n){q(n,V)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return x.indexOf(k(n))>=0}(n);w(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&T(n,e)}(n,e,i),C(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return k(n)===v}(n)&&"IMG"===n.tagName&&(an(n),function(n){D(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),R(i,-1),A(n),C(e.callback_cancel,n,t,i))}(n,t,e,i),C(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return k(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){T(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En})); | ||
!function(n,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(n="undefined"!=typeof globalThis?globalThis:n||self).LazyLoad=t()}(this,(function(){"use strict";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t="undefined"!=typeof window,e=t&&!("onscroll"in window)||"undefined"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&"IntersectionObserver"in window,o=t&&"classList"in document.createElement("p"),a=t&&window.devicePixelRatio>1,r={elements_selector:".lazy",container:e||t?document:null,threshold:300,thresholds:null,data_src:"src",data_srcset:"srcset",data_sizes:"sizes",data_bg:"bg",data_bg_hidpi:"bg-hidpi",data_bg_multi:"bg-multi",data_bg_multi_hidpi:"bg-multi-hidpi",data_bg_set:"bg-set",data_poster:"poster",class_applied:"applied",class_loading:"loading",class_loaded:"loaded",class_error:"error",class_entered:"entered",class_exited:"exited",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i="LazyLoad::Initialized",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent("CustomEvent")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u="src",s="srcset",d="sizes",f="poster",_="llOriginalAttrs",g="data",v="loading",b="loaded",p="applied",m="error",h="native",E="data-",I="ll-status",y=function(n,t){return n.getAttribute(E+t)},k=function(n){return y(n,I)},w=function(n,t){return function(n,t,e){var i="data-ll-status";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===k(n)},O=function(n){return k(n)===h},x=[v,b,p,m],C=function(n,t,e,i){n&&"function"==typeof n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?" ":"")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp("(^|\\s+)"+t+"(\\s+|$)")," ").replace(/^\s+/,"").replace(/\s+$/,"")},z=function(n){return n.llTempImage},T=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},R=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},j=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)"SOURCE"===t.tagName&&e.push(t);return e},D=function(n,t){var e=n.parentNode;e&&"PICTURE"===e.tagName&&j(e).forEach(t)},H=function(n,t){j(n).forEach(t)},V=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,p),e&&(t.unobserve_completed&&T(n,t),C(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(R(e,1),C(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,y(n,t.data_sizes)),W(n,s,y(n,t.data_srcset)),W(n,u,y(n,t.data_src))},Y={IMG:function(n,t){D(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,V),W(n,u,y(n,t.data_src))},VIDEO:function(n,t){H(n,(function(n){$(n,V),W(n,u,y(n,t.data_src))})),$(n,F),W(n,f,y(n,t.data_poster)),W(n,u,y(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,y(n,t.data_src))}},Z=["IMG","IFRAME","VIDEO","OBJECT"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||C(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),R(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&T(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i="VIDEO"===n.tagName?"loadeddata":"load";tn(n,i,t),tn(n,"error",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),C(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),w(t,m),C(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement("IMG")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=y(n,t.data_bg),o=y(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url("'.concat(r,'")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_multi),o=y(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_set);if(i){var o=i.split("|"),a=o.map((function(n){return"image-set(".concat(n,")")}));n.style.backgroundImage=a.join(),""===n.style.backgroundImage&&(a=o.map((function(n){return"-webkit-image-set(".concat(n,")")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){D(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,V)},VIDEO:function(n){H(n,(function(n){q(n,V)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=["IMG","IFRAME","VIDEO"],gn=function(n){return n.use_native&&"loading"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return x.indexOf(k(n))>=0}(n);w(n,"entered"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&T(n,e)}(n,e,i),C(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return k(n)===v}(n)&&"IMG"===n.tagName&&(an(n),function(n){D(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),R(i,-1),A(n),C(e.callback_cancel,n,t,i))}(n,t,e,i),C(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},pn=function(n){return n.container.querySelectorAll(n.elements_selector)},mn=function(n){return function(n){return k(n)===m}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||pn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+"px"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=pn(n),bn(e).filter(mn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener("online",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute("loading","lazy"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener("online",this._onlineHandler),pn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){T(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;pn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En})); |
{ | ||
"name": "vanilla-lazyload", | ||
"version": "17.8.4", | ||
"version": "17.8.5", | ||
"description": "LazyLoad is a lightweight (2.4 kB) and flexible script that speeds up your web application by deferring the loading of your below-the-fold images, videos and iframes to when they will enter the viewport. It's written in plain \"vanilla\" JavaScript, it leverages the IntersectionObserver API, it supports responsive images, it optimizes your website for slower connections, and can enable native lazy loading.", | ||
@@ -5,0 +5,0 @@ "main": "dist/lazyload.min.js", |
@@ -178,3 +178,3 @@ LazyLoad is a lightweight (2.4 kB) and flexible script that **speeds up your web application** by deferring the loading of your below-the-fold images, animated SVGs, videos and iframes to **when they will enter the viewport**. It's written in plain "vanilla" JavaScript, it leverages the [IntersectionObserver](https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API) API, it supports [responsive images](https://alistapart.com/article/responsive-images-in-practice), it optimizes your website for slower connections, and can enable native lazy loading. See [all features](#-all-features-compared) for more. | ||
The latest, recommended version of LazyLoad is **17.8.4**. | ||
The latest, recommended version of LazyLoad is **17.8.5**. | ||
@@ -188,3 +188,3 @@ Quickly understand how to upgrade from a previous version reading the [practical upgrade guide](UPGRADE.md). | ||
```html | ||
<script src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.4/dist/lazyload.min.js"></script> | ||
<script src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.5/dist/lazyload.min.js"></script> | ||
``` | ||
@@ -230,3 +230,3 @@ | ||
async | ||
src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.4/dist/lazyload.min.js" | ||
src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.5/dist/lazyload.min.js" | ||
></script> | ||
@@ -265,3 +265,3 @@ ``` | ||
async | ||
src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.4/dist/lazyload.min.js" | ||
src="https://cdn.jsdelivr.net/npm/vanilla-lazyload@17.8.5/dist/lazyload.min.js" | ||
></script> | ||
@@ -268,0 +268,0 @@ ``` |
217828
3382