diff options
| author | Stephen Blott | 2017-09-15 07:06:50 +0100 | 
|---|---|---|
| committer | GitHub | 2017-09-15 07:06:50 +0100 | 
| commit | 29bb5cca58e549432b57634da582601f87c9c687 (patch) | |
| tree | c6fb4ad4789ba0020e10f742cfc1b4e7366b6165 | |
| parent | e60f329eb6180cbe3261adf582ee4df3cdc0b0fe (diff) | |
| parent | 09abac4c4c6be7a567478f726dab5f2456ee433d (diff) | |
| download | vimium-29bb5cca58e549432b57634da582601f87c9c687.tar.bz2 | |
Merge pull request #2649 from mrmr1993/linkhints-scaled-display-fix
Always use getBoundingClientRect for getViewportTopLeft
| -rw-r--r-- | lib/dom_utils.coffee | 17 | 
1 files changed, 13 insertions, 4 deletions
| diff --git a/lib/dom_utils.coffee b/lib/dom_utils.coffee index d0bd4615..b3fc981b 100644 --- a/lib/dom_utils.coffee +++ b/lib/dom_utils.coffee @@ -291,12 +291,21 @@ DomUtils =    getViewportTopLeft: ->      box = document.documentElement      style = getComputedStyle box +    rect = box.getBoundingClientRect()      if style.position == "static" and not /content|paint|strict/.test(style.contain or "") -      zoom = +style.zoom || 1 -      top: Math.ceil(window.scrollY / zoom), left: Math.ceil(window.scrollX / zoom) +      # The margin is included in the client rect, so we need to subtract it back out. +      marginTop = parseInt style.marginTop +      marginLeft = parseInt style.marginLeft +      top: -rect.top + marginTop, left: -rect.left + marginLeft      else -      rect = box.getBoundingClientRect() -      top: -rect.top - box.clientTop, left: -rect.left - box.clientLeft +      if Utils.isFirefox() +        # These are always 0 for documentElement on Firefox, so we derive them from CSS border. +        clientTop = parseInt style.borderTopWidth +        clientLeft = parseInt style.borderLeftWidth +      else +        {clientTop, clientLeft} = box +      top: -rect.top - clientTop, left: -rect.left - clientLeft +    suppressPropagation: (event) ->      event.stopImmediatePropagation() | 
