Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
<?xml version="1.0"?>
type="text/css"?>
title="XUL tree focus testing">
<script type="application/javascript"
src="../treeview.js" />
<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">
<![CDATA[
////////////////////////////////////////////////////////////////////////////
// Helpers
function getTreeItemAt(aTreeID, aIdx)
{ return getAccessible(aTreeID).getChildAt(aIdx + 1); }
function getFirstTreeItem(aTreeID)
{ return getTreeItemAt(aTreeID, 0); }
function getSecondTreeItem(aTreeID)
{ return getTreeItemAt(aTreeID, 1); }
////////////////////////////////////////////////////////////////////////////
// Test
//gA11yEventDumpID = "debug"; // debugging
//gA11yEventDumpToConsole = true; // debugging
async function doTest()
{
let firstItem = getFirstTreeItem("tree");
let focused = waitForEvent(EVENT_FOCUS, firstItem);
getNode("tree").focus();
await focused;
let secondItem = getSecondTreeItem("tree");
focused = waitForEvent(EVENT_FOCUS, secondItem);
synthesizeKey("VK_DOWN", {});
await focused;
focused = waitForEvent(EVENT_FOCUS, "emptytree");
getNode("emptytree").focus();
await focused;
// no focus event for changed current item for unfocused tree
getNode("tree").currentIndex = 0;
SimpleTest.finish();
}
SimpleTest.waitForExplicitFinish();
addA11yXULTreeLoadEvent(doTest, "tree", new nsTableTreeView(5));
]]>
</script>
<hbox flex="1" style="overflow: auto;">
<a target="_blank"
title="Need better solution for firing delayed event against xul tree">
</a>
<a target="_blank"
title="Don't fire accessible focus events if widget is not actually in focus, confuses screen readers">
</a>
<p id="display"></p>
<div id="content" style="display: none">
</div>
<pre id="test">
</pre>
</body>
<vbox id="debug"/>
<tree id="tree" flex="1">
<treecols>
<treecol id="col1" flex="1" primary="true" label="column"/>
<treecol id="col2" flex="1" label="column 2"/>
</treecols>
<treechildren id="treechildren"/>
</tree>
<tree id="emptytree" flex="1">
<treecols>
<treecol id="emptytree_col1" flex="1" primary="true" label="column"/>
<treecol id="emptytree_col2" flex="1" label="column 2"/>
</treecols>
<treechildren id="emptytree_treechildren"/>
</tree>
</hbox>
</window>