Skip to content
Snippets Groups Projects
webpack.client.common.js 1.31 KiB
Newer Older
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
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: [
    new CleanWebpackPlugin(['dist']),
    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.NamedModulesPlugin(),
    new webpack.HotModuleReplacementPlugin(),
    new webpack.DefinePlugin({
      'process.env.API_URL': JSON.stringify(apiUrl)
    })
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: /\.s?css$/,
Esko Ikkala's avatar
Esko Ikkala committed
        use: [
          'style-loader',
          'css-loader',
          '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']
  }
}