mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Back out changeset 6b26a933cad7 (Bug 649319) on suspicion of causing Windows debug Mochitest-other permaorange - CLOSED TREE.
This commit is contained in:
parent
edc6e0c61b
commit
c3e4065e5d
@ -85,6 +85,19 @@ function Drag(item, event, isFauxDrag) {
|
||||
this.safeWindowBounds = Items.getSafeWindowBounds();
|
||||
|
||||
Trenches.activateOthersTrenches(this.el);
|
||||
|
||||
if (!isFauxDrag) {
|
||||
// When a tab drag starts, make it the focused tab.
|
||||
if (this.item.isAGroupItem) {
|
||||
var tab = UI.getActiveTab();
|
||||
if (!tab || tab.parent != this.item) {
|
||||
if (this.item._children.length)
|
||||
UI.setActive(this.item._children[0]);
|
||||
}
|
||||
} else if (this.item.isATabItem) {
|
||||
UI.setActive(this.item);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
Drag.prototype = {
|
||||
|
@ -1014,7 +1014,8 @@ GroupItem.prototype = Utils.extend(new Item(), new Subscribable(), {
|
||||
if (typeof item.setResizable == 'function')
|
||||
item.setResizable(false, options.immediately);
|
||||
|
||||
if (item == UI.getActiveTab() || !this._activeTab)
|
||||
// if it is visually active, set it as the active tab.
|
||||
if (iQ(item.container).hasClass("focus"))
|
||||
this.setActiveTab(item);
|
||||
|
||||
// if it matches the selected tab or no active tab and the browser
|
||||
|
@ -151,9 +151,10 @@ Item.prototype = {
|
||||
this.dragOptions = {
|
||||
cancelClass: 'close stackExpander',
|
||||
start: function(e, ui) {
|
||||
UI.setActive(this);
|
||||
if (this.isAGroupItem)
|
||||
if (this.isAGroupItem) {
|
||||
UI.setActive(this);
|
||||
this._unfreezeItemSize();
|
||||
}
|
||||
// if we start dragging a tab within a group, start with dropSpace on.
|
||||
else if (this.parent != null)
|
||||
this.parent._dropSpaceActive = true;
|
||||
@ -200,7 +201,8 @@ Item.prototype = {
|
||||
minWidth: 90,
|
||||
minHeight: 90,
|
||||
start: function(e,ui) {
|
||||
UI.setActive(this);
|
||||
if (this.isAGroupItem)
|
||||
UI.setActive(this);
|
||||
resize.info = new Drag(this, e);
|
||||
},
|
||||
resize: function(e,ui) {
|
||||
|
@ -135,7 +135,6 @@ _BROWSER_FILES = \
|
||||
browser_tabview_bug648882.js \
|
||||
browser_tabview_bug649006.js \
|
||||
browser_tabview_bug649307.js \
|
||||
browser_tabview_bug649319.js \
|
||||
browser_tabview_bug651311.js \
|
||||
browser_tabview_dragdrop.js \
|
||||
browser_tabview_exit_button.js \
|
||||
|
@ -1,88 +0,0 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
function test() {
|
||||
waitForExplicitFinish();
|
||||
|
||||
newWindowWithTabView(function (win) {
|
||||
registerCleanupFunction(function () win.close());
|
||||
waitForFocus(function () testScenarios(win));
|
||||
});
|
||||
}
|
||||
|
||||
function testScenarios(win) {
|
||||
let simulateDragDrop = function (target) {
|
||||
EventUtils.synthesizeMouseAtCenter(target, {type: "mousedown"}, cw);
|
||||
EventUtils.synthesizeMouse(target, 40, 20, {type: "mousemove"}, cw);
|
||||
EventUtils.synthesizeMouse(target, 80, 20, {type: "mouseup"}, cw);
|
||||
}
|
||||
|
||||
let dragOutOfGroup = function (target) {
|
||||
EventUtils.synthesizeMouseAtCenter(target, {type: "mousedown"}, cw);
|
||||
EventUtils.synthesizeMouse(target, 600, 5, {type: "mousemove"}, cw);
|
||||
EventUtils.synthesizeMouse(target, 600, 5, {type: "mouseup"}, cw);
|
||||
}
|
||||
|
||||
let dragIntoGroup = function (target) {
|
||||
EventUtils.synthesizeMouseAtCenter(target, {type: "mousedown"}, cw);
|
||||
EventUtils.synthesizeMouse(target, -200, 5, {type: "mousemove"}, cw);
|
||||
EventUtils.synthesizeMouse(target, -200, 5, {type: "mouseup"}, cw);
|
||||
}
|
||||
|
||||
let assertActiveOrphan = function (tabItem) {
|
||||
ok(!cw.GroupItems.getActiveGroupItem(), "no groupItem is active");
|
||||
is(cw.UI.getActiveTab(), tabItem, "orphan tab is active");
|
||||
is(cw.UI.getActiveOrphanTab(), tabItem, "orphan tab is active");
|
||||
}
|
||||
|
||||
let cw = win.TabView.getContentWindow();
|
||||
let groupItem = cw.GroupItems.groupItems[0];
|
||||
let groupItem2 = createGroupItemWithBlankTabs(win, 400, 300, 20, 4);
|
||||
|
||||
// move group
|
||||
cw.UI.setActive(groupItem);
|
||||
simulateDragDrop(groupItem2.container);
|
||||
is(cw.GroupItems.getActiveGroupItem(), groupItem2, "second groupItem is active");
|
||||
is(cw.UI.getActiveTab(), groupItem2.getChild(0), "second groupItem's first tab is active");
|
||||
|
||||
// resize group
|
||||
cw.UI.setActive(groupItem);
|
||||
let tabItem = groupItem2.getChild(2);
|
||||
groupItem2.setActiveTab(tabItem);
|
||||
simulateDragDrop(groupItem2.$resizer[0]);
|
||||
is(cw.GroupItems.getActiveGroupItem(), groupItem2, "second groupItem is active");
|
||||
is(cw.UI.getActiveTab(), tabItem, "second groupItem's third tab is active");
|
||||
|
||||
// create orphan
|
||||
tabItem = groupItem2.getChild(0);
|
||||
dragOutOfGroup(tabItem.container);
|
||||
|
||||
// move orphan
|
||||
cw.UI.setActive(groupItem2);
|
||||
simulateDragDrop(tabItem.container);
|
||||
assertActiveOrphan(tabItem);
|
||||
|
||||
// resize orphan
|
||||
cw.UI.setActive(groupItem2);
|
||||
let $resizer = cw.iQ('.iq-resizable-handle', tabItem.container);
|
||||
simulateDragDrop($resizer[0]);
|
||||
assertActiveOrphan(tabItem);
|
||||
|
||||
// drag back into group
|
||||
dragIntoGroup(tabItem.container);
|
||||
cw.UI.setActive(groupItem);
|
||||
cw.UI.setActive(groupItem2);
|
||||
is(cw.UI.getActiveTab(), tabItem, "the dropped tab is active");
|
||||
|
||||
// hide + unhide groupItem
|
||||
hideGroupItem(groupItem2, function () {
|
||||
is(cw.GroupItems.getActiveGroupItem(), groupItem, "first groupItem is active");
|
||||
|
||||
unhideGroupItem(groupItem2, function () {
|
||||
is(cw.GroupItems.getActiveGroupItem(), groupItem2, "second groupItem is active");
|
||||
is(cw.UI.getActiveTab(), tabItem, "the dropped tab is active");
|
||||
|
||||
finish();
|
||||
});
|
||||
});
|
||||
}
|
Loading…
Reference in New Issue
Block a user