/* bttrlazyloading, responsive lazy loading plugin for jquery by julien renaux http://bttrlazyloading.julienrenaux.fr version: 1.0.8 full source at https://github.com/shprink/bttrlazyloading mit license, https://github.com/shprink/bttrlazyloading/blob/master/license */ (function() { "use strict"; var $, bttrlazyloading, bttrlazyloadingglobal, __hasprop = {}.hasownproperty; $ = jquery; bttrlazyloading = (function() { var _getimagesrc, _getimgobject, _getimgobjectperrange, _getlargestimgobject, _getrangefromscreensize, _isupdatable, _iswithinviewport, _setoptionsfromdata, _setupevents, _update, _updatecanvassize; bttrlazyloading.dpr = 1; function bttrlazyloading(img, options) { var defaultoptions; if (options == null) { options = {}; } this.$img = $(img); this.loaded = false; this.loading = false; defaultoptions = $.extend(true, {}, $.bttrlazyloading.constructor.options); this.options = $.extend(true, defaultoptions, options); this.breakpoints = $.bttrlazyloading.constructor.breakpoints; this.$container = $(this.options.container); if (typeof window.devicepixelratio === 'number') { this.constructor.dpr = window.devicepixelratio; } this.whitelist = ['lg', 'md', 'sm', 'xs']; this.blacklist = []; _setoptionsfromdata.call(this); this.$wrapper = $(''); if (this.options.wrapperclasses && typeof this.options.wrapperclasses === 'string') { this.$wrapper.addclass(this.options.wrapperclasses); } this.$img.before(this.$wrapper); this.$clone = $(''); _updatecanvassize.call(this); this.$wrapper.append(this.$clone); this.$img.hide(); this.$wrapper.append(this.$img); if (this.options.backgroundcolor) { this.$wrapper.css('background-color', this.options.backgroundcolor); } _setupevents.call(this, 'on'); settimeout((function(_this) { return function() { return _update.call(_this); }; })(this), 100); } /* private functions */ _updatecanvassize = function() { var imgobject; imgobject = _getimgobject.call(this); this.$clone.attr('width', imgobject.width); return this.$clone.attr('height', imgobject.height); }; _setoptionsfromdata = function() { var i, v, _ref, _results; _ref = this.$img.data(); _results = []; for (i in _ref) { if (!__hasprop.call(_ref, i)) continue; v = _ref[i]; if ((v != null) && i.indexof('bttrlazyloading') !== 0) { continue; } i = i.replace('bttrlazyloading', '').replace(/([a-z])([a-z])/g, '$1-$2').tolowercase().split('-'); if (i.length > 1) { if (typeof this.options[i[0]][i[1]] !== 'undefined') { _results.push(this.options[i[0]][i[1]] = v); } else { _results.push(void 0); } } else { if (typeof v === 'object') { _results.push($.extend(this.options[i[0]], v)); } else { if (typeof this.options[i[0]] !== 'undefined') { _results.push(this.options[i[0]] = v); } else { _results.push(void 0); } } } } return _results; }; _setupevents = function(onoroff) { var onbttrload, onerror, onload, update; onload = (function(_this) { return function() { _this.$clone.hide(); _this.$img.show(); _this.$wrapper.addclass('bttrlazyloading-loaded'); if (_this.options.animation) { _this.$img.addclass('animated ' + _this.options.animation); } _this.loaded = _this.$img.attr('src'); return _this.$img.trigger('bttrlazyloading.afterload'); }; })(this); this.$img[onoroff]('load', onload); onbttrload = (function(_this) { return function(e) { var imgobject; if (!_this.loading) { _this.loading = true; imgobject = _getimgobject.call(_this); if (!_this.loaded) { _this.$wrapper.css('background-image', "url('" + _this.options.placeholder + "')"); } else { _this.$wrapper.removeclass('bttrlazyloading-loaded'); if (_this.options.animation) { _this.$img.removeclass('animated ' + _this.options.animation); } _this.$img.removeattr('src'); _this.$img.hide(); _this.$clone.attr('width', imgobject.width); _this.$clone.attr('height', imgobject.height); _this.$clone.show(); } return settimeout(function() { _this.$img.trigger('bttrlazyloading.beforeload'); _this.$img.data('bttrlazyloading.range', imgobject.range); _this.$img.attr('src', _getimagesrc.call(_this, imgobject.src, imgobject.range)); return _this.loading = false; }, _this.options.delay); } }; })(this); this.$img[onoroff]('bttrlazyloading.load', onbttrload); onerror = (function(_this) { return function(e) { var range, src; src = _this.$img.attr('src'); range = _this.$img.data('bttrlazyloading.range'); if (_this.constructor.dpr >= 2 && _this.options.retina && src.match(/@2x/gi)) { _this.blacklist.push(range + '@2x'); } else { _this.blacklist.push(range); _this.whitelist.splice(_this.whitelist.indexof(range), 1); if (_this.whitelist.length === 0) { _this.$img.trigger('bttrlazyloading.error'); return false; } } return _this.$img.trigger('bttrlazyloading.load'); }; })(this); this.$img[onoroff]('error', onerror); update = (function(_this) { return function(e) { return _update.call(_this); }; })(this); this.$container[onoroff](this.options.event, update); if (this.options.container !== window) { $(window)[onoroff](this.options.event, update); } return $(window)[onoroff]("resize", update); }; _getrangefromscreensize = function() { var ww; ww = window.innerwidth; if (ww <= this.breakpoints.xs) { return 'xs'; } else if ((this.breakpoints.sm <= ww && ww < this.breakpoints.md)) { return 'sm'; } else if ((this.breakpoints.md <= ww && ww < this.breakpoints.lg)) { return 'md'; } else if (this.breakpoints.lg <= ww) { return 'lg'; } }; _getimgobject = function() { this.range = _getrangefromscreensize.call(this); return _getlargestimgobject.call(this); }; _getimagesrc = function(src, range) { if (this.constructor.dpr >= 2 && this.options.retina && this.blacklist.indexof(range + '@2x') === -1) { return src.replace(/\.\w+$/, function(match) { return '@2x' + match; }); } else { return src; } }; _getimgobjectperrange = function(range) { if (typeof this.options[range].src !== 'undefined' && this.options[range].src !== null) { return this.options[range]; } return null; }; _getlargestimgobject = function() { var index, range, src, _i, _len, _ref; index = this.whitelist.indexof(this.range); if (index > -1) { src = _getimgobjectperrange.call(this, this.range); if (src) { src.range = this.range; return src; } } _ref = this.whitelist; for (index = _i = 0, _len = _ref.length; _i < _len; index = ++_i) { range = _ref[index]; src = _getimgobjectperrange.call(this, range); if (src) { src.range = range; return src; } } return ''; }; _isupdatable = function() { var imgobject, iswithinwindowviewport, threshold; if (!this.loaded && this.options.triggermanually) { return false; } if (this.loaded && this.options.updatemanually) { return false; } imgobject = _getimgobject.call(this); if (!imgobject.src || this.loaded === _getimagesrc.call(this, imgobject.src, imgobject.range)) { return false; } threshold = 0; if (!this.loaded) { threshold = this.options.threshold; } iswithinwindowviewport = _iswithinviewport.call(this, $(window), { top: $(window).scrolltop() + threshold, left: $(window).scrollleft() }); if (this.options.container !== window) { return iswithinwindowviewport && _iswithinviewport.call(this, this.$container, { top: this.$container.offset().top + threshold, left: this.$container.offset().left }); } return iswithinwindowviewport; }; _iswithinviewport = function($container, viewport) { var bounds; if (viewport == null) { viewport = {}; } viewport.right = viewport.left + $container.width(); viewport.bottom = viewport.top + $container.height(); bounds = this.$wrapper.offset(); bounds.right = bounds.left + this.$wrapper.outerwidth(); bounds.bottom = bounds.top + this.$wrapper.outerheight(); return !(viewport.right < bounds.left || viewport.left > bounds.right || viewport.bottom < bounds.top || viewport.top > bounds.bottom); }; _update = function() { if (this.range !== _getrangefromscreensize.call(this)) { _updatecanvassize.call(this); } if (_isupdatable.call(this)) { return this.$img.trigger('bttrlazyloading.load'); } }; /* public functions */ bttrlazyloading.prototype.get$img = function() { return this.$img; }; bttrlazyloading.prototype.get$clone = function() { return this.$clone; }; bttrlazyloading.prototype.get$wrapper = function() { return this.$wrapper; }; bttrlazyloading.prototype.destroy = function() { this.$wrapper.before(this.$img); this.$wrapper.remove(); _setupevents.call(this, 'off'); this.$img.off('bttrlazyloading'); this.$wrapper.removeclass('bttrlazyloading-loaded'); if (this.options.animation) { this.$img.removeclass('animated ' + this.options.animation); } this.$img.removedata('bttrlazyloading'); return this.$img; }; return bttrlazyloading; })(); $.fn.extend({ bttrlazyloading: function(options) { return this.each(function() { var $this, data; $this = $(this); data = $this.data('bttrlazyloading'); if (typeof data === 'undefined') { data = new bttrlazyloading(this, options); $this.data('bttrlazyloading', data); } if (typeof options === 'string' && typeof data[options] !== 'undefined') { return data[options].call(data); } }); } }); $.fn.bttrlazyloading.constructor = bttrlazyloading; bttrlazyloadingglobal = (function() { function bttrlazyloadingglobal() {} bttrlazyloadingglobal.prototype.version = '1.0.8'; bttrlazyloadingglobal.breakpoints = { xs: 767, sm: 768, md: 992, lg: 1200 }; bttrlazyloadingglobal.options = { xs: { src: null, width: 100, height: 100, animation: null }, sm: { src: null, width: 100, height: 100, animation: null }, md: { src: null, width: 100, height: 100, animation: null }, lg: { src: null, width: 100, height: 100, animation: null }, retina: false, animation: 'bouncein', delay: 0, event: 'scroll', container: window, threshold: 0, triggermanually: false, updatemanually: false, wrapperclasses: null, backgroundcolor: '#eee', placeholder: '' }; bttrlazyloadingglobal.prototype.setoptions = function(object) { if (object == null) { object = {}; } $.extend(true, this.constructor.options, object); return this; }; bttrlazyloadingglobal.prototype.setranges = function(object) { if (object == null) { object = {}; } $.extend(true, this.constructor.breakpoints, object); return this; }; bttrlazyloadingglobal.prototype.setbreakpoints = function(object) { if (object == null) { object = {}; } $.extend(true, this.constructor.breakpoints, object); return this; }; return bttrlazyloadingglobal; })(); $.bttrlazyloading = new bttrlazyloadingglobal(); }).call(this);