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

const outputDirectory = 'dist/public'
const apiUrl = typeof process.env.API_URL !== 'undefined' ? process.env.API_URL : 'http://localhost:3001/api/v1'
Esko Ikkala's avatar
Esko Ikkala committed

module.exports = {
  entry: {
    app: './src/client/index.js'
Esko Ikkala's avatar
Esko Ikkala committed
  },
  plugins: [
esikkala's avatar
esikkala committed
    /**
     * All files inside webpack's output.path directory will be removed once, but the
     * directory itself will not be. If using webpack 4+'s default configuration,
     * everything under <PROJECT_DIR>/dist/ will be removed.
     * Use cleanOnceBeforeBuildPatterns to override this behavior.
     *
     * During rebuilds, all webpack assets that are not used anymore
     * will be removed automatically.
    */
    new CleanWebpackPlugin(),
Esko Ikkala's avatar
Esko Ikkala committed
    new HtmlWebpackPlugin({
      // Load a custom template
esikkala's avatar
esikkala committed
      template: 'src/client/index.html',
      favicon: 'src/client/favicon.ico'
Esko Ikkala's avatar
Esko Ikkala committed
    }),
    new webpack.HotModuleReplacementPlugin(),
    new webpack.DefinePlugin({
      'process.env.API_URL': JSON.stringify(apiUrl)
    })
Esko Ikkala's avatar
Esko Ikkala committed
  ],
  output: {
esikkala's avatar
esikkala committed
    filename: '[name].[fullhash].js',
Esko Ikkala's avatar
Esko Ikkala committed
    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: /\.s?css$/,
Esko Ikkala's avatar
Esko Ikkala committed
        use: [
esikkala's avatar
esikkala committed
          // Creates `style` nodes from JS strings
Esko Ikkala's avatar
Esko Ikkala committed
          'style-loader',
esikkala's avatar
esikkala committed
          // Translates CSS into CommonJS
Esko Ikkala's avatar
Esko Ikkala committed
          'css-loader',
esikkala's avatar
esikkala committed
          // Compiles Sass to CSS
          'sass-loader'
        ]
Esko Ikkala's avatar
Esko Ikkala committed
      },
      {
        test: /\.(png|svg|jpg|gif)$/,
        use: [
          'file-loader'
        ]
      }
    ]
Esko Ikkala's avatar
Esko Ikkala committed
  },
  resolve: {
    extensions: ['.js', '.jsx']
  }
}