| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 | var path = require('path')var config = require('../config')var utils = require('./utils')var projectRoot = path.resolve(__dirname, '../')var env = process.env.NODE_ENV// check env & config/index.js to decide weither to enable CSS Sourcemaps for the// various preprocessor loaders added to vue-loader at the end of this filevar cssSourceMapDev = (env === 'development' && config.dev.cssSourceMap)var cssSourceMapProd = (env === 'production' && config.build.productionSourceMap)var useCssSourceMap = cssSourceMapDev || cssSourceMapProdmodule.exports = {  entry: {    app: './src/main.js'  },  output: {    path: config.build.assetsRoot,    publicPath: process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath,    filename: '[name].js'  },  resolve: {    extensions: ['', '.js', '.vue'],    fallback: [path.join(__dirname, '../node_modules')],    alias: {      'vue$': 'vue/dist/vue',      'src': path.resolve(__dirname, '../src'),      'assets': path.resolve(__dirname, '../src/assets'),      'components': path.resolve(__dirname, '../src/components')    }  },  resolveLoader: {    fallback: [path.join(__dirname, '../node_modules')]  },  module: {    preLoaders: [      {        test: /\.vue$/,        loader: 'eslint',        include: projectRoot,        exclude: /node_modules/      },      {        test: /\.js$/,        loader: 'eslint',        include: projectRoot,        exclude: /node_modules/      }    ],    loaders: [      {        test: /\.vue$/,        loader: 'vue'      },      {        test: /\.js$/,        loader: 'babel',        include: projectRoot,        exclude: /node_modules/      },      {        test: /\.json$/,        loader: 'json'      },      {        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,        loader: 'url',        query: {          limit: 10000,          name: utils.assetsPath('img/[name].[hash:7].[ext]')        }      },      {        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,        loader: 'url',        query: {          limit: 10000,          name: utils.assetsPath('fonts/[name].[hash:7].[ext]')        }      }    ]  },  eslint: {    formatter: require('eslint-friendly-formatter')  },  vue: {    loaders: utils.cssLoaders({ sourceMap: useCssSourceMap }),    postcss: [      require('autoprefixer')({        browsers: ['last 2 versions']      })    ]  }}
 |