mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
125 lines
4.5 KiB
XML
125 lines
4.5 KiB
XML
<?xml version="1.0"?>
|
|
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
|
<!--
|
|
XUL Widget Test for the titlebar element and window dragging
|
|
-->
|
|
<window title="Titlebar" width="200" height="200"
|
|
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
|
|
|
|
<script type="application/javascript"
|
|
src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"/>
|
|
|
|
<titlebar id="titlebar">
|
|
<label id="label" value="Titlebar"/>
|
|
</titlebar>
|
|
|
|
<panel id="panel" onpopupshown="popupshown()" onpopuphidden="popuphidden()">
|
|
<titlebar>
|
|
<label id="panellabel" value="Titlebar"/>
|
|
</titlebar>
|
|
</panel>
|
|
|
|
<button id="button" label="OK"/>
|
|
<statusbar id="statusbar">
|
|
<statusbarpanel>
|
|
<label id="statuslabel" value="Status"/>
|
|
<label id="statuslabelnodrag" value="No Drag" onmousedown="event.preventDefault()"/>
|
|
</statusbarpanel>
|
|
</statusbar>
|
|
|
|
<script>
|
|
<![CDATA[
|
|
|
|
var SimpleTest = window.opener.wrappedJSObject.SimpleTest;
|
|
|
|
SimpleTest.waitForFocus(test_titlebar, window);
|
|
|
|
function test_titlebar()
|
|
{
|
|
var titlebar = document.getElementById("titlebar");
|
|
var label = document.getElementById("label");
|
|
|
|
var oldx, oldy;
|
|
|
|
// on Mac, the window can also be moved with the statusbar
|
|
if (navigator.platform.indexOf("Mac") >= 0) {
|
|
var statuslabel = document.getElementById("statuslabel");
|
|
var statuslabelnodrag = document.getElementById("statuslabelnodrag");
|
|
|
|
oldx = window.screenX;
|
|
oldy = window.screenY;
|
|
|
|
synthesizeMouse(statuslabel, 2, 2, { type: "mousedown" });
|
|
synthesizeMouse(statuslabel, 22, 22, { type: "mousemove" });
|
|
SimpleTest.is(window.screenX, oldx + 20, "move window with statusbar horizontal");
|
|
SimpleTest.is(window.screenY, oldy + 20, "move window with statusbar vertical");
|
|
synthesizeMouse(statuslabel, 22, 22, { type: "mouseup" });
|
|
|
|
// event was cancelled so the drag should not have occurred
|
|
synthesizeMouse(statuslabelnodrag, 2, 2, { type: "mousedown" });
|
|
synthesizeMouse(statuslabelnodrag, 22, 22, { type: "mousemove" });
|
|
SimpleTest.is(window.screenX, oldx + 20, "move window with statusbar cancelled mousedown horizontal");
|
|
SimpleTest.is(window.screenY, oldy + 20, "move window with statusbar cancelled mousedown vertical");
|
|
synthesizeMouse(statuslabelnodrag, 22, 22, { type: "mouseup" });
|
|
}
|
|
|
|
oldx = window.screenX;
|
|
oldy = window.screenY;
|
|
|
|
var target;
|
|
var mousedownListener = function (event) target = event.originalTarget;
|
|
window.addEventListener("mousedown", mousedownListener, false);
|
|
synthesizeMouse(label, 2, 2, { type: "mousedown" });
|
|
SimpleTest.is(target, titlebar, "movedown on titlebar");
|
|
synthesizeMouse(label, 22, 22, { type: "mousemove" });
|
|
SimpleTest.is(window.screenX, oldx + 20, "move window horizontal");
|
|
SimpleTest.is(window.screenY, oldy + 20, "move window vertical");
|
|
synthesizeMouse(label, 22, 22, { type: "mouseup" });
|
|
|
|
// with allowEvents set to true, the mouse should target the label instead
|
|
// and not move the window
|
|
titlebar.allowEvents = true;
|
|
|
|
synthesizeMouse(label, 2, 2, { type: "mousedown" });
|
|
SimpleTest.is(target, label, "movedown on titlebar with allowevents");
|
|
synthesizeMouse(label, 22, 22, { type: "mousemove" });
|
|
SimpleTest.is(window.screenX, oldx + 20, "mouse on label move window horizontal");
|
|
SimpleTest.is(window.screenY, oldy + 20, "mouse on label move window vertical");
|
|
synthesizeMouse(label, 22, 22, { type: "mouseup" });
|
|
|
|
window.removeEventListener("mousedown", mousedownListener, false);
|
|
|
|
document.getElementById("panel").openPopupAtScreen(window.screenX + 50, window.screenY + 60, false);
|
|
}
|
|
|
|
function popupshown()
|
|
{
|
|
var panellabel = document.getElementById("panellabel");
|
|
var panel = document.getElementById("panel");
|
|
var oldrect = panel.getBoundingClientRect();
|
|
|
|
synthesizeMouse(panellabel, 2, 2, { type: "mousedown" });
|
|
synthesizeMouse(panellabel, 22, 22, { type: "mousemove" });
|
|
|
|
var newrect = panel.getBoundingClientRect();
|
|
SimpleTest.is(newrect.left, oldrect.left + 20, "move popup horizontal");
|
|
SimpleTest.is(newrect.top, oldrect.top + 20, "move popup vertical");
|
|
synthesizeMouse(panellabel, 22, 22, { type: "mouseup" });
|
|
|
|
synthesizeMouse(document.getElementById("button"), 5, 5, { type: "mousemove" });
|
|
SimpleTest.is(newrect.left, oldrect.left + 20, "popup horizontal after mouse on button");
|
|
SimpleTest.is(newrect.top, oldrect.top + 20, "popup vertical after mouse on button");
|
|
|
|
panel.hidePopup();
|
|
}
|
|
|
|
function popuphidden()
|
|
{
|
|
window.opener.wrappedJSObject.done(window);
|
|
}
|
|
|
|
]]>
|
|
</script>
|
|
|
|
</window>
|