Skip to content

Instantly share code, notes, and snippets.

@IcarusFW
Created September 13, 2016 08:05
Show Gist options
  • Save IcarusFW/0564edce91eeb2fe06f0efc464d65b94 to your computer and use it in GitHub Desktop.
Save IcarusFW/0564edce91eeb2fe06f0efc464d65b94 to your computer and use it in GitHub Desktop.
LazyLoader - preload overlay generator
var LazyLoader = function(selector, args) {
var fn = {
insert: function(){
target.each(function(){
var docFragment = $(document.createDocumentFragment());
docFragment.append('<div class="lazyLoader"><span class="lazyLoader-icon"></span></div>')
$(this).prepend(docFragment);
});
},
fade: function(){
target.each(function(i){
var loading = $(this).find('.lazyLoader');
setTimeout(function(){
loading
.animate({
'opacity': '0'
}, prop.fade, function(){
$(this).remove(); // destroy overlay when animation completes
});
}, prop.delay * i);
});
},
delay: function(){
setTimeout(function(){
fn.fade(); // call this function once all of the overlays have been inserted
}, prop.load);
},
init: function(){
fn.insert();
fn.delay();
}
},
helper = {
clone: function(obj, src) {
var clone = {};
Object.keys(obj).forEach(function(key) { clone[key] = obj[key]; });
Object.keys(src).forEach(function(key) { clone[key] = src[key]; });
return clone;
},
extend: function(obj, src){
Object.keys(src).forEach(function(key) { obj[key] = src[key]; });
return obj;
}
},
target = $(selector),
count = target.length - 1,
defaults = {
load: 3000, // time between insert and fade start
fade: 200, // fade duration
delay: 100 // delay between each successive insert fade out
},
prop = (typeof args === "object") ? helper.clone(defaults, args) : defaults;
return {
view: {
target: function(){
console.log(target);
},
defaults: function(obj){
switch(obj) {
case 'defaults':
console.log(defaults);
break;
case 'prop':
console.log(prop);
break;
default:
console.log(defaults);
break;
}
}
},
change: {
target: function(newTarget){
target = newTarget;
},
defaults: function(obj){
helper.extend(prop, obj);
},
reset: function(){
helper.extend(prop, defaults);
}
},
execute: function(act){
switch(act){
case 'init':
case 'insert':
case 'fade':
case 'delay':
fn[act]();
break;
default:
fn.init();
break;
}
}
};
};
.lazyLoader {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
background-color: #cdcdcd;
z-index: 10;
.lazyLoader-icon {
position: absolute;
top: 50%;
left: 50%;
margin-left: -36.5px;
margin-top: -23.5px;
width: 72px;
height: 47px;
background: #929292;
z-index: 0;
&:before {
content: "";
position: absolute;
background: rgba(0, 0, 0, 0.4);
width: 100%;
bottom: 0;
-webkit-animation: wipe 2.4s cubic-bezier(.2,.6,.8,.4) forwards;
-moz-animation: wipe 2.4s cubic-bezier(.2,.6,.8,.4) forwards;
animation: wipe 2.4s cubic-bezier(.2,.6,.8,.4) forwards;
animation-iteration-count: infinite;
}
&:after {
content: "";
position: absolute;
width: 100%;
height: 100%;
top: 0;
background-repeat: no-repeat;
background-image: url('');
}
}
}
@-webkit-keyframes wipe {
0% {
height: 0;
}
100% {
height: 100%;
}
}
@keyframes wipe {
0% {
height: 0;
}
100% {
height: 100%;
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment