about summary refs log tree commit diff stats
path: root/autoscroll.js
diff options
context:
space:
mode:
authorStevan Andjelkovic <stevan.andjelkovic@strath.ac.uk>2012-01-03 23:02:20 +0100
committerStevan Andjelkovic <stevan.andjelkovic@strath.ac.uk>2012-01-03 23:02:20 +0100
commitcfd919ea2eb2fcfca2f2759cde43b1aeec539d84 (patch)
tree8e8ff7b721c362c7bd5408bdf0cb9c381bea4e47 /autoscroll.js
parent70d1199aecf94acc6658f95884db5d64bcb3a443 (diff)
downloadxombrero-cfd919ea2eb2fcfca2f2759cde43b1aeec539d84.tar.gz
Favicons for compact tab + autoscroll
FS#214 and #144.

Thanks to Stefan Bolte (dwb browser) for relicensing his
javascript code for autoscroll!

ok marco@
Diffstat (limited to 'autoscroll.js')
-rw-r--r--autoscroll.js129
1 files changed, 129 insertions, 0 deletions
diff --git a/autoscroll.js b/autoscroll.js
new file mode 100644
index 0000000..126b2e8
--- /dev/null
+++ b/autoscroll.js
@@ -0,0 +1,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 (ev.button == 0) {
+      if (_span) {
+        clear();
+      }
+    } else if (ev.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);
+})();