(elem: Element)
| 132 | } |
| 133 | |
| 134 | function getClientRect(elem: Element): Rect { |
| 135 | var cachedRect = clientRectCache.get(elem); |
| 136 | if (cachedRect) { |
| 137 | return cachedRect; |
| 138 | } |
| 139 | |
| 140 | var rect: Rect; |
| 141 | var imageMap = maybeFindImageMap(elem); |
| 142 | if (imageMap) { |
| 143 | rect = imageMap.rect; |
| 144 | } else { |
| 145 | var elemTagName = typeof (elem as Element).tagName === 'string' ? (elem as Element).tagName : ''; |
| 146 | if (elemTagName.toUpperCase() === 'HTML') { |
| 147 | var doc = (elem as Element).ownerDocument; |
| 148 | // In quirks mode (no DOCTYPE), viewport dimensions come from document.body; |
| 149 | // documentElement.clientWidth/Height is unreliable and can be 0. |
| 150 | var sizeElem = doc.compatMode === 'CSS1Compat' ? doc.documentElement : (doc.body || doc.documentElement); |
| 151 | rect = createRect(0, 0, sizeElem.clientWidth, sizeElem.clientHeight); |
| 152 | } else { |
| 153 | try { |
| 154 | var nativeRect = (elem as Element).getBoundingClientRect(); |
| 155 | rect = { |
| 156 | left: nativeRect.left, |
| 157 | top: nativeRect.top, |
| 158 | right: nativeRect.right, |
| 159 | bottom: nativeRect.bottom, |
| 160 | width: nativeRect.right - nativeRect.left, |
| 161 | height: nativeRect.bottom - nativeRect.top, |
| 162 | }; |
| 163 | } catch (_error) { |
| 164 | rect = createRect(0, 0, 0, 0); |
| 165 | } |
| 166 | } |
| 167 | } |
| 168 | |
| 169 | clientRectCache.set(elem, rect); |
| 170 | return rect; |
| 171 | } |
| 172 | |
| 173 | function getAreaRelativeRect(area: HTMLAreaElement): Rect { |
| 174 | var shape = area.shape.toLowerCase(); |
no test coverage detected