import path from 'path'; import webpack from 'webpack'; import * as dotenv from 'dotenv'; import HtmlWebpackPlugin from 'html-webpack-plugin'; import MiniCssExtractPlugin from 'mini-css-extract-plugin'; import { CleanWebpackPlugin } from 'clean-webpack-plugin'; import CssMinimizerPlugin from 'css-minimizer-webpack-plugin'; import TerserPlugin from 'terser-webpack-plugin'; import ESLintPlugin from 'eslint-webpack-plugin'; import { resolveTsAliases } from 'resolve-ts-aliases'; const dotEnvToParse = dotenv.config(); const externalCss = process.env.EXTERNAL_CSS === 'true' ? true : false const externalCssName = process.env.EXTERNAL_CSS_NAME ? process.env.EXTERNAL_CSS_NAME : 'index.css' const alias = resolveTsAliases(path.resolve('tsconfig.json')); export default { entry: './src/components/index.tsx', resolve: { extensions: ['.js', '.jsx','.ts','.tsx', '.json'], alias, }, mode: 'development', output: { path: path.resolve(__dirname, 'dist'), }, target: 'web', plugins: [ new CleanWebpackPlugin(), ...(externalCss === true ? [ new MiniCssExtractPlugin({ filename: externalCssName, }), ] : []), new webpack.DefinePlugin({ 'process.env': JSON.stringify(dotEnvToParse.parsed), }), new ESLintPlugin(), new HtmlWebpackPlugin({ template: path.join(__dirname, 'public', 'index.html'), }), new webpack.ProvidePlugin({ React: 'react', }), ], module: { rules: [ { test: /\.(js|jsx|ts|tsx)$/, exclude: /node_modules/, use: { loader: 'babel-loader', }, }, { test: /\.(css|sass|scss)$/, use: [ externalCss === true ? MiniCssExtractPlugin.loader : 'style-loader', { 'loader': 'css-loader', 'options': { modules: { auto: /\.module\.\w+$/i, } }, }, 'sass-loader', ], }, { test: /\.(ttf|otf|eot|woff|woff2)$/, loader: 'url-loader', options: { name: 'assets/fonts/[name].[ext]', esModule: false, }, }, ] }, optimization: { minimize: true, minimizer: [ new CssMinimizerPlugin(), new TerserPlugin(), ], }, }