-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathconfig.client.dev.js
73 lines (69 loc) · 1.82 KB
/
config.client.dev.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
import BrowserSyncPlugin from 'browser-sync-webpack-plugin';
import FriendlyErrorsWebpackPlugin from 'friendly-errors-webpack-plugin';
import webpack from 'webpack';
import getenv from 'getenv';
import path from 'path';
import { logServerConfigWebpack, webhost } from '@/utils/logger';
const Dir = global.DIR;
export function loader() {
return {
jsx: {
query: {
presets: [['es2015', { modules: false }], 'stage-0', 'react'],
plugins: [
'transform-decorators-legacy',
'transform-class-properties',
'transform-runtime',
'babel-root-import',
'react-hot-loader/babel',
],
},
},
cssModules: {
loaders: [
'style-loader',
['css-loader?modules',
'importLoaders=1',
'localIdentName=[name]__[local]___[hash:base64:5]']
.join('&'),
'postcss-loader',
],
},
};
}
export function config(entry) {
return {
devtool: 'cheap-module-eval-source-map',
entry: {
app: [
'babel-polyfill',
'isomorphic-fetch',
'whatwg-fetch',
'react-hot-loader/patch',
'webpack-hot-middleware/client',
// ['webpack-hot-middleware/client', webhost].join('?'),
path.join(Dir.src, entry, 'client'),
],
},
output: {
path: '/',
publicPath: '/',
filename: 'bundle.js',
},
plugins: [
new FriendlyErrorsWebpackPlugin({
clearConsole: true,
compilationSuccessInfo: {
messages: logServerConfigWebpack(entry),
},
}),
new BrowserSyncPlugin({
host: getenv('BROWSERSYNC_HOST'),
port: getenv('BROWSERSYNC_PORT'),
proxy: webhost(entry),
}, { reload: false }),
new webpack.HotModuleReplacementPlugin(),
new webpack.NoErrorsPlugin(),
],
};
}