123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512 |
- /* 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 Services = require("Services");
- const osString = Services.appinfo.OS;
- // Panels
- loader.lazyGetter(this, "OptionsPanel", () => require("devtools/client/framework/toolbox-options").OptionsPanel);
- loader.lazyGetter(this, "InspectorPanel", () => require("devtools/client/inspector/panel").InspectorPanel);
- loader.lazyGetter(this, "WebConsolePanel", () => require("devtools/client/webconsole/panel").WebConsolePanel);
- loader.lazyGetter(this, "DebuggerPanel", () => require("devtools/client/debugger/panel").DebuggerPanel);
- loader.lazyGetter(this, "StyleEditorPanel", () => require("devtools/client/styleeditor/styleeditor-panel").StyleEditorPanel);
- loader.lazyGetter(this, "ShaderEditorPanel", () => require("devtools/client/shadereditor/panel").ShaderEditorPanel);
- loader.lazyGetter(this, "CanvasDebuggerPanel", () => require("devtools/client/canvasdebugger/panel").CanvasDebuggerPanel);
- loader.lazyGetter(this, "WebAudioEditorPanel", () => require("devtools/client/webaudioeditor/panel").WebAudioEditorPanel);
- loader.lazyGetter(this, "MemoryPanel", () => require("devtools/client/memory/panel").MemoryPanel);
- loader.lazyGetter(this, "PerformancePanel", () => require("devtools/client/performance/panel").PerformancePanel);
- loader.lazyGetter(this, "NetMonitorPanel", () => require("devtools/client/netmonitor/panel").NetMonitorPanel);
- loader.lazyGetter(this, "StoragePanel", () => require("devtools/client/storage/panel").StoragePanel);
- loader.lazyGetter(this, "ScratchpadPanel", () => require("devtools/client/scratchpad/scratchpad-panel").ScratchpadPanel);
- loader.lazyGetter(this, "DomPanel", () => require("devtools/client/dom/dom-panel").DomPanel);
- const {LocalizationHelper} = require("devtools/shared/l10n");
- const L10N = new LocalizationHelper("devtools/client/locales/startup.properties");
- var Tools = {};
- exports.Tools = Tools;
- // Definitions
- Tools.options = {
- id: "options",
- ordinal: 0,
- url: "chrome://devtools/content/framework/toolbox-options.xhtml",
- icon: "chrome://devtools/skin/images/tool-options.svg",
- invertIconForDarkTheme: true,
- bgTheme: "theme-body",
- label: l10n("options.label"),
- iconOnly: true,
- panelLabel: l10n("options.panelLabel"),
- tooltip: l10n("optionsButton.tooltip"),
- inMenu: false,
- isTargetSupported: function () {
- return true;
- },
- build: function (iframeWindow, toolbox) {
- return new OptionsPanel(iframeWindow, toolbox);
- }
- };
- Tools.inspector = {
- id: "inspector",
- accesskey: l10n("inspector.accesskey"),
- key: l10n("inspector.commandkey"),
- ordinal: 1,
- modifiers: osString == "Darwin" ? "accel,alt" : "accel,shift",
- icon: "chrome://devtools/skin/images/tool-inspector.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/inspector/inspector.xhtml",
- label: l10n("inspector.label"),
- panelLabel: l10n("inspector.panelLabel"),
- get tooltip() {
- return l10n("inspector.tooltip2",
- (osString == "Darwin" ? "Cmd+Opt+" : "Ctrl+Shift+") + this.key);
- },
- inMenu: true,
- commands: [
- "devtools/client/responsivedesign/resize-commands",
- "devtools/client/inspector/inspector-commands"
- ],
- preventClosingOnKey: true,
- onkey: function (panel, toolbox) {
- toolbox.highlighterUtils.togglePicker();
- },
- isTargetSupported: function (target) {
- return target.hasActor("inspector");
- },
- build: function (iframeWindow, toolbox) {
- return new InspectorPanel(iframeWindow, toolbox);
- }
- };
- Tools.webConsole = {
- id: "webconsole",
- key: l10n("cmd.commandkey"),
- accesskey: l10n("webConsoleCmd.accesskey"),
- modifiers: Services.appinfo.OS == "Darwin" ? "accel,alt" : "accel,shift",
- ordinal: 2,
- icon: "chrome://devtools/skin/images/tool-webconsole.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/webconsole/webconsole.xul",
- label: l10n("ToolboxTabWebconsole.label"),
- menuLabel: l10n("MenuWebconsole.label"),
- panelLabel: l10n("ToolboxWebConsole.panelLabel"),
- get tooltip() {
- return l10n("ToolboxWebconsole.tooltip2",
- (osString == "Darwin" ? "Cmd+Opt+" : "Ctrl+Shift+") + this.key);
- },
- inMenu: true,
- commands: "devtools/client/webconsole/console-commands",
- preventClosingOnKey: true,
- onkey: function (panel, toolbox) {
- if (toolbox.splitConsole) {
- return toolbox.focusConsoleInput();
- }
- panel.focusInput();
- return undefined;
- },
- isTargetSupported: function () {
- return true;
- },
- build: function (iframeWindow, toolbox) {
- return new WebConsolePanel(iframeWindow, toolbox);
- }
- };
- Tools.jsdebugger = {
- id: "jsdebugger",
- key: l10n("debuggerMenu.commandkey"),
- accesskey: l10n("debuggerMenu.accesskey"),
- modifiers: osString == "Darwin" ? "accel,alt" : "accel,shift",
- ordinal: 3,
- icon: "chrome://devtools/skin/images/tool-debugger.svg",
- invertIconForDarkTheme: true,
- highlightedicon: "chrome://devtools/skin/images/tool-debugger-paused.svg",
- url: "chrome://devtools/content/debugger/debugger.xul",
- label: l10n("ToolboxDebugger.label"),
- panelLabel: l10n("ToolboxDebugger.panelLabel"),
- get tooltip() {
- return l10n("ToolboxDebugger.tooltip2",
- (osString == "Darwin" ? "Cmd+Opt+" : "Ctrl+Shift+") + this.key);
- },
- inMenu: true,
- commands: "devtools/client/debugger/debugger-commands",
- isTargetSupported: function () {
- return true;
- },
- build: function (iframeWindow, toolbox) {
- return new DebuggerPanel(iframeWindow, toolbox);
- }
- };
- function switchDebugger() {
- if (Services.prefs.getBoolPref("devtools.debugger.new-debugger-frontend")) {
- const NewDebuggerPanel = require("devtools/client/debugger/new/panel").DebuggerPanel;
- Tools.jsdebugger.url = "chrome://devtools/content/debugger/new/index.html";
- Tools.jsdebugger.build = function (iframeWindow, toolbox) {
- return new NewDebuggerPanel(iframeWindow, toolbox);
- };
- } else {
- Tools.jsdebugger.url = "chrome://devtools/content/debugger/debugger.xul";
- Tools.jsdebugger.build = function (iframeWindow, toolbox) {
- return new DebuggerPanel(iframeWindow, toolbox);
- };
- }
- }
- switchDebugger();
- Services.prefs.addObserver(
- "devtools.debugger.new-debugger-frontend",
- { observe: switchDebugger },
- false
- );
- Tools.styleEditor = {
- id: "styleeditor",
- key: l10n("open.commandkey"),
- ordinal: 4,
- visibilityswitch: "devtools.styleeditor.enabled",
- accesskey: l10n("open.accesskey"),
- modifiers: "shift",
- icon: "chrome://devtools/skin/images/tool-styleeditor.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/styleeditor/styleeditor.xul",
- label: l10n("ToolboxStyleEditor.label"),
- panelLabel: l10n("ToolboxStyleEditor.panelLabel"),
- get tooltip() {
- return l10n("ToolboxStyleEditor.tooltip3",
- "Shift+" + functionkey(this.key));
- },
- inMenu: true,
- commands: "devtools/client/styleeditor/styleeditor-commands",
- isTargetSupported: function (target) {
- return target.hasActor("styleEditor") || target.hasActor("styleSheets");
- },
- build: function (iframeWindow, toolbox) {
- return new StyleEditorPanel(iframeWindow, toolbox);
- }
- };
- Tools.shaderEditor = {
- id: "shadereditor",
- ordinal: 5,
- visibilityswitch: "devtools.shadereditor.enabled",
- icon: "chrome://devtools/skin/images/tool-shadereditor.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/shadereditor/shadereditor.xul",
- label: l10n("ToolboxShaderEditor.label"),
- panelLabel: l10n("ToolboxShaderEditor.panelLabel"),
- tooltip: l10n("ToolboxShaderEditor.tooltip"),
- isTargetSupported: function (target) {
- return target.hasActor("webgl") && !target.chrome;
- },
- build: function (iframeWindow, toolbox) {
- return new ShaderEditorPanel(iframeWindow, toolbox);
- }
- };
- Tools.canvasDebugger = {
- id: "canvasdebugger",
- ordinal: 6,
- visibilityswitch: "devtools.canvasdebugger.enabled",
- icon: "chrome://devtools/skin/images/tool-canvas.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/canvasdebugger/canvasdebugger.xul",
- label: l10n("ToolboxCanvasDebugger.label"),
- panelLabel: l10n("ToolboxCanvasDebugger.panelLabel"),
- tooltip: l10n("ToolboxCanvasDebugger.tooltip"),
- // Hide the Canvas Debugger in the Add-on Debugger and Browser Toolbox
- // (bug 1047520).
- isTargetSupported: function (target) {
- return target.hasActor("canvas") && !target.chrome;
- },
- build: function (iframeWindow, toolbox) {
- return new CanvasDebuggerPanel(iframeWindow, toolbox);
- }
- };
- Tools.performance = {
- id: "performance",
- ordinal: 7,
- icon: "chrome://devtools/skin/images/tool-profiler.svg",
- invertIconForDarkTheme: true,
- highlightedicon: "chrome://devtools/skin/images/tool-profiler-active.svg",
- url: "chrome://devtools/content/performance/performance.xul",
- visibilityswitch: "devtools.performance.enabled",
- label: l10n("performance.label"),
- panelLabel: l10n("performance.panelLabel"),
- get tooltip() {
- return l10n("performance.tooltip", "Shift+" + functionkey(this.key));
- },
- accesskey: l10n("performance.accesskey"),
- key: l10n("performance.commandkey"),
- modifiers: "shift",
- inMenu: true,
- isTargetSupported: function (target) {
- return target.hasActor("profiler");
- },
- build: function (frame, target) {
- return new PerformancePanel(frame, target);
- }
- };
- Tools.memory = {
- id: "memory",
- ordinal: 8,
- icon: "chrome://devtools/skin/images/tool-memory.svg",
- invertIconForDarkTheme: true,
- highlightedicon: "chrome://devtools/skin/images/tool-memory-active.svg",
- url: "chrome://devtools/content/memory/memory.xhtml",
- visibilityswitch: "devtools.memory.enabled",
- label: l10n("memory.label"),
- panelLabel: l10n("memory.panelLabel"),
- tooltip: l10n("memory.tooltip"),
- isTargetSupported: function (target) {
- return target.getTrait("heapSnapshots") && !target.isAddon;
- },
- build: function (frame, target) {
- return new MemoryPanel(frame, target);
- }
- };
- Tools.netMonitor = {
- id: "netmonitor",
- accesskey: l10n("netmonitor.accesskey"),
- key: l10n("netmonitor.commandkey"),
- ordinal: 9,
- modifiers: osString == "Darwin" ? "accel,alt" : "accel,shift",
- visibilityswitch: "devtools.netmonitor.enabled",
- icon: "chrome://devtools/skin/images/tool-network.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/netmonitor/netmonitor.xul",
- label: l10n("netmonitor.label"),
- panelLabel: l10n("netmonitor.panelLabel"),
- get tooltip() {
- return l10n("netmonitor.tooltip2",
- (osString == "Darwin" ? "Cmd+Opt+" : "Ctrl+Shift+") + this.key);
- },
- inMenu: true,
- isTargetSupported: function (target) {
- return target.getTrait("networkMonitor");
- },
- build: function (iframeWindow, toolbox) {
- return new NetMonitorPanel(iframeWindow, toolbox);
- }
- };
- Tools.storage = {
- id: "storage",
- key: l10n("storage.commandkey"),
- ordinal: 10,
- accesskey: l10n("storage.accesskey"),
- modifiers: "shift",
- visibilityswitch: "devtools.storage.enabled",
- icon: "chrome://devtools/skin/images/tool-storage.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/storage/storage.xul",
- label: l10n("storage.label"),
- menuLabel: l10n("storage.menuLabel"),
- panelLabel: l10n("storage.panelLabel"),
- get tooltip() {
- return l10n("storage.tooltip3", "Shift+" + functionkey(this.key));
- },
- inMenu: true,
- isTargetSupported: function (target) {
- return target.isLocalTab ||
- (target.hasActor("storage") && target.getTrait("storageInspector"));
- },
- build: function (iframeWindow, toolbox) {
- return new StoragePanel(iframeWindow, toolbox);
- }
- };
- Tools.webAudioEditor = {
- id: "webaudioeditor",
- ordinal: 11,
- visibilityswitch: "devtools.webaudioeditor.enabled",
- icon: "chrome://devtools/skin/images/tool-webaudio.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/webaudioeditor/webaudioeditor.xul",
- label: l10n("ToolboxWebAudioEditor1.label"),
- panelLabel: l10n("ToolboxWebAudioEditor1.panelLabel"),
- tooltip: l10n("ToolboxWebAudioEditor1.tooltip"),
- isTargetSupported: function (target) {
- return !target.chrome && target.hasActor("webaudio");
- },
- build: function (iframeWindow, toolbox) {
- return new WebAudioEditorPanel(iframeWindow, toolbox);
- }
- };
- Tools.scratchpad = {
- id: "scratchpad",
- ordinal: 12,
- visibilityswitch: "devtools.scratchpad.enabled",
- icon: "chrome://devtools/skin/images/tool-scratchpad.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/scratchpad/scratchpad.xul",
- label: l10n("scratchpad.label"),
- panelLabel: l10n("scratchpad.panelLabel"),
- tooltip: l10n("scratchpad.tooltip"),
- inMenu: false,
- commands: "devtools/client/scratchpad/scratchpad-commands",
- isTargetSupported: function (target) {
- return target.hasActor("console");
- },
- build: function (iframeWindow, toolbox) {
- return new ScratchpadPanel(iframeWindow, toolbox);
- }
- };
- Tools.dom = {
- id: "dom",
- accesskey: l10n("dom.accesskey"),
- key: l10n("dom.commandkey"),
- ordinal: 13,
- modifiers: osString == "Darwin" ? "accel,alt" : "accel,shift",
- visibilityswitch: "devtools.dom.enabled",
- icon: "chrome://devtools/skin/images/tool-dom.svg",
- invertIconForDarkTheme: true,
- url: "chrome://devtools/content/dom/dom.html",
- label: l10n("dom.label"),
- panelLabel: l10n("dom.panelLabel"),
- get tooltip() {
- return l10n("dom.tooltip",
- (osString == "Darwin" ? "Cmd+Opt+" : "Ctrl+Shift+") + this.key);
- },
- inMenu: true,
- isTargetSupported: function (target) {
- return target.getTrait("webConsoleCommands");
- },
- build: function (iframeWindow, toolbox) {
- return new DomPanel(iframeWindow, toolbox);
- }
- };
- var defaultTools = [
- Tools.options,
- Tools.webConsole,
- Tools.inspector,
- Tools.jsdebugger,
- Tools.styleEditor,
- Tools.shaderEditor,
- Tools.canvasDebugger,
- Tools.webAudioEditor,
- Tools.performance,
- Tools.netMonitor,
- Tools.storage,
- Tools.scratchpad,
- Tools.memory,
- Tools.dom,
- ];
- exports.defaultTools = defaultTools;
- Tools.darkTheme = {
- id: "dark",
- label: l10n("options.darkTheme.label2"),
- ordinal: 1,
- stylesheets: ["chrome://devtools/skin/dark-theme.css"],
- classList: ["theme-dark"],
- };
- Tools.lightTheme = {
- id: "light",
- label: l10n("options.lightTheme.label2"),
- ordinal: 2,
- stylesheets: ["chrome://devtools/skin/light-theme.css"],
- classList: ["theme-light"],
- };
- Tools.firebugTheme = {
- id: "firebug",
- label: l10n("options.firebugTheme.label2"),
- ordinal: 3,
- stylesheets: ["chrome://devtools/skin/firebug-theme.css"],
- classList: ["theme-light", "theme-firebug"],
- };
- exports.defaultThemes = [
- Tools.darkTheme,
- Tools.lightTheme,
- Tools.firebugTheme,
- ];
- // White-list buttons that can be toggled to prevent adding prefs for
- // addons that have manually inserted toolbarbuttons into DOM.
- // (By default, supported target is only local tab)
- exports.ToolboxButtons = [
- { id: "command-button-frames",
- isTargetSupported: target => {
- return target.activeTab && target.activeTab.traits.frames;
- }
- },
- { id: "command-button-splitconsole",
- isTargetSupported: target => !target.isAddon },
- { id: "command-button-responsive" },
- { id: "command-button-paintflashing" },
- { id: "command-button-scratchpad" },
- { id: "command-button-screenshot" },
- { id: "command-button-rulers" },
- { id: "command-button-measure" },
- { id: "command-button-noautohide",
- isTargetSupported: target => target.chrome },
- ];
- /**
- * Lookup l10n string from a string bundle.
- *
- * @param {string} name
- * The key to lookup.
- * @param {string} arg
- * Optional format argument.
- * @returns A localized version of the given key.
- */
- function l10n(name, arg) {
- try {
- return arg ? L10N.getFormatStr(name, arg) : L10N.getStr(name);
- } catch (ex) {
- console.log("Error reading '" + name + "'");
- throw new Error("l10n error with " + name);
- }
- }
- function functionkey(shortkey) {
- return shortkey.split("_")[1];
- }
|