blob: 167b350c42925ecb23402657a1dda7ccee7422e5 [file] [log] [blame]
<!DOCTYPE html>
<meta charset="utf-8">
<link rel="author" title="Mason Freed" href="mailto:masonfreed@chromium.org">
<link rel=help href="https://github.com/MicrosoftEdge/MSEdgeExplainers/blob/main/Popup/explainer.md">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<popup id=p1 anchor=b1><p>This is popup #1</p>
<button id=b2 onclick='p2.show()'>Popup 2</button>
<button id=b4 onclick='p4.show()'>Popup 4</button>
</popup>
<popup id=p2 anchor=b2><p>This is popup #2</p>
<button id=b3 onclick='p3.show()'>Popup 3</button>
</popup>
<popup id=p3 anchor=b3><p>This is popup #3</p></popup>
<popup id=p4 anchor=b4><p>This is popup #4</p></popup>
<button id=b1 onclick='p1.show()'>Popup 1</button>
<dialog id=d1>This is a dialog<button onclick='this.parentElement.close()'>Close</button></dialog>
<button id=b5 onclick='d1.show()'>Dialog</button>
<script>
const popups = [p1, p2, p3, p4];
function assertState(...states) {
assert_equals(popups.length,states.length);
for(let i=0;i<popups.length;++i) {
assert_equals(popups[i].open,states[i],`Popup #${i+1} incorrect state`);
}
}
test(function() {
assertState(false,false,false,false);
p1.show();
assertState(true,false,false,false);
p2.show();
assertState(true,true,false,false);
p3.show();
assertState(true,true,true,false);
// P4 is a sibling of P2, so showing it should
// close P2 and P3.
p4.show();
assertState(true,false,false,true);
// P2 should close P4 now.
p2.show();
assertState(true,true,false,false);
// Hiding P1 should hide all.
p1.hide();
assertState(false,false,false,false);
}, "popup stacking behavior")
test(function() {
function openManyPopups() {
p1.show();
p2.show();
p3.show();
assertState(true,true,true,false);
}
openManyPopups();
d1.show(); // Dialog.show() should hide all popups.
assertState(false,false,false,false);
d1.close();
openManyPopups();
d1.showModal(); // Dialog.showModal() should also hide all popups.
assertState(false,false,false,false);
d1.close();
}, "popups should be closed by dialogs")
test(function() {
d1.show();
assert_true(d1.open);
p1.show();
assertState(true,false,false,false);
assert_true(d1.open);
p1.hide();
assert_true(d1.open);
d1.close();
}, "dialogs should not be closed by popups")
</script>
<style>
#p1 { top:350px; }
#p2 { top:350px; left:200px; }
#p3 { top:500px; }
#p4 { top:500px;left:200px; }
</style>