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 | |
| 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
| -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 |
