Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wechat-miniprogram/glass-easel-devtools

DevTools extension for glass-easel
https://github.com/wechat-miniprogram/glass-easel-devtools

Last synced: 3 days ago
JSON representation

DevTools extension for glass-easel

Awesome Lists containing this project

README

        



# glass-easel DevTools

DevTools for debugging [glass-easel](https://github.com/wechat-miniprogram/glass-easel) applications.

An important usage is to run as a browser DevTools extension. Install the extension in the browser, and it will add a `glass-easel` panel in the browser DevTools (F12).

However, it can also be integrated into other JS environments.

Still in rapid development.

## Installation

### Easy Installation

For Chrome, [install from the Chrome web store](https://chromewebstore.google.com/detail/glass-easel-devtools/oojokbffoladmkgochnnchnngjefidfd).

For Firefox, [install from the add-ons center](https://addons.mozilla.org/zh-CN/firefox/addon/glass-easel-devtools/).

### Manual Installation

If you want a pre-release build, see [releases](https://github.com/wechat-miniprogram/glass-easel-devtools/releases) for the latest builds.

For Chrome:

1. download the corresponding zip file;
1. unzip it;
1. go to [chrome://extensions/](chrome://extensions/), enable developer mode, and click *load unpacked* to load the unzipped directory.

For Firefox:

1. download the corresponding zip file;
1. unzip it;
1. go to [about:debugging#/runtime/this-firefox](about:debugging#/runtime/this-firefox), and *load temporary add-on* to load the unzipped directory.

## Usage

### Use Dev Builds of glass-easel

Firstly, the dev builds of glass-easel (version >= 0.9.0) should be used. By default, the glass-easel is built in production mode, which does not contain debug interfaces.

If you are using webpack, the best way to use the dev builds is adding following configuration into your `webpack.config.js` :

```js
{
resolve: {
alias: {
"glass-easel": "glass-easel/dist/glass_easel.dev.all.es.js"
}
}
}
```

This tells webpack to use the dev builds of glass-easel. Webpack will automatically replace all `import "glass-easel"` to `import "glass-easel/dist/glass_easel.dev.all.es.js"` under the hood.

If you are not using webpack, you can manually modify the code - `import "glass-easel/dist/glass_easel.dev.all.es.js"` instead of `import "glass-easel"` .

### Open the Browser DevTools

In the browser DevTools (F12), there should be a *glass-easel* panel.

If there is any mount point created by dev builds of glass-easel, it will be shown in the tree view.

## Development Guide

After git clone, run `pnpm install` to do basic setup.

### The Core Modules

The core modules are `glass-easel-devtools-agent` and `glass-easel-devtools-panel` , i.e. an agent and a panel.

The agent is an information extractor that should work along with glass-easel. The glass-easel dist should be built in development mode (i.e. `glass_easel.dev.all.es.js` ) and the agent can extract neccessary information from the glass-easel node tree.

The panel is the front end to display the information extracted by the agent. It can work in an independent environment, as long as it can communicate with the panel through a "message channel".

To build these two modules:

1. run `npm run build` in `glass-easel-devtools-agent` directory;
1. run `npm run build` in `glass-easel-devtools-panel` directory.

While development, run `npm run dev` instead (more debug logs and webpack will watch changes).

These two modules are also available as npm public packages.

### The Extension

The extension `glass-easel-devtools-extension` is a wrapper for both the agent and the panel. It acts as an Chrome/Firefox extension.

1. Run `npm run build` in `glass-easel-devtools-extension` directory to build the extension.
1. Then the directory can be loaded as an browser extension.
* In Chrome, open `chrome://extensions/` and load this extracted extension.
* In Firefox, open `about:debugging#/runtime/this-firefox` and temporarily load this extension.

This extension appears in DevTools (F12) in every web pages.

While development, run `npm run dev` instead.

### The Standalone Usage

The agent and the panel can also be loaded as common JS modules. The `examples/standalone` is an example that shows how to use them.

1. Run `npm run build` in `examples/miniprogram` directory to build a glass-easel application for debugging.
1. Run `npm run build` in `examples/standalone` directory.
1. Open the `examples/standalone/index.html` (may need a web server to host the directory).

While development, run `npm run dev` instead.

When developing the agent and the panel, the standalone environment is more convinient.