Nuxt/lib/builder/webpack/base.config.js

138 lines
4.3 KiB
JavaScript
Raw Normal View History

const ExtractTextPlugin = require('extract-text-webpack-plugin')
const { cloneDeep } = require('lodash')
const { join, resolve } = require('path')
const { isUrl, urlJoin } = require('../../common/utils')
2017-12-29 08:56:32 +00:00
const vueLoader = require('./vue-loader')
const styleLoader = require('./style-loader')
const TimeFixPlugin = require('./plugins/timefix')
const WarnFixPlugin = require('./plugins/warnfix')
2016-11-07 01:34:58 +00:00
/*
|--------------------------------------------------------------------------
| Webpack Shared Config
|
2016-11-18 03:02:43 +00:00
| This is the config which is extended by the server and client
2016-11-07 01:34:58 +00:00
| webpack config files
|--------------------------------------------------------------------------
*/
module.exports = function webpackBaseConfig({ name, isServer }) {
// Prioritize nested node_modules in webpack search path (#2558)
const webpackModulesDir = ['node_modules'].concat(this.options.modulesDir)
2018-02-03 11:54:16 +00:00
const configAlias = {}
2018-02-03 11:10:06 +00:00
// Used by vue-loader so we can use in templates
// with <img src="~/assets/nuxt.png"/>
2018-02-03 16:04:15 +00:00
configAlias[this.options.dir.assets] = join(this.options.srcDir, this.options.dir.assets)
configAlias[this.options.dir.static] = join(this.options.srcDir, this.options.dir.static)
2018-02-03 11:10:06 +00:00
2017-06-15 22:19:53 +00:00
const config = {
name,
2018-02-26 10:26:31 +00:00
mode: this.options.dev ? 'development' : 'prodoction',
entry: {
2017-08-20 18:22:01 +00:00
app: null
},
output: {
2017-06-15 22:19:53 +00:00
path: resolve(this.options.buildDir, 'dist'),
filename: this.getFileName('app'),
chunkFilename: this.getFileName('chunk'),
publicPath: isUrl(this.options.build.publicPath)
2017-06-11 14:17:36 +00:00
? this.options.build.publicPath
: urlJoin(this.options.router.base, this.options.build.publicPath)
},
2016-12-15 17:53:00 +00:00
performance: {
2017-06-19 23:04:01 +00:00
maxEntrypointSize: 1000000,
2017-03-24 15:12:59 +00:00
maxAssetSize: 300000,
2017-06-15 22:19:53 +00:00
hints: this.options.dev ? false : 'warning'
2016-12-15 17:53:00 +00:00
},
resolve: {
2018-01-26 13:37:00 +00:00
extensions: ['.js', '.json', '.vue', '.jsx'],
2018-02-03 11:10:06 +00:00
alias: Object.assign({
2017-06-11 14:17:36 +00:00
'~': join(this.options.srcDir),
2017-07-04 14:21:41 +00:00
'~~': join(this.options.rootDir),
'@': join(this.options.srcDir),
2018-02-03 11:54:16 +00:00
'@@': join(this.options.rootDir)
}, configAlias),
modules: webpackModulesDir
},
resolveLoader: {
modules: webpackModulesDir
},
module: {
2017-08-14 14:03:07 +00:00
noParse: /es6-promise\.js$/, // Avoid webpack shimming process
rules: [
{
test: /\.vue$/,
2016-11-14 22:59:54 +00:00
loader: 'vue-loader',
2017-12-29 08:56:32 +00:00
options: vueLoader.call(this, { isServer })
},
{
2018-01-18 12:10:23 +00:00
test: /\.jsx?$/,
2016-11-14 22:59:54 +00:00
loader: 'babel-loader',
exclude: /node_modules/,
options: this.getBabelOptions({ isServer })
},
2017-12-29 08:56:32 +00:00
{ test: /\.css$/, use: styleLoader.call(this, 'css') },
{ test: /\.less$/, use: styleLoader.call(this, 'less', 'less-loader') },
{
test: /\.sass$/,
use: styleLoader.call(this, 'sass', {
loader: 'sass-loader',
options: { indentedSyntax: true }
})
},
2017-12-29 08:56:32 +00:00
{ test: /\.scss$/, use: styleLoader.call(this, 'scss', 'sass-loader') },
{
test: /\.styl(us)?$/,
use: styleLoader.call(this, 'stylus', 'stylus-loader')
},
2017-06-11 19:04:59 +00:00
{
test: /\.(png|jpe?g|gif|svg)$/,
loader: 'url-loader',
2017-08-14 14:03:07 +00:00
options: {
2017-06-11 19:04:59 +00:00
limit: 1000, // 1KO
name: 'img/[name].[hash:7].[ext]'
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url-loader',
2017-08-14 14:03:07 +00:00
options: {
2017-06-11 19:04:59 +00:00
limit: 1000, // 1 KO
name: 'fonts/[name].[hash:7].[ext]'
}
2017-07-31 08:41:40 +00:00
},
{
test: /\.(webm|mp4)$/,
2017-08-14 14:03:07 +00:00
loader: 'file-loader',
options: {
2017-08-01 15:40:31 +00:00
name: 'videos/[name].[hash:7].[ext]'
}
2017-06-11 19:04:59 +00:00
}
]
},
plugins: this.options.build.plugins
2016-11-07 01:34:58 +00:00
}
2017-06-15 22:19:53 +00:00
// Add timefix-plugin before others plugins
2017-06-15 22:19:53 +00:00
if (this.options.dev) {
config.plugins.unshift(new TimeFixPlugin())
2017-06-15 22:19:53 +00:00
}
2017-12-08 08:42:18 +00:00
// Hide warnings about plugins without a default export (#1179)
config.plugins.push(new WarnFixPlugin())
// CSS extraction
2017-11-11 12:52:45 +00:00
const extractCSS = this.options.build.extractCSS
if (extractCSS) {
const extractOptions = Object.assign(
{ filename: this.getFileName('css') },
2017-11-11 12:52:45 +00:00
typeof extractCSS === 'object' ? extractCSS : {}
2017-06-15 22:19:53 +00:00
)
2017-11-11 12:52:45 +00:00
config.plugins.push(new ExtractTextPlugin(extractOptions))
2017-06-15 22:19:53 +00:00
}
// Clone deep avoid leaking config between Client and Server
return cloneDeep(config)
2016-11-07 01:34:58 +00:00
}