IMPROVEMENT: load data-lazy-bg

This commit is contained in:
Tony Air 2020-02-05 01:15:22 +07:00
parent a14c47c898
commit ae701b7b99
2 changed files with 70 additions and 44 deletions

View File

@ -1,4 +1,4 @@
"use strict"; 'use strict';
import $ from 'jquery'; import $ from 'jquery';
@ -15,8 +15,7 @@ import FormBasics from './_components/_ui.form.basics';
import SmoothScroll from 'smooth-scroll'; import SmoothScroll from 'smooth-scroll';
const smoothScroll = SmoothScroll(); const smoothScroll = SmoothScroll();
const MainUI = ($ => {
const MainUI = (($) => {
// Constants // Constants
const W = window; const W = window;
const D = document; const D = document;
@ -48,7 +47,6 @@ const MainUI = (($) => {
} }
}); });
// update online/offline state // update online/offline state
const updateOnlineStatus = () => { const updateOnlineStatus = () => {
if (!navigator.onLine) { if (!navigator.onLine) {
@ -63,13 +61,21 @@ const MainUI = (($) => {
}; };
if (typeof navigator.onLine !== 'undefined') { if (typeof navigator.onLine !== 'undefined') {
W.addEventListener('offline', () => { W.addEventListener(
'offline',
() => {
updateOnlineStatus(); updateOnlineStatus();
}, false); },
false,
);
W.addEventListener('online', () => { W.addEventListener(
'online',
() => {
updateOnlineStatus(); updateOnlineStatus();
}, false); },
false,
);
W.addEventListener('load', () => { W.addEventListener('load', () => {
updateOnlineStatus(); updateOnlineStatus();
@ -78,17 +84,14 @@ const MainUI = (($) => {
// scrollTo // scrollTo
const ScrollTo = (trigger, selector) => { const ScrollTo = (trigger, selector) => {
smoothScroll.animateScroll( smoothScroll.animateScroll(D.querySelector(selector), trigger, {
D.querySelector(selector),
trigger, {
speed: 500, speed: 500,
offset: -20, offset: -20,
//easing: 'easeInOutCubic', //easing: 'easeInOutCubic',
// Callback API // Callback API
//before: (anchor, toggle) => {}, // Callback to run before scroll //before: (anchor, toggle) => {}, // Callback to run before scroll
//`after: (anchor, toggle) => {} // Callback to run after scroll //`after: (anchor, toggle) => {} // Callback to run after scroll
} });
);
}; };
// session ping // session ping
@ -118,9 +121,9 @@ const MainUI = (($) => {
}, 300000); // 5 min in ms }, 300000); // 5 min in ms
W.URLDetails = { W.URLDetails = {
'base': $('base').attr('href'), base: $('base').attr('href'),
'relative': '/', relative: '/',
'hash': '', hash: '',
}; };
class MainUI { class MainUI {
@ -171,7 +174,7 @@ const MainUI = (($) => {
// //
// scroll links // scroll links
$('.js-scrollTo').on('click', (e) => { $('.js-scrollTo').on('click', e => {
e.preventDefault(); e.preventDefault();
const el = e.currentTarget; const el = e.currentTarget;
const $el = $(e.currentTarget); const $el = $(e.currentTarget);
@ -181,7 +184,9 @@ const MainUI = (($) => {
// load external fonts // load external fonts
if ($('[data-extfont]').length) { if ($('[data-extfont]').length) {
$.getScript('//ajax.googleapis.com/ajax/libs/webfont/1/webfont.js', () => { $.getScript(
'//ajax.googleapis.com/ajax/libs/webfont/1/webfont.js',
() => {
const fonts = []; const fonts = [];
$('[data-extfont]').each((i, el) => { $('[data-extfont]').each((i, el) => {
@ -193,11 +198,12 @@ const MainUI = (($) => {
families: fonts, families: fonts,
}, },
}); });
}); },
);
} }
// data-set links // data-set links
$('[data-set-target]').on('click', (e) => { $('[data-set-target]').on('click', e => {
const $el = $(e.currentTarget); const $el = $(e.currentTarget);
const $target = $($el.data('set-target')); const $target = $($el.data('set-target'));
@ -261,14 +267,17 @@ const MainUI = (($) => {
const hash = location.indexOf('#'); const hash = location.indexOf('#');
W.URLDetails.relative = location.split('#')[0]; W.URLDetails.relative = location.split('#')[0];
W.URLDetails.hash = (hash >= 0) ? location.substr(location.indexOf('#')) : ''; W.URLDetails.hash =
hash >= 0 ? location.substr(location.indexOf('#')) : '';
} }
// show site-wide alert // show site-wide alert
static alert(msg, cls) { static alert(msg, cls) {
$SiteWideMessage.fadeOut('fast'); $SiteWideMessage.fadeOut('fast');
$SiteWideMessage.html(`<div class="page-alert"><div class="alert alert-${cls}"><i class="close" data-dismiss="alert">&times;</i>${msg}</div></div>`); $SiteWideMessage.html(
`<div class="page-alert"><div class="alert alert-${cls}"><i class="close" data-dismiss="alert">&times;</i>${msg}</div></div>`,
);
$SiteWideMessage.find('.page-alert').alert(); $SiteWideMessage.find('.page-alert').alert();
$SiteWideMessage.find('.close[data-dismiss="alert"]').click(() => { $SiteWideMessage.find('.close[data-dismiss="alert"]').click(() => {
@ -294,10 +303,7 @@ const MainUI = (($) => {
}); });
} }
if ( if ($AlertNotify.length && typeof $AlertNotify[0].stop !== 'undefined') {
$AlertNotify.length &&
typeof $AlertNotify[0].stop !== 'undefined'
) {
$AlertNotify[0].stop(); $AlertNotify[0].stop();
} }
@ -334,6 +340,26 @@ const MainUI = (($) => {
} }
}); });
// load lazy backgrounds
$Body.find('[data-lazy-bg]').each((i, el) => {
const $el = $(el);
const lazySrc = $el.data('lazy-bg');
if (lazySrc && lazySrc.length) {
$imgLazyUrls.push(lazySrc);
$el.addClass('loading');
AjaxUI.preload([lazySrc]).then(() => {
$el.css({ 'background-image': lazySrc });
$el.addClass('loaded');
$el.removeClass('loading');
$el.trigger('image-lazy-bg-loaded');
});
}
});
// load defined images // load defined images
AjaxUI.preload($imgUrls).then(() => { AjaxUI.preload($imgUrls).then(() => {
$(W).trigger('images-loaded'); $(W).trigger('images-loaded');

View File

@ -117,7 +117,7 @@ textarea,
.field { .field {
position: relative; position: relative;
margin: ($grid-gutter-height / 4) 0; margin: ($grid-gutter-height / 2) 0;
&.composite { &.composite {
margin-top: 0; margin-top: 0;