-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack-config.js
122 lines (122 loc) · 5.48 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";
Object.defineProperty(exports, "__esModule", { value: true });
const webpack_1 = require("@ngtools/webpack");
const read_tsconfig_1 = require("../utilities/read-tsconfig");
const require_project_module_1 = require("../utilities/require-project-module");
const webpackMerge = require('webpack-merge');
const config_1 = require("./config");
const webpack_configs_1 = require("./webpack-configs");
const path = require("path");
class NgCliWebpackConfig {
constructor(buildOptions, appConfig) {
this.validateBuildOptions(buildOptions);
const configPath = config_1.CliConfig.configFilePath();
const projectRoot = path.dirname(configPath);
appConfig = this.addAppConfigDefaults(appConfig);
buildOptions = this.addTargetDefaults(buildOptions);
buildOptions = this.mergeConfigs(buildOptions, appConfig, projectRoot);
const tsconfigPath = path.resolve(projectRoot, appConfig.root, appConfig.tsconfig);
const tsConfig = read_tsconfig_1.readTsconfig(tsconfigPath);
const projectTs = require_project_module_1.requireProjectModule(projectRoot, 'typescript');
const supportES2015 = tsConfig.options.target !== projectTs.ScriptTarget.ES3
&& tsConfig.options.target !== projectTs.ScriptTarget.ES5;
this.wco = { projectRoot, buildOptions, appConfig, tsConfig, supportES2015 };
}
buildConfig() {
const platformConfig = this.wco.appConfig.platform === 'server' ?
webpack_configs_1.getServerConfig(this.wco) : webpack_configs_1.getBrowserConfig(this.wco);
let webpackConfigs = [
webpack_configs_1.getCommonConfig(this.wco),
platformConfig,
webpack_configs_1.getStylesConfig(this.wco),
this.getTargetConfig(this.wco)
];
if (this.wco.appConfig.main || this.wco.appConfig.polyfills) {
const typescriptConfigPartial = this.wco.buildOptions.aot
? webpack_configs_1.getAotConfig(this.wco)
: webpack_configs_1.getNonAotConfig(this.wco);
webpackConfigs.push(typescriptConfigPartial);
}
this.config = webpackMerge(webpackConfigs);
// 設定為 electron-renderer , 支援 Compile for electron renderer process
this.config.target = 'electron-renderer';
return this.config;
}
getTargetConfig(webpackConfigOptions) {
switch (webpackConfigOptions.buildOptions.target) {
case 'development':
return webpack_configs_1.getDevConfig(webpackConfigOptions);
case 'production':
return webpack_configs_1.getProdConfig(webpackConfigOptions);
}
}
// Validate build options
validateBuildOptions(buildOptions) {
buildOptions.target = buildOptions.target || 'development';
if (buildOptions.target !== 'development' && buildOptions.target !== 'production') {
throw new Error("Invalid build target. Only 'development' and 'production' are available.");
}
if (buildOptions.buildOptimizer
&& !(buildOptions.aot || buildOptions.target === 'production')) {
throw new Error('The `--build-optimizer` option cannot be used without `--aot`.');
}
}
// Fill in defaults for build targets
addTargetDefaults(buildOptions) {
const targetDefaults = {
development: {
environment: 'dev',
outputHashing: 'media',
sourcemaps: true,
extractCss: false,
namedChunks: true,
aot: false,
buildOptimizer: false
},
production: {
environment: 'prod',
outputHashing: 'all',
sourcemaps: false,
extractCss: true,
namedChunks: false,
aot: true
}
};
let merged = Object.assign({}, targetDefaults[buildOptions.target], buildOptions);
// Use Build Optimizer on prod AOT builds by default when AngularCompilerPlugin is supported.
const buildOptimizerDefault = {
buildOptimizer: buildOptions.target == 'production' && buildOptions.aot !== false
&& webpack_1.AngularCompilerPlugin.isSupported()
};
merged = Object.assign({}, buildOptimizerDefault, merged);
// Default vendor chunk to false when build optimizer is on.
const vendorChunkDefault = {
vendorChunk: !merged.buildOptimizer
};
merged = Object.assign({}, vendorChunkDefault, merged);
return merged;
}
// Fill in defaults from .angular-cli.json
mergeConfigs(buildOptions, appConfig, projectRoot) {
const mergeableOptions = {
outputPath: path.resolve(projectRoot, appConfig.outDir),
deployUrl: appConfig.deployUrl,
baseHref: appConfig.baseHref
};
return Object.assign({}, mergeableOptions, buildOptions);
}
addAppConfigDefaults(appConfig) {
const appConfigDefaults = {
testTsconfig: appConfig.tsconfig,
scripts: [],
styles: []
};
// can't use Object.assign here because appConfig has a lot of getters/setters
for (let key of Object.keys(appConfigDefaults)) {
appConfig[key] = appConfig[key] || appConfigDefaults[key];
}
return appConfig;
}
}
exports.NgCliWebpackConfig = NgCliWebpackConfig;
//# sourceMappingURL=/users/hansl/sources/hansl/angular-cli/models/webpack-config.js.map