-
Notifications
You must be signed in to change notification settings - Fork 3.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement dialog.requestClose() [4/N]
This implements dialog.requestClose() and adds a test. See spec PR for details: whatwg/html#10737 Bug: 376516550 Change-Id: Iaac3d89c28844d2b54ff5b1a7b68dc356d1fd172
- Loading branch information
1 parent
af91552
commit e4718b3
Showing
1 changed file
with
71 additions
and
0 deletions.
There are no files selected for viewing
71 changes: 71 additions & 0 deletions
71
html/semantics/interactive-elements/the-dialog-element/dialog-requestclose.tentative.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
<!doctype html> | ||
<meta charset="utf-8"> | ||
<link rel=help href="https://html.spec.whatwg.org/multipage/interactive-elements.html#dom-dialog-request-close"> | ||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
<script src="/resources/testdriver.js"></script> | ||
<script src="/resources/testdriver-actions.js"></script> | ||
<script src="/resources/testdriver-vendor.js"></script> | ||
<script src="../../popovers/resources/popover-utils.js"></script> | ||
|
||
<dialog>Dialog</dialog> | ||
|
||
<script> | ||
const dialog = document.querySelector('dialog'); | ||
function openDialog(modal) { | ||
assert_false(dialog.open); | ||
if (modal) { | ||
dialog.showModal(); | ||
} else { | ||
dialog.show(); | ||
} | ||
assert_true(dialog.open); | ||
assert_equals(dialog.matches(':modal'),modal); | ||
} | ||
function getSignal(t) { | ||
const controller = new AbortController(); | ||
const signal = controller.signal; | ||
t.add_cleanup(() => controller.abort()); | ||
return signal; | ||
} | ||
|
||
// Run this test first, since the user activation from other tests will persist. | ||
promise_test(async (t) => { | ||
t.add_cleanup(() => dialog.close()); | ||
const signal = getSignal(t); | ||
dialog.addEventListener('cancel',(e) => { | ||
e.preventDefault(); | ||
},{signal}); | ||
openDialog(/*modal*/true); | ||
dialog.requestClose(); | ||
assert_false(dialog.open,'Without user activation, requestClose can\'t be cancelled'); | ||
},`requestClose requires user activation in order to be cancelable`); | ||
|
||
[false,true].forEach(modal => { | ||
promise_test(async (t) => { | ||
t.add_cleanup(() => dialog.close()); | ||
openDialog(modal); | ||
dialog.requestClose(); | ||
assert_false(dialog.open); | ||
},`${modal ? "Modal:" : "Non-modal:"} requestClose closes the dialog`); | ||
|
||
promise_test(async (t) => { | ||
t.add_cleanup(() => dialog.close()); | ||
const signal = getSignal(t); | ||
let shouldPreventDefault = true; | ||
dialog.addEventListener('cancel',(e) => { | ||
if (shouldPreventDefault) { | ||
e.preventDefault(); | ||
} | ||
},{signal}); | ||
openDialog(modal); | ||
await clickOn(dialog); // User activation | ||
dialog.requestClose(); | ||
assert_true(dialog.open,'cancel event was cancelled - dialog shouldn\'t close'); | ||
shouldPreventDefault = false; | ||
await clickOn(dialog); // User activation | ||
dialog.requestClose(); | ||
assert_false(dialog.open,'cancel event was not cancelled - dialog should now close'); | ||
},`${modal ? "Modal:" : "Non-modal:"} requestClose can be cancelled`); | ||
}); | ||
</script> |