summaryrefslogtreecommitdiffstats
path: root/dox-sequence-diagram-ui/webpack.config.js
blob: bd5ea2ab0d6fda2d4243673e0d36b7150f8fb7c4 (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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
var webpack = require('webpack');
var path = require('path');

var PATHS = {
    SRC: path.resolve(__dirname, 'src/main/webapp'),
    TARGET: path.resolve(__dirname, 'dist')
};

module.exports = (env, argv) => {
    let devmode = argv.mode && argv.mode === 'development';
    let entry = [];
    if (devmode) {
        entry.push(path.resolve(PATHS.SRC, 'lib/main.jsx'));
    } else {
        entry.push(
            path.resolve(PATHS.SRC, 'lib/ecomp/asdc/sequencer/Sequencer.jsx')
        );
    }

    let config = {
        entry: entry,
        performance: { hints: false },
        output: {
            path: PATHS.TARGET,
            filename: 'index.js',
            libraryTarget: 'umd'
        },
        resolve: {
            extensions: ['.js', '.jsx']
        },
        devtool: 'eval-source-map',
        module: {
            rules: [
                {
                    test: /\.(js|jsx)$/,
                    loader: 'eslint-loader',
                    include: [/src/],
                    enforce: 'pre'
                },
                {
                    test: /\.(js|jsx)$/,
                    loader: 'babel-loader',
                    include: path.join(PATHS.SRC, 'lib')
                },
                {
                    test: /\.(css)$/,
                    use: [{ loader: 'style-loader' }, { loader: 'css-loader' }]
                },
                {
                    test: /\.(png|woff|woff2|eot|ttf|otf)$/,
                    loader: 'url-loader?limit=100000'
                },
                {
                    test: /\.scss$/,
                    include: path.join(PATHS.SRC, 'res'),
                    loaders: ['style-loader', 'css-loader', 'sass-loader']
                },
                {
                    test: /\.html$/,
                    include: path.join(PATHS.SRC, 'lib'),
                    loaders: ['raw-loader']
                },
                {
                    test: /\.svg$/,
                    loader: 'svg-sprite-loader',
                    options: {
                        symbolId: '[name]_[hash]',
                        extract: false
                    }
                }
            ]
        },
        externals: devmode
            ? {}
            : {
                  'd3-zoom': 'd3-zoom',
                  'd3-selection': 'd3-selection',
                  'lodash/merge': 'lodash/merge',
                  'lodash/template': 'lodash/template',
                  react: 'react',
                  'react-dnd': 'react-dnd',
                  'react-dnd-html5-backend': 'react-dnd-html5-backend',
                  'react-dom': 'react-dom',
                  'react-redux': 'react-redux',
                  'react-select': 'react-select',
                  redux: 'redux',
                  'prop-types': 'prop-types'
              },
        devServer: {
            port: 4096,
            quiet: false,
            contentBase: 'src/main/webapp',
            proxy: {
                '/services/*': {
                    target: 'http://localhost:38080/asdc-sequencer',
                    secure: false
                }
            }
        },
        plugins: devmode
            ? [
                  new webpack.DefinePlugin({
                      DEBUG: devmode === true,
                      DEV: devmode === true
                  }),
                  new webpack.HotModuleReplacementPlugin(),
                  new webpack.LoaderOptionsPlugin({
                      options: {
                          eslint: {
                              failOnWarning: false,
                              failOnError: false,
                              configFile: 'eslintrc.json'
                          },
                          context: '/'
                      }
                  })
              ]
            : [
                  new webpack.DefinePlugin({
                      DEBUG: devmode === true,
                      DEV: devmode === true
                  }),
                  new webpack.LoaderOptionsPlugin({
                      options: {
                          eslint: {
                              failOnWarning: false,
                              failOnError: false,
                              configFile: 'eslintrc.json'
                          },
                          context: '/'
                      }
                  })
              ]
    };

    return config;
};