Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
<?xml version="1.0"?>
type="text/css"?>
title="Tabbox focus testing">
<script type="application/javascript"
src="../common.js" />
<script type="application/javascript"
src="../role.js" />
<script type="application/javascript"
src="../states.js" />
<script type="application/javascript"
src="../promisified-events.js" />
<script type="application/javascript">
//gA11yEventDumpID = "eventdump"; // debug stuff
//gA11yEventDumpToConsole = true; // debug stuff
async function doTests() {
if (MAC) {
todo(false, "Tests disabled because of imminent failure.");
SimpleTest.finish();
return;
}
// Test focus events.
const input = getNode("input");
let focused = waitForEvent(EVENT_FOCUS, "tab1");
synthesizeMouseAtCenter(getNode("tab1"), {});
await focused;
focused = waitForEvent(EVENT_FOCUS, "checkbox1");
synthesizeKey("VK_TAB", {});
await focused;
focused = waitForEvent(EVENT_FOCUS, input);
synthesizeKey("VK_TAB", { ctrlKey: true });
await focused;
focused = waitForEvent(EVENT_FOCUS, "tab3");
synthesizeKey("VK_TAB", { ctrlKey: true });
await focused;
focused = waitForEvent(EVENT_FOCUS, "tab1");
synthesizeKey("VK_TAB", { ctrlKey: true });
await focused;
SimpleTest.finish();
}
SimpleTest.waitForExplicitFinish();
addA11yLoadEvent(doTests);
</script>
<hbox flex="1" style="overflow: auto;">
<a target="_blank"
title="Control+Tab to an empty tab panel in a tabbox causes focus to leave the tabbox">
</a>
<p id="display"></p>
<div id="content" style="display: none"></div>
<pre id="test">
</pre>
</body>
<vbox flex="1">
<tabbox>
<tabs>
<tab id="tab1" label="Tab1" selected="true"/>
<tab id="tab2" label="Tab2" />
<tab id="tab3" label="Tab3" />
</tabs>
<tabpanels>
<tabpanel orient="vertical">
<groupbox orient="vertical">
<checkbox id="checkbox1" label="Monday" width="75"/>
<checkbox label="Tuesday" width="75"/>
<checkbox label="Wednesday" width="75"/>
<checkbox label="Thursday" width="75"/>
<checkbox label="Friday" width="75"/>
<checkbox label="Saturday" width="75"/>
<checkbox label="Sunday" width="75"/>
</groupbox>
<spacer style="height: 10px" />
<label value="Label After checkboxes" />
</tabpanel>
<tabpanel orient="vertical">
<html:input id="input" />
</tabpanel>
<tabpanel orient="vertical">
<description>Tab 3 content</description>
</tabpanel>
</tabpanels>
</tabbox>
<vbox id="eventdump"/>
</vbox>
</hbox>
</window>