From 4f19d9fd564eadc93e40c2016d78d4cfac2a5873 Mon Sep 17 00:00:00 2001 From: RainLoop Date: Thu, 21 Sep 2017 01:18:41 +0300 Subject: [PATCH] Try the lozad lazy loader --- .eslintrc.js | 2 +- dev/Common/Consts.js | 2 ++ dev/Model/Message.js | 45 +++++++++++++++++++++++++------------------- dev/boot.js | 1 + gulpfile.js | 2 +- package.json | 2 ++ yarn.lock | 8 ++++++++ 7 files changed, 41 insertions(+), 21 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 2b72199e2..4b8cd2065 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -24,7 +24,7 @@ module.exports = { // errors 'no-cond-assign': [2, 'always'], - 'no-console': 2, + 'no-console': 0, 'no-constant-condition': 2, 'no-control-regex': 2, 'no-debugger': 2, diff --git a/dev/Common/Consts.js b/dev/Common/Consts.js index 56b48b3b6..9199e528c 100644 --- a/dev/Common/Consts.js +++ b/dev/Common/Consts.js @@ -41,3 +41,5 @@ export const RAINLOOP_TRIAL_KEY = 'RAINLOOP-TRIAL-KEY'; export const DATA_IMAGE_USER_DOT_PIC = ''; export const DATA_IMAGE_TRANSP_PIC = ''; + +export const DATA_IMAGE_LAZY_PLACEHOLDER_PIC = ''; diff --git a/dev/Model/Message.js b/dev/Model/Message.js index dcaec99b7..4d8a0c227 100644 --- a/dev/Model/Message.js +++ b/dev/Model/Message.js @@ -4,9 +4,11 @@ import $ from '$'; import ko from 'ko'; import moment from 'moment'; import classnames from 'classnames'; +import lozad from 'lozad'; import {MessagePriority, SignedVerifyStatus} from 'Common/Enums'; import {i18n} from 'Common/Translator'; +import {DATA_IMAGE_LAZY_PLACEHOLDER_PIC} from 'Common/Consts'; import { pInt, inArray, isArray, isUnd, trim, @@ -743,11 +745,28 @@ class MessageModel extends AbstractModel if (this.body) { $('.lazy.lazy-inited[data-original]', this.body).each(function() { - $(this).attr('src', $(this).attr('data-original')).removeAttr('data-original'); // eslint-disable-line no-invalid-this + $(this).attr('src', $(this).attr('data-original')) // eslint-disable-line no-invalid-this + .removeAttr('data-original').removeAttr('data-loaded'); }); } } + lozad() { + lozad('img.lazy:not(.lazy-inited)', { + threshold: 0.4, + load: (element) => { + // console.log('lazy', element.dataset.original); + element.src = DATA_IMAGE_LAZY_PLACEHOLDER_PIC; + $(element) + .addClass('lazy-inited') + .attr('src', element.dataset.original) + .removeAttr('data-loaded') + .css({opacity: 0.3}) + .animate({opacity: 1}, 500); + } + }).observe(); + } + showExternalImages(lazy = false) { if (this.body && this.body.data('rl-has-images')) { @@ -762,11 +781,13 @@ class MessageModel extends AbstractModel $this .addClass('lazy') .attr('data-original', $this.attr(attr)) + .removeAttr('data-loaded') .removeAttr(attr); } else { - $this.attr('src', $this.attr(attr)).removeAttr(attr); + $this.attr('src', $this.attr(attr)) + .removeAttr('data-loaded').removeAttr(attr); } }); @@ -780,13 +801,7 @@ class MessageModel extends AbstractModel if (lazy) { - $('img.lazy', this.body).addClass('lazy-inited').lazyload({ - 'threshold': 400, - 'effect': 'fadeIn', - 'skip_invisible': false, - 'container': $('.RL-MailMessageView .messageView .messageItem .content')[0] - }); - + this.lozad(); $win.resize(); } @@ -867,16 +882,8 @@ class MessageModel extends AbstractModel if (lazy) { - (function($oImg, oContainer) { - _.delay(() => { - $oImg.addClass('lazy-inited').lazyload({ - 'threshold': 400, - 'effect': 'fadeIn', - 'skip_invisible': false, - 'container': oContainer - }); - }, 300); - }($('img.lazy', self.body), $('.RL-MailMessageView .messageView .messageItem .content')[0])); + // $('.RL-MailMessageView .messageView .messageItem .content')[0] + _.delay(() => this.lozad(), 300); } windowResize(500); diff --git a/dev/boot.js b/dev/boot.js index 2fb116e85..565019d95 100644 --- a/dev/boot.js +++ b/dev/boot.js @@ -22,6 +22,7 @@ window.progressJs.onbeforeend(() => { }); require('json3'); +require('intersection-observer'); require('../vendors/modernizr/modernizr-custom.js'); require('Common/Booter'); diff --git a/gulpfile.js b/gulpfile.js index 4626b6e32..76ac623ad 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -194,7 +194,7 @@ cfg.paths.js = { 'node_modules/jquery/dist/jquery.min.js', 'node_modules/jquery-mousewheel/jquery.mousewheel.js', 'node_modules/jquery-scrollstop/jquery.scrollstop.js', - 'node_modules/jquery-lazyload/jquery.lazyload.js ', + // 'node_modules/jquery-lazyload/jquery.lazyload.js', 'node_modules/jquery-backstretch/jquery.backstretch.min.js', 'vendors/jquery-ui/js/jquery-ui-1.10.3.custom.min.js', // custom 'vendors/jquery-nanoscroller/jquery.nanoscroller.js', // custom (modified) diff --git a/package.json b/package.json index b45a21fea..0b53bff16 100644 --- a/package.json +++ b/package.json @@ -93,6 +93,7 @@ "gulp-util": "3.0.8", "gulp-zip": "4.0.0", "ifvisible.js": "1.0.6", + "intersection-observer": "^0.4.2", "jquery": "2.2.4", "jquery-backstretch": "2.1.16", "jquery-lazyload": "1.9.7", @@ -105,6 +106,7 @@ "knockout-projections": "github:stevesanderson/knockout-projections#v1.1.0", "knockout-sortable": "0.14.1", "lightgallery": "1.2.21", + "lozad": "1.0.2", "matchmedia-polyfill": "0.3.0", "moment": "2.18.1", "node-fs": "0.1.7", diff --git a/yarn.lock b/yarn.lock index f516de72b..0fb28dfbc 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2876,6 +2876,10 @@ interpret@^1.0.0: version "1.0.4" resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.0.4.tgz#820cdd588b868ffb191a809506d6c9c8f212b1b0" +intersection-observer@^0.4.2: + version "0.4.2" + resolved "https://registry.yarnpkg.com/intersection-observer/-/intersection-observer-0.4.2.tgz#24100ed620baf6a427072996d4d73366e9ec93ef" + invariant@^2.2.0, invariant@^2.2.2: version "2.2.2" resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.2.tgz#9e1f56ac0acdb6bf303306f338be3b204ae60360" @@ -3681,6 +3685,10 @@ loud-rejection@^1.0.0: currently-unhandled "^0.4.1" signal-exit "^3.0.0" +lozad@1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/lozad/-/lozad-1.0.2.tgz#9936b781f81592e2c8309e14e9556ad9bebb403d" + lru-cache@2: version "2.7.3" resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-2.7.3.tgz#6d4524e8b955f95d4f5b58851ce21dd72fb4e952"