From e72ef92b5bdc43cd2584198e2e54e951b70299e8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 03:32:58 -0500 Subject: Add Basilisk --- .../content/aboutPrivateBrowsing.css | 10 +++ .../content/aboutPrivateBrowsing.js | 98 ++++++++++++++++++++++ .../content/aboutPrivateBrowsing.xhtml | 79 +++++++++++++++++ .../basilisk/components/privatebrowsing/jar.mn | 8 ++ .../basilisk/components/privatebrowsing/moz.build | 7 ++ 5 files changed, 202 insertions(+) create mode 100644 application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.css create mode 100644 application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.js create mode 100644 application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.xhtml create mode 100644 application/basilisk/components/privatebrowsing/jar.mn create mode 100644 application/basilisk/components/privatebrowsing/moz.build (limited to 'application/basilisk/components/privatebrowsing') diff --git a/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.css b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.css new file mode 100644 index 000000000..29d7a843d --- /dev/null +++ b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.css @@ -0,0 +1,10 @@ +html.private .showNormal, +html.normal .showPrivate, +body[tpEnabled] .showTpDisabled, +body:not([tpEnabled]) .showTpEnabled { + display: none !important; +} + +.hide { + display: none; +} diff --git a/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.js b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.js new file mode 100644 index 000000000..4a95efbd5 --- /dev/null +++ b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.js @@ -0,0 +1,98 @@ +/* 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 {classes: Cc, interfaces: Ci, utils: Cu} = Components; + +Cu.import("resource://gre/modules/Services.jsm"); +Cu.import("resource://gre/modules/PrivateBrowsingUtils.jsm"); +Cu.import("resource://gre/modules/XPCOMUtils.jsm"); + +const FAVICON_QUESTION = "chrome://global/skin/icons/question-32.png"; +const FAVICON_PRIVACY = "chrome://browser/skin/privatebrowsing/favicon.svg"; + +var stringBundle = Services.strings.createBundle( + "chrome://browser/locale/aboutPrivateBrowsing.properties"); + +var prefBranch = Services.prefs.getBranch("privacy.trackingprotection."); +var prefObserver = { + QueryInterface: XPCOMUtils.generateQI([Ci.nsIObserver, + Ci.nsISupportsWeakReference]), + observe: function () { + let tpSubHeader = document.getElementById("tpSubHeader"); + let tpToggle = document.getElementById("tpToggle"); + let tpButton = document.getElementById("tpButton"); + let title = document.getElementById("title"); + let titleTracking = document.getElementById("titleTracking"); + let globalTrackingEnabled = prefBranch.getBoolPref("enabled"); + let trackingEnabled = globalTrackingEnabled || + prefBranch.getBoolPref("pbmode.enabled"); + + tpButton.classList.toggle("hide", globalTrackingEnabled); + tpToggle.checked = trackingEnabled; + title.classList.toggle("hide", trackingEnabled); + titleTracking.classList.toggle("hide", !trackingEnabled); + tpSubHeader.classList.toggle("tp-off", !trackingEnabled); + } +}; +prefBranch.addObserver("pbmode.enabled", prefObserver, true); +prefBranch.addObserver("enabled", prefObserver, true); + +function setFavIcon(url) { + document.getElementById("favicon").setAttribute("href", url); +} + +document.addEventListener("DOMContentLoaded", function () { + if (!PrivateBrowsingUtils.isContentWindowPrivate(window)) { + document.documentElement.classList.remove("private"); + document.documentElement.classList.add("normal"); + document.title = stringBundle.GetStringFromName("title.normal"); + document.getElementById("favicon") + .setAttribute("href", FAVICON_QUESTION); + document.getElementById("startPrivateBrowsing") + .addEventListener("command", openPrivateWindow); + return; + } + + let tpToggle = document.getElementById("tpToggle"); + document.getElementById("tpButton").addEventListener('click', () => { + tpToggle.click(); + }); + + document.title = stringBundle.GetStringFromName("title.head"); + document.getElementById("favicon") + .setAttribute("href", FAVICON_PRIVACY); + tpToggle.addEventListener("change", toggleTrackingProtection); + document.getElementById("startTour") + .addEventListener("click", dontShowIntroPanelAgain); + + let formatURLPref = Cc["@mozilla.org/toolkit/URLFormatterService;1"] + .getService(Ci.nsIURLFormatter).formatURLPref; + document.getElementById("startTour").setAttribute("href", + formatURLPref("privacy.trackingprotection.introURL")); + document.getElementById("learnMore").setAttribute("href", + formatURLPref("app.support.baseURL") + "private-browsing"); + + // Update state that depends on preferences. + prefObserver.observe(); +}); + +function openPrivateWindow() { + // Ask chrome to open a private window + document.dispatchEvent( + new CustomEvent("AboutPrivateBrowsingOpenWindow", {bubbles:true})); +} + +function toggleTrackingProtection() { + // Ask chrome to enable tracking protection + document.dispatchEvent( + new CustomEvent("AboutPrivateBrowsingToggleTrackingProtection", + {bubbles: true})); +} + +function dontShowIntroPanelAgain() { + // Ask chrome to disable the doorhanger + document.dispatchEvent( + new CustomEvent("AboutPrivateBrowsingDontShowIntroPanelAgain", + {bubbles: true})); +} diff --git a/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.xhtml b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.xhtml new file mode 100644 index 000000000..466207734 --- /dev/null +++ b/application/basilisk/components/privatebrowsing/content/aboutPrivateBrowsing.xhtml @@ -0,0 +1,79 @@ + + + + %htmlDTD; + + %globalDTD; + + %brandDTD; + + %browserDTD; + + %aboutPrivateBrowsingDTD; +]> + + + + + + + + + + +

&aboutPrivateBrowsing.notPrivate;

+