-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwebpack.common.js
More file actions
76 lines (72 loc) · 2.24 KB
/
webpack.common.js
File metadata and controls
76 lines (72 loc) · 2.24 KB
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
'use strict';
const path = require('path');
const {CleanWebpackPlugin} = require('clean-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const {CheckerPlugin} = require('awesome-typescript-loader');
const apps = require('./apps');
const entry = process.env.DEV_APP ? apps.getDevApplication(process.env.DEV_APP) : apps.getApplicationsToBeBuilt(process.env.APPS);
// @see https://www.typescriptlang.org/docs/handbook/react-&-webpack.html
module.exports = {
// Don't attempt to continue if there are any errors.
bail: true,
entry: entry,
output: {
filename: '[name].bundle.js',
chunkFilename: '[name].chunk.js',
path: path.resolve('./dist'),
// FIX-ME Not possible to use relative path corresponding to the target html in "assets/pages".
publicPath: '/',
},
resolve: {
extensions: ['.ts', '.tsx', '.js', '.jsx', '.json', '.less'],
modules: [
// Allow import from 'src/*'.
// @see https://stackoverflow.com/questions/27502608/resolving-require-paths-with-webpack
path.resolve('.'),
path.resolve('./node_modules'),
path.resolve('../node_modules'),
path.resolve('../../node_modules'),
path.resolve('../../../node_modules'),
],
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
template: `./assets/index.html`,
filename: './index.html',
}),
new CheckerPlugin(),
],
module: {
rules: [{
test: /\.html$/, use: [{loader: 'html-loader'}],
}, {
test: /\.tsx?$/, loader: 'awesome-typescript-loader',
}, {
// @see https://github.com/webpack-contrib/less-loader
test: /\.less$/,
use: [
// creates style nodes from JS strings
{loader: 'style-loader'},
// translates CSS into CommonJS
{loader: 'css-loader'},
// compiles Less to CSS
{loader: 'less-loader'},
],
}, {
test: /\.css$/,
use: [
{loader: 'style-loader'},
{loader: 'css-loader'},
],
}],
},
// // When importing a module whose path matches one of the following, just
// // assume a corresponding global variable exists and use that instead.
// // This is important because it allows us to avoid bundling all of our
// // dependencies, which allows browsers to cache those libraries between builds.
// externals: {
// 'react': 'React',
// 'react-dom': 'ReactDOM',
// },
};