downgrade-webpack-loader-config
v0.1.2
Published
Downgrade webpack v2 config to v1 loadable
Downloads
2
Readme
downgrade-webpack-loader-config
Downgrade webpack v2 config to v1 loadable
Install
$ npm install -D downgrade-webpack-loader-config
Use case (When I use this package?)
- Prepare for upgrade webpack v2.
- Some sub tools compatibility (i.e. storybook)
Exmaple
Usage
const downgrade = require('downgrade-webpack-loader-config')
const webpack2Conf = require('../webpack.config') // webpack v2 config
const loaderConf = downgrade(webpack2Conf.module.rules)
// webpack v1 compatible config
module.exports = {
module: loaderConf,
}
Input / Output
const downgrade = require('downgrade-webpack-loader-config')
const v2Config = [
{
test: /.js?$/,
use: ['babel-loader'],
exclude: /node_modules/
},
{
test: /.js?$/,
enforce: "post",
use: ['eslint-loader'],
},
{
test: /\.css$/,
use: [
{ loader: 'style-loader' },
{ loader: 'css-loader', options: { modules: true } },
{ loader: 'postcss-loader' }
]
},
{
test: /\.(png|jpeg|svg)$/,
use: [
"url-loader"
]
}
]
const output = downgrade(v2Config)
assert.deepEqual(output, {
loaders: [
{ test: /.js?$/, loader: 'babel-loader' },
{ test: /\.css$/, loader: 'style-loader' },
{ test: /\.css$/,
loader: 'css-loader',
query: { modules: true }
},
{ test: /\.css$/, loader: 'postcss-loader' },
{ test: /\.(png|jpeg|svg)$/, loader: 'url-loader' }
],
"postLoaders": [
{ "test": /.js?$/, "loader": "eslint-loader" }
]
})
// => assert OK
References
- https://webpack.js.org/guides/migrating/#module-loaders-is-now-module-rules