diff options
| author | Stephen Blott | 2015-04-28 03:52:39 +0100 | 
|---|---|---|
| committer | Stephen Blott | 2015-04-28 03:52:39 +0100 | 
| commit | d6b195ea85b06dcab8d66d047f8c494c3304e88e (patch) | |
| tree | bae0ce9b8339a4518e68e8be86f010aeb380de23 /content_scripts/scroller.coffee | |
| parent | ceab5272bb7300a50a6643a69bf90abc6dc3ddfe (diff) | |
| parent | 24ece1dc315e66a0e0bf24e27c4c89fa847ead08 (diff) | |
| download | vimium-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.coffee | 16 | 
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 | 
