lozad_js.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. /*! lozad.js - v1.16.0 - 2020-09-06
  2. * https://github.com/ApoorvSaxena/lozad.js
  3. * Copyright (c) 2020 Apoorv Saxena; Licensed MIT */
  4. (function (global, factory) {
  5. typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
  6. typeof define === 'function' && define.amd ? define(factory) :
  7. (global.lozad = factory());
  8. }(this, (function () { 'use strict';
  9. /**
  10. * Detect IE browser
  11. * @const {boolean}
  12. * @private
  13. */
  14. var isIE = typeof document !== 'undefined' && document.documentMode;
  15. var defaultConfig = {
  16. rootMargin: '0px',
  17. threshold: 0,
  18. load: function load(element) {
  19. if (element.nodeName.toLowerCase() === 'picture') {
  20. var img = element.querySelector('img');
  21. var append = false;
  22. if (img === null) {
  23. img = document.createElement('img');
  24. append = true;
  25. }
  26. if (isIE && element.getAttribute('data-iesrc')) {
  27. img.src = element.getAttribute('data-iesrc');
  28. }
  29. if (element.getAttribute('data-alt')) {
  30. img.alt = element.getAttribute('data-alt');
  31. }
  32. if (append) {
  33. element.append(img);
  34. }
  35. }
  36. if (element.nodeName.toLowerCase() === 'video' && !element.getAttribute('data-src')) {
  37. if (element.children) {
  38. var childs = element.children;
  39. var childSrc = void 0;
  40. for (var i = 0; i <= childs.length - 1; i++) {
  41. childSrc = childs[i].getAttribute('data-src');
  42. if (childSrc) {
  43. childs[i].src = childSrc;
  44. }
  45. }
  46. element.load();
  47. }
  48. }
  49. if (element.getAttribute('data-poster')) {
  50. element.poster = element.getAttribute('data-poster');
  51. }
  52. if (element.getAttribute('data-src')) {
  53. element.src = element.getAttribute('data-src');
  54. }
  55. if (element.getAttribute('data-srcset')) {
  56. element.setAttribute('srcset', element.getAttribute('data-srcset'));
  57. }
  58. var backgroundImageDelimiter = ',';
  59. if (element.getAttribute('data-background-delimiter')) {
  60. backgroundImageDelimiter = element.getAttribute('data-background-delimiter');
  61. }
  62. if (element.getAttribute('data-background-image')) {
  63. element.style.backgroundImage = 'url(\'' + element.getAttribute('data-background-image').split(backgroundImageDelimiter).join('\'),url(\'') + '\')';
  64. } else if (element.getAttribute('data-background-image-set')) {
  65. var imageSetLinks = element.getAttribute('data-background-image-set').split(backgroundImageDelimiter);
  66. var firstUrlLink = imageSetLinks[0].substr(0, imageSetLinks[0].indexOf(' ')) || imageSetLinks[0]; // Substring before ... 1x
  67. firstUrlLink = firstUrlLink.indexOf('url(') === -1 ? 'url(' + firstUrlLink + ')' : firstUrlLink;
  68. if (imageSetLinks.length === 1) {
  69. element.style.backgroundImage = firstUrlLink;
  70. } else {
  71. element.setAttribute('style', (element.getAttribute('style') || '') + ('background-image: ' + firstUrlLink + '; background-image: -webkit-image-set(' + imageSetLinks + '); background-image: image-set(' + imageSetLinks + ')'));
  72. }
  73. }
  74. if (element.getAttribute('data-toggle-class')) {
  75. element.classList.toggle(element.getAttribute('data-toggle-class'));
  76. }
  77. },
  78. loaded: function loaded() {}
  79. };
  80. function markAsLoaded(element) {
  81. element.setAttribute('data-loaded', true);
  82. }
  83. function preLoad(element) {
  84. if (element.getAttribute('data-placeholder-background')) {
  85. element.style.background = element.getAttribute('data-placeholder-background');
  86. }
  87. }
  88. var isLoaded = function isLoaded(element) {
  89. return element.getAttribute('data-loaded') === 'true';
  90. };
  91. var onIntersection = function onIntersection(load, loaded) {
  92. return function (entries, observer) {
  93. entries.forEach(function (entry) {
  94. if (entry.intersectionRatio > 0 || entry.isIntersecting) {
  95. observer.unobserve(entry.target);
  96. if (!isLoaded(entry.target)) {
  97. load(entry.target);
  98. markAsLoaded(entry.target);
  99. loaded(entry.target);
  100. }
  101. }
  102. });
  103. };
  104. };
  105. var getElements = function getElements(selector) {
  106. var root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document;
  107. if (selector instanceof Element) {
  108. return [selector];
  109. }
  110. if (selector instanceof NodeList) {
  111. return selector;
  112. }
  113. return root.querySelectorAll(selector);
  114. };
  115. function lozad () {
  116. var selector = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '.lozad';
  117. var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
  118. var _Object$assign = Object.assign({}, defaultConfig, options),
  119. root = _Object$assign.root,
  120. rootMargin = _Object$assign.rootMargin,
  121. threshold = _Object$assign.threshold,
  122. load = _Object$assign.load,
  123. loaded = _Object$assign.loaded;
  124. var observer = void 0;
  125. if (typeof window !== 'undefined' && window.IntersectionObserver) {
  126. observer = new IntersectionObserver(onIntersection(load, loaded), {
  127. root: root,
  128. rootMargin: rootMargin,
  129. threshold: threshold
  130. });
  131. }
  132. var elements = getElements(selector, root);
  133. for (var i = 0; i < elements.length; i++) {
  134. preLoad(elements[i]);
  135. }
  136. return {
  137. observe: function observe() {
  138. var elements = getElements(selector, root);
  139. for (var _i = 0; _i < elements.length; _i++) {
  140. if (isLoaded(elements[_i])) {
  141. continue;
  142. }
  143. if (observer) {
  144. observer.observe(elements[_i]);
  145. continue;
  146. }
  147. load(elements[_i]);
  148. markAsLoaded(elements[_i]);
  149. loaded(elements[_i]);
  150. }
  151. },
  152. triggerLoad: function triggerLoad(element) {
  153. if (isLoaded(element)) {
  154. return;
  155. }
  156. load(element);
  157. markAsLoaded(element);
  158. loaded(element);
  159. },
  160. observer: observer
  161. };
  162. }
  163. return lozad;
  164. })));