mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-02-22 18:32:00 +00:00
data:image/s3,"s3://crabby-images/7d1f2/7d1f232ca48a1ce620eb70a6728fbe1e5d53418e" alt="Julian Descottes"
Make about:debugging code less verbose: - use component factories to avoid having to remove calls to createElement - use React.DOM helpers - components only module.export their class (require('my-component.js').MyComponent -> require('my-component.js')) MozReview-Commit-ID: CBWLgcPUkMf --HG-- extra : rebase_source : 8e3184bf82ad1b59d65bf0e94cc2f4662db856bd
121 lines
3.2 KiB
JavaScript
121 lines
3.2 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/. */
|
|
|
|
"use strict";
|
|
|
|
const { AddonManager } = require("resource://gre/modules/AddonManager.jsm");
|
|
const Services = require("Services");
|
|
|
|
const { createFactory, createClass, DOM: dom } =
|
|
require("devtools/client/shared/vendor/react");
|
|
const AddonsControls = createFactory(require("./addons-controls"));
|
|
const TabHeader = createFactory(require("./tab-header"));
|
|
const TargetList = createFactory(require("./target-list"));
|
|
|
|
const ExtensionIcon = "chrome://mozapps/skin/extensions/extensionGeneric.svg";
|
|
const Strings = Services.strings.createBundle(
|
|
"chrome://devtools/locale/aboutdebugging.properties");
|
|
|
|
const CHROME_ENABLED_PREF = "devtools.chrome.enabled";
|
|
const REMOTE_ENABLED_PREF = "devtools.debugger.remote-enabled";
|
|
|
|
module.exports = createClass({
|
|
displayName: "AddonsTab",
|
|
|
|
getInitialState() {
|
|
return {
|
|
extensions: [],
|
|
debugDisabled: false,
|
|
};
|
|
},
|
|
|
|
componentDidMount() {
|
|
AddonManager.addAddonListener(this);
|
|
|
|
Services.prefs.addObserver(CHROME_ENABLED_PREF,
|
|
this.updateDebugStatus, false);
|
|
Services.prefs.addObserver(REMOTE_ENABLED_PREF,
|
|
this.updateDebugStatus, false);
|
|
|
|
this.updateDebugStatus();
|
|
this.updateAddonsList();
|
|
},
|
|
|
|
componentWillUnmount() {
|
|
AddonManager.removeAddonListener(this);
|
|
Services.prefs.removeObserver(CHROME_ENABLED_PREF,
|
|
this.updateDebugStatus);
|
|
Services.prefs.removeObserver(REMOTE_ENABLED_PREF,
|
|
this.updateDebugStatus);
|
|
},
|
|
|
|
render() {
|
|
let { client } = this.props;
|
|
let { debugDisabled, extensions: targets } = this.state;
|
|
let name = Strings.GetStringFromName("extensions");
|
|
|
|
return dom.div({
|
|
id: "tab-addons",
|
|
className: "tab",
|
|
role: "tabpanel",
|
|
"aria-labelledby": "tab-addons-header-name" },
|
|
TabHeader({
|
|
id: "tab-addons-header-name",
|
|
name: Strings.GetStringFromName("addons") }),
|
|
AddonsControls({ debugDisabled }),
|
|
dom.div({ id: "addons" },
|
|
TargetList({ name, targets, client, debugDisabled })));
|
|
},
|
|
|
|
updateDebugStatus() {
|
|
let debugDisabled =
|
|
!Services.prefs.getBoolPref(CHROME_ENABLED_PREF) ||
|
|
!Services.prefs.getBoolPref(REMOTE_ENABLED_PREF);
|
|
|
|
this.setState({ debugDisabled });
|
|
},
|
|
|
|
updateAddonsList() {
|
|
AddonManager.getAllAddons(addons => {
|
|
let extensions = addons.filter(addon => addon.isDebuggable).map(addon => {
|
|
return {
|
|
name: addon.name,
|
|
icon: addon.iconURL || ExtensionIcon,
|
|
type: addon.type,
|
|
addonID: addon.id
|
|
};
|
|
});
|
|
this.setState({ extensions });
|
|
});
|
|
},
|
|
|
|
/**
|
|
* Mandatory callback as AddonManager listener.
|
|
*/
|
|
onInstalled() {
|
|
this.updateAddonsList();
|
|
},
|
|
|
|
/**
|
|
* Mandatory callback as AddonManager listener.
|
|
*/
|
|
onUninstalled() {
|
|
this.updateAddonsList();
|
|
},
|
|
|
|
/**
|
|
* Mandatory callback as AddonManager listener.
|
|
*/
|
|
onEnabled() {
|
|
this.updateAddonsList();
|
|
},
|
|
|
|
/**
|
|
* Mandatory callback as AddonManager listener.
|
|
*/
|
|
onDisabled() {
|
|
this.updateAddonsList();
|
|
},
|
|
});
|