mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
1f8228e780
--HG-- extra : rebase_source : 9076dbf84083b547498e997fa3ceaa9d7fa04b7e
84 lines
2.7 KiB
JavaScript
84 lines
2.7 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
let tabViewShownCount = 0;
|
|
let timerId;
|
|
|
|
// ----------
|
|
function test() {
|
|
waitForExplicitFinish();
|
|
|
|
// verify initial state
|
|
ok(!TabView.isVisible(), "Tab View starts hidden");
|
|
|
|
// launch tab view for the first time
|
|
window.addEventListener("tabviewshown", onTabViewLoadedAndShown, false);
|
|
TabView.toggle();
|
|
|
|
registerCleanupFunction(function () {
|
|
window.removeEventListener("tabviewshown", onTabViewLoadedAndShown, false);
|
|
if (timerId)
|
|
clearTimeout(timerId);
|
|
TabView.hide()
|
|
});
|
|
}
|
|
|
|
// ----------
|
|
function onTabViewLoadedAndShown() {
|
|
window.removeEventListener("tabviewshown", onTabViewLoadedAndShown, false);
|
|
|
|
// Evidently sometimes isVisible (which is based on the selectedIndex of the
|
|
// tabview deck) isn't updated immediately when called from button.doCommand,
|
|
// so we add a little timeout here to get outside of the doCommand call.
|
|
// If the initial timeout isn't enough, we keep waiting in case it's taking
|
|
// longer than expected.
|
|
// See bug 594909.
|
|
let deck = document.getElementById("tab-view-deck");
|
|
let iframe = document.getElementById("tab-view");
|
|
ok(iframe, "The tab view iframe exists");
|
|
|
|
function waitForSwitch() {
|
|
if (deck.selectedPanel == iframe) {
|
|
ok(TabView.isVisible(), "Tab View is visible. Count: " + tabViewShownCount);
|
|
tabViewShownCount++;
|
|
|
|
// kick off the series
|
|
window.addEventListener("tabviewshown", onTabViewShown, false);
|
|
window.addEventListener("tabviewhidden", onTabViewHidden, false);
|
|
|
|
registerCleanupFunction(function () {
|
|
window.removeEventListener("tabviewshown", onTabViewShown, false);
|
|
window.removeEventListener("tabviewhidden", onTabViewHidden, false);
|
|
});
|
|
TabView.toggle();
|
|
} else {
|
|
timerId = setTimeout(waitForSwitch, 10);
|
|
}
|
|
}
|
|
|
|
timerId = setTimeout(waitForSwitch, 1);
|
|
}
|
|
|
|
// ----------
|
|
function onTabViewShown() {
|
|
// add the count to the message so we can track things more easily.
|
|
ok(TabView.isVisible(), "Tab View is visible. Count: " + tabViewShownCount);
|
|
tabViewShownCount++;
|
|
TabView.toggle();
|
|
}
|
|
|
|
// ----------
|
|
function onTabViewHidden() {
|
|
ok(!TabView.isVisible(), "Tab View is hidden. Count: " + tabViewShownCount);
|
|
|
|
if (tabViewShownCount == 1) {
|
|
document.getElementById("menu_tabview").doCommand();
|
|
} else if (tabViewShownCount == 2) {
|
|
EventUtils.synthesizeKey("E", { accelKey: true, shiftKey: true });
|
|
} else if (tabViewShownCount == 3) {
|
|
window.removeEventListener("tabviewshown", onTabViewShown, false);
|
|
window.removeEventListener("tabviewhidden", onTabViewHidden, false);
|
|
finish();
|
|
}
|
|
}
|