First off, thanks a lot for taking time to read this part. Extension.js' core phiolosophy is to make it very easy to develop browser extensions, and that includes the program that makes it happen as well. Hope this guide makes it very easy for you to contribute ;)
Extension.js runs on top of webpack using custom plugins. The whole Extension.js program consists of three core modules.
Program | Description |
---|---|
cli |
The Command Line Interface that executes the Extension.js programs. |
create |
Create extensions from built-in templates. This is what runs when extension create is fired. |
develop |
Wrapper around the webpack config that consists of the dev , start , and build commands. |
- Clone the project
git@github.com:cezaraugusto/extension.git
&&cd extension
. - Install dependencies (will symlink files where appropriate)
pnpm install
- Create an
.env
file at the project root and addEXTENSION_ENV=development
To watch and apply changes to the project, you will need two or more terminals open:
Use it to watch file changes. Under the hood this runs the compiler (pnpm compile
) infinitely.
pnpm watch
Now that you have the watcher running, running pnpm extension <command> [argument]
will emulate the production extension <command> [argument]
. Use it to experiment with the multiple Extension.js CLI commands.
pnpm extension <command> [argument]
That's all!
Extension.js uses its own templates for testing. If you need to test a React extension behavior for example, running pnpm extension dev ./examples/new-react
will open the new-react
template and use the defaults applied for a React configuration.
The monorepo's package.json
includes scripts that affect all programs and packages at once
and are needed for the project development.
This is the same command users run when they do `npx extension
pnpm extension <command> [args] [flags]
Compiles (builds) packages and programns. This npm script generates the /dist
folder that other packages may consume.
pnpm compile
Like compile, but listens for code changes, where it compiles again.
Note: You want a terminal always running this command during development.
pnpm watch
Iterates over all projects and lint them using ESLint.
pnpm lint
Run the test suite of each package and program (where available).
pnpm test
Deletes cache, dist/
and node_modules/
across packages and programs.
pnpm clean