diff options
| author | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
|---|---|---|
| committer | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
| commit | 1d5c4510dff326a0f12b914868ac8614ab460e83 (patch) | |
| tree | 7173f465175c6eb6b5bbfe96c932b49fd621f0b0 /webpack.config.js | |
| parent | c7c146adbd0b188eba56139ab914edaf73774d3f (diff) | |
| parent | e0f16b89cba102a4fcd156bb3d4148432eca2ab7 (diff) | |
merge
Diffstat (limited to 'webpack.config.js')
| -rw-r--r-- | webpack.config.js | 77 | 
1 files changed, 49 insertions, 28 deletions
| diff --git a/webpack.config.js b/webpack.config.js index 6a14dfcda..6265883fd 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -3,6 +3,36 @@ var webpack = require('webpack');  const CopyWebpackPlugin = require("copy-webpack-plugin");  const ForkTsCheckerWebpackPlugin = require("fork-ts-checker-webpack-plugin"); +const plugins = [ +    new CopyWebpackPlugin([{ +        from: "deploy", +        to: path.join(__dirname, "build") +    }]), +    new ForkTsCheckerWebpackPlugin({ +        tslint: true, +        useTypescriptIncrementalApi: true +    }), +    new webpack.optimize.OccurrenceOrderPlugin(), +    new webpack.HotModuleReplacementPlugin(), +]; + +const dotenv = require('dotenv'); + +function transferEnvironmentVariables() { +    const prefix = "_CLIENT_"; +    const env = dotenv.config().parsed; +    if (env) { +        plugins.push(new webpack.DefinePlugin(Object.keys(env).reduce((mapping, envKey) => { +            if (envKey.startsWith(prefix)) { +                mapping[`process.env.${envKey.replace(prefix, "")}`] = JSON.stringify(env[envKey]); +            } +            return mapping; +        }, {}))); +    } +} + +transferEnvironmentVariables(); +  module.exports = {      mode: 'development',      entry: { @@ -33,17 +63,18 @@ module.exports = {          extensions: ['.js', '.ts', '.tsx']      },      module: { -        rules: [ -            { +        rules: [{                  test: [/\.tsx?$/], -                use: [ -                    { loader: 'ts-loader', options: { transpileOnly: true } } -                ] +                use: [{ +                    loader: 'ts-loader', +                    options: { +                        transpileOnly: true +                    } +                }]              },              {                  test: /\.scss|css$/, -                use: [ -                    { +                use: [{                          loader: "style-loader"                      },                      { @@ -56,32 +87,22 @@ module.exports = {              },              {                  test: /\.(jpg|png|pdf)$/, -                use: [ -                    { -                        loader: 'file-loader' -                    } -                ] +                use: [{ +                    loader: 'file-loader' +                }]              },              {                  test: /\.(png|jpg|gif)$/i, -                use: [ -                    { -                        loader: 'url-loader', -                        options: { -                            limit: 8192 -                        } +                use: [{ +                    loader: 'url-loader', +                    options: { +                        limit: 8192                      } -                ] -            }] +                }] +            } +        ]      }, -    plugins: [ -        new CopyWebpackPlugin([{ from: "deploy", to: path.join(__dirname, "build") }]), -        new ForkTsCheckerWebpackPlugin({ -            tslint: true, useTypescriptIncrementalApi: true -        }), -        new webpack.optimize.OccurrenceOrderPlugin(), -        new webpack.HotModuleReplacementPlugin(), -    ], +    plugins,      devServer: {          compress: false,          host: "localhost", | 
