aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/webpack.config.prod.ts
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-05-30 23:41:31 +0800
committerGitHub <noreply@github.com>2020-05-30 23:41:31 +0800
commitc8d71a3b5e7aef4fcf75bad44b7be90b45aaaf0b (patch)
treef76ecd77c99c4136d1ab4771b91a92f1e5ad4a35 /Timeline/ClientApp/webpack.config.prod.ts
parent7e393559d2883a37b1be0c82cccc06bc97c3d102 (diff)
parent83de798e74323e96e81b8196b04e23ed2bd4efbf (diff)
downloadtimeline-c8d71a3b5e7aef4fcf75bad44b7be90b45aaaf0b.tar.gz
timeline-c8d71a3b5e7aef4fcf75bad44b7be90b45aaaf0b.tar.bz2
timeline-c8d71a3b5e7aef4fcf75bad44b7be90b45aaaf0b.zip
Merge pull request #72 from crupest/merge-frontend
Merge frontend repo into this repo.
Diffstat (limited to 'Timeline/ClientApp/webpack.config.prod.ts')
-rw-r--r--Timeline/ClientApp/webpack.config.prod.ts59
1 files changed, 59 insertions, 0 deletions
diff --git a/Timeline/ClientApp/webpack.config.prod.ts b/Timeline/ClientApp/webpack.config.prod.ts
new file mode 100644
index 00000000..77ee7966
--- /dev/null
+++ b/Timeline/ClientApp/webpack.config.prod.ts
@@ -0,0 +1,59 @@
+import path from 'path';
+import webpack from 'webpack';
+import { CleanWebpackPlugin } from 'clean-webpack-plugin';
+import HtmlWebpackPlugin from 'html-webpack-plugin';
+import ForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin';
+import CopyPlugin from 'copy-webpack-plugin';
+
+import { commonRules, htmlCommonConfig } from './webpack.common';
+
+const config: webpack.Configuration = {
+ entry: ['./src/index.tsx'],
+ mode: 'production',
+ devtool: 'source-map',
+ module: {
+ rules: [
+ ...commonRules,
+ {
+ test: /\.(js|jsx|ts|tsx)$/,
+ exclude: /node_modules/,
+ loader: 'babel-loader'
+ }
+ ]
+ },
+ resolve: {
+ extensions: ['*', '.js', '.jsx', '.ts', '.tsx']
+ },
+ optimization: {
+ runtimeChunk: 'single',
+ splitChunks: {
+ chunks: 'all',
+ cacheGroups: {
+ vendor: {
+ test: /[\\/]node_modules[\\/]/,
+ name: 'vendors',
+ chunks: 'all'
+ }
+ }
+ }
+ },
+ output: {
+ path: path.resolve(__dirname, 'dist/'),
+ filename: '[name].[hash].js',
+ chunkFilename: '[name].[hash].js',
+ publicPath: '/'
+ },
+ plugins: [
+ new CleanWebpackPlugin(),
+ new HtmlWebpackPlugin(htmlCommonConfig),
+ new ForkTsCheckerWebpackPlugin(),
+ new CopyPlugin([
+ {
+ from: path.resolve(__dirname, 'public/'),
+ to: path.resolve(__dirname, 'dist/')
+ }
+ ])
+ ]
+};
+
+export default config;