-
Notifications
You must be signed in to change notification settings - Fork 37
/
autoscroll.js
129 lines (128 loc) · 6.04 KB
/
autoscroll.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
/* MIT/X Consortium License
*
* Copyright (c) 2011-2012 Stefan Bolte <portix@gmx.net>
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*/
MouseAutoScroll = (function() {
const SCROLL_ICON="transparent url() no-repeat scroll center";
const SIZE = 32;
const OFFSET = 5;
var doc;
Math.sign = function(x) { return x >=0 ? 1 : -1; };
var span = null;
var x = 0;
var y = 0;
var ev = null;
var timerId = 0;
var cursorStyle = null;
function startTimer() {
timerId = window.setInterval(timer, 40);
}
function stopTimer () {
window.clearInterval(timerId);
timerId = 0;
}
function timer () {
if (ev) {
var scrollY = (ev.y - y);
var scrollX = (ev.x - x);
var b = scrollY > 0
&& doc.documentElement.scrollHeight == (window.innerHeight + window.pageYOffset);
var r = scrollX > 0
&& doc.documentElement.scrollWidth == (window.innerWidth + window.pageXOffset);
var l = scrollX < 0 && window.pageXOffset == 0;
var t = scrollY < 0 && window.pageYOffset == 0;
var offX = Math.abs(scrollX) < OFFSET;
var offY = Math.abs(scrollY) < OFFSET;
if ( timerId != 0
&& (( b && r ) || ( b && l) || ( b && offX )
|| ( t && r ) || ( t && l) || ( t && offX )
|| (offY && r) || (offY && l) )) {
stopTimer();
return;
}
window.scrollBy(scrollX - Math.sign(scrollX) * OFFSET,
scrollY - Math.sign(scrollY) * OFFSET);
}
}
function mouseMove (e) {
if (timerId == 0) {
startTimer();
}
ev = e;
}
function init (e) {
doc = e.target.ownerDocument;
if (window.innerHeight >= doc.documentElement.scrollHeight
&& window.innerWidth >= doc.documentElement.scrollWidth) {
return;
}
span = doc.createElement("div");
span.style.width = SIZE + "px";
span.style.height = SIZE + "px";
span.style.background = SCROLL_ICON;
span.style.left = e.x - (SIZE / 2) + "px";
span.style.top = e.y - (SIZE / 2) + "px";
span.style.position = "fixed";
span.style.fontSize = SIZE + "px";
span.style.opacity = 0.6;
cursorStyle = doc.defaultView.getComputedStyle(doc.body, null).cursor;
doc.body.style.cursor = "move";
doc.body.appendChild(span);
doc.addEventListener('mousemove', mouseMove, false);
span = span;
}
function clear (e) {
doc.body.style.cursor = cursorStyle;
span.parentNode.removeChild(span);
doc.removeEventListener('mousemove', mouseMove, false);
stopTimer();
if (span)
span = null;
if (ev)
ev = null;
}
function mouseUp (e) { /* Simulate click, click event does not work during scrolling */
if (Math.abs(e.x - x) < 5 && Math.abs(e.y - y) < 5) {
init(e);
window.removeEventListener('mouseup', mouseUp, false);
}
}
function mouseDown (e) {
var t = e.target;
if (e.button == 0) {
if (span) {
clear();
}
} else if (e.button == 1) {
if (span) {
clear();
}
else if (!t.hasAttribute("href")
&& !t.hasAttribute("onmousedown")
&& !(t.hasAttribute("onclick"))) {
x = e.x;
y = e.y;
window.addEventListener('mouseup', mouseUp, false);
}
}
}
window.addEventListener('mousedown', mouseDown, false);
})();