author | Ryan VanderMeulen <ryanvm@gmail.com> |
Fri, 25 Apr 2014 16:24:02 -0400 | |
changeset 180254 | 0e91262606a631fbc4e0ea24c1447c0604787de1 |
parent 180234 | 992ddc6bd0a9faa9ea107783abc2ef1596b33050 (current diff) |
parent 180253 | 8364bff2be23003f9293b769d9efaa81427c4d45 (diff) |
child 180255 | 1f67e8c65ce54e60d2c4bc0cb6c6ea1c02329326 |
child 180260 | a9d318e1cc9df09b72a3e2e6dbfde4f65196e3ad |
child 180289 | d353282fc0a6f001e30003c136ede5525dd03f87 |
child 180333 | ea4e380efa0ad3422e017a0e4c74cc61c9ed5187 |
push id | 26658 |
push user | ryanvm@gmail.com |
push date | Fri, 25 Apr 2014 20:24:05 +0000 |
treeherder | mozilla-central@0e91262606a6 [default view] [failures only] |
perfherder | [talos] [build metrics] [platform microbench] (compared to previous push) |
milestone | 31.0a1 |
first release with | nightly linux32
0e91262606a6
/
31.0a1
/
20140426030204
/
files
nightly linux64
0e91262606a6
/
31.0a1
/
20140426030204
/
files
nightly mac
0e91262606a6
/
31.0a1
/
20140426030204
/
files
nightly win32
0e91262606a6
/
31.0a1
/
20140426030204
/
files
nightly win64
0e91262606a6
/
31.0a1
/
20140426030204
/
files
|
last release without | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
releases | nightly linux32
31.0a1
/
20140426030204
/
pushlog to previous
nightly linux64
31.0a1
/
20140426030204
/
pushlog to previous
nightly mac
31.0a1
/
20140426030204
/
pushlog to previous
nightly win32
31.0a1
/
20140426030204
/
pushlog to previous
nightly win64
31.0a1
/
20140426030204
/
pushlog to previous
|
browser/themes/shared/devtools/images/option-icon.png | file | annotate | diff | comparison | revisions | |
mobile/android/base/tests/testFilterOpenTab.java | file | annotate | diff | comparison | revisions |
--- a/addon-sdk/source/test/test-ui-sidebar.js +++ b/addon-sdk/source/test/test-ui-sidebar.js @@ -1206,17 +1206,17 @@ exports.testShowToOpenXToClose = functio let sidebar = Sidebar({ id: testName, title: testName, url: url, onShow: function() { assert.ok(isChecked(menuitem), 'menuitem is checked'); - let closeButton = window.document.querySelector('#sidebar-header > toolbarbutton.tabs-closebutton'); + let closeButton = window.document.querySelector('#sidebar-header > toolbarbutton.close-icon'); simulateCommand(closeButton); }, onHide: function() { assert.ok(!isChecked(menuitem), 'menuitem is not checked'); sidebar.destroy(); done(); }
--- a/browser/app/profile/firefox.js +++ b/browser/app/profile/firefox.js @@ -452,23 +452,16 @@ pref("browser.tabs.loadBookmarksInBackgr pref("browser.tabs.tabClipWidth", 140); pref("browser.tabs.animate", true); #ifdef UNIX_BUT_NOT_MAC pref("browser.tabs.drawInTitlebar", false); #else pref("browser.tabs.drawInTitlebar", true); #endif -// Where to show tab close buttons: -// 0 on active tab only -// 1 on all tabs until tabClipWidth is reached, then active tab only -// 2 no close buttons at all -// 3 at the end of the tabstrip -pref("browser.tabs.closeButtons", 1); - // When tabs opened by links in other tabs via a combination of // browser.link.open_newwindow being set to 3 and target="_blank" etc are // closed: // true return to the tab that opened this tab (its owner) // false return to the adjacent tab (old default) pref("browser.tabs.selectOwnerOnClose", true); pref("browser.ctrlTab.previews", false); @@ -1158,17 +1151,16 @@ pref("services.sync.prefs.sync.browser.l pref("services.sync.prefs.sync.browser.offline-apps.notify", true); pref("services.sync.prefs.sync.browser.safebrowsing.enabled", true); pref("services.sync.prefs.sync.browser.safebrowsing.malware.enabled", true); pref("services.sync.prefs.sync.browser.search.selectedEngine", true); pref("services.sync.prefs.sync.browser.search.update", true); pref("services.sync.prefs.sync.browser.sessionstore.restore_on_demand", true); pref("services.sync.prefs.sync.browser.startup.homepage", true); pref("services.sync.prefs.sync.browser.startup.page", true); -pref("services.sync.prefs.sync.browser.tabs.closeButtons", true); pref("services.sync.prefs.sync.browser.tabs.loadInBackground", true); pref("services.sync.prefs.sync.browser.tabs.warnOnClose", true); pref("services.sync.prefs.sync.browser.tabs.warnOnOpen", true); pref("services.sync.prefs.sync.browser.urlbar.autocomplete.enabled", true); pref("services.sync.prefs.sync.browser.urlbar.default.behavior", true); pref("services.sync.prefs.sync.browser.urlbar.maxRichResults", true); pref("services.sync.prefs.sync.dom.disable_open_during_load", true); pref("services.sync.prefs.sync.dom.disable_window_flip", true);
--- a/browser/base/content/browser.css +++ b/browser/base/content/browser.css @@ -484,20 +484,16 @@ toolbar[mode="full"] #bookmarks-menu-but menupopup[emptyplacesresult="true"] > .hide-if-empty-places-result { display: none; } menuitem.spell-suggestion { font-weight: bold; } -#sidebar-header > .tabs-closebutton { - -moz-user-focus: normal; -} - /* apply Fitts' law to the notification bar's close button */ window[sizemode="maximized"] #content .notification-inner { border-right: 0px !important; } /* Hide extension toolbars that neglected to set the proper class */ window[chromehidden~="location"][chromehidden~="toolbar"] toolbar:not(.chromeclass-menubar), window[chromehidden~="toolbar"] toolbar:not(.toolbar-primary):not(.chromeclass-menubar) {
--- a/browser/base/content/browser.xul +++ b/browser/base/content/browser.xul @@ -544,17 +544,17 @@ <toolbar id="TabsToolbar" class="toolbar-primary" fullscreentoolbar="true" customizable="true" mode="icons" iconsize="small" aria-label="&tabsToolbar.label;" context="toolbar-context-menu" - defaultset="tabbrowser-tabs,new-tab-button,alltabs-button,tabs-closebutton" + defaultset="tabbrowser-tabs,new-tab-button,alltabs-button" collapsed="true"> #if defined(MOZ_WIDGET_GTK) || defined(MOZ_WIDGET_QT) <hbox id="private-browsing-indicator" skipintoolbarset="true"/> #endif <tabs id="tabbrowser-tabs" @@ -595,23 +595,16 @@ label="&viewTabGroups.label;" command="Browser:ToggleTabView" cui-areatype="toolbar" observes="tabviewGroupsNumber"/> <menuseparator id="alltabs-popup-separator"/> </menupopup> </toolbarbutton> - <toolbarbutton id="tabs-closebutton" - class="close-button tabs-closebutton close-icon" - command="cmd_close" - label="&closeTab.label;" - cui-areatype="toolbar" - tooltiptext="&closeTab.label;"/> - #if !defined(MOZ_WIDGET_GTK) && !defined(MOZ_WIDGET_QT) <hbox class="private-browsing-indicator" skipintoolbarset="true"/> #endif #ifdef CAN_DRAW_IN_TITLEBAR <hbox class="titlebar-placeholder" type="caption-buttons" id="titlebar-placeholder-on-TabsToolbar-for-captions-buttons" persist="width" #ifndef XP_MACOSX ordinal="1000" @@ -1049,17 +1042,17 @@ <deck id="content-deck" flex="1"> <hbox flex="1" id="browser"> <vbox id="browser-border-start" hidden="true" layer="true"/> <vbox id="sidebar-box" hidden="true" class="chromeclass-extrachrome"> <sidebarheader id="sidebar-header" align="center"> <label id="sidebar-title" persist="value" flex="1" crop="end" control="sidebar"/> <image id="sidebar-throbber"/> - <toolbarbutton class="tabs-closebutton close-icon" tooltiptext="&sidebarCloseButton.tooltip;" oncommand="toggleSidebar();"/> + <toolbarbutton class="close-icon tabbable" tooltiptext="&sidebarCloseButton.tooltip;" oncommand="toggleSidebar();"/> </sidebarheader> <browser id="sidebar" flex="1" autoscroll="false" disablehistory="true" style="min-width: 14em; width: 18em; max-width: 36em;"/> </vbox> <splitter id="sidebar-splitter" class="chromeclass-extrachrome sidebar-splitter" hidden="true"/> <vbox id="appcontent" flex="1"> <tabbrowser id="content"
--- a/browser/base/content/tabbrowser.css +++ b/browser/base/content/tabbrowser.css @@ -7,22 +7,21 @@ } .tabbrowser-arrowscrollbox { -moz-binding: url("chrome://browser/content/tabbrowser.xml#tabbrowser-arrowscrollbox"); } .tab-close-button { -moz-binding: url("chrome://browser/content/tabbrowser.xml#tabbrowser-close-tab-button"); - display: none; } -.tabbrowser-tabs[closebuttons="activetab"] > * > * > * > .tab-close-button:not([pinned])[selected="true"], -.tabbrowser-tabs[closebuttons="alltabs"] > * > * > * > .tab-close-button:not([pinned]) { - display: -moz-box; +.tab-close-button[pinned], +.tabbrowser-tabs[closebuttons="activetab"] > * > * > * > .tab-close-button:not([selected="true"]) { + display: none; } .tab-label[pinned] { width: 0; margin-left: 0 !important; margin-right: 0 !important; padding-left: 0 !important; padding-right: 0 !important;
--- a/browser/base/content/tabbrowser.xml +++ b/browser/base/content/tabbrowser.xml @@ -1908,17 +1908,17 @@ } } var closeWindow = false; var newTab = false; if (this.tabs.length - this._removingTabs.length == 1) { closeWindow = aCloseWindowWithLastTab != null ? aCloseWindowWithLastTab : !window.toolbar.visible || - this.tabContainer._closeWindowWithLastTab; + Services.prefs.getBoolPref("browser.tabs.closeWindowWithLastTab"); // Closing the tab and replacing it with a blank one is notably slower // than closing the window right away. If the caller opts in, take // the fast path. if (closeWindow && aCloseWindowFastpath && this._removingTabs.length == 0) { // This call actually closes the window, unless the user @@ -3367,44 +3367,34 @@ style="width: 0;"/> </xul:arrowscrollbox> </content> <implementation implements="nsIDOMEventListener"> <constructor> <![CDATA[ this.mTabClipWidth = Services.prefs.getIntPref("browser.tabs.tabClipWidth"); - this.mCloseButtons = Services.prefs.getIntPref("browser.tabs.closeButtons"); - this._closeWindowWithLastTab = Services.prefs.getBoolPref("browser.tabs.closeWindowWithLastTab"); var tab = this.firstChild; tab.label = this.tabbrowser.mStringBundle.getString("tabs.emptyTabTitle"); tab.setAttribute("crop", "end"); tab.setAttribute("onerror", "this.removeAttribute('image');"); - this.adjustTabstrip(); - - Services.prefs.addObserver("browser.tabs.", this._prefObserver, false); + window.addEventListener("resize", this, false); window.addEventListener("load", this, false); try { this._tabAnimationLoggingEnabled = Services.prefs.getBoolPref("browser.tabs.animationLogging.enabled"); } catch (ex) { this._tabAnimationLoggingEnabled = false; } this._browserNewtabpageEnabled = Services.prefs.getBoolPref("browser.newtabpage.enabled"); ]]> </constructor> - <destructor> - <![CDATA[ - Services.prefs.removeObserver("browser.tabs.", this._prefObserver); - ]]> - </destructor> - <field name="tabbrowser" readonly="true"> document.getElementById(this.getAttribute("tabbrowser")); </field> <field name="tabbox" readonly="true"> this.tabbrowser.mTabBox; </field> @@ -3466,32 +3456,16 @@ let hoveredTab = this._hoveredTab; if (hoveredTab) { hoveredTab._mouseleave(); hoveredTab._mouseenter(); } ]]></body> </method> - <field name="_prefObserver"><![CDATA[({ - tabContainer: this, - - observe: function (subject, topic, data) { - switch (data) { - case "browser.tabs.closeButtons": - this.tabContainer.mCloseButtons = Services.prefs.getIntPref(data); - this.tabContainer.adjustTabstrip(); - break; - case "browser.tabs.closeWindowWithLastTab": - this.tabContainer._closeWindowWithLastTab = Services.prefs.getBoolPref(data); - this.tabContainer.adjustTabstrip(); - break; - } - } - });]]></field> <field name="_blockDblClick">false</field> <field name="_tabDropIndicator"> document.getAnonymousElementByAttribute(this, "anonid", "tab-drop-indicator"); </field> <field name="_dragOverDelay">350</field> <field name="_dragTime">0</field> @@ -3558,52 +3532,33 @@ this.visible = true; ]]></body> </method> <method name="adjustTabstrip"> <body><![CDATA[ let numTabs = this.childNodes.length - this.tabbrowser._removingTabs.length; - // modes for tabstrip - // 0 - button on active tab only - // 1 - close buttons on all tabs - // 2 - no close buttons at all - // 3 - close button at the end of the tabstrip - switch (this.mCloseButtons) { - case 0: - this.setAttribute("closebuttons", "activetab"); - break; - case 1: - if (numTabs <= 2) { - // This is an optimization to avoid layout flushes by calling - // getBoundingClientRect() when we just opened a second tab. In - // this case it's highly unlikely that the tab width is smaller - // than mTabClipWidth and the tab close button obscures too much - // of the tab's label. In the edge case of the window being too - // narrow (or if tabClipWidth has been set to a way higher value), - // we'll correct the 'closebuttons' attribute after the tabopen - // animation has finished. - this.setAttribute("closebuttons", "alltabs"); - } else { - let tab = this.tabbrowser.visibleTabs[this.tabbrowser._numPinnedTabs]; - if (tab && tab.getBoundingClientRect().width > this.mTabClipWidth) - this.setAttribute("closebuttons", "alltabs"); - else - this.setAttribute("closebuttons", "activetab"); + if (numTabs > 2) { + // This is an optimization to avoid layout flushes by calling + // getBoundingClientRect() when we just opened a second tab. In + // this case it's highly unlikely that the tab width is smaller + // than mTabClipWidth and the tab close button obscures too much + // of the tab's label. In the edge case of the window being too + // narrow (or if tabClipWidth has been set to a way higher value), + // we'll correct the 'closebuttons' attribute after the tabopen + // animation has finished. + + let tab = this.tabbrowser.visibleTabs[this.tabbrowser._numPinnedTabs]; + if (tab && tab.getBoundingClientRect().width <= this.mTabClipWidth) { + this.setAttribute("closebuttons", "activetab"); + return; } - break; - case 2: - case 3: - this.setAttribute("closebuttons", "never"); - break; } - var tabstripClosebutton = document.getElementById("tabs-closebutton"); - if (tabstripClosebutton && tabstripClosebutton.parentNode == this._container) - tabstripClosebutton.collapsed = this.mCloseButtons != 3; + this.removeAttribute("closebuttons"); ]]></body> </method> <method name="_handleTabSelect"> <parameter name="aSmoothScroll"/> <body><![CDATA[ if (this.getAttribute("overflow") == "true") this.mTabstrip.ensureElementIsVisible(this.selectedItem, aSmoothScroll); @@ -4267,18 +4222,17 @@ } ]]></handler> <handler event="click"><![CDATA[ if (event.button != 1) return; if (event.target.localName == "tab") { - if (this.childNodes.length > 1 || !this._closeWindowWithLastTab) - this.tabbrowser.removeTab(event.target, {animate: true, byMouse: true}); + this.tabbrowser.removeTab(event.target, {animate: true, byMouse: true}); } else if (event.originalTarget.localName == "box") { BrowserOpenTab(); } else { return; } event.stopPropagation(); ]]></handler>
--- a/browser/components/customizableui/src/CustomizableUI.jsm +++ b/browser/components/customizableui/src/CustomizableUI.jsm @@ -219,17 +219,16 @@ let CustomizableUIInternal = { #endif this.registerArea(CustomizableUI.AREA_TABSTRIP, { legacy: true, type: CustomizableUI.TYPE_TOOLBAR, defaultPlacements: [ "tabbrowser-tabs", "new-tab-button", "alltabs-button", - "tabs-closebutton", ], defaultCollapsed: null, }, true); this.registerArea(CustomizableUI.AREA_BOOKMARKS, { legacy: true, type: CustomizableUI.TYPE_TOOLBAR, defaultPlacements: [ "personal-bookmarks",
--- a/browser/components/customizableui/src/CustomizeMode.jsm +++ b/browser/components/customizableui/src/CustomizeMode.jsm @@ -174,20 +174,20 @@ CustomizeMode.prototype = { CustomizableUI.dispatchToolboxEvent("beforecustomization", {}, window); CustomizableUI.notifyStartCustomizing(this.window); // Add a keypress listener to the document so that we can quickly exit // customization mode when pressing ESC. document.addEventListener("keypress", this); - // Same goes for the menu button - if we're customizing, a mousedown to the + // Same goes for the menu button - if we're customizing, a click on the // menu button means a quick exit from customization mode. window.PanelUI.hide(); - window.PanelUI.menuButton.addEventListener("mousedown", this); + window.PanelUI.menuButton.addEventListener("command", this); window.PanelUI.menuButton.open = true; window.PanelUI.beginBatchUpdate(); // The menu panel is lazy, and registers itself when the popup shows. We // need to force the menu panel to register itself, or else customization // is really not going to work. We pass "true" to ensureRegistered to // indicate that we're handling calling startBatchUpdate and // endBatchUpdate. @@ -326,17 +326,17 @@ CustomizeMode.prototype = { this.panelUIContents.removeAttribute("showoutline"); } this._removeExtraToolbarsIfEmpty(); CustomizableUI.removeListener(this); this.document.removeEventListener("keypress", this); - this.window.PanelUI.menuButton.removeEventListener("mousedown", this); + this.window.PanelUI.menuButton.removeEventListener("command", this); this.window.PanelUI.menuButton.open = false; this.window.PanelUI.beginBatchUpdate(); this._removePanelCustomizationPlaceholders(); let window = this.window; let document = this.document; @@ -1176,23 +1176,23 @@ CustomizeMode.prototype = { this._onDragDrop(aEvent); break; case "dragexit": this._onDragExit(aEvent); break; case "dragend": this._onDragEnd(aEvent); break; - case "mousedown": - if (aEvent.button == 0 && - (aEvent.originalTarget == this.window.PanelUI.menuButton)) { + case "command": + if (aEvent.originalTarget == this.window.PanelUI.menuButton) { this.exit(); aEvent.preventDefault(); - return; } + break; + case "mousedown": this._onMouseDown(aEvent); break; case "mouseup": this._onMouseUp(aEvent); break; case "keypress": if (aEvent.keyCode == aEvent.DOM_VK_ESCAPE) { this.exit();
--- a/browser/components/customizableui/test/browser.ini +++ b/browser/components/customizableui/test/browser.ini @@ -60,16 +60,29 @@ skip-if = e10s # Bug ?????? - test uses [browser_940107_home_button_in_bookmarks_toolbar.js] [browser_940307_panel_click_closure_handling.js] [browser_940946_removable_from_navbar_customizemode.js] [browser_941083_invalidate_wrapper_cache_createWidget.js] [browser_942581_unregisterArea_keeps_placements.js] [browser_943683_migration_test.js] [browser_944887_destroyWidget_should_destroy_in_palette.js] [browser_945739_showInPrivateBrowsing_customize_mode.js] +[browser_947914_button_addons.js] +[browser_947914_button_copy.js] +[browser_947914_button_cut.js] +[browser_947914_button_find.js] +[browser_947914_button_history.js] +[browser_947914_button_newPrivateWindow.js] +[browser_947914_button_newWindow.js] +[browser_947914_button_paste.js] +[browser_947914_button_print.js] +[browser_947914_button_savePage.js] +[browser_947914_button_zoomIn.js] +[browser_947914_button_zoomOut.js] +[browser_947914_button_zoomReset.js] [browser_947987_removable_default.js] [browser_948985_non_removable_defaultArea.js] [browser_952963_areaType_getter_no_area.js] [browser_956602_remove_special_widget.js] [browser_962884_opt_in_disable_hyphens.js] [browser_963639_customizing_attribute_non_customizable_toolbar.js] [browser_967000_button_charEncoding.js] skip-if = e10s # Bug ?????? - test uses promiseTabLoadEvent() which isn't e10s friendly.
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_addons.js @@ -0,0 +1,34 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check addons button existence and functionality"); + + let initialLocation = gBrowser.currentURI.spec; + + yield PanelUI.show(); + + let addonsButton = document.getElementById("add-ons-button"); + ok(addonsButton, "Add-ons button exists in Panel Menu"); + addonsButton.click(); + + yield waitForCondition(function() gBrowser.currentURI && + gBrowser.currentURI.spec == "about:addons"); + + let addonsPage = gBrowser.selectedBrowser.contentWindow.document. + getElementById("addons-page"); + ok(addonsPage, "Add-ons page was opened"); + + // close the add-ons tab + if(gBrowser.tabs.length > 1) { + gBrowser.removeTab(gBrowser.selectedTab); + } + else { + var tabToRemove = gBrowser.selectedTab; + gBrowser.addTab(initialLocation); + gBrowser.removeTab(tabToRemove); + } +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_copy.js @@ -0,0 +1,51 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check copy button existence and functionality"); + + var testText = "copy text test"; + let initialLocation = gBrowser.currentURI.spec; + + yield PanelUI.show(); + + let copyButton = document.getElementById("copy-button"); + ok(copyButton, "Copy button exists in Panel Menu"); + is(copyButton.getAttribute("disabled"), "true", "Copy button is initially disabled"); + + // copy text from URL bar + gURLBar.value = testText; + gURLBar.focus(); + gURLBar.select(); + yield PanelUI.show(); + + ok(!copyButton.hasAttribute("disabled"), "Copy button gets enabled"); + + copyButton.click(); + is(gURLBar.value, testText, "Selected text is unaltered when clicking copy"); + + // check that the text was added to the clipboard + let clipboard = Services.clipboard; + let transferable = Cc["@mozilla.org/widget/transferable;1"].createInstance(Ci.nsITransferable); + const globalClipboard = clipboard.kGlobalClipboard; + + transferable.init(null); + transferable.addDataFlavor("text/unicode"); + clipboard.getData(transferable, globalClipboard); + let str = {}, strLength = {}; + transferable.getTransferData("text/unicode", str, strLength); + let clipboardValue = ""; + + if (str.value) { + str.value.QueryInterface(Ci.nsISupportsString); + clipboardValue = str.value.data; + } + is(clipboardValue, testText, "Data was copied to the clipboard."); + + // restore the tab location and clear the clipboard + Services.clipboard.emptyClipboard(globalClipboard); + gURLBar.value = initialLocation; +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_cut.js @@ -0,0 +1,50 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check cut button existence and functionality"); + + var testText = "cut text test"; + let initialLocation = gBrowser.currentURI.spec; + + yield PanelUI.show(); + + let cutButton = document.getElementById("cut-button"); + ok(cutButton, "Cut button exists in Panel Menu"); + ok(cutButton.getAttribute("disabled"), "Cut button is disabled"); + + // cut text from URL bar + gURLBar.value = testText; + gURLBar.focus(); + gURLBar.select(); + yield PanelUI.show(); + + ok(!cutButton.hasAttribute("disabled"), "Cut button gets enabled"); + cutButton.click(); + is(gURLBar.value, "", "Selected text is removed from source when clicking on cut"); + + // check that the text was added to the clipboard + let clipboard = Services.clipboard; + let transferable = Cc["@mozilla.org/widget/transferable;1"].createInstance(Ci.nsITransferable); + const globalClipboard = clipboard.kGlobalClipboard; + + transferable.init(null); + transferable.addDataFlavor("text/unicode"); + clipboard.getData(transferable, globalClipboard); + let str = {}, strLength = {}; + transferable.getTransferData("text/unicode", str, strLength); + let clipboardValue = ""; + + if (str.value) { + str.value.QueryInterface(Ci.nsISupportsString); + clipboardValue = str.value.data; + } + is(clipboardValue, testText, "Data was copied to the clipboard."); + + // restore the tab location and clear the clipboard + gBrowser.value = initialLocation; + Services.clipboard.emptyClipboard(globalClipboard); +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_find.js @@ -0,0 +1,20 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check find button existence and functionality"); + + yield PanelUI.show(); + + let findButton = document.getElementById("find-button"); + ok(findButton, "Find button exists in Panel Menu"); + + findButton.click(); + ok(!gFindBar.hasAttribute("hidden"), "Findbar opened successfully"); + + // close find bar + gFindBar.close(); +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_history.js @@ -0,0 +1,22 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check history button existence and functionality"); + + yield PanelUI.show(); + + let historyButton = document.getElementById("history-panelmenu"); + ok(historyButton, "History button appears in Panel Menu"); + + historyButton.click(); + let historyPanel = document.getElementById("PanelUI-history"); + ok(historyPanel.getAttribute("current"), "History Panel is in view"); + + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_newPrivateWindow.js @@ -0,0 +1,45 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check private browsing button existence and functionality"); + yield PanelUI.show(); + + var windowWasHandled = false; + let privateWindow = null; + + let observerWindowOpened = { + observe: function(aSubject, aTopic, aData) { + if (aTopic == "domwindowopened") { + privateWindow = aSubject.QueryInterface(Components.interfaces.nsIDOMWindow); + privateWindow.addEventListener("load", function newWindowHandler() { + privateWindow.removeEventListener("load", newWindowHandler, false); + is(privateWindow.location.href, "chrome://browser/content/browser.xul", + "A new browser window was opened"); + ok(PrivateBrowsingUtils.isWindowPrivate(privateWindow), "Window is private"); + windowWasHandled = true; + }, false); + } + } + } + + Services.ww.registerNotification(observerWindowOpened); + + let privateBrowsingButton = document.getElementById("privatebrowsing-button"); + ok(privateBrowsingButton, "Private browsing button exists in Panel Menu"); + privateBrowsingButton.click(); + + try{ + yield waitForCondition(() => windowWasHandled); + yield promiseWindowClosed(privateWindow); + } + catch(e) { + ok(false, "The new private browser window was not properly handled"); + } + finally { + Services.ww.unregisterNotification(observerWindowOpened); + } +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_newWindow.js @@ -0,0 +1,45 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check new window button existence and functionality"); + yield PanelUI.show(); + + var windowWasHandled = false; + var newWindow = null; + + let observerWindowOpened = { + observe: function(aSubject, aTopic, aData) { + if (aTopic == "domwindowopened") { + newWindow = aSubject.QueryInterface(Components.interfaces.nsIDOMWindow); + newWindow.addEventListener("load", function newWindowHandler() { + newWindow.removeEventListener("load", newWindowHandler, false); + is(newWindow.location.href, "chrome://browser/content/browser.xul", + "A new browser window was opened"); + ok(!PrivateBrowsingUtils.isWindowPrivate(newWindow), "Window is not private"); + windowWasHandled = true; + }, false); + } + } + } + + Services.ww.registerNotification(observerWindowOpened); + + let newWindowButton = document.getElementById("new-window-button"); + ok(newWindowButton, "New Window button exists in Panel Menu"); + newWindowButton.click(); + + try{ + yield waitForCondition(() => windowWasHandled); + yield promiseWindowClosed(newWindow); + } + catch(e) { + ok(false, "The new browser window was not properly handled"); + } + finally { + Services.ww.unregisterNotification(observerWindowOpened); + } +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_paste.js @@ -0,0 +1,35 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check paste button existence and functionality"); + + let initialLocation = gBrowser.currentURI.spec; + let clipboard = Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper); + const globalClipboard = Services.clipboard.kGlobalClipboard; + + yield PanelUI.show(); + + let pasteButton = document.getElementById("paste-button"); + ok(pasteButton, "Paste button exists in Panel Menu"); + + // add text to clipboard + var text = "Sample text for testing"; + clipboard.copyString(text); + + // test paste button by pasting text to URL bar + gURLBar.focus(); + yield PanelUI.show(); + + ok(!pasteButton.hasAttribute("disabled"), "Paste button is enabled"); + pasteButton.click(); + + is(gURLBar.value, text, "Text pasted successfully"); + + // clear the clipboard and restore the tab location as it was at the begining of the test + Services.clipboard.emptyClipboard(globalClipboard); + gURLBar.value = initialLocation; +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_print.js @@ -0,0 +1,32 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +const isOSX = (Services.appinfo.OS === "Darwin"); + +add_task(function() { + info("Check print button existence and functionality"); + + yield PanelUI.show(); + + let printButton = document.getElementById("print-button"); + ok(printButton, "Print button exists in Panel Menu"); + + if(isOSX) { + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise; + } + else { + printButton.click(); + yield waitForCondition(() => window.gInPrintPreviewMode); + + ok(window.gInPrintPreviewMode, "Entered print preview mode"); + + // close print preview + PrintUtils.exitPrintPreview(); + yield waitForCondition(() => !window.gInPrintPreviewMode); + } +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_savePage.js @@ -0,0 +1,18 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check save page button existence"); + + yield PanelUI.show(); + + let savePageButton = document.getElementById("save-page-button"); + ok(savePageButton, "Save Page button exists in Panel Menu"); + + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise; +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_zoomIn.js @@ -0,0 +1,31 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check zoom in button existence and functionality"); + + let initialPageZoom = ZoomManager.zoom; + is(initialPageZoom, 1, "Initial zoom factor should be 1"); + + yield PanelUI.show(); + + let zoomInButton = document.getElementById("zoom-in-button"); + ok(zoomInButton, "Zoom in button exists in Panel Menu"); + + zoomInButton.click(); + let pageZoomLevel = parseInt(ZoomManager.zoom * 100); + let zoomResetButton = document.getElementById("zoom-reset-button"); + let expectedZoomLevel = parseInt(zoomResetButton.getAttribute("label"), 10); + ok(pageZoomLevel > 100 && pageZoomLevel == expectedZoomLevel, "Page zoomed in correctly"); + + // close the Panel + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise; + + // reset zoom level + ZoomManager.zoom = initialPageZoom; +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_zoomOut.js @@ -0,0 +1,32 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check zoom out button existence and functionality"); + + let initialPageZoom = ZoomManager.zoom; + is(initialPageZoom, 1, "Initial zoom factor should be 1"); + + yield PanelUI.show(); + + let zoomOutButton = document.getElementById("zoom-out-button"); + ok(zoomOutButton, "Zoom out button exists in Panel Menu"); + + zoomOutButton.click(); + let pageZoomLevel = Math.round(ZoomManager.zoom*100); + + let zoomResetButton = document.getElementById("zoom-reset-button"); + let expectedZoomLevel = parseInt(zoomResetButton.getAttribute("label"), 10); + ok(pageZoomLevel < 100 && pageZoomLevel == expectedZoomLevel, "Page zoomed out correctly"); + + // close the panel + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise; + + // reset zoom level + ZoomManager.zoom = initialPageZoom; +});
new file mode 100644 --- /dev/null +++ b/browser/components/customizableui/test/browser_947914_button_zoomReset.js @@ -0,0 +1,30 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +add_task(function() { + info("Check zoom reset button existence and functionality"); + + let initialPageZoom = ZoomManager.zoom; + is(initialPageZoom, 1, "Initial zoom factor should be 1"); + ZoomManager.zoom = 0.5; + yield PanelUI.show(); + + let zoomResetButton = document.getElementById("zoom-reset-button"); + ok(zoomResetButton, "Zoom reset button exists in Panel Menu"); + + zoomResetButton.click(); + let pageZoomLevel = parseInt(ZoomManager.zoom * 100); + let expectedZoomLevel = parseInt(zoomResetButton.getAttribute("label"), 10); + ok(pageZoomLevel == expectedZoomLevel && pageZoomLevel == 100, "Page zoom reset correctly"); + + // close the panel + let panelHiddenPromise = promisePanelHidden(window); + PanelUI.hide(); + yield panelHiddenPromise; + + //reset the zoom level + ZoomManager.zoom = initialPageZoom; +});
--- a/browser/components/search/test/browser_bing.js +++ b/browser/components/search/test/browser_bing.js @@ -98,16 +98,21 @@ function test() { value: "MOZSPG", purpose: "homepage", }, { name: "form", value: "MOZLBR", purpose:"keyword", }, + { + name: "form", + value: "MOZTSB", + purpose: "newtab", + }, ], mozparams: {}, }, ], }, }; isSubObjectOf(EXPECTED_ENGINE, engine, "Bing");
--- a/browser/components/search/test/browser_bing_behavior.js +++ b/browser/components/search/test/browser_bing_behavior.js @@ -62,17 +62,17 @@ function test() { registerCleanupFunction(function () { sb.value = ""; }); EventUtils.synthesizeKey("VK_RETURN", {}); } }, { name: "new tab search", - searchURL: base, + searchURL: base + "&form=MOZTSB", run: function () { function doSearch(doc) { // Re-add the listener, and perform a search gBrowser.addProgressListener(listener); doc.getElementById("newtab-search-text").value = "foo"; doc.getElementById("newtab-search-submit").click(); }
--- a/browser/components/tabview/test/browser_tabview_bug606905.js +++ b/browser/components/tabview/test/browser_tabview_bug606905.js @@ -15,17 +15,17 @@ function test() { executeSoon(function() { is(gBrowser.tabContainer.getAttribute("closebuttons"), "activetab", "Only show button on selected tab."); // move a tab to another group and check the closebuttons attribute TabView._initFrame(function() { TabView.moveTabTo(newTabs[newTabs.length - 1], null); ok(gBrowser.visibleTabs[0].getBoundingClientRect().width > gBrowser.tabContainer.mTabClipWidth, "Tab width is bigger than tab clip width"); - is(gBrowser.tabContainer.getAttribute("closebuttons"), "alltabs", "Show button on all tabs.") + is(gBrowser.tabContainer.getAttribute("closebuttons"), "", "Show button on all tabs.") // clean up and finish newTabs.forEach(function(tab) { gBrowser.removeTab(tab); }); finish(); }); });
--- a/browser/locales/en-US/chrome/browser/browser.dtd +++ b/browser/locales/en-US/chrome/browser/browser.dtd @@ -442,17 +442,16 @@ These should match what Safari and other <!ENTITY bookmarkPageCmd2.label "Bookmark This Page"> <!ENTITY bookmarkPageCmd2.accesskey "m"> <!ENTITY bookmarkThisLinkCmd.label "Bookmark This Link"> <!ENTITY bookmarkThisLinkCmd.accesskey "L"> <!ENTITY bookmarkThisFrameCmd.label "Bookmark This Frame"> <!ENTITY bookmarkThisFrameCmd.accesskey "m"> <!ENTITY emailPageCmd.label "Email Link…"> <!ENTITY emailPageCmd.accesskey "E"> -<!ENTITY switchToMetroCmd.label "Relaunch in Windows 8 style &brandShortName;"> <!ENTITY savePageCmd.label "Save Page As…"> <!ENTITY savePageCmd.accesskey "A"> <!-- alternate for content area context menu --> <!ENTITY savePageCmd.accesskey2 "P"> <!ENTITY savePageCmd.commandkey "s"> <!ENTITY saveFrameCmd.label "Save Frame As…"> <!ENTITY saveFrameCmd.accesskey "F"> <!ENTITY printFrameCmd.label "Print Frame…"> @@ -734,52 +733,12 @@ just addresses the organization to follo <!ENTITY tabCrashed.header "Tab crashed"> <!ENTITY tabCrashed.message "Well, this is embarrassing. We tried to display this Web page, but it's not responding."> <!ENTITY tabCrashed.checkSendReport "Tell &vendorShortName; about this crash so they can fix it."> <!ENTITY tabCrashed.tryAgain "Try Again"> <!ENTITY uiTour.infoPanel.close "Close"> -<!-- LOCALIZATION NOTE: the following strings are unused in Australis, they're - kept here to avoid warnings from l10n tools like compare-locales on - l10n-central. They will be definitely removed when Australis is ready - for mozilla-aurora. --> +<!ENTITY appMenuSidebars.label "Sidebars"> -<!ENTITY navbarCmd.accesskey "N"> -<!ENTITY addonBarCmd.label "Add-on Bar"> -<!ENTITY addonBarCmd.accesskey "A"> -<!ENTITY throbberItem.title "Activity Indicator"> -<!ENTITY appMenuButton.label "Menu"> -<!ENTITY appMenuButton.tooltip "Open &brandShortName; menu"> -<!ENTITY feedButton.label "Subscribe"> -<!ENTITY feedButton.tooltip "Subscribe to this page…"> -<!ENTITY bookmarksButton.tooltip "Display your bookmarks"> -<!ENTITY historyButton.tooltip "Display pages you've viewed recently"> -<!ENTITY viewTabsOnTop.label "Tabs on Top"> -<!ENTITY viewTabsOnTop.accesskey "T"> -<!ENTITY appMenuEdit.label "Edit"> -<!ENTITY appMenuToolbarLayout.label "Toolbar Layout…"> -<!ENTITY appMenuSidebars.label "Sidebars"> -<!ENTITY appMenuFind.label "Find…"> -<!ENTITY appMenuUnsorted.label "Unsorted Bookmarks"> -<!ENTITY appMenuWebDeveloper.label "Web Developer"> -<!ENTITY appMenuGettingStarted.label "Getting Started"> -<!ENTITY appMenuSafeMode.label "Restart with Add-ons Disabled…"> -<!ENTITY appMenuSafeMode.accesskey "R"> -<!ENTITY cutButton.tooltip "Cut"> -<!ENTITY copyButton.tooltip "Copy"> -<!ENTITY pasteButton.tooltip "Paste"> -<!ENTITY zoomOutButton.tooltip "Zoom out"> -<!ENTITY zoomInButton.tooltip "Zoom in"> -<!ENTITY zoomControls.label "Zoom Controls"> -<!ENTITY addonBarCloseButton.tooltip "Close Add-on Bar"> -<!ENTITY toggleAddonBarCmd.key "/"> -<!ENTITY backForwardItem.title "Back/Forward"> -<!ENTITY viewBookmarksSidebar.label "Show in Sidebar"> -<!ENTITY bookmarksItem.title "Bookmarks"> -<!ENTITY openLocationCmd.label "Open Location…"> -<!ENTITY openLocationCmd.accesskey "L"> -<!ENTITY bookmarksMenuButton.tooltip "Display your bookmarks"> <!ENTITY switchToMetroCmd2.label "Relaunch in &brandShortName; for Windows 8 Touch"> -<!ENTITY tabGroupsButton.tooltip "Group your tabs"> -<!-- end of strings to be removed post-Australis -->
--- a/browser/locales/en-US/searchplugins/amazondotcom.xml +++ b/browser/locales/en-US/searchplugins/amazondotcom.xml @@ -2,16 +2,18 @@ - License, v. 2.0. If a copy of the MPL was not distributed with this - file, You can obtain one at http://mozilla.org/MPL/2.0/. --> <SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/"> <ShortName>Amazon.com</ShortName> <Description>Amazon.com Search</Description> <InputEncoding>ISO-8859-1</InputEncoding> <Image width="16" height="16"></Image> +<Image width="65" height="26"></Image> +<Image width="130" height="52"></Image> <Url type="text/html" method="GET" template="http://www.amazon.com/exec/obidos/external-search/"> <Param name="field-keywords" value="{searchTerms}"/> <Param name="mode" value="blended"/> <Param name="tag" value="mozilla-20"/> <Param name="sourceid" value="Mozilla-search"/> </Url> <SearchForm>http://www.amazon.com/</SearchForm> </SearchPlugin>
--- a/browser/locales/en-US/searchplugins/bing.xml +++ b/browser/locales/en-US/searchplugins/bing.xml @@ -2,23 +2,26 @@ - License, v. 2.0. If a copy of the MPL was not distributed with this - file, You can obtain one at http://mozilla.org/MPL/2.0/. --> <SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/"> <ShortName>Bing</ShortName> <Description>Bing. Search by Microsoft.</Description> <InputEncoding>UTF-8</InputEncoding> <Image width="16" height="16"></Image> + <Image width="65" height="26"></Image> + <Image width="130" height="52"></Image> <Url type="application/x-suggestions+json" template="http://api.bing.com/osjson.aspx"> <Param name="query" value="{searchTerms}"/> <Param name="form" value="OSDJAS"/> <Param name="language" value="{moz:locale}"/> </Url> <Url type="text/html" method="GET" template="http://www.bing.com/search"> <Param name="q" value="{searchTerms}"/> <MozParam name="pc" condition="pref" pref="ms-pc"/> <MozParam name="form" condition="purpose" purpose="contextmenu" value="MOZCON"/> <MozParam name="form" condition="purpose" purpose="searchbar" value="MOZSBR"/> <MozParam name="form" condition="purpose" purpose="homepage" value="MOZSPG"/> <MozParam name="form" condition="purpose" purpose="keyword" value="MOZLBR"/> + <MozParam name="form" condition="purpose" purpose="newtab" value="MOZTSB"/> </Url> <SearchForm>http://www.bing.com/search</SearchForm> </SearchPlugin>
--- a/browser/modules/BrowserUITelemetry.jsm +++ b/browser/modules/BrowserUITelemetry.jsm @@ -57,17 +57,16 @@ XPCOMUtils.defineLazyGetter(this, "DEFAU // in the document. "toolbar-menubar": [ "menubar-items", ], "TabsToolbar": [ "tabbrowser-tabs", "new-tab-button", "alltabs-button", - "tabs-closebutton", ], "PersonalToolbar": [ "personal-bookmarks", ], }; let showCharacterEncoding = Services.prefs.getComplexValue( "browser.menu.showCharacterEncoding",
--- a/browser/themes/linux/browser.css +++ b/browser/themes/linux/browser.css @@ -1767,71 +1767,37 @@ richlistitem[type~="action"][actiontype= /* Tab drag and drop */ .tab-drop-indicator { list-style-image: url(chrome://browser/skin/tabbrowser/tabDragIndicator.png); margin-bottom: -9px; z-index: 3; } -/* In-tab close button */ -.tab-close-button > .toolbarbutton-icon { - /* XXX Buttons have padding in widget/ that we don't want here but can't override with good CSS, so we must - use evil CSS to give the impression of smaller content */ - margin: -4px; -} - -/* Tabstrip close button */ -.tabs-closebutton, -.tab-close-button { - -moz-appearance: none; - height: 16px; - width: 16px; -} - -.tabs-closebutton:not([selected]):not(:hover), +/* Tab close button */ .tab-close-button:not([selected]):not(:hover) { background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 64, 16, 48); } -.tabs-closebutton:not([selected]):not(:hover):-moz-lwtheme-brighttext, .tab-close-button:not([selected]):not(:hover):-moz-lwtheme-brighttext { background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 80, 16, 64); } -.tabs-closebutton:not([selected]):not(:hover):-moz-lwtheme-darktext, .tab-close-button:not([selected]):not(:hover):-moz-lwtheme-darktext { background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 96, 16, 80); } /* Tabstrip new tab button */ .tabs-newtab-button, #TabsToolbar > #new-tab-button , #TabsToolbar > #wrapper-new-tab-button > #new-tab-button { list-style-image: url("moz-icon://stock/gtk-add?size=menu"); -moz-image-region: auto; } -.customization-tipPanel-closeBox > .close-icon { - -moz-appearance: none; - width: 16px; - height: 16px; -} - -/* The :hover:active style from toolkit doesn't seem to work in this panel so just use :active. */ -.customization-tipPanel-closeBox > .close-icon:active { - background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 48, 16, 32); -} - -.tabs-closebutton > .toolbarbutton-icon { - /* XXX Buttons have padding in widget/ that we don't want here but can't override with good CSS, so we must - use evil CSS to give the impression of smaller content */ - margin: -2px; -} - /* Tabbrowser arrowscrollbox arrows */ .tabbrowser-arrowscrollbox > .scrollbutton-up, .tabbrowser-arrowscrollbox > .scrollbutton-down { -moz-appearance: none; margin: 0 0 @tabToolbarNavbarOverlap@; } .tabbrowser-arrowscrollbox > .scrollbutton-up { @@ -1898,21 +1864,16 @@ richlistitem[type~="action"][actiontype= } .alltabs-item[tabIsVisible] { /* box-shadow instead of background-color to work around native styling */ box-shadow: inset -5px 0 ThreeDShadow; } /* Sidebar */ -#sidebar-header > .tabs-closebutton { - margin-bottom: 0px !important; - padding: 0px 2px 0px 2px !important; -} - #sidebar-throbber[loading="true"] { list-style-image: url("chrome://global/skin/icons/loading_16.png"); -moz-margin-end: 4px; } toolbarbutton.chevron { list-style-image: url("chrome://global/skin/toolbar/chevron.gif") !important; } @@ -2230,16 +2191,21 @@ chatbox { #main-window[customize-entered] #TabsToolbar { -moz-appearance: none; background-clip: padding-box; border-right: 3px solid transparent; border-left: 3px solid transparent; } +/* The :hover:active style from toolkit doesn't seem to work in this panel so just use :active. */ +.customization-tipPanel-closeBox > .close-icon:active { + background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 48, 16, 32); +} + /* End customization mode */ #main-window[privatebrowsingmode=temporary] #private-browsing-indicator { background: url("chrome://browser/skin/privatebrowsing-mask.png") center no-repeat; width: 40px; }
--- a/browser/themes/linux/devtools/netmonitor.css +++ b/browser/themes/linux/devtools/netmonitor.css @@ -4,17 +4,17 @@ %include ../../shared/devtools/netmonitor.inc.css #headers-summary-resend { padding: 4px; } .requests-menu-status-and-method { - width: 7em; + width: 9em; } .requests-menu-domain { width: 16vw; } .requests-menu-size { width: 6em;
--- a/browser/themes/linux/jar.mn +++ b/browser/themes/linux/jar.mn @@ -223,17 +223,16 @@ browser.jar: * skin/classic/browser/devtools/shadereditor.css (devtools/shadereditor.css) * skin/classic/browser/devtools/splitview.css (../shared/devtools/splitview.css) skin/classic/browser/devtools/styleeditor.css (../shared/devtools/styleeditor.css) * skin/classic/browser/devtools/webaudioeditor.css (devtools/webaudioeditor.css) skin/classic/browser/devtools/magnifying-glass.png (../shared/devtools/images/magnifying-glass.png) skin/classic/browser/devtools/magnifying-glass@2x.png (../shared/devtools/images/magnifying-glass@2x.png) skin/classic/browser/devtools/magnifying-glass-light.png (../shared/devtools/images/magnifying-glass-light.png) skin/classic/browser/devtools/magnifying-glass-light@2x.png (../shared/devtools/images/magnifying-glass-light@2x.png) - skin/classic/browser/devtools/option-icon.png (../shared/devtools/images/option-icon.png) skin/classic/browser/devtools/itemToggle.png (../shared/devtools/images/itemToggle.png) skin/classic/browser/devtools/itemToggle-light.png (../shared/devtools/images/itemToggle-light.png) skin/classic/browser/devtools/itemArrow-dark-rtl.png (../shared/devtools/images/itemArrow-dark-rtl.png) skin/classic/browser/devtools/itemArrow-dark-ltr.png (../shared/devtools/images/itemArrow-dark-ltr.png) skin/classic/browser/devtools/itemArrow-rtl.svg (../shared/devtools/images/itemArrow-rtl.svg) skin/classic/browser/devtools/itemArrow-ltr.svg (../shared/devtools/images/itemArrow-ltr.svg) skin/classic/browser/devtools/background-noise-toolbar.png (devtools/background-noise-toolbar.png) skin/classic/browser/devtools/noise.png (devtools/noise.png)
--- a/browser/themes/osx/browser.css +++ b/browser/themes/osx/browser.css @@ -2618,20 +2618,16 @@ sidebarheader { font-weight: bold; } .sidebar-throbber[loading="true"], #sidebar-throbber[loading="true"] { list-style-image: url("chrome://global/skin/icons/loading_16.png"); } -sidebarheader > .tabs-closebutton > .toolbarbutton-text { - display: none; -} - /* ----- CONTENT ----- */ .browserContainer > findbar { background: @scopeBarBackground@; border-top: @scopeBarSeparatorBorder@; color: -moz-DialogText; text-shadow: none; } @@ -3174,28 +3170,16 @@ toolbarbutton.chevron > .toolbarbutton-m list-style-image: url("chrome://global/skin/icons/loading_16.png") !important; } .alltabs-item[tabIsVisible] { /* box-shadow instead of background-color to work around native styling */ box-shadow: inset -5px 0 ThreeDShadow; } -/* Tabstrip close button */ -.tabs-closebutton { - -moz-padding-end: 4px; - border: none; -} - -@media (min-resolution: 2dppx) { - .tabs-closebutton > .toolbarbutton-icon { - width: 16px; - } -} - /* Bookmarks toolbar */ #PlacesToolbarDropIndicator { list-style-image: url(chrome://browser/skin/places/toolbarDropMarker.png); } /* Bookmark drag and drop styles */ .bookmark-item[dragover-into="true"] {
--- a/browser/themes/osx/jar.mn +++ b/browser/themes/osx/jar.mn @@ -344,17 +344,16 @@ browser.jar: * skin/classic/browser/devtools/shadereditor.css (devtools/shadereditor.css) * skin/classic/browser/devtools/splitview.css (../shared/devtools/splitview.css) skin/classic/browser/devtools/styleeditor.css (../shared/devtools/styleeditor.css) * skin/classic/browser/devtools/webaudioeditor.css (devtools/webaudioeditor.css) skin/classic/browser/devtools/magnifying-glass.png (../shared/devtools/images/magnifying-glass.png) skin/classic/browser/devtools/magnifying-glass@2x.png (../shared/devtools/images/magnifying-glass@2x.png) skin/classic/browser/devtools/magnifying-glass-light.png (../shared/devtools/images/magnifying-glass-light.png) skin/classic/browser/devtools/magnifying-glass-light@2x.png (../shared/devtools/images/magnifying-glass-light@2x.png) - skin/classic/browser/devtools/option-icon.png (../shared/devtools/images/option-icon.png) skin/classic/browser/devtools/itemToggle.png (../shared/devtools/images/itemToggle.png) skin/classic/browser/devtools/itemToggle-light.png (../shared/devtools/images/itemToggle-light.png) skin/classic/browser/devtools/itemArrow-dark-rtl.png (../shared/devtools/images/itemArrow-dark-rtl.png) skin/classic/browser/devtools/itemArrow-dark-ltr.png (../shared/devtools/images/itemArrow-dark-ltr.png) skin/classic/browser/devtools/itemArrow-rtl.svg (../shared/devtools/images/itemArrow-rtl.svg) skin/classic/browser/devtools/itemArrow-ltr.svg (../shared/devtools/images/itemArrow-ltr.svg) skin/classic/browser/devtools/background-noise-toolbar.png (devtools/background-noise-toolbar.png) skin/classic/browser/devtools/noise.png (devtools/noise.png)
--- a/browser/themes/shared/customizableui/panelUIOverlay.inc.css +++ b/browser/themes/shared/customizableui/panelUIOverlay.inc.css @@ -723,17 +723,17 @@ menuitem.subviewbutton@menuStateHover@, background-color: hsla(210,4%,10%,.08); border-color: hsla(210,4%,10%,.11); } .toolbaritem-combined-buttons@inAnyPanel@@buttonStateHover@ { border-color: hsla(210,4%,10%,.11); } -panelview .toolbarbutton-1@buttonStateActive@, +panelview .toolbarbutton-1:-moz-any(@buttonStateActive@,[checked=true]), toolbarbutton.subviewbutton@buttonStateActive@, menu.subviewbutton@menuStateActive@, menuitem.subviewbutton@menuStateActive@, .widget-overflow-list .toolbarbutton-1@buttonStateActive@, .toolbaritem-combined-buttons@inAnyPanel@ > toolbarbutton@buttonStateActive@ { background-color: hsla(210,4%,10%,.12); border-color: hsla(210,4%,10%,.14); box-shadow: 0 1px 0 hsla(210,4%,10%,.03) inset;
deleted file mode 100644 index afdc6a209726575db92b96eb5e0529f8b85c5b96..0000000000000000000000000000000000000000 GIT binary patch literal 0 Hc$@<O00001
--- a/browser/themes/shared/devtools/toolbars.inc.css +++ b/browser/themes/shared/devtools/toolbars.inc.css @@ -114,24 +114,24 @@ } .theme-dark .devtools-toolbarbutton[checked=true]:hover:active { background-color: hsla(210,8%,5%,.2) !important; } .devtools-option-toolbarbutton { -moz-appearance: none; - list-style-image: url("chrome://browser/skin/devtools/option-icon.png"); - -moz-image-region: rect(0px 16px 16px 0px); + list-style-image: url("chrome://browser/skin/devtools/tool-options.svg"); background: none; + opacity: .8; border: none; } .devtools-option-toolbarbutton[open=true] { - -moz-image-region: rect(0px 32px 16px 16px); + opacity: 1; } .devtools-menulist > .menulist-label-box { text-align: center; } .devtools-menulist > .menulist-dropmarker { -moz-appearance: none; @@ -787,17 +787,16 @@ filter: url(filters.svg#invert); } /* Since selected backgrounds are blue, we want to use the normal * (light) icons. */ .theme-light .command-button-invertable[checked=true]:not(:active) > image, .theme-light .devtools-tab[icon-invertable][selected] > image, .theme-light .devtools-tab[icon-invertable][highlighted] > image, -.theme-light .devtools-option-toolbarbutton[open] > image, .theme-light #resume[checked] > image { filter: none !important; } .theme-light .command-button:hover { background-color: inherit; }
--- a/browser/themes/windows/browser.css +++ b/browser/themes/windows/browser.css @@ -1761,16 +1761,23 @@ toolbarbutton[type="socialmark"] > .tool #sidebar { background-color: Window; } #sidebar-title { -moz-padding-start: 0px; } +#sidebar-header > .close-icon { + -moz-appearance: none; + padding: 4px 2px; + margin: 0; + border: none; +} + .browserContainer > findbar { background-color: -moz-dialog; color: -moz-DialogText; text-shadow: none; } /* Tabstrip */ @@ -1992,30 +1999,16 @@ toolbarbutton[type="socialmark"] > .tool list-style-image: url("chrome://global/skin/icons/loading_16.png"); } .alltabs-item[tabIsVisible] { /* box-shadow instead of background-color to work around native styling */ box-shadow: inset -5px 0 ThreeDShadow; } -/* Tabstrip close button */ -.tabs-closebutton { - -moz-appearance: none; - padding: 4px 2px; - margin: 0px; - border: none; -} - -.tabs-closebutton > .toolbarbutton-icon { - -moz-margin-end: 0px !important; - -moz-padding-end: 2px !important; - -moz-padding-start: 2px !important; -} - toolbarbutton.chevron { list-style-image: url("chrome://global/skin/toolbar/chevron.gif") !important; } toolbarbutton.chevron:-moz-locale-dir(rtl) > .toolbarbutton-icon { transform: scaleX(-1); }
--- a/browser/themes/windows/jar.mn +++ b/browser/themes/windows/jar.mn @@ -260,17 +260,16 @@ browser.jar: * skin/classic/browser/devtools/shadereditor.css (devtools/shadereditor.css) * skin/classic/browser/devtools/splitview.css (../shared/devtools/splitview.css) skin/classic/browser/devtools/styleeditor.css (../shared/devtools/styleeditor.css) * skin/classic/browser/devtools/webaudioeditor.css (devtools/webaudioeditor.css) skin/classic/browser/devtools/magnifying-glass.png (../shared/devtools/images/magnifying-glass.png) skin/classic/browser/devtools/magnifying-glass@2x.png (../shared/devtools/images/magnifying-glass@2x.png) skin/classic/browser/devtools/magnifying-glass-light.png (../shared/devtools/images/magnifying-glass-light.png) skin/classic/browser/devtools/magnifying-glass-light@2x.png (../shared/devtools/images/magnifying-glass-light@2x.png) - skin/classic/browser/devtools/option-icon.png (../shared/devtools/images/option-icon.png) skin/classic/browser/devtools/itemToggle.png (../shared/devtools/images/itemToggle.png) skin/classic/browser/devtools/itemToggle-light.png (../shared/devtools/images/itemToggle-light.png) skin/classic/browser/devtools/itemArrow-dark-rtl.png (../shared/devtools/images/itemArrow-dark-rtl.png) skin/classic/browser/devtools/itemArrow-dark-ltr.png (../shared/devtools/images/itemArrow-dark-ltr.png) skin/classic/browser/devtools/itemArrow-rtl.svg (../shared/devtools/images/itemArrow-rtl.svg) skin/classic/browser/devtools/itemArrow-ltr.svg (../shared/devtools/images/itemArrow-ltr.svg) skin/classic/browser/devtools/background-noise-toolbar.png (devtools/background-noise-toolbar.png) skin/classic/browser/devtools/noise.png (devtools/noise.png) @@ -623,17 +622,16 @@ browser.jar: * skin/classic/aero/browser/devtools/scratchpad.css (devtools/scratchpad.css) * skin/classic/aero/browser/devtools/shadereditor.css (devtools/shadereditor.css) * skin/classic/aero/browser/devtools/splitview.css (../shared/devtools/splitview.css) skin/classic/aero/browser/devtools/styleeditor.css (../shared/devtools/styleeditor.css) skin/classic/aero/browser/devtools/magnifying-glass.png (../shared/devtools/images/magnifying-glass.png) skin/classic/aero/browser/devtools/magnifying-glass@2x.png (../shared/devtools/images/magnifying-glass@2x.png) skin/classic/aero/browser/devtools/magnifying-glass-light.png (../shared/devtools/images/magnifying-glass-light.png) skin/classic/aero/browser/devtools/magnifying-glass-light@2x.png (../shared/devtools/images/magnifying-glass-light@2x.png) - skin/classic/aero/browser/devtools/option-icon.png (../shared/devtools/images/option-icon.png) skin/classic/aero/browser/devtools/itemToggle.png (../shared/devtools/images/itemToggle.png) skin/classic/aero/browser/devtools/itemToggle-light.png (../shared/devtools/images/itemToggle-light.png) skin/classic/aero/browser/devtools/itemArrow-dark-rtl.png (../shared/devtools/images/itemArrow-dark-rtl.png) skin/classic/aero/browser/devtools/itemArrow-dark-ltr.png (../shared/devtools/images/itemArrow-dark-ltr.png) skin/classic/aero/browser/devtools/itemArrow-rtl.svg (../shared/devtools/images/itemArrow-rtl.svg) skin/classic/aero/browser/devtools/itemArrow-ltr.svg (../shared/devtools/images/itemArrow-ltr.svg) skin/classic/aero/browser/devtools/background-noise-toolbar.png (devtools/background-noise-toolbar.png) skin/classic/aero/browser/devtools/noise.png (devtools/noise.png)
--- a/mobile/android/base/TabsAccessor.java +++ b/mobile/android/base/TabsAccessor.java @@ -16,17 +16,16 @@ import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.net.Uri; import android.util.Log; import java.util.ArrayList; import java.util.Collections; import java.util.List; -import java.util.regex.Pattern; public final class TabsAccessor { private static final String LOGTAG = "GeckoTabsAccessor"; private static final String[] CLIENTS_AVAILABILITY_PROJECTION = new String[] { BrowserContract.Clients.GUID }; @@ -45,17 +44,16 @@ public final class TabsAccessor { NAME }; private static final String CLIENTS_SELECTION = BrowserContract.Clients.GUID + " IS NOT NULL"; private static final String TABS_SELECTION = BrowserContract.Tabs.CLIENT_GUID + " IS NOT NULL"; private static final String LOCAL_CLIENT_SELECTION = BrowserContract.Clients.GUID + " IS NULL"; private static final String LOCAL_TABS_SELECTION = BrowserContract.Tabs.CLIENT_GUID + " IS NULL"; - private static final Pattern FILTERED_URL_PATTERN = Pattern.compile("^(about|chrome|wyciwyg|file):.*$"); public static class RemoteTab { public String title; public String url; public String guid; public String name; } @@ -146,19 +144,19 @@ public final class TabsAccessor { */ private static void insertLocalTabs(final ContentResolver cr, final Iterable<Tab> tabs) { // Reuse this for serializing individual history URLs as JSON. JSONArray history = new JSONArray(); ArrayList<ContentValues> valuesToInsert = new ArrayList<ContentValues>(); int position = 0; for (Tab tab : tabs) { - // Skip this tab if it has a null URL or is in private browsing mode, or is a filtered URL. + // Skip this tab if it has a null URL or is in private browsing mode String url = tab.getURL(); - if (url == null || tab.isPrivate() || isFilteredURL(url)) + if (url == null || tab.isPrivate()) continue; ContentValues values = new ContentValues(); values.put(BrowserContract.Tabs.URL, url); values.put(BrowserContract.Tabs.TITLE, tab.getTitle()); values.put(BrowserContract.Tabs.LAST_USED, tab.getLastUsed()); String favicon = tab.getFaviconURL(); @@ -189,18 +187,9 @@ public final class TabsAccessor { } // Deletes all local tabs and replaces them with a new list of tabs. public static synchronized void persistLocalTabs(final ContentResolver cr, final Iterable<Tab> tabs) { deleteLocalTabs(cr); insertLocalTabs(cr, tabs); updateLocalClient(cr); } - - /** - * Matches the supplied URL string against the set of URLs to filter. - * - * @return true if the supplied URL should be skipped; false otherwise. - */ - private static boolean isFilteredURL(String url) { - return FILTERED_URL_PATTERN.matcher(url).matches(); - } }
--- a/mobile/android/base/db/BrowserContract.java +++ b/mobile/android/base/db/BrowserContract.java @@ -342,16 +342,19 @@ public class BrowserContract { public static final String DATASET_ID = "dataset_id"; public static final String URL = "url"; public static final String TITLE = "title"; public static final String DESCRIPTION = "description"; public static final String IMAGE_URL = "image_url"; public static final String CREATED = "created"; public static final String FILTER = "filter"; + + public static final String[] DEFAULT_PROJECTION = + new String[] { _ID, DATASET_ID, URL, TITLE, DESCRIPTION, IMAGE_URL, FILTER }; } /* * Contains names and schema definitions for tables and views * no longer being used by current ContentProviders. These values are used * to make incremental updates to the schema during a database upgrade. Will be * removed with bug 947018. */
--- a/mobile/android/base/db/HomeProvider.java +++ b/mobile/android/base/db/HomeProvider.java @@ -80,22 +80,27 @@ public class HomeProvider extends SQLite throw new IllegalArgumentException("All queries should contain a dataset ID parameter"); } selection = DBUtils.concatenateWhere(selection, HomeItems.DATASET_ID + " = ?"); selectionArgs = DBUtils.appendSelectionArgs(selectionArgs, new String[] { datasetId }); // Otherwise, let the SQLiteContentProvider implementation take care of this query for us! - final Cursor c = super.query(uri, projection, selection, selectionArgs, sortOrder); - if (c != null) { - final ContentResolver cr = getContext().getContentResolver(); - c.setNotificationUri(cr, getDatasetNotificationUri(datasetId)); + Cursor c = super.query(uri, projection, selection, selectionArgs, sortOrder); + + // SQLiteBridgeContentProvider may return a null Cursor if the database hasn't been created yet. + // However, we need a non-null cursor in order to listen for notifications. + if (c == null) { + c = new MatrixCursor(projection != null ? projection : HomeItems.DEFAULT_PROJECTION); } + final ContentResolver cr = getContext().getContentResolver(); + c.setNotificationUri(cr, getDatasetNotificationUri(datasetId)); + return c; } /** * Returns a cursor populated with static fake data. */ private Cursor queryFakeItems(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { JSONArray items = null; @@ -105,27 +110,17 @@ public class HomeProvider extends SQLite } catch (IOException e) { Log.e(LOGTAG, "Error getting fake home items", e); return null; } catch (JSONException e) { Log.e(LOGTAG, "Error parsing fake_home_items.json", e); return null; } - final String[] itemsColumns = new String[] { - HomeItems._ID, - HomeItems.DATASET_ID, - HomeItems.URL, - HomeItems.TITLE, - HomeItems.DESCRIPTION, - HomeItems.IMAGE_URL, - HomeItems.FILTER - }; - - final MatrixCursor c = new MatrixCursor(itemsColumns); + final MatrixCursor c = new MatrixCursor(HomeItems.DEFAULT_PROJECTION); for (int i = 0; i < items.length(); i++) { try { final JSONObject item = items.getJSONObject(i); c.addRow(new Object[] { item.getInt("id"), item.getString("dataset_id"), item.getString("url"), item.getString("title"),
--- a/mobile/android/base/home/PanelGridView.java +++ b/mobile/android/base/home/PanelGridView.java @@ -14,54 +14,64 @@ import org.mozilla.gecko.home.HomeConfig import org.mozilla.gecko.home.HomePager.OnUrlOpenListener; import org.mozilla.gecko.home.PanelLayout.DatasetBacked; import org.mozilla.gecko.home.PanelLayout.FilterManager; import org.mozilla.gecko.home.PanelLayout.OnItemOpenListener; import org.mozilla.gecko.home.PanelLayout.PanelView; import android.content.Context; import android.database.Cursor; +import android.util.Log; import android.view.View; import android.widget.AdapterView; import android.widget.GridView; public class PanelGridView extends GridView implements DatasetBacked, PanelView { private static final String LOGTAG = "GeckoPanelGridView"; private final ViewConfig viewConfig; private final PanelViewAdapter adapter; private PanelViewItemHandler itemHandler; + private OnItemOpenListener itemOpenListener; public PanelGridView(Context context, ViewConfig viewConfig) { super(context, null, R.attr.panelGridViewStyle); this.viewConfig = viewConfig; itemHandler = new PanelViewItemHandler(viewConfig); adapter = new PanelViewAdapter(context, viewConfig); setAdapter(adapter); setOnItemClickListener(new PanelGridItemClickListener()); } @Override + public void onAttachedToWindow() { + super.onAttachedToWindow(); + itemHandler.setOnItemOpenListener(itemOpenListener); + } + + @Override public void onDetachedFromWindow() { super.onDetachedFromWindow(); itemHandler.setOnItemOpenListener(null); } @Override public void setDataset(Cursor cursor) { + Log.d(LOGTAG, "Setting dataset: " + viewConfig.getDatasetId()); adapter.swapCursor(cursor); } @Override public void setOnItemOpenListener(OnItemOpenListener listener) { itemHandler.setOnItemOpenListener(listener); + itemOpenListener = listener; } @Override public void setFilterManager(FilterManager filterManager) { adapter.setFilterManager(filterManager); itemHandler.setFilterManager(filterManager); }
--- a/mobile/android/base/home/PanelListView.java +++ b/mobile/android/base/home/PanelListView.java @@ -22,54 +22,62 @@ import android.util.Log; import android.view.View; import android.widget.AdapterView; public class PanelListView extends HomeListView implements DatasetBacked, PanelView { private static final String LOGTAG = "GeckoPanelListView"; - private final PanelViewAdapter mAdapter; - private final ViewConfig mViewConfig; - private final PanelViewItemHandler mItemHandler; + private final ViewConfig viewConfig; + private final PanelViewAdapter adapter; + private final PanelViewItemHandler itemHandler; + private OnItemOpenListener itemOpenListener; public PanelListView(Context context, ViewConfig viewConfig) { super(context); - mViewConfig = viewConfig; - mItemHandler = new PanelViewItemHandler(viewConfig); + this.viewConfig = viewConfig; + itemHandler = new PanelViewItemHandler(viewConfig); - mAdapter = new PanelViewAdapter(context, viewConfig); - setAdapter(mAdapter); + adapter = new PanelViewAdapter(context, viewConfig); + setAdapter(adapter); setOnItemClickListener(new PanelListItemClickListener()); } + @Override + public void onAttachedToWindow() { + super.onAttachedToWindow(); + itemHandler.setOnItemOpenListener(itemOpenListener); + } + @Override public void onDetachedFromWindow() { super.onDetachedFromWindow(); - mItemHandler.setOnItemOpenListener(null); + itemHandler.setOnItemOpenListener(null); } @Override public void setDataset(Cursor cursor) { - Log.d(LOGTAG, "Setting dataset: " + mViewConfig.getDatasetId()); - mAdapter.swapCursor(cursor); + Log.d(LOGTAG, "Setting dataset: " + viewConfig.getDatasetId()); + adapter.swapCursor(cursor); } @Override public void setOnItemOpenListener(OnItemOpenListener listener) { - mItemHandler.setOnItemOpenListener(listener); + itemHandler.setOnItemOpenListener(listener); + itemOpenListener = listener; } @Override public void setFilterManager(FilterManager filterManager) { - mAdapter.setFilterManager(filterManager); - mItemHandler.setFilterManager(filterManager); + adapter.setFilterManager(filterManager); + itemHandler.setFilterManager(filterManager); } private class PanelListItemClickListener implements AdapterView.OnItemClickListener { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { - mItemHandler.openItemAtPosition(mAdapter.getCursor(), position); + itemHandler.openItemAtPosition(adapter.getCursor(), position); } } }
--- a/mobile/android/base/tests/robocop.ini +++ b/mobile/android/base/tests/robocop.ini @@ -27,17 +27,16 @@ skip-if = android_version == "10" # disabled on 2.3; bug 979603 skip-if = android_version == "10" [testBrowserSearchVisibility] [testClearPrivateData] # disabled on x86 and 2.3; bug 948591 skip-if = android_version == "10" || processor == "x86" [testDistribution] [testDoorHanger] -[testFilterOpenTab] # disabled on 2.3; bug 986172 skip-if = android_version == "10" [testFindInPage] # disabled on Android 2.3; bug 975155 skip-if = android_version == "10" [testFlingCorrectness] # disabled on x86 only; bug 927476 skip-if = processor == "x86"
deleted file mode 100644 --- a/mobile/android/base/tests/testFilterOpenTab.java +++ /dev/null @@ -1,125 +0,0 @@ -package org.mozilla.gecko.tests; - -import java.util.ArrayList; -import java.util.List; -import java.util.concurrent.Callable; - -import org.mozilla.gecko.PrivateTab; -import org.mozilla.gecko.Tab; -import org.mozilla.gecko.TabsAccessor; -import org.mozilla.gecko.db.BrowserContract; -import org.mozilla.gecko.db.TabsProvider; - -import android.content.ContentProvider; -import android.content.Context; -import android.database.Cursor; - -/** - * Tests that local tabs are filtered prior to upload. - * - create a set of tabs and perists them through TabsAccessor. - * - verifies that tabs are filtered by querying. - */ -public class testFilterOpenTab extends ContentProviderTest { - private static final String[] TABS_PROJECTION_COLUMNS = new String[] { - BrowserContract.Tabs.TITLE, - BrowserContract.Tabs.URL, - BrowserContract.Clients.GUID, - BrowserContract.Clients.NAME - }; - - private static final String LOCAL_TABS_SELECTION = BrowserContract.Tabs.CLIENT_GUID + " IS NULL"; - - /** - * Factory function that makes new ContentProvider instances. - * <p> - * We want a fresh provider each test, so this should be invoked in - * <code>setUp</code> before each individual test. - */ - protected static Callable<ContentProvider> sTabProviderCallable = new Callable<ContentProvider>() { - @Override - public ContentProvider call() { - return new TabsProvider(); - } - }; - - private Cursor getTabsFromLocalClient() throws Exception { - return mProvider.query(BrowserContract.Tabs.CONTENT_URI, - TABS_PROJECTION_COLUMNS, - LOCAL_TABS_SELECTION, - null, - null); - } - - private Tab createTab(int id, String url, boolean external, int parentId, String title) { - return new Tab((Context) getActivity(), id, url, external, parentId, title); - } - - private Tab createPrivateTab(int id, String url, boolean external, int parentId, String title) { - return new PrivateTab((Context) getActivity(), id, url, external, parentId, title); - } - - @Override - public void setUp() throws Exception { - super.setUp(sTabProviderCallable, BrowserContract.TABS_AUTHORITY, "tabs.db"); - mTests.add(new TestInsertLocalTabs()); - } - - public void testFilterOpenTab() throws Exception { - for (int i = 0; i < mTests.size(); i++) { - Runnable test = mTests.get(i); - - setTestName(test.getClass().getSimpleName()); - test.run(); - } - } - - private class TestInsertLocalTabs extends TestCase { - @Override - public void test() throws Exception { - final String TITLE1 = "Google"; - final String URL1 = "http://www.google.com/"; - final String TITLE2 = "Mozilla Start Page"; - final String URL2 = "about:home"; - final String TITLE3 = "Chrome Weave URL"; - final String URL3 = "chrome://weave/"; - final String TITLE4 = "What You Cache Is What You Get"; - final String URL4 = "wyciwyg://1/test.com"; - final String TITLE5 = "Root Folder"; - final String URL5 = "file:///"; - - // Create a list of local tabs. - List<Tab> tabs = new ArrayList<Tab>(6); - Tab tab1 = createTab(1, URL1, false, 0, TITLE1); - Tab tab2 = createTab(2, URL2, false, 0, TITLE2); - Tab tab3 = createTab(3, URL3, false, 0, TITLE3); - Tab tab4 = createTab(4, URL4, false, 0, TITLE4); - Tab tab5 = createTab(5, URL5, false, 0, TITLE5); - Tab tab6 = createPrivateTab(6, URL1, false, 0, TITLE1); - tabs.add(tab1); - tabs.add(tab2); - tabs.add(tab3); - tabs.add(tab4); - tabs.add(tab5); - tabs.add(tab6); - - // Persist the created tabs. - TabsAccessor.persistLocalTabs(mResolver, tabs); - - // Get the persisted tab and check if urls are filtered. - Cursor c = getTabsFromLocalClient(); - assertCountIsAndClose(c, 1, 1 + " tabs entries found"); - } - } - - /** - * Assert that the provided cursor has the expected number of rows, - * closing the cursor afterwards. - */ - private void assertCountIsAndClose(Cursor c, int expectedCount, String message) { - try { - mAsserter.is(c.getCount(), expectedCount, message); - } finally { - c.close(); - } - } -}
--- a/toolkit/themes/linux/global/global.css +++ b/toolkit/themes/linux/global/global.css @@ -305,16 +305,19 @@ notification > button { .autoscroller[scrolldir="EW"] { background-position: right bottom; } /* :::::: Close button icons ::::: */ .close-icon { + -moz-appearance: none; + height: 16px; + width: 16px; background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 16, 16, 0); background-position: center center; background-repeat: no-repeat; } .close-icon:hover { background-image: -moz-image-rect(url("chrome://global/skin/icons/close.svg"), 0, 32, 16, 16); }
--- a/toolkit/themes/linux/global/notification.css +++ b/toolkit/themes/linux/global/notification.css @@ -47,19 +47,16 @@ notification[type="critical"] { list-style-image: url("moz-icon://stock/gtk-dialog-warning?size=menu"); } .messageImage[type="critical"] { list-style-image: url("moz-icon://stock/gtk-dialog-error?size=menu"); } .messageCloseButton { - -moz-appearance: none; - width: 16px; - height: 16px; padding-left: 11px; padding-right: 11px; } /* Popup notification */ .popup-notification-description { max-width: 24em;
--- a/uriloader/exthandler/android/nsMIMEInfoAndroid.cpp +++ b/uriloader/exthandler/android/nsMIMEInfoAndroid.cpp @@ -12,35 +12,41 @@ using namespace mozilla::widget::android; NS_IMPL_ISUPPORTS2(nsMIMEInfoAndroid, nsIMIMEInfo, nsIHandlerInfo) NS_IMETHODIMP nsMIMEInfoAndroid::LaunchDefaultWithFile(nsIFile* aFile) { - LaunchWithFile(aFile); - return NS_OK; + return LaunchWithFile(aFile); } NS_IMETHODIMP nsMIMEInfoAndroid::LoadUriInternal(nsIURI * aURI) { nsCString uriSpec; aURI->GetSpec(uriSpec); nsCString uriScheme; aURI->GetScheme(uriScheme); - return mozilla::widget::android::GeckoAppShell::OpenUriExternal(NS_ConvertUTF8toUTF16(uriSpec), - (mType.Equals(uriScheme) || mType.Equals(uriSpec)) ? - EmptyString() : NS_ConvertUTF8toUTF16(mType)) ? NS_OK : NS_ERROR_FAILURE; + nsAutoString mimeType; + if (mType.Equals(uriScheme) || mType.Equals(uriSpec)) { + mimeType = EmptyString(); + } else { + mimeType = NS_ConvertUTF8toUTF16(mType); + } + + if (GeckoAppShell::OpenUriExternal(NS_ConvertUTF8toUTF16(uriSpec), mimeType)) { + return NS_OK; + } + return NS_ERROR_FAILURE; } - bool nsMIMEInfoAndroid::GetMimeInfoForMimeType(const nsACString& aMimeType, nsMIMEInfoAndroid** aMimeInfo) { nsRefPtr<nsMIMEInfoAndroid> info = new nsMIMEInfoAndroid(aMimeType); mozilla::AndroidBridge* bridge = mozilla::AndroidBridge::Bridge(); // we don't have access to the bridge, so just assume we can handle // the mime type for now and let the system deal with it @@ -53,44 +59,44 @@ nsMIMEInfoAndroid::GetMimeInfoForMimeTyp if (!IsUTF8(aMimeType, true)) return false; NS_ConvertUTF8toUTF16 mimeType(aMimeType); bridge->GetHandlersForMimeType(mimeType, info->mHandlerApps, &systemDefault); - + if (systemDefault) info->mPrefApp = systemDefault; nsAutoCString fileExt; bridge->GetExtensionFromMimeType(aMimeType, fileExt); info->SetPrimaryExtension(fileExt); - + uint32_t len; info->mHandlerApps->GetLength(&len); if (len == 1) { info.forget(aMimeInfo); return false; } - + info.forget(aMimeInfo); return true; } - + bool nsMIMEInfoAndroid::GetMimeInfoForFileExt(const nsACString& aFileExt, nsMIMEInfoAndroid **aMimeInfo) { nsCString mimeType; if (mozilla::AndroidBridge::Bridge()) mozilla::AndroidBridge::Bridge()-> GetMimeTypeFromExtensions(aFileExt, mimeType); - + // "*/*" means that the bridge didn't know. if (mimeType.Equals(nsDependentCString("*/*"), nsCaseInsensitiveCStringComparator())) return false; bool found = GetMimeInfoForMimeType(mimeType, aMimeInfo); (*aMimeInfo)->SetPrimaryExtension(aFileExt); return found; } @@ -101,47 +107,47 @@ nsMIMEInfoAndroid::GetMimeInfoForFileExt nsresult nsMIMEInfoAndroid::GetMimeInfoForURL(const nsACString &aURL, bool *found, nsIHandlerInfo **info) { nsMIMEInfoAndroid *mimeinfo = new nsMIMEInfoAndroid(aURL); NS_ADDREF(*info = mimeinfo); *found = true; - + mozilla::AndroidBridge* bridge = mozilla::AndroidBridge::Bridge(); if (!bridge) { // we don't have access to the bridge, so just assume we can handle // the protocol for now and let the system deal with it return NS_OK; } nsIHandlerApp* systemDefault = nullptr; bridge->GetHandlersForURL(NS_ConvertUTF8toUTF16(aURL), mimeinfo->mHandlerApps, &systemDefault); - + if (systemDefault) mimeinfo->mPrefApp = systemDefault; nsAutoCString fileExt; nsAutoCString mimeType; mimeinfo->GetType(mimeType); bridge->GetExtensionFromMimeType(mimeType, fileExt); mimeinfo->SetPrimaryExtension(fileExt); - + uint32_t len; mimeinfo->mHandlerApps->GetLength(&len); if (len == 1) { // Code that calls this requires an object regardless if the OS has // something for us, so we return the empty object. *found = false; return NS_OK; } - + return NS_OK; } NS_IMETHODIMP nsMIMEInfoAndroid::GetType(nsACString& aType) { aType.Assign(mType); return NS_OK; @@ -354,18 +360,17 @@ nsMIMEInfoAndroid::GetPossibleLocalHandl return NS_ERROR_NOT_IMPLEMENTED; } NS_IMETHODIMP nsMIMEInfoAndroid::LaunchWithFile(nsIFile *aFile) { nsCOMPtr<nsIURI> uri; NS_NewFileURI(getter_AddRefs(uri), aFile); - LoadUriInternal(uri); - return NS_OK; + return LoadUriInternal(uri); } nsMIMEInfoAndroid::nsMIMEInfoAndroid(const nsACString& aMIMEType) : mType(aMIMEType), mAlwaysAsk(true), mPrefAction(nsIMIMEInfo::useHelperApp) { mPrefApp = new nsMIMEInfoAndroid::SystemChooser(this); nsresult rv;