Skip to content
Snippets Groups Projects
webpack.client.common.js 1.26 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');
esikkala's avatar
esikkala committed
const CopyWebpackPlugin = require('copy-webpack-plugin');
Esko Ikkala's avatar
Esko Ikkala committed
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(),
esikkala's avatar
esikkala committed
    new CopyWebpackPlugin([
      {from: 'src/client/img', to: 'img'}
    ])
Esko Ikkala's avatar
Esko Ikkala committed
  ],
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, outputDirectory),
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        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'],
  },
};