yarn add module-mapper-webpack-plugin -D
// webpack.config.ts
import { ModuleReplaceWebpackPlugin, replacePath } from 'module-mapper-webpack-plugin'
export default {
// ...
plugins: [
new ModuleReplaceWebpackPlugin({
async replacer(requestInfo) {
// modify requestInfo object directly
requestInfo.request = 'absolute path or path relative to issuer'
// or return a new partial requestInfo
return {
request: 'absolute path or path relative to issuer',
}
// for example:
if (
!/\/file\.overlay\b/.test(requestInfo.contextInfo.issuer) &&
/\/file\b/.test(requestInfo.request)
) {
return {
request: replacePath(
reqPath =>
path.resolve(
path.resolve(requestInfo.context, reqPath),
'../file.overlay.js',
),
d.request,
),
}
}
return requestInfo
},
} as ModuleReplaceWebpackPlugin.ConstructOptions)
],
}
yarn build # build code
yarn watch # build and watch code