mirror of
				https://github.com/phuoc-ng/csslayout.git
				synced 2025-10-26 03:08:14 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * A collection of popular layouts and patterns made with CSS (https://csslayout.io)
 | |
|  * (c) 2019 - 2021 Nguyen Huu Phuoc <https://twitter.com/nghuuphuoc>
 | |
|  */
 | |
| 
 | |
| const path = require('path');
 | |
| const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
 | |
| const HtmlWebPackPlugin = require("html-webpack-plugin");
 | |
| const MiniCssExtractPlugin = require('mini-css-extract-plugin');
 | |
| 
 | |
| const plugins = [
 | |
|     new HtmlWebPackPlugin({
 | |
|         template: './client/index.html',
 | |
|         filename: './index.html',
 | |
|     }),
 | |
|     new MiniCssExtractPlugin({
 | |
|         filename: '[name].[contenthash].css',
 | |
|         ignoreOrder: false, // Enable to remove warnings about conflicting order
 | |
|     }),
 | |
| ];
 | |
|   
 | |
| if (process.env.NODE_ENV === "analyse") {
 | |
|     plugins.push(new BundleAnalyzerPlugin());
 | |
| }
 | |
| 
 | |
| module.exports = {
 | |
|     mode: process.env.NODE_ENV,
 | |
|     entry: {
 | |
|         client: './client/index.tsx',
 | |
|     },
 | |
|     output: {
 | |
|         path: path.join(__dirname, 'dist'),
 | |
|         filename: '[name].[contenthash].js',
 | |
|         // If user browser enables ad blocking, then the pattern likes `Cookie banner` can't be loaded
 | |
|         // In order to fix that, we remove the `[name]` from the bundled output
 | |
|         chunkFilename: '[contenthash].js',
 | |
|         // It's very important
 | |
|         // All the chunk generated by webpack then will be loaded such as
 | |
|         // <script charset="utf-8" src="/[chunk-name].bundle.js"></script>
 | |
|         // The script is accessible from any page that exported by a 3rd party such as react-snap
 | |
|         publicPath: '/',
 | |
|     },
 | |
|     module: {
 | |
|         rules: [
 | |
|             {
 | |
|                 test: /\.css$/,
 | |
|                 use: [
 | |
|                     {
 | |
|                         loader: MiniCssExtractPlugin.loader,
 | |
|                     },
 | |
|                     'css-loader',
 | |
|                 ],
 | |
|             },
 | |
|             {
 | |
|                 test: /\.ts(x?)$/,
 | |
|                 exclude: /node_modules/,
 | |
|                 // The order of loaders are very important
 | |
|                 // It will make the @loadable/component work
 | |
|                 use: ['babel-loader', 'ts-loader'],
 | |
|             },
 | |
|             {
 | |
|                 enforce: "pre",
 | |
|                 test: /\.js$/,
 | |
|                 loader: 'source-map-loader',
 | |
|             },
 | |
|         ],
 | |
|     },
 | |
|     resolve: {
 | |
|         extensions: ['.js', '.jsx', '.ts', '.tsx'],
 | |
|     },
 | |
|     devtool: process.env.NODE_ENV === 'production' ? false : 'source-map',
 | |
|     devServer: {
 | |
|         contentBase: path.join(__dirname, 'dist'),
 | |
|         historyApiFallback: true,
 | |
|         port: 1234,
 | |
|     },
 | |
|     plugins,
 | |
| }; |