--- a/toolkit/mozapps/extensions/content/extensions.js
+++ b/toolkit/mozapps/extensions/content/extensions.js
@@ -73,16 +73,37 @@ XPCOMUtils.defineLazyGetter(gStrings, "d
XPCOMUtils.defineLazyGetter(gStrings, "brandShortName", function() {
return this.brand.GetStringFromName("brandShortName");
});
XPCOMUtils.defineLazyGetter(gStrings, "appVersion", function() {
return Services.appinfo.version;
});
+var global = {};
+XPCOMUtils.defineLazyGetter(global, "stylesheets", () => {
+ let styleSheetService = Cc["@mozilla.org/content/style-sheet-service;1"]
+ .getService(Components.interfaces.nsIStyleSheetService);
+ let styleSheetURI = Services.io.newURI("chrome://mozapps/skin/extensions/browser-style.css",
+ null, null);
+ let styleSheet = styleSheetService.preloadSheet(styleSheetURI,
+ styleSheetService.AGENT_SHEET);
+ let stylesheets = [styleSheet];
+
+ if (AppConstants.platform === "macosx") {
+ styleSheetURI = Services.io.newURI("chrome://mozapps/skin/extensions/browser-style-mac.css",
+ null, null);
+ let macStyleSheet = styleSheetService.preloadSheet(styleSheetURI,
+ styleSheetService.AGENT_SHEET);
+ stylesheets.push(macStyleSheet);
+ }
+ return stylesheets;
+});
+
+
document.addEventListener("load", initialize, true);
window.addEventListener("unload", shutdown, false);
var gPendingInitializations = 1;
Object.defineProperty(this, "gIsInitializing", {
get: () => gPendingInitializations > 0
});
@@ -3366,16 +3387,23 @@ var gDetailView = {
var rows = document.getElementById("detail-downloads").parentNode;
try {
if (this._addon.optionsType == AddonManager.OPTIONS_TYPE_INLINE_BROWSER) {
whenViewLoaded(() => {
this.createOptionsBrowser(rows).then(browser => {
// Make sure the browser is unloaded as soon as we change views,
// rather than waiting for the next detail view to load.
+ if (this._addon.optionsBrowserStyle) {
+ let winUtils = browser.contentWindow
+ .QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils);
+ for (let stylesheet of global.stylesheets) {
+ winUtils.addSheet(stylesheet, winUtils.AGENT_SHEET);
+ }
+ }
document.addEventListener("ViewChanged", function viewChangedEventListener() {
document.removeEventListener("ViewChanged", viewChangedEventListener);
browser.remove();
});
finish(browser);
});
});
--- a/toolkit/mozapps/extensions/internal/XPIProvider.jsm
+++ b/toolkit/mozapps/extensions/internal/XPIProvider.jsm
@@ -899,24 +899,31 @@ var loadManifestFromWebManifest = Task.a
addon.bootstrap = true;
addon.hasBinaryComponents = false;
addon.multiprocessCompatible = true;
addon.internalName = null;
addon.updateURL = bss.update_url;
addon.updateKey = null;
addon.optionsURL = null;
addon.optionsType = null;
+ addon.optionsBrowserStyle = true;
addon.aboutURL = null;
if (manifest.options_ui) {
addon.optionsURL = extension.getURL(manifest.options_ui.page);
if (manifest.options_ui.open_in_tab)
addon.optionsType = AddonManager.OPTIONS_TYPE_TAB;
else
addon.optionsType = AddonManager.OPTIONS_TYPE_INLINE_BROWSER;
+
+ if (manifest.options_ui.browser_style === null)
+ logger.warn("Please specify whether you want browser_style " +
+ "or not in your options_ui options.");
+ else
+ addon.optionsBrowserStyle = manifest.options_ui.browser_style;
}
// WebExtensions don't use iconURLs
addon.iconURL = null;
addon.icon64URL = null;
addon.icons = manifest.icons || {};
addon.applyBackgroundUpdates = AddonManager.AUTOUPDATE_DEFAULT;
@@ -1115,20 +1122,21 @@ function loadManifestFromRDF(aUri, aStre
}
}
else {
// Some add-on types are always restartless.
if (RESTARTLESS_TYPES.has(addon.type)) {
addon.bootstrap = true;
}
- // Only extensions are allowed to provide an optionsURL, optionsType or aboutURL. For
- // all other types they are silently ignored
+ // Only extensions are allowed to provide an optionsURL, optionsType,
+ // optionsBrowserStyle, or aboutURL. For all other types they are silently ignored
addon.optionsURL = null;
addon.optionsType = null;
+ addon.optionsBrowserStyle = null;
addon.aboutURL = null;
if (addon.type == "theme") {
if (!addon.internalName)
throw new Error("Themes must include an internalName property");
addon.skinnable = getRDFProperty(ds, root, "skinnable") == "true";
}
}
@@ -7015,16 +7023,22 @@ AddonWrapper.prototype = {
return AddonManager.OPTIONS_TYPE_INLINE;
if (hasOptionsURL)
return AddonManager.OPTIONS_TYPE_DIALOG;
return null;
},
+ get optionsBrowserStyle() {
+ let addon = addonFor(this);
+ return addon.optionsBrowserStyle;
+ },
+
+
get iconURL() {
return AddonManager.getPreferredIconURL(this, 48);
},
get icon64URL() {
return AddonManager.getPreferredIconURL(this, 64);
},
--- a/toolkit/mozapps/extensions/internal/XPIProviderUtils.js
+++ b/toolkit/mozapps/extensions/internal/XPIProviderUtils.js
@@ -73,25 +73,25 @@ const DB_METADATA = ["syncGUID",
const DB_BOOL_METADATA = ["visible", "active", "userDisabled", "appDisabled",
"pendingUninstall", "bootstrap", "skinnable",
"softDisabled", "isForeignInstall",
"hasBinaryComponents", "strictCompatibility"];
// Properties to save in JSON file
const PROP_JSON_FIELDS = ["id", "syncGUID", "location", "version", "type",
"internalName", "updateURL", "updateKey", "optionsURL",
- "optionsType", "aboutURL", "icons", "iconURL", "icon64URL",
- "defaultLocale", "visible", "active", "userDisabled",
- "appDisabled", "pendingUninstall", "descriptor", "installDate",
- "updateDate", "applyBackgroundUpdates", "bootstrap",
- "skinnable", "size", "sourceURI", "releaseNotesURI",
- "softDisabled", "foreignInstall", "hasBinaryComponents",
- "strictCompatibility", "locales", "targetApplications",
- "targetPlatforms", "multiprocessCompatible", "signedState",
- "seen"];
+ "optionsType", "optionsBrowserStyle", "aboutURL", "icons",
+ "iconURL", "icon64URL", "defaultLocale", "visible", "active",
+ "userDisabled", "appDisabled", "pendingUninstall", "descriptor",
+ "installDate", "updateDate", "applyBackgroundUpdates",
+ "bootstrap", "skinnable", "size", "sourceURI",
+ "releaseNotesURI", "softDisabled", "foreignInstall",
+ "hasBinaryComponents", "strictCompatibility", "locales",
+ "targetApplications", "targetPlatforms",
+ "multiprocessCompatible", "signedState", "seen"];
// Properties that should be migrated where possible from an old database. These
// shouldn't include properties that can be read directly from install.rdf files
// or calculated
const DB_MIGRATE_METADATA= ["installDate", "userDisabled", "softDisabled",
"sourceURI", "applyBackgroundUpdates",
"releaseNotesURI", "foreignInstall", "syncGUID"];
new file mode 100644
--- /dev/null
+++ b/toolkit/themes/shared/extensions/browser-style-mac.css
@@ -0,0 +1,11 @@
+button,
+select,
+input[type="checkbox"] + label::before {
+ border-radius: 4px;
+}
+
+.panel-section-footer {
+ border-bottom-left-radius: 4px;
+ border-bottom-right-radius: 4px;
+ overflow: hidden;
+}
new file mode 100644
--- /dev/null
+++ b/toolkit/themes/shared/extensions/browser-style.css
@@ -0,0 +1,572 @@
+/* stylelint-disable property-no-vendor-prefix */
+/* stylelint-disable property-no-vendor-prefix */
+/* Base */
+button,
+select,
+option,
+input {
+ -moz-appearance: none;
+}
+
+/* Variables */
+html,
+body {
+ background-color: #fcfcfc;
+ box-sizing: border-box;
+ color: #222426;
+ cursor: default;
+ display: flex;
+ flex-direction: column;
+ font: caption;
+ margin: 0;
+ padding: 0;
+ -moz-user-select: none;
+}
+
+body * {
+ box-sizing: border-box;
+ text-align: start;
+}
+
+/* stylelint-disable property-no-vendor-prefix */
+/* Buttons */
+button,
+select {
+ background-color: #fbfbfb;
+ border: 1px solid #b1b1b1;
+ box-shadow: 0 0 0 0 transparent;
+ font: caption;
+ height: 24px;
+ outline: 0 !important;
+ padding: 0 8px 0;
+ transition-duration: 250ms;
+ transition-property: box-shadow, border;
+}
+
+select {
+ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDE2IDE2Ij4KICA8cGF0aCBkPSJNOCwxMkwzLDcsNCw2bDQsNCw0LTQsMSwxWiIgZmlsbD0iIzZBNkE2QSIgLz4KPC9zdmc+Cg==);
+ background-position: calc(100% - 4px) center;
+ background-repeat: no-repeat;
+ padding-inline-end: 24px;
+ text-overflow: ellipsis;
+}
+
+label {
+ font: caption;
+}
+
+button::-moz-focus-inner {
+ border: 0;
+ outline: 0;
+}
+
+/* Dropdowns */
+select {
+ background-color: #fbfbfb;
+ border: 1px solid #b1b1b1;
+ box-shadow: 0 0 0 0 transparent;
+ font: caption;
+ height: 24px;
+ outline: 0 !important;
+ padding: 0 8px 0;
+ transition-duration: 250ms;
+ transition-property: box-shadow, border;
+}
+
+select {
+ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDE2IDE2Ij4KICA8cGF0aCBkPSJNOCwxMkwzLDcsNCw2bDQsNCw0LTQsMSwxWiIgZmlsbD0iIzZBNkE2QSIgLz4KPC9zdmc+Cg==);
+ background-position: calc(100% - 4px) center;
+ background-repeat: no-repeat;
+ padding-inline-end: 24px;
+ text-overflow: ellipsis;
+}
+
+select:-moz-focusring {
+ color: transparent;
+ text-shadow: 0 0 0 #000;
+}
+
+select:-moz-focusring * {
+ color: #000;
+ text-shadow: none;
+}
+
+button.hover,
+select.hover {
+ background-color: #ebebeb;
+ border: 1px solid #b1b1b1;
+}
+
+button.pressed,
+select.pressed {
+ background-color: #d4d4d4;
+ border: 1px solid #858585;
+}
+
+button.disabled,
+select.disabled {
+ color: #999;
+ opacity: .5;
+}
+
+button.focused,
+select.focused {
+ border-color: #fff;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+button.default {
+ background-color: #0996f8;
+ border-color: #0670cc;
+ color: #fff;
+}
+
+button.default.hover {
+ background-color: #0670cc;
+ border-color: #005bab;
+}
+
+button.default.pressed {
+ background-color: #005bab;
+ border-color: #004480;
+}
+
+button.default.focused {
+ border-color: #fff;
+}
+
+/* Radio Buttons */
+.radioItem {
+ margin-bottom: 6px;
+ text-align: left;
+}
+
+input[type="radio"] {
+ display: none;
+}
+
+input[type="radio"] + label {
+ -moz-user-select: none;
+}
+
+input[type="radio"] + label::before {
+ background-color: #fff;
+ background-position: center;
+ border: 1px solid #b1b1b1;
+ border-radius: 50%;
+ content: "";
+ display: inline-block;
+ height: 16px;
+ margin-right: 6px;
+ vertical-align: text-top;
+ width: 16px;
+}
+
+input[type="radio"]:hover + label::before,
+.radioItem.hover input[type="radio"]:not(active) + label::before {
+ background-color: #fbfbfb;
+ border-color: #b1b1b1;
+}
+
+input[type="radio"]:hover:active + label::before,
+.radioItem.pressed input[type="radio"]:not(active) + label::before {
+ background-color: #ebebeb;
+ border-color: #858585;
+}
+
+input[type="radio"]:checked + label::before {
+ background-color: #0996f8;
+ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDE2IDE2Ij4KICA8Y2lyY2xlIGN4PSI4IiBjeT0iOCIgcj0iNCIgZmlsbD0iI2ZmZiIgLz4KPC9zdmc+Cg==);
+ border-color: #0670cc;
+}
+
+input[type="radio"]:checked:hover + label::before,
+.radioItem.hover input[type="radio"]:checked:not(active) + label::before {
+ background-color: #0670cc;
+ border-color: #005bab;
+}
+
+input[type="radio"]:checked:hover:active + label::before,
+.radioItem.pressed input[type="radio"]:checked:not(active) + label::before {
+ background-color: #005bab;
+ border-color: #004480;
+}
+
+.radioItem.disabled input[type="radio"] + label,
+.radioItem.disabled input[type="radio"]:hover + label,
+.radioItem.disabled input[type="radio"]:hover:active + label {
+ color: #999;
+ opacity: .5;
+}
+
+.radioItem.focused input[type="radio"] + label::before {
+ border-color: #0996f8;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+.radioItem.focused input[type="radio"]:checked + label::before {
+ border-color: #fff;
+}
+
+/* Checkboxes */
+.checkboxItem {
+ margin-bottom: 6px;
+ text-align: left;
+}
+
+input[type="checkbox"] {
+ display: none;
+}
+
+input[type="checkbox"] + label {
+ -moz-user-select: none;
+}
+
+input[type="checkbox"] + label::before {
+ background-color: #fff;
+ background-position: center;
+ border: 1px solid #b1b1b1;
+ content: "";
+ display: inline-block;
+ height: 16px;
+ margin-right: 6px;
+ vertical-align: text-top;
+ width: 16px;
+}
+
+input[type="checkbox"]:hover + label::before,
+.checkboxItem.hover input[type="checkbox"]:not(active) + label::before {
+ background-color: #fbfbfb;
+ border-color: #b1b1b1;
+}
+
+input[type="checkbox"]:hover:active + label::before,
+.checkboxItem.pressed input[type="checkbox"]:not(active) + label::before {
+ background-color: #ebebeb;
+ border-color: #858585;
+}
+
+input[type="checkbox"]:checked + label::before {
+ background-color: #0996f8;
+ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDE2IDE2Ij4KICA8cGF0aCBkPSJNNy43LDEyLjkgQzcuNCwxMy4zIDYuOCwxMy40IDYuNCwxMyBMMy4yLDkuOCBDMi44LDkuNCAyLjgsOC42IDMuMiw4LjIgQzMuNiw3LjggNC40LDcuOCA0LjgsOC4yIEw2LjksMTAuMyBMMTEuMSw0LjQgQzExLjUsMy45IDEyLjIsMy44IDEyLjcsNC4xIEMxMy4yLDQuNSAxMy4zLDUuMiAxMyw1LjcgTDcuNywxMi45IEw3LjcsMTIuOSBaIiBmaWxsPSIjZmZmIiAvPgo8L3N2Zz4K);
+ border-color: #0670cc;
+}
+
+input[type="checkbox"]:checked:hover + label::before,
+.checkboxItem.hover input[type="checkbox"]:checked:not(active) + label::before {
+ background-color: #0670cc;
+ border-color: #005bab;
+}
+
+input[type="checkbox"]:checked:hover:active + label::before,
+.checkboxItem.pressed input[type="checkbox"]:checked:not(active) + label::before {
+ background-color: #005bab;
+ border-color: #004480;
+}
+
+.checkboxItem.disabled input[type="checkbox"] + label,
+.checkboxItem.disabled input[type="checkbox"]:hover + label,
+.checkboxItem.disabled input[type="checkbox"]:hover:active + label {
+ color: #999;
+ opacity: .5;
+}
+
+.checkboxItem.focused input[type="checkbox"] + label::before {
+ border-color: #0996f8;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+.checkboxItem.focused input[type="checkbox"]:checked + label::before {
+ border-color: #fff;
+}
+
+/* Expander Button */
+button.expander {
+ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDE2IDE2Ij4KICA8cGF0aCBkPSJNOCwxMkwzLDcsNCw2bDQsNCw0LTQsMSwxWiIgZmlsbD0iIzZBNkE2QSIgLz4KPC9zdmc+Cg==);
+ background-position: center;
+ background-repeat: no-repeat;
+ height: 24px;
+ padding: 0;
+ width: 24px;
+}
+
+/* Interactive States */
+button:hover:not(.pressed):not(.disabled):not(.focused),
+select:hover:not(.pressed):not(.disabled):not(.focused) {
+ background-color: #ebebeb;
+ border: 1px solid #b1b1b1;
+}
+
+button:hover:active:not(.hover):not(.disabled):not(.focused),
+select:hover:active:not(.hover):not(.disabled):not(.focused) {
+ background-color: #d4d4d4;
+ border: 1px solid #858585;
+}
+
+button.default:hover:not(.pressed):not(.disabled):not(.focused) {
+ background-color: #0670cc;
+ border-color: #005bab;
+}
+
+button.default:hover:active:not(.hover):not(.disabled):not(.focused) {
+ background-color: #005bab;
+ border-color: #004480;
+}
+
+button:focus:not(.disabled) {
+ border-color: #fff !important;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+/* Fields */
+input[type="text"],
+textarea {
+ background-color: #fff;
+ border: 1px solid #b1b1b1;
+ box-shadow: 0 0 0 0 rgba(97, 181, 255, 0);
+ font: caption;
+ padding: 0 6px 0;
+ transition-duration: 250ms;
+ transition-property: box-shadow;
+}
+
+input[type="text"] {
+ height: 24px;
+}
+
+input[type="text"].hover,
+textarea.hover {
+ border: 1px solid #858585;
+}
+
+input[type="text"].disabled,
+textarea.disabled {
+ color: #999;
+ opacity: .5;
+}
+
+input[type="text"].focused,
+textarea.focused {
+ border-color: #0996f8;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+/* Interactive States */
+input[type="text"]:not(disabled):hover,
+textarea:not(disabled):hover {
+ border: 1px solid #858585;
+}
+
+input[type="text"]:focus,
+input[type="text"]:focus:hover,
+textarea:focus,
+textarea:focus:hover {
+ border-color: #0996f8;
+ box-shadow: 0 0 0 2px rgba(97, 181, 255, 0.75);
+}
+
+/* stylelint-disable property-no-vendor-prefix */
+.panel-section {
+ display: flex;
+ flex-direction: row;
+}
+
+.panel-section-separator {
+ background-color: rgba(0, 0, 0, 0.15);
+ min-height: 1px;
+}
+
+/* Panel Section - Header */
+.panel-section-header {
+ border-bottom: 1px solid rgba(0, 0, 0, 0.15);
+ padding: 16px;
+}
+
+.panel-section-header > .icon-section-header {
+ background-position: center center;
+ background-repeat: no-repeat;
+ height: 32px;
+ margin-right: 16px;
+ position: relative;
+ width: 32px;
+}
+
+.panel-section-header > .text-section-header {
+ align-self: center;
+ font-size: 1.385em;
+ font-weight: lighter;
+}
+
+/* Panel Section - List */
+.panel-section-list {
+ flex-direction: column;
+ padding: 4px 0;
+}
+
+.panel-list-item {
+ align-items: center;
+ display: flex;
+ flex-direction: row;
+ height: 24px;
+ padding: 0 16px;
+}
+
+.panel-list-item:not(.disabled):hover {
+ background-color: rgba(0, 0, 0, 0.06);
+ border-bottom: 1px solid rgba(0, 0, 0, 0.1);
+ border-top: 1px solid rgba(0, 0, 0, 0.1);
+}
+
+.panel-list-item:not(.disabled):hover:active {
+ background-color: rgba(0, 0, 0, 0.1);
+}
+
+.panel-list-item.disabled {
+ color: #999;
+}
+
+.panel-list-item > .icon {
+ flex-grow: 0;
+ flex-shrink: 0;
+}
+
+.panel-list-item > .text {
+ flex-grow: 10;
+}
+
+.panel-list-item > .text-shortcut {
+ color: #808080;
+ font-family: "Lucida Grande", caption;
+ font-size: .847em;
+ justify-content: flex-end;
+}
+
+.panel-section-list .panel-section-separator {
+ margin: 4px 0;
+}
+
+/* Panel Section - Form Elements */
+.panel-section-formElements {
+ display: flex;
+ flex-direction: column;
+ padding: 16px;
+}
+
+.panel-formElements-item {
+ align-items: center;
+ display: flex;
+ flex-direction: row;
+ margin-bottom: 12px;
+}
+
+.panel-formElements-item:last-child {
+ margin-bottom: 0;
+}
+
+.panel-formElements-item label {
+ flex-shrink: 0;
+ margin-right: 6px;
+ text-align: right;
+}
+
+.panel-formElements-item input[type="text"],
+.panel-formElements-item select {
+ flex-grow: 1;
+}
+
+/* Panel Section - Footer */
+.panel-section-footer {
+ background-color: rgba(0, 0, 0, 0.06);
+ border-top: 1px solid rgba(0, 0, 0, 0.15);
+ color: #1a1a1a;
+ display: flex;
+ flex-direction: row;
+ height: 41px;
+ margin-top: -1px;
+ padding: 0;
+}
+
+.panel-section-footer-button {
+ flex: 1 1 auto;
+ height: 100%;
+ margin: 0 -1px;
+ padding: 12px;
+ text-align: center;
+}
+
+.panel-section-footer-button > .text-shortcut {
+ color: #808080;
+ font-family: "Lucida Grande", caption;
+ font-size: .847em;
+}
+
+.panel-section-footer-button:hover {
+ background-color: rgba(0, 0, 0, 0.06);
+}
+
+.panel-section-footer-button:hover:active {
+ background-color: rgba(0, 0, 0, 0.1);
+}
+
+.panel-section-footer-button.default {
+ background-color: #0996f8;
+ box-shadow: 0 1px 0 #0670cc inset;
+ color: #fff;
+}
+
+.panel-section-footer-button.default:hover {
+ background-color: #0670cc;
+ box-shadow: 0 1px 0 #005bab inset;
+}
+
+.panel-section-footer-button.default:hover:active {
+ background-color: #005bab;
+ box-shadow: 0 1px 0 #004480 inset;
+}
+
+.panel-section-footer-separator {
+ background-color: rgba(0, 0, 0, 0.1);
+ width: 1px;
+ z-index: 99;
+}
+
+/* Panel Section - Tabs */
+.panel-section-tabs {
+ color: #1a1a1a;
+ display: flex;
+ flex-direction: row;
+ height: 41px;
+ margin-bottom: -1px;
+ padding: 0;
+}
+
+.panel-section-tabs-button {
+ flex: 1 1 auto;
+ height: 100%;
+ margin: 0 -1px;
+ padding: 12px;
+ text-align: center;
+}
+
+.panel-section-tabs-button:hover {
+ background-color: rgba(0, 0, 0, 0.06);
+}
+
+.panel-section-tabs-button:hover:active {
+ background-color: rgba(0, 0, 0, 0.1);
+}
+
+.panel-section-tabs-button.selected {
+ box-shadow: 0 -1px 0 #0670cc inset, 0 -4px 0 #0996f8 inset;
+ color: #0996f8;
+}
+
+.panel-section-tabs-button.selected:hover {
+ color: #0670cc;
+}
+
+.panel-section-tabs-separator {
+ background-color: rgba(0, 0, 0, 0.1);
+ width: 1px;
+ z-index: 99;
+}
--- a/toolkit/themes/shared/mozapps.inc.mn
+++ b/toolkit/themes/shared/mozapps.inc.mn
@@ -14,16 +14,18 @@
skin/classic/mozapps/extensions/alerticon-error.svg (../../shared/extensions/alerticon-error.svg)
skin/classic/mozapps/extensions/alerticon-info-positive.svg (../../shared/extensions/alerticon-info-positive.svg)
skin/classic/mozapps/extensions/alerticon-info-negative.svg (../../shared/extensions/alerticon-info-negative.svg)
skin/classic/mozapps/formautofill/requestAutocomplete.css (../../shared/formautofill/requestAutocomplete.css)
skin/classic/mozapps/plugins/pluginProblem.css (../../shared/plugins/pluginProblem.css)
skin/classic/mozapps/aboutNetworking.css (../../shared/aboutNetworking.css)
#ifndef ANDROID
skin/classic/mozapps/aboutProfiles.css (../../shared/aboutProfiles.css)
+ skin/classic/mozapps/extensions/browser-style.css (../../shared/extensions/browser-style.css)
+ skin/classic/mozapps/extensions/browser-style-mac.css (../../shared/extensions/browser-style-mac.css)
#endif
skin/classic/mozapps/aboutServiceWorkers.css (../../shared/aboutServiceWorkers.css)
skin/classic/mozapps/plugins/contentPluginActivate.png (../../shared/plugins/contentPluginActivate.png)
skin/classic/mozapps/plugins/contentPluginBlocked.png (../../shared/plugins/contentPluginBlocked.png)
skin/classic/mozapps/plugins/contentPluginClose.png (../../shared/plugins/contentPluginClose.png)
skin/classic/mozapps/plugins/contentPluginCrashed.png (../../shared/plugins/contentPluginCrashed.png)
skin/classic/mozapps/plugins/contentPluginDisabled.png (../../shared/plugins/contentPluginDisabled.png)
skin/classic/mozapps/plugins/contentPluginDownload.png (../../shared/plugins/contentPluginDownload.png)