123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- const path = require('path');
- const webpack = require('webpack');
- const BabiliWebpackPlugin = require('babili-webpack-plugin');
- const vueLoaderConfig = require('./vue-loader.conf');
- const { IS_DEV, styleRule } = require('./utils');
- const DIST = 'dist';
- const definePlugin = new webpack.DefinePlugin({
- 'process.env': {
- NODE_ENV: JSON.stringify(process.env.NODE_ENV),
- // DEBUG: IS_DEV ? 'true' : 'false', // whether to log message errors
- DEBUG: 'false',
- },
- });
- function resolve(dir) {
- return path.join(__dirname, '..', dir);
- }
- module.exports = {
- output: {
- path: resolve(DIST),
- publicPath: '/',
- filename: '[name].js',
- },
- resolve: {
- extensions: ['.js', '.vue'],
- alias: {
- src: resolve('src'),
- }
- },
- node: {
- // css-loader requires unnecessary `Buffer` polyfill,
- // which increases the bundle size significantly.
- // See:
- // - https://github.com/webpack-contrib/css-loader/issues/454
- // - https://github.com/vuejs/vue-loader/issues/720
- Buffer: false,
- },
- module: {
- rules: [
- // {
- // test: /\.(js|vue)$/,
- // loader: 'eslint-loader',
- // enforce: 'pre',
- // include: [resolve('src'), resolve('test')],
- // options: {
- // formatter: require('eslint-friendly-formatter')
- // }
- // },
- {
- test: /\.vue$/,
- loader: 'vue-loader',
- options: vueLoaderConfig
- },
- {
- test: /\.js$/,
- loader: 'babel-loader',
- include: [resolve('src'), resolve('test')]
- },
- styleRule({
- fallback: 'vue-style-loader',
- loaders: ['postcss-loader'],
- }),
- ],
- },
- // cheap-module-eval-source-map is faster for development
- devtool: IS_DEV ? '#inline-source-map' : false,
- plugins: [
- definePlugin,
- !IS_DEV && new BabiliWebpackPlugin(),
- ].filter(Boolean),
- };
|