|
2 | 2 |
|
3 | 3 | module.exports = function extendWebpack(api, opts) { |
4 | 4 |
|
5 | | - api.assertVersion('>=0.3.0'); |
| 5 | + api.assertVersion('>=0.3.14'); |
6 | 6 |
|
7 | 7 | const registerMethods = require('./methods'); |
8 | 8 | registerMethods(api); |
9 | 9 |
|
10 | 10 | const { _, smartMerge } = require('@micro-app/shared-utils'); |
11 | 11 |
|
12 | | - // 扩增 microsConfig 配置 |
13 | | - api.modifyMicrosConfig(_config => { |
14 | | - const configParser = require('./configParser'); |
15 | | - const microsExtraConfig = api.microsExtraConfig; |
16 | | - return Object.keys(_config).reduce((obj, key) => { |
17 | | - const _configParser = configParser(obj, key, microsExtraConfig[key]); |
18 | | - Object.assign(obj[key], { |
19 | | - entry: _configParser.entry(), |
20 | | - htmls: _configParser.htmls(), |
21 | | - staticPaths: _configParser.staticPaths(), |
22 | | - }); |
23 | | - return obj; |
24 | | - }, _config); |
25 | | - }); |
26 | | - |
27 | | - // 扩增 config 配置 |
28 | | - api.modifyDefaultConfig(_config => { |
29 | | - const configCombine = require('./configCombine'); |
30 | | - const microsConfig = api.microsConfig; |
31 | | - const selfConfig = api.selfConfig; |
32 | | - const _selfConfigCombine = configCombine(selfConfig); |
33 | | - |
34 | | - function pickOptions(obj) { |
35 | | - return _.pick(obj, [ |
36 | | - 'alias', |
37 | | - 'resolveAlias', |
38 | | - 'shared', |
39 | | - 'resolveShared', |
40 | | - 'entry', |
41 | | - 'htmls', |
42 | | - 'staticPaths', |
43 | | - ]); |
44 | | - } |
45 | | - |
46 | | - const micros = api.micros; |
47 | | - const finalMicrosConfigs = micros.map(key => { |
48 | | - const obj = microsConfig[key]; |
49 | | - if (!obj) return {}; |
50 | | - const _configCombine = configCombine(obj); |
51 | | - return Object.assign({ |
52 | | - pages: _configCombine.pages(), |
53 | | - nodeModulesPaths: _configCombine.nodeModulesPaths(), |
54 | | - }, pickOptions(obj)); |
| 12 | + // 直接在 microsConfig 上设置, 扩增 microsConfig 配置 |
| 13 | + const configParser = require('./configParser'); |
| 14 | + const configCombine = require('./configCombine'); |
| 15 | + const microsExtraConfig = api.microsExtraConfig; |
| 16 | + const microsConfig = api.microsConfig; |
| 17 | + Object.keys(microsConfig).forEach(key => { |
| 18 | + const item = microsConfig[key]; |
| 19 | + const _configParser = configParser(microsConfig, key, microsExtraConfig[key]); |
| 20 | + Object.assign(item, { |
| 21 | + entry: _configParser.entry(), |
| 22 | + htmls: _configParser.htmls(), |
| 23 | + staticPaths: _configParser.staticPaths(), |
| 24 | + }); |
| 25 | + const _configCombine = configCombine(item); |
| 26 | + Object.assign(item, { |
| 27 | + pages: _configCombine.pages(), |
| 28 | + nodeModulesPaths: _configCombine.nodeModulesPaths(), |
55 | 29 | }); |
| 30 | + }); |
56 | 31 |
|
57 | | - const finalConfig = smartMerge({}, ...finalMicrosConfigs, Object.assign({ |
58 | | - pages: _selfConfigCombine.pages(), |
59 | | - nodeModulesPaths: _selfConfigCombine.nodeModulesPaths(), |
60 | | - }, pickOptions(selfConfig), selfConfig)); |
| 32 | + // 直接在 config 上设置, 扩增 config 配置 |
| 33 | + const config = api.config; |
61 | 34 |
|
62 | | - const originalConfig = selfConfig.originalConfig || {}; |
63 | | - const defaultConfig = { |
64 | | - outputDir: 'dist', |
65 | | - publicPath: '/', |
66 | | - assetsDir: '', |
67 | | - devServer: {}, |
68 | | - css: {}, |
69 | | - }; |
70 | | - const otherConfig = Object.assign({ // default config |
71 | | - ...defaultConfig, |
72 | | - }, _.pick(originalConfig, [ |
| 35 | + // 只使用所有配置中的一个 |
| 36 | + const originalConfig = smartMerge({}, ...Object.values(microsConfig).map(item => { |
| 37 | + const originalConfig = item.originalConfig || {}; |
| 38 | + return _.pick(originalConfig, [ |
73 | 39 | 'outputDir', |
74 | 40 | 'publicPath', |
75 | 41 | 'assetsDir', |
76 | 42 | 'devServer', |
77 | 43 | 'css', |
78 | | - ])); |
79 | | - // 校验 |
80 | | - return Object.assign({}, _config, _.cloneDeep(finalConfig), otherConfig); |
81 | | - }); |
| 44 | + ]); |
| 45 | + })); |
| 46 | + |
| 47 | + // 增加校验配置 |
| 48 | + api.validateSchema(require('./configSchema'), originalConfig); |
| 49 | + |
| 50 | + const defaultConfig = { // default config |
| 51 | + outputDir: 'dist', |
| 52 | + publicPath: '/', |
| 53 | + assetsDir: '', |
| 54 | + devServer: {}, |
| 55 | + css: {}, |
| 56 | + }; |
| 57 | + smartMerge(config, ...Object.values(microsConfig).map(item => { |
| 58 | + return _.pick(item || {}, [ |
| 59 | + 'entry', |
| 60 | + 'htmls', |
| 61 | + 'staticPaths', |
| 62 | + 'pages', |
| 63 | + 'nodeModulesPaths', |
| 64 | + ]); |
| 65 | + }), defaultConfig, originalConfig); |
| 66 | + |
82 | 67 | }; |
83 | 68 |
|
84 | 69 | module.exports.configuration = { |
|
0 commit comments