forked from silvestreh/onScreen
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery.onscreen.js
116 lines (96 loc) · 4.41 KB
/
jquery.onscreen.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
/*
* onScreen.js
* by Silvestre Herrera
*
* Checks if matched elements are inside the viewport.
*/
(function($) {
$.fn.onScreen = function(options) {
var params = $.extend({
direction: 'vertical',
toggleClass: true,
doIn: null,
doOut: null,
tolerance: 0,
lazyAttr: null,
lazyPlaceholder: ''
}, options);
return this.each(function() {
var isOnScreen = false; // Initialize boolean
var scrollTop; // Initialize Scroll Position (probably not needed)
var $el = $(this); // Matched element
function verticalIn() {
return elTop < winBottom - params.tolerance && scrollTop < (elTop + elHeight) - params.tolerance && !isOnScreen;
}
function verticalOut() {
return elTop + elHeight < scrollTop && isOnScreen || elTop > winBottom && isOnScreen;
}
function horizontalIn() {
return elLeft < winRight - params.tolerance && scrollLeft < (elLeft + elWidth) - params.tolerance && !isOnScreen;
}
function horizontalOut() {
return elLeft + elWidth < scrollLeft && isOnScreen || elLeft > winRight && isOnScreen;
}
function directionIn() {
if (params.direction == 'vertical') {
return verticalIn();
} else if (params.direction == 'horizontal') {
return horizontalIn();
}
}
function directionOut() {
if (params.direction == 'vertical') {
return verticalOut();
} else if (params.direction == 'horizontal') {
return horizontalOut();
}
}
function checkPos() {
// Viewport dimensions
$win = $(window);
winHeight = $win.height();
winWidth = $win.width();
winBottom = $win.scrollTop() + winHeight;
winRight = $win.scrollLeft() + winWidth;
// Element dimensions & position
elHeight = $el.height();
elWidth = $el.height();
elTop = $el.offset().top;
elLeft = $el.offset().left;
// Update scroll position
scrollTop = $win.scrollTop();
scrollLeft = $win.scrollLeft();
if (directionIn()) {
if (params.toggleClass) {
$el.addClass('onScreen');
}
if (typeof(params.doIn) == 'function') {
params.doIn.call($el[0]);
}
if (params.lazyAttr && $el.prop('tagName') === 'IMG') {
lazyImg = $el.attr(params.lazyAttr);
$el.css({
'background': 'url(' + params.lazyPlaceholder + ') center center no-repeat',
'min-height': '5px',
'min-width': '16px'
});
$el.prop('src',lazyImg);
}
isOnScreen = true;
}
else if (directionOut()) {
if (params.toggleClass) {
$el.removeClass('onScreen');
}
if (typeof(params.doOut) == 'function') {
params.doOut.call($el[0]);
}
isOnScreen = false;
}
}
checkPos();
$(window).on('scroll',checkPos).on('resize',checkPos).on('load',checkPos);
});
return this;
};
})(jQuery);