This repository has been archived by the owner on Jul 4, 2022. It is now read-only.
forked from meganz/webclient
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
executable file
·124 lines (119 loc) · 4.16 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
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
var webpack = require("webpack");
var entryPoints = [
'./js/chat/chat.jsx',
'./js/chat/ui/conversations.jsx',
];
const path = require('path');
var webpackConfigs = {
dev: {
cache: false,
entry: {
app: [
'webpack-dev-server/client?http://localhost:8089', // WebpackDevServer host and port
'webpack/hot/only-dev-server', // "only" prevents reload on syntax errors
'react-hot-loader/patch'
].concat(entryPoints)
},
output: {
path: __dirname + "/.",
publicPath: "/",
filename: "js/chat/bundle.js"
},
devtool: "source-map",
externals: {
"jquery": "jQuery",
"react": "React",
"react-dom": "ReactDOM",
},
optimization: {
// We no not want to minimize our code.
minimize: false
},
module: {
rules: [
{test: /\.less$/, loader: "style!css!less"},
//{ test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader'},
//{ test: /\.jsx$/, loaders: ['react-hot', 'jsx?harmony&stripTypes&insertPragma=React.DOM'], exclude: 'node_modules'},
//{test: /\.jsx$/, loaders: ['react-hot', 'babel-loader?experimental=true&optional=runtime'], exclude: 'node_modules'},
{
test: /\.(js|jsx)$/,
exclude: /(node_modules|bower_components)/,
// include: [
// path.join(__dirname, '../js'), // + any other paths that need to be transpiled
// /\/node_modules\/react/,
// ],
use: [
'react-hot-loader/webpack',
{
loader: 'babel-loader',
options: {
presets: ['@babel/preset-react', '@babel/preset-env'],
// plugins: ['react-hot-loader/babel'],
}
}
]
},
{test: /\.json$/, loader: "json"}
]
},
plugins: [
new webpack.BannerPlugin({
raw: true,
banner: "React.makeElement = React['createElement'];"
})
]
},
dist: {
entry: {
app: entryPoints
},
output: {
path: __dirname + "/",
publicPath: "/",
filename: "js/chat/bundle.js"
},
module: {
rules: [
{test: /\.less$/, loader: "style!css!less"},
// {test: /\.jsx$/, loaders: ['babel-loader', 'stripcomment-loader'], exclude: 'node_modules'},
{
test: /\.(js|jsx)$/,
exclude: /(node_modules|bower_components)/,
use: [
// 'react-hot-loader/webpack',
{
loader: 'babel-loader',
options: {
presets: ['@babel/preset-react', '@babel/preset-env'],
// plugins: ['react-hot-loader/babel'],
}
}
]
},
{test: /\.json$/, loader: "json"}
]
},
optimization: {
// We no not want to minimize our code.
minimize: false
},
externals: {
"jquery": "jQuery",
"react": "React",
"react-dom": "ReactDOM",
},
plugins: [
new webpack.BannerPlugin({
"banner": "React.makeElement = React['createElement'];",
"raw": true
}),
new webpack.DefinePlugin({
"process.env": {
NODE_ENV: JSON.stringify("production"),
BROWSER: JSON.stringify(true)
}
})
]
}
};
module.exports = webpackConfigs[process.env.NODE_ENV == "production" ? "dist" : "dev"];