Works for Chrome, Opera, Edge & Firefox.
Write in your favorite framework - React! :)
Now you can create part of your extensions in React framework - as you wish ;)
Write once and deploy to Chrome, Opera, Edge & Firefox
Based on WebExtensions. It also includes a tiny polyfill to bring uniformity to the APIs exposed by different browsers.
Live-reload
Your changes to CSS, HTML & JS files will be relayed instantly without having to manually reload the extension. This ends up saving a lot of time and improving the developer experience. Based on https://github.com/xpl/crx-hotreload
Newest js technology stack
You can use ES6, ES5.
Comfortable styles import
With react you can load styles directly and you can use scss for styling.
Easily configurable and extendable
Project use webpack so you can easily customize your project depends on your needs. In config.json you can define source path for each browser (if needed - default it's the same source), destination and develop directory.
Clean code
Clean code is the best way for long term support for project. Boilerplate has fully configured eslint with airbnb style guide.
Test your components!
Project use some library which support your testing process. As test runner we use karma, as testing framework mocha. As support to assertion we use chai.
- Clone the repository
git clone https://github.com/WebExp0528/>React-Extension-Boilerplate.git
- Run
npm install
oryarn install
- Run
npm run build
oryarn build
Note: You can download build file
- Open Chrome/Opera browser and navigate to chrome://extensions
- Select "Developer Mode" and then click "Load unpacked extension..."
- From the file browser, choose to
React-Extension-Boilerplate/dev/chrome
or > (React-Extension-Boilerplate/dev/opera
)
- Open Firefox browser and navigate to about:debugging
- Click "Load Temporary Add-on" and from the file browser, choose >>
React-Extension-Boilerplate/dev/firefox
https://docs.microsoft.com/en-us/microsoft-edge/extensions/guides/adding-and-removing-extensions>
The following tasks can be used when you want to start developing the extension and want to enable live reload -
npm run watch-dev
oryarn watch-dev
Run
npm run build
oryarn build
to create a zipped, production-ready extension for each browser. You can then upload that to the app store.
This project is licensed under the MIT license.
If you have any questions or comments, please create a new issue. I'd be happy to hear your thoughts.