Arthur de Jong

Open Source / Free Software developer

summaryrefslogtreecommitdiffstats
path: root/webpack.config.js
blob: e39405018b04ceab91d9548b43e655469813e6dc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
const HtmlWebpackPlugin = require('html-webpack-plugin')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const ZipPlugin = require('./webpack-plugins/zip-plugin')
const path = require('path')
const webpack = require('webpack')

module.exports = (env, options) => {
  return {
    entry: './src/munin-plot.js',
    output: {
      filename: 'munin-plot.[contenthash].js',
      path: path.resolve(__dirname, 'muninplot/static'),
      publicPath: '',
      assetModuleFilename: '[name][ext]'
    },
    optimization: {
      minimize: options.mode === 'production'
    },
    plugins: [
      new MiniCssExtractPlugin({
        filename: 'munin-plot.[contenthash].css'
      }),
      new HtmlWebpackPlugin({
        template: 'src/index.html'
      }),
      new webpack.ProvidePlugin({
        $: 'jquery',
        Plotly: 'plotly.js/dist/plotly-basic',
        bootstrap: 'bootstrap',
        d3: 'd3',
        jQuery: 'jquery',
        moment: 'moment'
      }),
      new ZipPlugin({
        filename: 'munin-plot.zip',
        entries: [
          '*.py',
          '.eslintrc.yml',
          'COPYING',
          'MANIFEST.in',
          'NEWS',
          'README.md',
          'muninplot/**/*.py',
          'package*.json',
          'setup.cfg',
          'src/*.css',
          'src/*.html',
          'src/*.ico',
          'src/*.js',
          'src/*.png',
          'tox.ini',
          'webpack-plugins/*.js',
          'webpack.config.js'
        ]
      })
    ],
    module: {
      rules: [
        {
          test: /\.(sa|sc|c)ss$/,
          use: [
            MiniCssExtractPlugin.loader,
            'css-loader',
            'sass-loader'
          ]
        },
        {
          test: /\.(woff(2)?|ttf|eot|svg)$/,
          use: [
            {
              loader: 'file-loader',
              options: {
                name: '[name].[contenthash:20].[ext]',
                esModule: false
              }
            }
          ]
        },
        {
          test: /\.(ico|png)$/,
          type: 'asset/resource'
        },
        {
          test: /\.(html)$/,
          use: {
            loader: 'html-loader',
            options: {
              minimize: options.mode === 'production'
            }
          }
        }
      ]
    }
  }
}