File: //home/arjun/projects/buyercall/node_modules/flowbite/webpack.config.js
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const CssMinimizerPlugin = require("css-minimizer-webpack-plugin")
const TerserPlugin = require("terser-webpack-plugin")
const { SourceMapDevToolPlugin } = require("webpack")
const path = require('path');
module.exports = {
entry: {
datepicker: path.resolve(__dirname, 'src/plugins/datepicker.js'),
flowbite: path.resolve(__dirname, 'src/flowbite.js'),
docs: path.resolve(__dirname, 'src/docs.js')
},
output: {
filename: '[name].js',
path: path.resolve(__dirname, 'static/'),
},
module: {
rules: [
{
test: /\.js$/,
enforce: 'pre',
use: ['source-map-loader'],
},
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env']
}
}
},
{
test: /\.css$/,
use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader'],
},
{
test: /\.(png|jpg|gif|svg)$/,
loader: 'file-loader',
options: {
outputPath: 'static/images/'
}
},
{
test: /\.(ttf|eot|svg|gif|woff|woff2)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
use: [{
loader: 'file-loader',
}]
}
],
},
resolve: {
extensions: ['', '.js', '.jsx', '.css']
},
plugins: [
new MiniCssExtractPlugin(),
new SourceMapDevToolPlugin({
filename: "[file].map"
}),
],
optimization: {
minimize: true,
minimizer: [
// For webpack@5 you can use the `...` syntax to extend existing minimizers (i.e. `terser-webpack-plugin`), uncomment the next line
// `...`,
new CssMinimizerPlugin(),
new TerserPlugin()
],
}
};