gecko-dev/browser/themes/ThemeVariableMap.jsm

194 строки
4.0 KiB
JavaScript

/* 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/. */
var EXPORTED_SYMBOLS = ["ThemeVariableMap", "ThemeContentPropertyList"];
const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
const ThemeVariableMap = [
[
"--lwt-accent-color-inactive",
{
lwtProperty: "accentcolorInactive",
},
],
[
"--lwt-background-alignment",
{
isColor: false,
lwtProperty: "backgroundsAlignment",
},
],
[
"--lwt-background-tiling",
{
isColor: false,
lwtProperty: "backgroundsTiling",
},
],
[
"--tab-loading-fill",
{
lwtProperty: "tab_loading",
optionalElementID: "tabbrowser-tabs",
},
],
[
"--lwt-tab-text",
{
lwtProperty: "tab_text",
},
],
[
"--lwt-tab-line-color",
{
lwtProperty: "tab_line",
optionalElementID: "tabbrowser-tabs",
},
],
[
"--lwt-background-tab-separator-color",
{
lwtProperty: "tab_background_separator",
},
],
[
"--toolbar-bgcolor",
{
lwtProperty: "toolbarColor",
},
],
[
"--toolbar-color",
{
lwtProperty: "toolbar_text",
},
],
[
"--lwt-tabs-border-color",
{
lwtProperty: "toolbar_top_separator",
optionalElementID: "navigator-toolbox",
},
],
[
"--toolbarseparator-color",
{
lwtProperty: "toolbar_vertical_separator",
},
],
[
"--chrome-content-separator-color",
{
lwtProperty: "toolbar_bottom_separator",
},
],
[
"--toolbarbutton-icon-fill",
{
lwtProperty: "icon_color",
},
],
[
"--lwt-toolbarbutton-icon-fill-attention",
{
lwtProperty: "icon_attention_color",
},
],
[
"--toolbarbutton-hover-background",
{
lwtProperty: "button_background_hover",
},
],
[
"--toolbarbutton-active-background",
{
lwtProperty: "button_background_active",
},
],
[
"--lwt-selected-tab-background-color",
{
lwtProperty: "tab_selected",
},
],
[
"--autocomplete-popup-highlight-background",
{
lwtProperty: "popup_highlight",
},
],
[
"--autocomplete-popup-highlight-color",
{
lwtProperty: "popup_highlight_text",
},
],
[
"--sidebar-background-color",
{
lwtProperty: "sidebar",
optionalElementID: "sidebar-box",
processColor(rgbaChannels, element) {
if (!rgbaChannels) {
element.removeAttribute("lwt-sidebar");
return null;
}
const { r, g, b } = rgbaChannels;
element.setAttribute("lwt-sidebar", "true");
// Drop alpha channel
return `rgb(${r}, ${g}, ${b})`;
},
},
],
[
"--sidebar-text-color",
{
lwtProperty: "sidebar_text",
optionalElementID: "sidebar-box",
},
],
[
"--sidebar-border-color",
{
lwtProperty: "sidebar_border",
optionalElementID: "browser",
},
],
[
"--tabpanel-background-color",
{
lwtProperty: "ntp_background",
processColor(rgbaChannels) {
if (
!rgbaChannels ||
!Services.prefs.getBoolPref("browser.newtabpage.enabled")
) {
// We only set the tabpanel background to the new tab background color
// if the user uses about:home for new tabs. Otherwise, we flash a
// colorful background when a new tab is opened. We will flash the
// newtab color in new windows if the user uses about:home for new
// tabs but not new windows. However, the flash is concealed by the OS
// window-open animation.
return null;
}
// Drop alpha channel
let { r, g, b } = rgbaChannels;
return `rgb(${r}, ${g}, ${b})`;
},
},
],
];
const ThemeContentPropertyList = [
"ntp_background",
"ntp_card_background",
"ntp_text",
"sidebar",
"sidebar_highlight",
"sidebar_highlight_text",
"sidebar_text",
];