forked from firefox-devtools/debugger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
122 lines (109 loc) · 3.37 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
"use strict";
require("babel-register");
const path = require("path");
const webpack = require("webpack");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const features = require("./config/feature");
const isDevelopment = features.isDevelopment;
const isFirefoxPanel = features.isFirefoxPanel;
const isEnabled = features.isEnabled;
const getConfig = require("./config/config").getConfig;
const NODE_ENV = process.env.NODE_ENV || "development";
const defaultBabelPlugins = [
"transform-flow-strip-types",
"transform-async-to-generator"
];
let webpackConfig = {
entry: {
bundle: ["./public/js/main.js"],
"source-map-worker": "./public/js/utils/source-map-worker.js",
"pretty-print-worker": "./public/js/utils/pretty-print-worker.js"
},
devtool: "source-map",
output: {
path: path.join(__dirname, "public/build"),
filename: "[name].js",
publicPath: "/public/build"
},
resolve: {
alias: {
"devtools/client/shared/vendor/react": "react",
"devtools/shared/event-emitter": path.join(
__dirname,
"./public/js/utils/event-emitter"
),
"devtools": path.join(__dirname, "./public/js/lib/devtools"),
"devtools-sham": path.join(__dirname, "./public/js/lib/devtools-sham"),
"sdk": path.join(__dirname, "./public/js/lib/devtools-sham/sdk"),
"Services": path.join(
__dirname,
"./public/js/lib/devtools/client/shared/shim/Services"
)
}
},
module: {
loaders: [
{ test: /\.json$/,
loader: "json" },
{ test: /\.js$/,
exclude: /(node_modules|bower_components)/,
loaders: [
"babel?" +
defaultBabelPlugins.map(p => "plugins[]=" + p) +
"&ignore=public/js/lib"
],
isJavaScriptLoader: true
},
{ test: /\.svg$/,
loader: "svg-inline" }
]
},
plugins: [
new webpack.DefinePlugin({
"process.env": {
NODE_ENV: JSON.stringify(NODE_ENV),
TARGET: JSON.stringify("local")
},
"DebuggerConfig": JSON.stringify(getConfig())
})
]
};
if (isDevelopment()) {
webpackConfig.module.loaders.push({
test: /\.css$/,
loader: "style!css"
});
if (isEnabled("hotReloading")) {
webpackConfig.entry.bundle.push("webpack-hot-middleware/client");
webpackConfig.plugins = webpackConfig.plugins.concat([
new webpack.HotModuleReplacementPlugin(),
new webpack.NoErrorsPlugin()
]);
webpackConfig.module.loaders.forEach(spec => {
if (spec.isJavaScriptLoader) {
spec.loaders.unshift("react-hot");
}
});
}
} else {
// Extract CSS into a single file
webpackConfig.module.loaders.push({
test: /\.css$/,
loader: ExtractTextPlugin.extract("style-loader", "css-loader")
});
webpackConfig.plugins.push(new ExtractTextPlugin("styles.css"));
}
if (isFirefoxPanel()) {
webpackConfig = require("./webpack.config.devtools")(webpackConfig);
}
// NOTE: This is only needed to fix a bug with chrome devtools' debugger and
// destructuring params https://github.com/devtools-html/debugger.html/issues/67
if (isEnabled("transformParameters")) {
webpackConfig.module.loaders.forEach(spec => {
if (spec.isJavaScriptLoader) {
const idx = spec.loaders.findIndex(loader => loader.includes("babel"));
spec.loaders[idx] += "&plugins[]=transform-es2015-parameters";
}
});
}
module.exports = webpackConfig;