aboutsummaryrefslogtreecommitdiffstats
path: root/content_scripts/scroller.coffee
diff options
context:
space:
mode:
authorStephen Blott2015-04-28 03:52:39 +0100
committerStephen Blott2015-04-28 03:52:39 +0100
commitd6b195ea85b06dcab8d66d047f8c494c3304e88e (patch)
treebae0ce9b8339a4518e68e8be86f010aeb380de23 /content_scripts/scroller.coffee
parentceab5272bb7300a50a6643a69bf90abc6dc3ddfe (diff)
parent24ece1dc315e66a0e0bf24e27c4c89fa847ead08 (diff)
downloadvimium-d6b195ea85b06dcab8d66d047f8c494c3304e88e.tar.bz2
Merge pull request #1601 from mrmr1993/fix-scrollIntoView
Fix bounds and amounts in Scroller.scrollIntoView
Diffstat (limited to 'content_scripts/scroller.coffee')
-rw-r--r--content_scripts/scroller.coffee16
1 files changed, 8 insertions, 8 deletions
diff --git a/content_scripts/scroller.coffee b/content_scripts/scroller.coffee
index ff95651c..27fc9cdc 100644
--- a/content_scripts/scroller.coffee
+++ b/content_scripts/scroller.coffee
@@ -257,22 +257,22 @@ Scroller =
rect = element. getClientRects()?[0]
if rect?
# Scroll y axis.
- if rect.top < 0
- amount = rect.top - 10
+ if rect.bottom < 0
+ amount = rect.bottom - Math.min(rect.height, window.innerHeight)
element = findScrollableElement element, "y", amount, 1
CoreScroller.scroll element, "y", amount, false
- else if window.innerHeight < rect.bottom
- amount = rect.bottom - window.innerHeight + 10
+ else if window.innerHeight < rect.top
+ amount = rect.top + Math.min(rect.height - window.innerHeight, 0)
element = findScrollableElement element, "y", amount, 1
CoreScroller.scroll element, "y", amount, false
# Scroll x axis.
- if rect.left < 0
- amount = rect.left - 10
+ if rect.right < 0
+ amount = rect.right - Math.min(rect.width, window.innerWidth)
element = findScrollableElement element, "x", amount, 1
CoreScroller.scroll element, "x", amount, false
- else if window.innerWidth < rect.right
- amount = rect.right - window.innerWidth + 10
+ else if window.innerWidth < rect.left
+ amount = rect.left + Math.min(rect.width - window.innerWidth, 0)
element = findScrollableElement element, "x", amount, 1
CoreScroller.scroll element, "x", amount, false