webpack.dev.config.js 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. const path = require('path');
  2. const webpack = require('webpack');
  3. const pckg = require('../package.json');
  4. const { merge } = require('webpack-merge');
  5. const baseWpConfig = require('./webpack.base.config');
  6. baseWpConfig.entry.unshift('webpack-hot-middleware/client');
  7. const HtmlWebpackPlugin = require('html-webpack-plugin');
  8. const CopyWebpackPlugin = require('copy-webpack-plugin');
  9. const publicDir = path.resolve(__dirname, `../server/.${pckg.name}/public`);
  10. const clientDir = path.resolve(__dirname, '../client');
  11. module.exports = merge(baseWpConfig, {
  12. mode: 'development',
  13. devtool: 'inline-source-map',
  14. output: {
  15. path: `${publicDir}${baseWpConfig.output.publicPath}`,
  16. filename: 'bundle.js',
  17. },
  18. module: {
  19. rules: [
  20. {
  21. test: /\.css$/,
  22. use: [
  23. 'vue-style-loader',
  24. 'css-loader'
  25. ]
  26. },
  27. ]
  28. },
  29. plugins: [
  30. new webpack.HotModuleReplacementPlugin(),
  31. new webpack.NoEmitOnErrorsPlugin(),
  32. new HtmlWebpackPlugin({
  33. template: `${clientDir}/index.html.template`,
  34. filename: `${publicDir}/index.html`
  35. }),
  36. new CopyWebpackPlugin({patterns: [{context: `${clientDir}/assets`, from: `${clientDir}/assets/*`, to: `${publicDir}/`}]})
  37. ]
  38. });