summaryrefslogtreecommitdiff
path: root/spec/frontend/helpers/dom_shims/get_client_rects.js
blob: d740c1bf154fef038660ec2eb2e7c0fc6bbb785d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
function hasHiddenStyle(node) {
  if (!node.style) {
    return false;
  } else if (node.style.display === 'none' || node.style.visibility === 'hidden') {
    return true;
  }

  return false;
}

function createDefaultClientRect() {
  return {
    bottom: 0,
    height: 0,
    left: 0,
    right: 0,
    top: 0,
    width: 0,
    x: 0,
    y: 0,
  };
}

/**
 * This is needed to get the `toBeVisible` matcher to work in `jsdom`
 *
 * Reference:
 * - https://github.com/jsdom/jsdom/issues/1322
 * - https://github.com/unindented/custom-jquery-matchers/blob/v2.1.0/packages/custom-jquery-matchers/src/matchers.js#L157
 */
window.Element.prototype.getClientRects = function getClientRects() {
  let node = this;

  while (node) {
    if (node === document) {
      break;
    }

    if (hasHiddenStyle(node)) {
      return [];
    }
    node = node.parentNode;
  }

  if (!node) {
    return [];
  }

  return [createDefaultClientRect()];
};