"use strict"; // PNG image data for a simple red dot. const BACKGROUND_1 = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg=="; const ACCENT_COLOR_1 = "#a14040"; const TEXT_COLOR_1 = "#fac96e"; // PNG image data for the Mozilla dino head. const BACKGROUND_2 = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABGdBTUEAAK/INwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAHWSURBVHjaYvz//z8DJQAggJiQOe/fv2fv7Oz8rays/N+VkfG/iYnJfyD/1+rVq7ffu3dPFpsBAAHEAHIBCJ85c8bN2Nj4vwsDw/8zQLwKiO8CcRoQu0DxqlWrdsHUwzBAAIGJmTNnPgYa9j8UqhFElwPxf2MIDeIrKSn9FwSJoRkAEEAM0DD4DzMAyPi/G+QKY4hh5WAXGf8PDQ0FGwJ22d27CjADAAIIrLmjo+MXA9R2kAHvGBA2wwx6B8W7od6CeQcggKCmCEL8bgwxYCbUIGTDVkHDBia+CuotgACCueD3TDQN75D4xmAvCoK9ARMHBzAw0AECiBHkAlC0Mdy7x9ABNA3obAZXIAa6iKEcGlMVQHwWyjYuL2d4v2cPg8vZswx7gHyAAAK7AOif7SAbOqCmn4Ha3AHFsIDtgPq/vLz8P4MSkJ2W9h8ggBjevXvHDo4FQUQg/kdypqCg4H8lUIACnQ/SOBMYI8bAsAJFPcj1AAEEjwVQqLpAbXmH5BJjqI0gi9DTAAgDBBCcAVLkgmQ7yKCZxpCQxqUZhAECCJ4XgMl493ug21ZD+aDAXH0WLM4A9MZPXJkJIIAwTAR5pQMalaCABQUULttBGCCAGCnNzgABBgAMJ5THwGvJLAAAAABJRU5ErkJggg=="; const ACCENT_COLOR_2 = "#03fe03"; const TEXT_COLOR_2 = "#0ef325"; function hexToRGB(hex) { hex = parseInt(hex.indexOf("#") > -1 ? hex.substring(1) : hex, 16); return ( "rgb(" + [hex >> 16, (hex & 0x00ff00) >> 8, hex & 0x0000ff].join(", ") + ")" ); } function validateTheme(backgroundImage, accentColor, textColor, isLWT) { let docEl = window.document.documentElement; let rootCS = window.getComputedStyle(docEl); let toolbox = document.querySelector("#navigator-toolbox"); let toolboxCS = window.getComputedStyle(toolbox); if (isLWT) { Assert.ok(docEl.hasAttribute("lwtheme"), "LWT attribute should be set"); Assert.equal( docEl.getAttribute("lwtheme-brighttext"), "true", "LWT text color attribute should be set" ); } if (accentColor.startsWith("#")) { accentColor = hexToRGB(accentColor); } if (textColor.startsWith("#")) { textColor = hexToRGB(textColor); } Assert.ok( toolboxCS.backgroundImage.includes(backgroundImage), "Expected correct background image" ); Assert.equal( getToolboxBackgroundColor(), accentColor, "Expected correct accent color" ); Assert.equal(rootCS.color, textColor, "Expected correct text color"); } add_task(async function test_dynamic_theme_updates() { let extension = ExtensionTestUtils.loadExtension({ manifest: { permissions: ["theme"], }, files: { "image1.png": BACKGROUND_1, "image2.png": BACKGROUND_2, }, background() { browser.test.onMessage.addListener((msg, details) => { if (msg === "update-theme") { browser.theme.update(details).then(() => { browser.test.sendMessage("theme-updated"); }); } else { browser.theme.reset().then(() => { browser.test.sendMessage("theme-reset"); }); } }); }, }); let rootCS = window.getComputedStyle(window.document.documentElement); let toolboxCS = window.getComputedStyle( window.document.documentElement.querySelector("#navigator-toolbox") ); await extension.startup(); extension.sendMessage("update-theme", { images: { theme_frame: "image1.png", }, colors: { frame: ACCENT_COLOR_1, tab_background_text: TEXT_COLOR_1, }, }); await extension.awaitMessage("theme-updated"); validateTheme("image1.png", ACCENT_COLOR_1, TEXT_COLOR_1, true); // Check with the LWT aliases (to update on Firefox 69, because the // LWT aliases are going to be removed). extension.sendMessage("update-theme", { images: { theme_frame: "image2.png", }, colors: { frame: ACCENT_COLOR_2, tab_background_text: TEXT_COLOR_2, }, }); await extension.awaitMessage("theme-updated"); validateTheme("image2.png", ACCENT_COLOR_2, TEXT_COLOR_2, true); extension.sendMessage("reset-theme"); await extension.awaitMessage("theme-reset"); let { color } = rootCS; let backgroundImage = toolboxCS.backgroundImage; let backgroundColor = getToolboxBackgroundColor(); validateTheme(backgroundImage, backgroundColor, color, false); await extension.unload(); let docEl = window.document.documentElement; Assert.ok(!docEl.hasAttribute("lwtheme"), "LWT attribute should not be set"); }); add_task(async function test_dynamic_theme_updates_with_data_url() { let extension = ExtensionTestUtils.loadExtension({ manifest: { permissions: ["theme"], }, background() { browser.test.onMessage.addListener((msg, details) => { if (msg === "update-theme") { browser.theme.update(details).then(() => { browser.test.sendMessage("theme-updated"); }); } else { browser.theme.reset().then(() => { browser.test.sendMessage("theme-reset"); }); } }); }, }); let rootCS = window.getComputedStyle(window.document.documentElement); let toolboxCS = window.getComputedStyle( window.document.documentElement.querySelector("#navigator-toolbox") ); await extension.startup(); extension.sendMessage("update-theme", { images: { theme_frame: BACKGROUND_1, }, colors: { frame: ACCENT_COLOR_1, tab_background_text: TEXT_COLOR_1, }, }); await extension.awaitMessage("theme-updated"); validateTheme(BACKGROUND_1, ACCENT_COLOR_1, TEXT_COLOR_1, true); extension.sendMessage("update-theme", { images: { theme_frame: BACKGROUND_2, }, colors: { frame: ACCENT_COLOR_2, tab_background_text: TEXT_COLOR_2, }, }); await extension.awaitMessage("theme-updated"); validateTheme(BACKGROUND_2, ACCENT_COLOR_2, TEXT_COLOR_2, true); extension.sendMessage("reset-theme"); await extension.awaitMessage("theme-reset"); let { color } = rootCS; let backgroundImage = toolboxCS.backgroundImage; let backgroundColor = getToolboxBackgroundColor(); validateTheme(backgroundImage, backgroundColor, color, false); await extension.unload(); let docEl = window.document.documentElement; Assert.ok(!docEl.hasAttribute("lwtheme"), "LWT attribute should not be set"); });