aboutsummaryrefslogtreecommitdiff
path: root/contexts/data/lib/closure-library/closure/goog/positioning/anchoredviewportposition_test.html
blob: 188a27e14334065b8690a5aefe4a2506051d04fa (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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
<!DOCTYPE HTML>
<!--

-->
<html>
<!--
Copyright 2009 The Closure Library Authors. All Rights Reserved.

Use of this source code is governed by the Apache License, Version 2.0.
See the COPYING file for details.
-->
<head>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Closure Unit Tests - goog.positioning.AnchoredViewportPosition</title>
<script src="../base.js"></script>
<script>
goog.require('goog.dom');
goog.require('goog.positioning.AnchoredViewportPosition');
goog.require('goog.positioning.Corner');
goog.require('goog.positioning.OverflowStatus');
goog.require('goog.style');
goog.require('goog.testing.jsunit');
</script>
</head>
<body>
<!-- Use IFRAME to avoid non-deterministic window size problems in Selenium. -->
<iframe id="frame1" style="width:200px; height:200px;"
        src="anchoredviewportposition_test_iframe.html">
</iframe>
<script>
var frame, doc, dom, viewportSize, anchor, popup;
var corner = goog.positioning.Corner;

function setUp() {
  frame = document.getElementById('frame1');
  doc = goog.dom.getFrameContentDocument(frame);
  dom = goog.dom.getDomHelper(doc);
  viewportSize = dom.getViewportSize();
  anchor = dom.getElement('anchor');
  popup = dom.getElement('popup');
  goog.style.setSize(popup, 20, 20);
}

// The frame has enough space at the bottom of the anchor.
function testRepositionBottom() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_LEFT, false);
  goog.style.setSize(anchor, 100, 100);
  goog.style.setPosition(anchor, 0, 0);
  assertTrue(viewportSize.height >= 100 + 20);

  avp.reposition(popup, corner.TOP_LEFT);
  var anchorRect = goog.style.getBounds(anchor);
  assertEquals(anchorRect.top + anchorRect.height,
               goog.style.getPageOffset(popup).y);
}

// No enough space at the bottom, but at the top.
function testRepositionTop() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_LEFT, false);
  var newTop = viewportSize.height - 100;
  goog.style.setSize(anchor, 100, 100);
  goog.style.setPosition(anchor, 50, newTop);
  assertTrue(newTop >= 20);

  avp.reposition(popup, corner.TOP_LEFT);
  anchorRect = goog.style.getBounds(anchor);
  var popupRect = goog.style.getBounds(popup);
  assertEquals(anchorRect.top, popupRect.top + popupRect.height);
}

// Not enough space either at the bottom or right but there is enough space at
// top left.
function testRepositionBottomRight() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_RIGHT, false);
  goog.style.setSize(anchor, 100, 100);
  goog.style.setPosition(anchor, viewportSize.width - 110,
      viewportSize.height - 110);

  avp.reposition(popup, corner.TOP_LEFT);
  anchorRect = goog.style.getBounds(anchor);
  var popupRect = goog.style.getBounds(popup);
  assertEquals(anchorRect.top, popupRect.top + popupRect.height);
  assertEquals(anchorRect.left, popupRect.left + popupRect.width);
}

// Enough space at neither the bottom nor the top.  Adjustment flag is false.
function testRepositionNoSpaceWithoutAdjustment() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_LEFT, false);
  goog.style.setPosition(anchor, 50, 10);
  goog.style.setSize(anchor, 100, viewportSize.height - 20);

  avp.reposition(popup, corner.TOP_LEFT);
  anchorRect = goog.style.getBounds(anchor);
  popupRect = goog.style.getBounds(popup);
  assertEquals(anchorRect.top + anchorRect.height, popupRect.top);
  assertTrue(popupRect.top + popupRect.height > viewportSize.height);
}

// Enough space at neither the bottom nor the top.  Adjustment flag is true.
function testRepositionNoSpaceWithAdjustment() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_LEFT, true);
  goog.style.setPosition(anchor, 50, 10);
  goog.style.setSize(anchor, 100, viewportSize.height - 20);

  avp.reposition(popup, corner.TOP_LEFT);
  anchorRect = goog.style.getBounds(anchor);
  popupRect = goog.style.getBounds(popup);
  assertTrue(anchorRect.top + anchorRect.height > popupRect.top);
  assertEquals(viewportSize.height, popupRect.top + popupRect.height);
}

function testAdjustCorner() {
  var avp = new goog.positioning.AnchoredViewportPosition(
      anchor, corner.BOTTOM_LEFT);
  assertEquals(corner.BOTTOM_LEFT, avp.adjustCorner(0, corner.BOTTOM_LEFT));
  assertEquals(corner.BOTTOM_RIGHT, avp.adjustCorner(
      goog.positioning.OverflowStatus.FAILED_HORIZONTAL, corner.BOTTOM_LEFT));
  assertEquals(corner.TOP_LEFT, avp.adjustCorner(
      goog.positioning.OverflowStatus.FAILED_VERTICAL, corner.BOTTOM_LEFT));
  assertEquals(corner.TOP_RIGHT, avp.adjustCorner(
      goog.positioning.OverflowStatus.FAILED_VERTICAL |
      goog.positioning.OverflowStatus.FAILED_HORIZONTAL,
      corner.BOTTOM_LEFT));
}
</script>
</body>
</html>