Note
This project is listed in the Awesome Vite
Tip
Share storage state between all pages
2024-07-20.12.36.15.mov
- Intro
- Features
- Structure
- Installation
- Install dependency
- Environment variables
- Troubleshooting
- Community
- Debugging
- Reference
- Star History
- Contributors
This boilerplate helps you create Chrome/Firefox extensions using React and Typescript. It improves the build speed and development experience by using Vite and Turborepo.
- React
- TypeScript
- Tailwindcss
- Vite with Rollup
- Turborepo
- Prettier
- ESLint
- Chrome Extensions Manifest Version 3
- Custom i18n package
- Custom HMR (Hot Module Rebuild) plugin
- End-to-end testing with WebdriverIO
- Clone this repository.( git clone https://github.com/Jonghakseo/chrome-extension-boilerplate-react-vite)
- Ensure your node version is >= than in .nvmrcfile, recommend to use nvm
- Edit /packages/i18n/locales/{your locale(s)}/messages.json
- In the objects extensionDescriptionandextensionName, change themessagefields (leavedescriptionalone)
- Install pnpm globally: npm install -g pnpm
- Run pnpm install
- Check if you have that configuration in your IDE/Editor:
- VS Code:
- Installed ESLint extension
- Installed Prettier extension
- Enabled Typescript Workbench versionin settings:- CTRL + SHIFT + P -> Search: Typescript: Select Typescript version...->Use Workbench version
- Read more
 
- CTRL + SHIFT + P -> Search: 
- Optional, for imports to work correctly in WSL, you might need to install the Remote - WSL extension and connect to WSL remotely from VS Code. See overview section in the extension page for more information.
 
- WebStorm:
 
- VS Code:
- Run pnpm update-version <version>for change theversionto the desired version of your extension.
Important
On Windows, make sure you have WSL enabled and Linux distribution (e.g. Ubuntu) installed on WSL.
Then, depending on the target browser:
- Run:
- Dev: pnpm dev(on Windows, you should run as administrator; see issue#456)
- Prod: pnpm build
 
- Dev: 
- Open in browser - chrome://extensions
- Check - Developer mode
- Click - Load unpacked in the upper left corner
- Select the distdirectory from the boilerplate project
- Run:
- Dev: pnpm dev:firefox
- Prod: pnpm build:firefox
 
- Dev: 
- Open in browser - about:debugging#/runtime/this-firefox
- Click - Load Temporary Add-on... in the upper right corner
- Select the ./dist/manifest.jsonfile from the boilerplate project
Note
In Firefox, you load add-ons in temporary mode. That means they'll disappear after each browser close. You have to load the add-on on every browser launch.
- Run pnpm i <package> -w
- Run pnpm i <package> -F <module name>
package - Name of the package you want to install e.g. nodemon 
module-name - You can find it inside each package.json under the key name, e.g. @extension/content-script, you
can use only content-script without @extension/ prefix
Read: Env Documentation
The extension lives in the chrome-extension directory and includes the following files:
- manifest.ts- script that outputs the- manifest.json
- src/background- background script (- background.service_workerin manifest.json)
- public- icons referenced in the manifest; content CSS for user's page injection
Important
To facilitate development, the boilerplate is configured to "Read and change all your data on all websites".
In production, it's best practice to limit the premissions to only the strictly necessary websites. See
Declaring permissions
and edit manifest.js accordingly.
Code that is transpiled to be part of the extension lives in the pages directory.
- content- Scripts injected into specified pages (You can see it in console)
- content-ui- React Components injected into specified pages (You can see it at the very bottom of pages)
- content-runtime- injected content scripts This can be injected from e.g.- popuplike standard- content
- devtools- extend the browser DevTools (- devtools_pagein manifest.json)
- devtools-panel- DevTools panel for devtools
- new-tab- override the default New Tab page (- chrome_url_overrides.newtabin manifest.json)
- options- options page (- options_pagein manifest.json)
- popup- popup shown when clicking the extension in the toolbar (- action.default_popupin manifest.json)
- side-panel- sidepanel (Chrome 114+) (- side_panel.default_pathin manifest.json)
Some shared packages:
- dev-utils- utilities for Chrome extension development (manifest-parser, logger)
- env- exports object which contain all environment variables from- .envand dynamically declared
- hmr- custom HMR plugin for Vite, injection script for reload/refresh, HMR dev-server
- i18n- custom internationalization package; provides i18n function with type safety and other validation
- shared- shared code for the entire project (types, constants, custom hooks, components etc.)
- storage- helpers for easier integration with storage, e.g. local/session storages
- tailwind-config- shared Tailwind config for entire project
- tsconfig- shared tsconfig for the entire project
- ui- function to merge your Tailwind config with the global one; you can save components here
- vite-config- shared Vite config for the entire project
Other useful packages:
- zipper- run- pnpm zipto pack the- distfolder into- extension-YYYYMMDD-HHmmss.zipinside the newly created- dist-zip
- module-manager- run- pnpm module-managerto enable/disable modules
- e2e- run- pnpm e2efor end-to-end tests of your zipped extension on different browsers
If saving source files doesn't cause the extension HMR code to trigger a reload of the browser page, try this:
- Ctrl+C the development server and restart it (pnpm run dev)
- If you get a grpcerror, kill theturboprocess and runpnpm devagain.
If you are using WSL and imports are not resolving correctly, ensure that you have connected VS Code to WSL remotely using the Remote - WSL extension.
To chat with other community members, you can join the Discord server. You can ask questions on that server, and you can also help others.
Also, suggest new features or share any challenges you've faced while developing Chrome extensions!
If you're debugging one, you can use Brie lets you capture screenshots, errors, and network activity, making it easier for us to help.
This Boilerplate is made possible thanks to all of its contributors.
|  | 
|---|
Made by Jonghakseo
