-
Notifications
You must be signed in to change notification settings - Fork 1
/
webpack.development.config.js
100 lines (95 loc) · 2.48 KB
/
webpack.development.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
const path = require('path');
const webpack = require('webpack');
const PACKAGE_VERSION = require('./package.json').version;
module.exports = {
entry: {
'main': './src/client/demo/index.js',
'rich-editors': './src/client/index.integration.js'
},
output: {
publicPath: '/static',
path: path.resolve(__dirname, 'build/client'),
filename: '[name].bundle.js',
library: 'react-[name]',
libraryTarget: 'umd'
},
devtool: 'inline-source-map',
plugins: [
new webpack.NoEmitOnErrorsPlugin(),
new webpack.DefinePlugin({
'process.env.HOST': JSON.stringify(process.env.HOST ? process.env.HOST : 'localhost'),
'process.env.PORT': JSON.stringify(process.env.PORT ? process.env.PORT : 3001)
})
],
resolve: {
modules: ['node_modules'],
extensions: ['.json', '.js']
},
resolveLoader: {
moduleExtensions: ['-loader']
},
module: {
loaders: [
{
include: /\.json$/,
loader: 'json-loader'
},
{
test : /\.(png|jpg|jpeg|gif|ttf|eot|svg|woff(2)?)(\?[a-z0-9=&.]+)?$/,
loader : 'file-loader'
},
{
test: /\.md$/,
loader: 'raw-loader'
},
{
test: /\.(css|less)$/,
use: [
{ loader: 'style-loader' },
{
loader: 'css-loader',
options: {
localIdentName: `[name]__[local]__${PACKAGE_VERSION}_[hash:base64:3]`,
modules: true
}
},
{
loader: 'postcss-loader',
options: {
config: path.resolve(__dirname, './postcss.config.js')
}
},
{ loader: 'less-loader', options: { sourceMap: true } }
],
include: /\.module\.(css|less)$/
},
{
test: /\.(css|less)$/,
use: [
{ loader: 'style-loader' },
{ loader: 'css-loader' },
{
loader: 'postcss-loader',
options: {
config: path.resolve(__dirname, './postcss.config.js')
}
},
{ loader: 'less-loader', options: { sourceMap: true } }
],
exclude: /\.module\.(css|less)$/
},
{
test: /.js$/,
loader: 'babel-loader',
include: [
path.join(__dirname, 'src/client'),
path.join(__dirname, 'server')
],
query: {
presets: ['es2015', 'react', 'stage-0'],
plugins: ['transform-decorators-legacy']
}
}
]
}
};