-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
64 lines (63 loc) · 1.41 KB
/
webpack.config.js
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
const path = require('path');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const BrowserSyncPlugin = require('browser-sync-webpack-plugin');
module.exports = {
"mode": "development",
"entry": {
"app": "./src/index.ts"
},
"devtool": "source-map",
"module": {
"rules": [
{
"test": /\.tsx?$/,
"exclude": /node_modules/,
"use": {
"loader": "ts-loader",
"options": {
"transpileOnly": true
}
}
},
{
"test": /\.scss$/,
"use": [
"style-loader",
"css-loader",
"sass-loader"
]
}
]
},
"resolve": {
"extensions": ['.ts', '.js', '.json']
},
"output": {
"path": __dirname+'/dist',
"filename": "[name].bundle.js"
},
"plugins": [
new CleanWebpackPlugin(['dist']),
new HtmlWebpackPlugin({
template: './src/index.html'
}),
new BrowserSyncPlugin({
host: 'localhost',
port: 8080,
publicPath: __dirname+'/dist',
server: { baseDir: [__dirname+'/dist'] }
})
],
devServer: {
contentBase: path.resolve(__dirname, 'public'),
publicPath: '/dist/',
host: '127.0.0.1',
port: 8080,
open: true
},
watchOptions: {
ignored: /node_modules/
},
watch: true
};