Skip to content
Snippets Groups Projects
webpack.client.common.js 1.15 KiB
Newer Older
Esko Ikkala's avatar
Esko Ikkala committed
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const webpack = require('webpack');

const outputDirectory = 'dist/public';

module.exports = {
  entry: {
    app: './src/client/index.js',
  },
  plugins: [
    new CleanWebpackPlugin(['dist']),
    new HtmlWebpackPlugin({
Esko Ikkala's avatar
Esko Ikkala committed
      title: 'Mapping Manuscript Migrations – A Digging into Data project for 2017-2019',
Esko Ikkala's avatar
Esko Ikkala committed
      // Load a custom template
      template: 'src/client/index.html',
    }),
    new webpack.NamedModulesPlugin(),
    new webpack.HotModuleReplacementPlugin()
Esko Ikkala's avatar
Esko Ikkala committed
  ],
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, outputDirectory),
esikkala's avatar
esikkala committed
    publicPath: '/'
Esko Ikkala's avatar
Esko Ikkala committed
  },
  module: {
    rules: [
      {
        test: /\.m?js$/,
Esko Ikkala's avatar
Esko Ikkala committed
        exclude: /node_modules/,
Esko Ikkala's avatar
Esko Ikkala committed
        use: ['babel-loader']
Esko Ikkala's avatar
Esko Ikkala committed
      },
      {
        test: /\.css$/,
        use: [
          'style-loader',
          'css-loader',
        ],
      },
      {
        test: /\.(png|svg|jpg|gif)$/,
        use: [
          'file-loader',
        ],
      },
    ],
  },
  resolve: {
    extensions: ['.js', '.jsx'],
  },
};