Skip to content

Commit

Permalink
Backed out changeset 703fa1371dd4 (bug 1652641) for bc failures on br…
Browse files Browse the repository at this point in the history
…owser_multiselect_tabs_close.js . CLOSED TREE
  • Loading branch information
nbeleuzu committed Jul 20, 2020
1 parent 77046eb commit 09c4f9d
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 63 deletions.
13 changes: 6 additions & 7 deletions browser/base/content/browser.xhtml
Original file line number Diff line number Diff line change
Expand Up @@ -165,9 +165,7 @@
<menupopup oncommand="TabContextMenu.reopenInContainer(event);"
onpopupshowing="TabContextMenu.createReopenInContainerMenu(event);"/>
</menu>
<menu id="context_moveTabOptions"
data-lazy-l10n-id="tab-context-move-tabs"
data-l10n-args='{"tabCount": 1}'>
<menu id="context_moveTabOptions">
<menupopup id="moveTabOptionsMenu">
<menuitem id="context_moveToStart"
data-lazy-l10n-id="move-to-start"
Expand Down Expand Up @@ -201,10 +199,11 @@
data-lazy-l10n-id="tab-context-undo-close-tabs"
data-l10n-args='{"tabCount": 1}'
observes="History:UndoCloseTab"/>
<menuitem id="context_closeTab"
data-lazy-l10n-id="tab-context-close-tabs"
data-l10n-args='{"tabCount": 1}'
oncommand="TabContextMenu.closeContextTabs();"/>
<menuitem id="context_closeTab" data-lazy-l10n-id="close-tab"
oncommand="gBrowser.removeTab(TabContextMenu.contextTab, { animate: true });"/>
<menuitem id="context_closeSelectedTabs" data-lazy-l10n-id="close-tabs"
hidden="true"
oncommand="gBrowser.removeMultiSelectedTabs();"/>
</menupopup>

<!-- bug 415444/582485: event.stopPropagation is here for the cloned version
Expand Down
25 changes: 9 additions & 16 deletions browser/base/content/tabbrowser.js
Original file line number Diff line number Diff line change
Expand Up @@ -6500,9 +6500,6 @@ var TabContextMenu = {

let disabled = gBrowser.tabs.length == 1;
let multiselectionContext = this.contextTab.multiselected;
let tabCountInfo = JSON.stringify({
tabCount: (multiselectionContext && gBrowser.multiSelectedTabsCount) || 1,
});

var menuItems = aPopupMenu.getElementsByAttribute(
"tbattr",
Expand Down Expand Up @@ -6554,8 +6551,11 @@ var TabContextMenu = {
let contextMoveTabOptions = document.getElementById(
"context_moveTabOptions"
);
contextMoveTabOptions.setAttribute("data-l10n-args", tabCountInfo);
contextMoveTabOptions.disabled = gBrowser.allTabsSelected();
document.l10n.setAttributes(
contextMoveTabOptions,
multiselectionContext ? "move-tabs" : "move-tab"
);
let selectedTabs = gBrowser.selectedTabs;
let contextMoveTabToEnd = document.getElementById("context_moveToEnd");
let allSelectedTabsAdjacent = selectedTabs.every(
Expand Down Expand Up @@ -6607,10 +6607,11 @@ var TabContextMenu = {
document.getElementById("context_closeOtherTabs").disabled =
unpinnedTabsToClose < 1;

// Update the close item with how many tabs will close.
document
.getElementById("context_closeTab")
.setAttribute("data-l10n-args", tabCountInfo);
// Only one of close_tab/close_selected_tabs should be visible
document.getElementById("context_closeTab").hidden = multiselectionContext;
document.getElementById(
"context_closeSelectedTabs"
).hidden = !multiselectionContext;

// Hide "Bookmark Tab" for multiselection.
// Update its state if visible.
Expand Down Expand Up @@ -6775,12 +6776,4 @@ var TabContextMenu = {
}
}
},

closeContextTabs(event) {
if (this.contextTab.multiselected) {
gBrowser.removeMultiSelectedTabs();
} else {
gBrowser.removeTab(this.contextTab, { animate: true });
}
},
};
35 changes: 11 additions & 24 deletions browser/base/content/test/tabs/browser_multiselect_tabs_close.js
Original file line number Diff line number Diff line change
@@ -1,19 +1,5 @@
const PREF_WARN_ON_CLOSE = "browser.tabs.warnOnCloseOtherTabs";

async function openTabMenuFor(tab) {
let tabMenu = tab.ownerDocument.getElementById("tabContextMenu");

let tabMenuShown = BrowserTestUtils.waitForEvent(tabMenu, "popupshown");
EventUtils.synthesizeMouseAtCenter(
tab,
{ type: "contextmenu" },
tab.ownerGlobal
);
await tabMenuShown;

return tabMenu;
}

add_task(async function setPref() {
await SpecialPowers.pushPrefEnv({
set: [[PREF_WARN_ON_CLOSE, false]],
Expand Down Expand Up @@ -81,6 +67,10 @@ add_task(async function usingTabContextMenu() {
let tab4 = await addTab();

let menuItemCloseTab = document.getElementById("context_closeTab");
let menuItemCloseSelectedTabs = document.getElementById(
"context_closeSelectedTabs"
);

is(gBrowser.multiSelectedTabsCount, 0, "Zero multiselected tabs");

await BrowserTestUtils.switchTab(gBrowser, tab1);
Expand All @@ -94,20 +84,17 @@ add_task(async function usingTabContextMenu() {

// Check the context menu with a non-multiselected tab
updateTabContextMenu(tab4);
let { args } = document.l10n.getAttributes(menuItemCloseTab);
is(args.tabCount, 1, "Close Tab item lists a single tab");
is(menuItemCloseTab.hidden, false, "Close Tab is visible");
is(menuItemCloseSelectedTabs.hidden, true, "Close Selected Tabs is hidden");

// Check the context menu with a multiselected tab. We have to actually open
// it (not just call `updateTabContextMenu`) in order for
// `TabContextMenu.contextTab` to stay non-null when we click an item.
let menu = openTabMenuFor(tab2);
({ args } = document.l10n.getAttributes(menuItemCloseTab));
is(args.tabCount, 2, "Close Tab item lists more than one tab");
// Check the context menu with a multiselected tab
updateTabContextMenu(tab2);
is(menuItemCloseTab.hidden, true, "Close Tab is hidden");
is(menuItemCloseSelectedTabs.hidden, false, "Close Selected Tabs is visible");

let tab1Closing = BrowserTestUtils.waitForTabClosing(tab1);
let tab2Closing = BrowserTestUtils.waitForTabClosing(tab2);
menuItemCloseTab.click();
menu.hidePopup();
menuItemCloseSelectedTabs.click();
await tab1Closing;
await tab2Closing;

Expand Down
27 changes: 11 additions & 16 deletions browser/locales/en-US/browser/tabContextMenu.ftl
Original file line number Diff line number Diff line change
Expand Up @@ -56,27 +56,22 @@ move-to-new-window =
tab-context-close-multiple-tabs =
.label = Close Multiple Tabs
.accesskey = M
## Variables:
## $tabCount (Number): the number of tabs that are affected by the action.
tab-context-undo-close-tabs =
.label =
{ $tabCount ->
[1] Undo Close Tab
*[other] Undo Close Tabs
}
.accesskey = U
tab-context-close-tabs =
.label =
{ $tabCount ->
[1] Close Tab
*[other] Close Tabs
}
.accesskey = C
tab-context-move-tabs =
.label =
{ $tabCount ->
[1] Move Tab
*[other] Move Tabs
}
close-tab =
.label = Close Tab
.accesskey = c
close-tabs =
.label = Close Tabs
.accesskey = S
move-tabs =
.label = Move Tabs
.accesskey = v
move-tab =
.label = Move Tab
.accesskey = v

0 comments on commit 09c4f9d

Please sign in to comment.