0.2.8 • Published 2 years ago
@shaojc/mv3-hot-reload v0.2.8
mv3-hot-reload
Enable hot reloading for content script and background script (service worker) in MV3.
Install
yarn add mv3-hot-reloadHow to use
1. Inject the code for hot reloading
Leverage Webpack's "multi-main entry" (Recommended)
// webpack.config.ts
const isDev = process.env.NODE_ENV === 'development'
function getEntry(name: string) {
  return [path.join(srcDir, name), ...(isDev ? [`mv3-hot-reload/${name}`] : [])]
}
const webpackConfig = {
  // ...
  entry: {
    // ...
    background: getEntry('background'),
    content: getEntry('content'),
  },
}Import files into your background script (service worker) and content script
The code for hot reloading will only execute when process.env.NODE_ENV === 'development'.
// background.ts
import 'mv3-hot-reload/background'
// your code...// content.ts
import 'mv3-hot-reload/content'
// your code...2. Add a script to your package.json and run it before development
Example:
    "watch:src": "webpack --config webpack/webpack.dev.js --watch",
+   "watch:dist": "mv3-hot-reload",
+   "dev": "concurrently yarn:watch:*",mv3-hot-reload.config.js (Optional)
module.exports = {
  // defaults to 9012
  port: 9012,
  globs: 'dist/*', // string || string[]
}If you want to set the port, you also need to expose it with process.env.MV3_HOT_RELOAD_PORT to
the client side.
An example:
// webpack.config.js
const config = require('./mv3-hot-reload.config')
module.exports = {
  // ...
  plugins: [
    new webpack.EnvironmentPlugin({
      MV3_HOT_RELOAD_PORT: config.port,
    }),
  ],
}Example
pacexy/chrome-extension-typescript-starter
Credits
The implementation of hot reloading in mv3 refers to theprimone/violet.
License
MIT
0.2.8
2 years ago