| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- const path = require('path');
- const webpack = require('webpack');
- const MinifyPlugin = require('babel-minify-webpack-plugin');
- const VueLoaderPlugin = require('vue-loader/lib/plugin');
- const vueLoaderConfig = require('./vue-loader.conf');
- const { isDev, isProd, styleRule, definitions } = require('./utils');
- const DIST = 'dist';
- const definePlugin = new webpack.DefinePlugin(definitions);
- function resolve(dir) {
- return path.join(__dirname, '..', dir);
- }
- module.exports = {
- output: {
- path: resolve(DIST),
- publicPath: '/',
- filename: '[name].js',
- },
- resolve: {
- // Tell webpack to look for peer dependencies in `node_modules`
- // when packages are linked from outside directories
- modules: [resolve('node_modules')],
- extensions: ['.js', '.vue'],
- alias: {
- '#': resolve('src'),
- }
- },
- module: {
- rules: [
- {
- test: /\.vue$/,
- loader: 'vue-loader',
- options: vueLoaderConfig
- },
- {
- test: /\.js$/,
- loader: 'babel-loader',
- include: [resolve('src'), resolve('test')]
- },
- {
- test: /\.svg$/,
- loader: 'svg-sprite-loader',
- include: [resolve('src/resources/icons')],
- },
- styleRule({
- fallback: 'vue-style-loader',
- loaders: ['postcss-loader'],
- }),
- ],
- },
- // cheap-module-eval-source-map is faster for development
- devtool: isDev ? '#inline-source-map' : false,
- plugins: [
- definePlugin,
- new VueLoaderPlugin(),
- isProd && new MinifyPlugin(),
- ].filter(Boolean),
- };
|