mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-05-15 18:07:20 +00:00
217 lines
7.4 KiB
JavaScript
217 lines
7.4 KiB
JavaScript
# -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
#
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
|
# the License. You may obtain a copy of the License at
|
|
# http://www.mozilla.org/MPL/
|
|
#
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
# for the specific language governing rights and limitations under the
|
|
# License.
|
|
#
|
|
# The Original Code is Mozilla.org Code.
|
|
#
|
|
# The Initial Developer of the Original Code is
|
|
# Doron Rosenberg.
|
|
# Portions created by the Initial Developer are Copyright (C) 2001
|
|
# the Initial Developer. All Rights Reserved.
|
|
#
|
|
# Contributor(s):
|
|
# Ben Goodger <ben@netscape.com> (Original Author)
|
|
# Blake Ross <blaker@netscape.com>
|
|
#
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
# either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
# the provisions above, a recipient may use your version of this file under
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
#
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
var gData;
|
|
const kPrefSvcContractID = "@mozilla.org/preferences;1";
|
|
const kPrefSvcIID = Components.interfaces.nsIPref;
|
|
const gPrefSvc = Components.classes[kPrefSvcContractID].getService(kPrefSvcIID);
|
|
|
|
try {
|
|
var chromeRegistry = Components.classes["@mozilla.org/chrome/chrome-registry;1"].getService();
|
|
if (chromeRegistry)
|
|
chromeRegistry = chromeRegistry.QueryInterface(Components.interfaces.nsIXULChromeRegistry);
|
|
}
|
|
catch(e) {}
|
|
|
|
function Startup()
|
|
{
|
|
gData = parent.hPrefWindow.wsm.dataManager.pageData["chrome://browser/content/pref/pref-themes.xul"].userData;
|
|
var list = document.getElementById( "skinsList" );
|
|
if ("loaded" in gData && "themeIndex" in gData) {
|
|
list.selectedIndex = gData.themeIndex;
|
|
removeInvalidThemes();
|
|
return;
|
|
}
|
|
gData.loaded = true;
|
|
parent.hPrefWindow.registerOKCallbackFunc(applyTheme);
|
|
|
|
var theme = null;
|
|
try {
|
|
theme = gPrefSvc.getComplexValue("general.skins.selectedSkin",
|
|
Components.interfaces.nsISupportsString).data;
|
|
} catch (e) {
|
|
}
|
|
var matches;
|
|
for (var i = 0; i < list.childNodes.length; ++i) {
|
|
var child = list.childNodes[i];
|
|
var name = child.getAttribute("name");
|
|
if (!theme)
|
|
matches = chromeRegistry.isSkinSelectedForPackage(name, "browser", true);
|
|
else
|
|
matches = name == theme;
|
|
if (matches) {
|
|
list.selectItem(child);
|
|
break;
|
|
}
|
|
}
|
|
removeInvalidThemes();
|
|
}
|
|
|
|
function removeInvalidThemes() {
|
|
var list = document.getElementById( "skinsList" );
|
|
for (var i = 0; i < list.childNodes.length; ++i) {
|
|
var child = list.childNodes[i];
|
|
var name = child.getAttribute("name");
|
|
if (name) {
|
|
var oldTheme = !chromeRegistry.checkThemeVersion(name);
|
|
if (oldTheme) {
|
|
list.removeItemAt(i);
|
|
i--;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function applyTheme()
|
|
{
|
|
var data = parent.hPrefWindow.wsm.dataManager.pageData["chrome://browser/content/pref/pref-themes.xul"].userData;
|
|
if (data.name == null)
|
|
return;
|
|
|
|
const kPrefSvcContractID = "@mozilla.org/preferences;1";
|
|
const kPrefSvcIID = Components.interfaces.nsIPref;
|
|
var prefSvc = Components.classes[kPrefSvcContractID].getService(kPrefSvcIID);
|
|
|
|
var theme = null;
|
|
try {
|
|
theme = prefSvc.getComplexValue("general.skins.selectedSkin",
|
|
Components.interfaces.nsISupportsString).data;
|
|
} catch (e) {
|
|
}
|
|
|
|
if (theme == data.name) return;
|
|
|
|
try {
|
|
var reg = Components.classes["@mozilla.org/chrome/chrome-registry;1"].getService();
|
|
if (reg)
|
|
reg = reg.QueryInterface(Components.interfaces.nsIXULChromeRegistry);
|
|
}
|
|
catch(e) {}
|
|
|
|
var inUse = reg.isSkinSelected(data.name, true);
|
|
if (!theme && inUse == Components.interfaces.nsIChromeRegistry.FULL) return;
|
|
|
|
var chromeRegistry = Components.classes["@mozilla.org/chrome/chrome-registry;1"]
|
|
.getService(Components.interfaces.nsIXULChromeRegistry);
|
|
|
|
var str = Components.classes["@mozilla.org/supports-string;1"]
|
|
.createInstance(Components.interfaces.nsISupportsString);
|
|
str.data = data.name;
|
|
prefSvc.setComplexValue("general.skins.selectedSkin", Components.interfaces.nsISupportsString, str);
|
|
|
|
|
|
chromeRegistry.selectSkin(data.name, true);
|
|
chromeRegistry.refreshSkins();
|
|
}
|
|
|
|
|
|
function uninstallSkin()
|
|
{
|
|
var list = document.getElementById("skinsList");
|
|
var selectedSkinItem = list.selectedItems[0];
|
|
var skinName = selectedSkinItem.getAttribute("name");
|
|
var inUse = chromeRegistry.isSkinSelected(skinName, true);
|
|
chromeRegistry.uninstallSkin(skinName, true);
|
|
if (inUse)
|
|
chromeRegistry.refreshSkins();
|
|
list.selectedIndex = 0;
|
|
}
|
|
|
|
function themeSelect()
|
|
{
|
|
var list = document.getElementById("skinsList");
|
|
|
|
if (!list)
|
|
return;
|
|
|
|
var prefbundle = document.getElementById("bundle_prefutilities");
|
|
|
|
var selectedItem = list.selectedItems.length ? list.selectedItems[0] : null;
|
|
if (selectedItem && selectedItem.getAttribute("skin") == "true") {
|
|
var themeName = selectedItem.getAttribute("displayName");
|
|
var skinName = selectedItem.getAttribute("name");
|
|
gData.name = skinName;
|
|
gData.themeIndex = list.selectedIndex;
|
|
|
|
var nameField = document.getElementById("displayName");
|
|
var author = document.getElementById("author");
|
|
var image = document.getElementById("previewImage");
|
|
var descText = document.createTextNode(selectedItem.getAttribute("description"));
|
|
var description = document.getElementById("description");
|
|
var uninstallButton = document.getElementById("uninstallSkin");
|
|
var uninstallLabel = prefbundle.getString("uninstallThemePrefix");
|
|
|
|
while (description.hasChildNodes())
|
|
description.removeChild(description.firstChild);
|
|
|
|
nameField.setAttribute("value", themeName);
|
|
|
|
author.setAttribute("value", selectedItem.getAttribute("author"));
|
|
var authorURL = selectedItem.getAttribute("authorURL");
|
|
if (authorURL != "") {
|
|
author.setAttribute("link", selectedItem.getAttribute("authorURL"));
|
|
author.className = "themesLink";
|
|
}
|
|
else {
|
|
author.removeAttribute("link");
|
|
author.className = "";
|
|
}
|
|
|
|
image.setAttribute("src", selectedItem.getAttribute("image"));
|
|
|
|
// XXX - this sucks and should only be temporary.
|
|
var selectedSkin = "";
|
|
try {
|
|
selectedSkin = gPrefSvc.CopyCharPref("general.skins.selectedSkin");
|
|
}
|
|
catch (e) {
|
|
}
|
|
description.appendChild(descText);
|
|
|
|
var locType = selectedItem.getAttribute("loctype");
|
|
uninstallButton.disabled = (selectedSkin == skinName) || (locType == "install");
|
|
|
|
uninstallLabel = uninstallLabel.replace(/%theme_name%/, themeName);
|
|
uninstallButton.label = uninstallLabel;
|
|
}
|
|
else {
|
|
uninstallButton.disabled = true;
|
|
gData.name = null;
|
|
}
|
|
}
|