2016-08-28 18:55:56 +05:30
|
|
|
/* eslint-env node */
|
|
|
|
|
2016-08-30 12:32:00 +05:30
|
|
|
const path = require('path');
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2016-08-30 12:32:00 +05:30
|
|
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
module.exports = (env, { mode = 'development' }) => {
|
|
|
|
const isProduction = mode === 'production';
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
return {
|
|
|
|
devtool: isProduction ? false : 'source-map',
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
entry: {
|
|
|
|
app: path.join(__dirname, 'src'),
|
|
|
|
},
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
target: isProduction ? 'node' : 'web',
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
output: {
|
|
|
|
path: path.join(__dirname, 'dist'),
|
|
|
|
publicPath: '/',
|
|
|
|
filename: isProduction ? '[name].js' : '[name].js?[hash]',
|
|
|
|
libraryTarget: isProduction ? 'commonjs2' : undefined,
|
|
|
|
},
|
2016-08-30 12:32:00 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
resolve: {
|
|
|
|
modules: [
|
|
|
|
path.join(__dirname, 'src'),
|
|
|
|
path.join(__dirname, 'node_modules'),
|
|
|
|
],
|
|
|
|
extensions: ['.js', '.jsx'],
|
|
|
|
},
|
2016-08-28 18:55:56 +05:30
|
|
|
|
2019-03-17 04:07:00 +05:30
|
|
|
resolveLoader: {
|
|
|
|
alias: {
|
|
|
|
'image-size-loader': path.join(__dirname, 'node_modules/@eoleo/image-size-loader/dist/cjs.js'),
|
2016-08-28 18:55:56 +05:30
|
|
|
},
|
2019-03-17 04:07:00 +05:30
|
|
|
},
|
|
|
|
|
|
|
|
devServer: {
|
|
|
|
host: 'localhost',
|
|
|
|
port: 8080,
|
|
|
|
hot: true,
|
|
|
|
inline: true,
|
|
|
|
historyApiFallback: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
plugins: [
|
|
|
|
new HtmlWebpackPlugin({
|
|
|
|
template: 'src/index.ejs',
|
|
|
|
favicon: 'src/favicon.ico',
|
|
|
|
filename: 'index.html',
|
|
|
|
inject: false,
|
|
|
|
}),
|
|
|
|
],
|
|
|
|
|
|
|
|
module: {
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
test: /\.jsx?$/,
|
|
|
|
exclude: /node_modules/,
|
|
|
|
use: [
|
|
|
|
{
|
|
|
|
loader: 'babel-loader',
|
|
|
|
options: {
|
|
|
|
presets: [
|
|
|
|
[
|
|
|
|
'@babel/preset-env',
|
|
|
|
{
|
|
|
|
targets: isProduction ? {
|
|
|
|
node: '8',
|
|
|
|
} : {
|
|
|
|
browsers: [
|
|
|
|
'last 1 chrome version',
|
|
|
|
'last 1 firefox version',
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'@babel/preset-react',
|
|
|
|
{
|
|
|
|
development: !isProduction,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
plugins: [
|
|
|
|
'@babel/plugin-proposal-class-properties',
|
|
|
|
'@babel/plugin-proposal-export-default-from',
|
|
|
|
// TODO: by unknown reasons react-intl plugins isn't working.
|
|
|
|
// investigate later
|
|
|
|
['react-intl', {
|
|
|
|
messagesDir: path.join(__dirname, 'dist/messages/'),
|
|
|
|
}],
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.(png|gif|jpg|svg)$/,
|
|
|
|
loader: 'file-loader',
|
|
|
|
query: {
|
|
|
|
name: 'assets/[name]-[folder].[ext]?[hash]',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.intl\.json$/,
|
|
|
|
loader: 'intl-json-loader',
|
|
|
|
type: 'javascript/auto',
|
|
|
|
},
|
|
|
|
]
|
|
|
|
},
|
|
|
|
};
|
2016-08-28 18:55:56 +05:30
|
|
|
};
|