This repository contains the Rubberduck chrome extension, and the native host app (inside native-host
).
-
Install dependencies
yarn
-
For development, run this in watch mode. Note: this will require the native host to be configured first (see native-host/README.md)
npm run watch
-
Run tests with (defaults to watch mode).
yarn test
While we have a script to pack a crx file for distribution, it has stopped working after the webpack changes.
npm run pack
As an alternative, you can use the Chrome's pack an extension utility. Remember to add the keys/local_key.pem
file to maintain the development extension id.
-
To be able to pack crx (for production), you need to setup
keys/production_key.pem
in your project directory. Get this key from here (needs Google account). -
This should not be required if we are distributing the extension through the Chrome Store. See below for publishing.
-
To publish the extension, ensure that your account on the Chrome developer dashboard is setup.
-
Bump the version -- open
manifest.json
and bump the version depending on your changes. -
Generate the zip file for uploading using the following. This also uploads the source maps to Sentry.
npm run chrome-build
-
Upload the generated zip file (
bundle.zip
) on the Chrome dashboard.
The extension has three components, which are bundled individually through Webpack.
-
Background page: this is the main page of the extension (also called "event page") in the docs. The background page listens for some chrome events, and injects scripts to the page.
-
Content script: this is the script that is injected in the page using programmatic injection. Since the injected script renders elements, this is built using React.
-
Options page: this is the settings page. Not much to see here.