mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-16 23:24:16 +00:00
[broadway] Move window to top when moving
This commit is contained in:
parent
618dc872b0
commit
fadaced85f
@ -122,6 +122,7 @@ var lastTimeStamp = 0;
|
|||||||
var realWindowWithMouse = 0;
|
var realWindowWithMouse = 0;
|
||||||
var windowWithMouse = 0;
|
var windowWithMouse = 0;
|
||||||
var surfaces = {};
|
var surfaces = {};
|
||||||
|
var stackingOrder = [];
|
||||||
var outstandingCommands = new Array();
|
var outstandingCommands = new Array();
|
||||||
var inputSocket = null;
|
var inputSocket = null;
|
||||||
var frameSizeX = -1;
|
var frameSizeX = -1;
|
||||||
@ -343,6 +344,7 @@ function cmdCreateSurface(id, x, y, width, height, isTemp)
|
|||||||
surface.document = document;
|
surface.document = document;
|
||||||
surface.transientToplevel = null;
|
surface.transientToplevel = null;
|
||||||
surface.frame = null;
|
surface.frame = null;
|
||||||
|
stackingOrder.push(id);
|
||||||
|
|
||||||
var canvas = document.createElement("canvas");
|
var canvas = document.createElement("canvas");
|
||||||
canvas.width = width;
|
canvas.width = width;
|
||||||
@ -488,11 +490,50 @@ function cmdSetTransientFor(id, parentId)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function restackWindows() {
|
||||||
|
if (useToplevelWindows)
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (var i = 0; i < stackingOrder.length; i++) {
|
||||||
|
var id = stackingOrder[i];
|
||||||
|
var surface = surfaces[id];
|
||||||
|
if (surface.frame)
|
||||||
|
surface.frame.style.zIndex = i;
|
||||||
|
else
|
||||||
|
surface.canvas.style.zIndex = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function moveToTopHelper(surface) {
|
||||||
|
var i = stackingOrder.indexOf(surface.id);
|
||||||
|
stackingOrder.splice(i, 1);
|
||||||
|
stackingOrder.push(surface.id);
|
||||||
|
|
||||||
|
for (var cid in surfaces) {
|
||||||
|
var child = surfaces[cid];
|
||||||
|
if (child.transientParent == surface.id)
|
||||||
|
moveToTopHelper(child);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function moveToTop(surface) {
|
||||||
|
moveToTopHelper(surface);
|
||||||
|
restackWindows();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function cmdDeleteSurface(id)
|
function cmdDeleteSurface(id)
|
||||||
{
|
{
|
||||||
var canvas = surfaces[id].canvas;
|
var surface = surfaces[id];
|
||||||
delete surfaces[id];
|
var i = stackingOrder.indexOf(id);
|
||||||
|
if (i >= 0)
|
||||||
|
stackingOrder.splice(i, 1);
|
||||||
|
var canvas = surface.canvas;
|
||||||
canvas.parentNode.removeChild(canvas);
|
canvas.parentNode.removeChild(canvas);
|
||||||
|
var frame = surface.frame;
|
||||||
|
if (frame)
|
||||||
|
frame.parentNode.removeChild(frame);
|
||||||
|
delete surfaces[id];
|
||||||
}
|
}
|
||||||
|
|
||||||
function cmdMoveSurface(id, x, y)
|
function cmdMoveSurface(id, x, y)
|
||||||
@ -912,6 +953,7 @@ function onMouseDown (ev) {
|
|||||||
localGrab.frame = ev.target;
|
localGrab.frame = ev.target;
|
||||||
localGrab.lastX = ev.pageX;
|
localGrab.lastX = ev.pageX;
|
||||||
localGrab.lastY = ev.pageY;
|
localGrab.lastY = ev.pageY;
|
||||||
|
moveToTop(localGrab.frame.frameFor);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user