Take dependency's webpack resolve configuration into consideration when bundling it with Webpack.
In some cases, you may want to resolve the code under node_modules with its own webpack resolve configuration. Assumes that you have the following project structure:
app
├── node_modules
| └── dependency
| ├── src
| | ├── containers
| | | └── index.js
| | └── index.js
| ├── index.js
| └── webpack.resolve.config.js
├── src
├── index.js
└── webpack.config.js
Here is the example code of each file:
// app/node_modules/dependency/src/containers/index.js
export default "containers in dependency"
// app/node_modules/dependency/src/index.js
import containers from "containers"
...
// app/node_modules/dependency/index.js
import app from "./src/index.js"
...
// app/node_modules/dependency/webpack.resolve.config.js
module.exports = {
resolve: {
modules: [
"node_modules",
path.resolve(__dirname, "src")
]
}
}
// app/index.js
import "dependency"
...
// app/webpack.config.js
module.exports = {
resolve: {
modules: [
"node_modules",
path.resolve(__dirname, "src")
]
}
}
If you run the app directly, webpack will fail with Cannot resolve "containers" in "app/node_modules/dependency/index.js"
error because webpack resolve the code under dependency with the resolve options in app/webpack.config.js. In this case, you can use WebpackResolveConfigPlugin to make webpack resolve the dependency code with dependency's webpack resolve configuration.
When webpack try to resolve a dependency in a file, it will pass a context to the resolver. Context is the current directory of the file. For instance, context will be app/node_modules/dependency/src
when webpack try to resolve containers
dependency in app/node_modules/dependency/src/index.js
file. WebpackResolveConfigPlugin hook into normalModuleFactory.beforeResolve to add dependency's own resolve confgurations to the resolveOptions passed to the resolver to make it resolve dependency based on current resolve config.
First things first, install it with npm/yarn:
// via npm
npm install --save-dev webpack-resolve-config-plugin
// via yarn
yarn add -D webpack-resolve-config-plugin
const WebpackResolveConfigPlugin = require("webpack-resolve-config-plugin")
module.exports = {
...
plugins: [
new WebpackResolveConfigPlugin(options)
]
}
You can pass a hash of configuration options to WebpackResolveConfigPlugin. Allowed values are as follows:
- [
include
]. Only the context matched with the regex ininclude
attribute will be resolved with its own configuration. Theinclude
attribute can be one of the following types:- Regex. A regex to test the resolve context.
- Object. The options object must have a
match
key which is a regex. Beside this, you can also provides the resolve configuration file name of the dependency(Default value for this iswebpack.resolve.config.js
) withfile
key. - Array. It can be either an array of regex or an array of the above options object.
- [
exclude
]. Context matched with the regex in exclude will be ignored by WebpackResolveConfigPlugin. Theexlcude
attribute can be one of the following types:- Regex. A regex to test the resolve context.
- Array. An array of regex.
Notes Exclude attribute has higher priority than the include attribute.
{
include: /dependency/,
exlcude: /anotherdependency/
}
{
include: {
match: /dependency/,
file: 'webpack.resolve.config.js'
}
}
{
include: [
{
match: /dependency1/,
file: 'webpack.resolve.js'
},
{
match: /dependency2/,
file: 'webpack.resolve.config.js'
}
],
exlcude: [
/dependency1/,
/dependency2/
]
}
The best practice to use WebpackResolveConfigPlugin is using a seperate configuration file for the resolve configuration(So the default webpack resolve configuration file is webpack.resolve.config.js
instead of webpack.config.js
). The reason for that is if you use a whole webpack configuration for the dependency, some dev dependencies of this package may needed to be installed to make it work.
The content of webpack.resolve.config.js is the exact same one documented in Webpack DOC.
Example:
const path = require('path')
module.exports = {
resolve: {
modules: [
'node_modules',
path.resolve(__dirname, 'src')
]
}
}