forked from theonion/comcastifyjs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
comcastify.js
160 lines (134 loc) · 6.93 KB
/
comcastify.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
var comcastifyjs = (function () {
// setup slowload modifier callback, structure avoids some annoying timer/closure problems
var slowloadModiferCallback = function (slowloadDiv, args) {
return function () {
(function (slowloadDiv, args) {
// calculate new height for box based on args
var img = slowloadDiv.slothifyData.img;
var newTopClip = slowloadDiv.slothifyData.imageTopClip + args.loadIncrement;
var progressiveJPEGInProgress = false;
if (args.randomPause === 0.0 || Math.random() > args.randomPause) {
slowloadDiv.style.width = img.offsetWidth + 'px';
slowloadDiv.style.height = img.offsetHeight + 'px';
slowloadDiv.style.top = img.offsetTop + 'px';
slowloadDiv.style.left = img.offsetLeft + 'px';
// update slowload div
slowloadDiv.style.clip = 'rect(' + newTopClip + 'px auto auto auto)';
// check stopping conditions
var maxImageHeight = img.height * args.loadMaxPercent;
}
//process progressive JPEG unblurring
if (args.progressiveJPEG && newTopClip >= maxImageHeight) {
var newTopClipBlur = slowloadDiv.slothifyData.blurImageTopClip + args.loadIncrement;
//continue to honor the randomPause setting
if (args.randomPause === 0.0 || Math.random() > args.randomPause) {
slowloadDiv.slothifyData.blurImg.style.width = img.offsetWidth + 'px';
slowloadDiv.slothifyData.blurImg.style.height = img.offsetHeight + 'px';
slowloadDiv.slothifyData.blurImg.style.top = img.offsetTop + 'px';
slowloadDiv.slothifyData.blurImg.style.left = img.offsetLeft + 'px';
// update slowload div
slowloadDiv.slothifyData.blurImg.style.clip = 'rect(' + newTopClipBlur + 'px auto auto auto)';
slowloadDiv.slothifyData.blurImageTopClip = newTopClipBlur;
}
// check stopping conditions
var maxImageHeightBlur = img.height * args.loadMaxPercent;
if (newTopClipBlur < maxImageHeightBlur) {
progressiveJPEGInProgress = true;
}
}
if (!img.complete) {
setTimeout(slowloadModiferCallback(slowloadDiv, args), args.loadSpeed);
} else if (typeof img.naturalHeight !== "undefined" && img.naturalWidth === 0) {
setTimeout(slowloadModiferCallback(slowloadDiv, args), args.loadSpeed);
} else if (!maxImageHeight || maxImageHeight === 0 || newTopClip < maxImageHeight || progressiveJPEGInProgress) {
// create new update timeout
slowloadDiv.slothifyData.imageTopClip = newTopClip;
setTimeout(slowloadModiferCallback(slowloadDiv, args), args.loadSpeed);
}
})(slowloadDiv, args);
};
};
var prepare = function () {
// hide images so image doesn't show up before box
var imgs = document.getElementsByTagName('img');
for(var i = 0; i < imgs.length; i++) {
var img = imgs[i];
img.style.visibility = 'hidden';
}
};
var slowImages = function (args) {
return function () {
var params = {
elements: args.elements || document.querySelectorAll('img:not([class="progressiveJPEGemulator"])'), // elements affected
boxColor: args.boxColor || '#000000', // color of box overlay
loadMaxPercent: args.loadMaxPercent || 0.0, // max percentage to load images
loadSpeed: args.loadSpeed || 500, // how often in ms to pass
randLoadIncrement: args.randLoadIncrement || false, // true to randomize load increment
loadIncrement: args.loadIncrement || 1, // pixels to load per pass
randomPause: args.randomPause || 0.0, // probability of skipping a pass
progressiveJPEG: args.progressiveJPEG || false // enable progressive JPEG emulation
};
// make 'em load slow
for(var i = 0; i < params.elements.length; i++) {
// get some things we need
var img = params.elements[i],
parent = img.parentNode,
slowload = document.createElement('DIV');
// set up initial state of box
slowload.style.backgroundColor = params.boxColor;
slowload.style.width = img.offsetWidth + 'px';
slowload.style.height = img.offsetHeight + 'px';
slowload.style.position = 'absolute';
slowload.style.top = img.offsetTop + 'px';
slowload.style.left = img.offsetLeft + 'px';
slowload.style.clip = 'rect(0 auto auto auto)';
// remember what the max height should be for later calculation
slowload.slothifyData = {
img: img,
imageTopClip: 0,
maxImageHeight: img.height * params.loadMaxPercent
};
// setup the blurred image for progressive JPEG if needed
if (params.progressiveJPEG === true) {
var progressiveJPEGdiv = document.createElement('DIV');
progressiveJPEGdiv.style.backgroundColor = params.boxColor;
progressiveJPEGdiv.style.width = img.offsetWidth + 'px';
progressiveJPEGdiv.style.height = img.offsetHeight + 'px';
progressiveJPEGdiv.style.position = 'absolute';
progressiveJPEGdiv.style.top = img.offsetTop + 'px';
progressiveJPEGdiv.style.left = img.offsetLeft + 'px';
progressiveJPEGdiv.style.clip = 'rect(0 auto auto auto)';
progressiveJPEGdiv.style.overflow = 'hidden';
var progressiveJPEGimg = document.createElement('IMG');
progressiveJPEGimg.setAttribute('class','progressiveJPEGemulator');
progressiveJPEGimg.setAttribute('src',img.src);
progressiveJPEGimg.setAttribute('style','margin: -2px 0 0 0; -webkit-filter: blur(5px); -moz-filter: blur(5px); -o-filter: blur(5px); -ms-filter: blur(5px); filter: blur(5px);');
progressiveJPEGimg.setAttribute('width', progressiveJPEGdiv.style.width);
progressiveJPEGimg.setAttribute('height', progressiveJPEGdiv.style.height);
progressiveJPEGdiv.appendChild(progressiveJPEGimg);
parent.appendChild(progressiveJPEGdiv);
slowload.slothifyData.blurImg = progressiveJPEGdiv;
slowload.slothifyData.blurImageTopClip = 0;
}
// put box over image
parent.appendChild(slowload);
// show image again
img.style.visibility = 'visible';
if (params.loadMaxPercent > 0.0) {
// allow for some changing of params per image
var modParamPerImg = Object.create(params);
if(modParamPerImg.randLoadIncrement) {
// randomize load increment
modParamPerImg.loadIncrement = Math.floor((Math.random() * 20) + 1);
}
// slowload using timeout since this is nicer to the browser :)
setTimeout(slowloadModiferCallback(slowload, modParamPerImg), params.loadSpeed);
}
}
}
};
return {
letsPrepareTheseImages: prepare,
fixMyImagesLoadingSoFast: slowImages
};
})();