gecko-dev/devtools/client/webconsole
2018-09-24 11:31:37 -07:00
..
actions Bug 1024913 - Enable reverse search in jsterm; r=bgrins,flod. 2018-09-10 10:24:40 +00:00
components Bug 1491354 - Extends top-level await mapping from debugger to toolbox; r=bgrins,jlast. 2018-09-24 08:17:30 +00:00
configs Bug 1442236 - Update console and netmonitor launchpads to v0.0.117; r=Honza. 2018-03-01 15:32:19 +01:00
enhancers Bug 1465455 - extract middleware and enhancer functions from store.js; r=nchevobbe 2018-06-08 08:21:32 +02:00
middleware Bug 1463095 - Instrument inspection of filter changes in the Web Console with event telemetry; r=jdescottes. 2018-07-24 09:55:36 +02:00
reducers Bug 1024913 - Enable reverse search in jsterm; r=bgrins,flod. 2018-09-10 10:24:40 +00:00
selectors Bug 1024913 - Enable reverse search in jsterm; r=bgrins,flod. 2018-09-10 10:24:40 +00:00
test Bug 1485676 - Fix missing await on TargetFactory.forTab in console tests after rebase. (hotfix) r=me 2018-09-24 11:31:37 -07:00
utils Bug 1470815 - Make sure the Security panel is visible for HTTP requests in the Console panel; r=nchevobbe 2018-08-22 11:14:45 +00:00
.babelrc Bug 1438476 - Fix launchpad configuration for console and netmonitor; r=jdescottes. 2018-02-16 14:59:51 +01:00
browser-console.js Bug 1460843 - Console clean up: split hudservice.js; r=nchevobbe 2018-07-02 17:08:02 +02:00
constants.js Bug 1024913 - Enable reverse search in jsterm; r=bgrins,flod. 2018-09-10 10:24:40 +00:00
hudservice.js Bug 1485605 - Remove usages of TabTarget.window. r=yulia 2018-09-20 12:16:51 +00:00
index.html Bug 1024913 - Enable reverse search in jsterm; r=bgrins,flod. 2018-09-10 10:24:40 +00:00
main.js Bug 1454696 - Run eslint --fix for prefer-const;r=yulia 2018-06-01 12:36:09 +02:00
moz.build Bug 1462399 - remove GCLI commands; r=ochameau 2018-09-03 17:24:32 +00:00
panel.js Bug 1485676 - Rename TabTarget.makeRemote to TabTarget.attach. r=jdescottes 2018-09-24 09:52:57 -07:00
README.md Bug 1486446 - Remove Console Launchpad support; r=bgrins. 2018-08-27 16:31:58 +00:00
store.js Bug 1024913 - Add a preference to enable the reverse search UI; r=bgrins. 2018-09-10 10:21:46 +00:00
types.js Bug 1486768 - Fix mocha tests;r=Honza. 2018-08-30 10:42:43 +00:00
utils.js Bug 1454696 - Run eslint --fix for prefer-const;r=yulia 2018-06-01 12:36:09 +02:00
webconsole-connection-proxy.js Bug 1466691 - Replace callback style in favor of promise for TabClient methods. r=jryans 2018-06-05 01:50:40 -07:00
webconsole-frame.js Bug 1487457 - Make console reflows faster; r=bgrins. 2018-08-31 12:51:36 +00:00
webconsole-l10n.js Bug 1454696 - Run eslint --fix for prefer-const;r=yulia 2018-06-01 12:36:09 +02:00
webconsole-output-wrapper.js Bug 1024913 - Move jsterm auto-focus handling into App.js; r=bgrins. 2018-09-10 10:22:47 +00:00
webconsole.js Bug 1491354 - Extends top-level await mapping from debugger to toolbox; r=bgrins,jlast. 2018-09-24 08:17:30 +00:00

WebConsole

The WebConsole (webconsole) shows you all the console API calls made by scripts and alerts you when javascript errors are thrown by a script. It can also display network logs, and you can evaluate expressions using the console input, a.k.a. JsTerm. You can read more about it on MDN to learn all the features and how to use the tool.

Run WebConsole

If you want to build the WebConsole inside of the DevTools toolbox (Firefox Devtools Panels), follow the simple Firefox build documentation. Start your compiled firefox and open the Firefox developer tool, you can then see the WebConsole tab.

Code Structure

Top level files are used to launch the WebConsole inside of the DevTools toolbox. The main files used to run the WebConsole are:

  • main.js called by devtools toolbox to launch the WebConsole panel.
  • index.html panel UI and launch scripts.

UI

The WebConsole UI is built using React components (in components/).

The React application is rendered from webconsole-output-wrapper.js. It contains 4 top components:

  • ConsoleOutput (in ConsoleOutput.js) is the component where messages are rendered.
  • FilterBar (in FilterBar.js) is the component for the filter bars (filter input and toggle buttons).
  • SideBar (in SideBar.js) is the component that render the sidebar where objects can be placed in.
  • JsTerm (in JsTerm.js) is the component that render the console input.

We prefer stateless component (defined by function) instead of stateful component (defined by class) unless the component has to maintain its internal state.

State

Besides the UI, the WebConsole manages the app state via [Redux]. The following locations define the app state:

  • src/constants.js constants used across the tool including action and event names.
  • src/actions/ for all actions that change the state.
  • src/reducers/ for all reducers that change the state.
  • src/selectors/ functions that return a formatted version of parts of the app state.

The redux state is a plain javascript object with the following properties:

{
  // State of the filter input and toggle buttons
  filters,
  // State of the input history
  history,
  // Console messages data and state (hidden, expanded, groups, …)
  messages,
  // State of notifications displayed on the output (e.g. self-XSS warning message)
  notifications,
  // Preferences (persist message, message limit, …)
  prefs,
  // Interface state (filter bar visible, sidebar visible, …)
  ui,
}

Tests

See test/README.md