@modern-js/app-tools 2.0.0-beta.2 → 2.0.0-canary.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (231) hide show
  1. package/CHANGELOG.md +251 -0
  2. package/bin/modern.js +10 -1
  3. package/dist/js/modern/analyze/constants.js +38 -16
  4. package/dist/js/modern/analyze/generateCode.js +271 -211
  5. package/dist/js/modern/analyze/getBundleEntry.js +31 -32
  6. package/dist/js/modern/analyze/getClientRoutes/getRoutes.js +93 -49
  7. package/dist/js/modern/analyze/getClientRoutes/getRoutesLegacy.js +89 -47
  8. package/dist/js/modern/analyze/getClientRoutes/index.js +6 -2
  9. package/dist/js/modern/analyze/getClientRoutes/utils.js +23 -10
  10. package/dist/js/modern/analyze/getFileSystemEntry.js +43 -22
  11. package/dist/js/modern/analyze/getHtmlTemplate.js +89 -49
  12. package/dist/js/modern/analyze/getServerRoutes.js +122 -126
  13. package/dist/js/modern/analyze/index.js +193 -159
  14. package/dist/js/modern/analyze/isDefaultExportFunction.js +30 -16
  15. package/dist/js/modern/analyze/makeLegalIdentifier.js +10 -11
  16. package/dist/js/modern/analyze/nestedRoutes.js +110 -53
  17. package/dist/js/modern/analyze/templates.js +190 -77
  18. package/dist/js/modern/analyze/utils.js +98 -51
  19. package/dist/js/modern/builder/builderPlugins/compatModern.js +124 -107
  20. package/dist/js/modern/builder/index.js +123 -86
  21. package/dist/js/modern/builder/loaders/routerLoader.js +17 -0
  22. package/dist/js/modern/builder/loaders/serverModuleLoader.js +7 -0
  23. package/dist/js/modern/builder/share.js +22 -20
  24. package/dist/js/modern/builder/webpackPlugins/htmlAsyncChunkPlugin.js +23 -22
  25. package/dist/js/modern/builder/webpackPlugins/htmlBottomTemplate.js +31 -27
  26. package/dist/js/modern/builder/webpackPlugins/routerPlugin.js +98 -84
  27. package/dist/js/modern/commands/build.js +67 -42
  28. package/dist/js/modern/commands/deploy.js +27 -4
  29. package/dist/js/modern/commands/dev.js +93 -47
  30. package/dist/js/modern/commands/index.js +1 -1
  31. package/dist/js/modern/commands/inspect.js +30 -5
  32. package/dist/js/modern/commands/start.js +37 -16
  33. package/dist/js/modern/config/default.js +103 -114
  34. package/dist/js/modern/config/index.js +8 -2
  35. package/dist/js/modern/config/initial/createHtmlConfig.js +5 -2
  36. package/dist/js/modern/config/initial/createOutputConfig.js +11 -9
  37. package/dist/js/modern/config/initial/createSourceConfig.js +5 -2
  38. package/dist/js/modern/config/initial/createToolsConfig.js +7 -6
  39. package/dist/js/modern/config/initial/index.js +9 -4
  40. package/dist/js/modern/config/initial/inits.js +109 -73
  41. package/dist/js/modern/config/initial/transformNormalizedConfig.js +6 -3
  42. package/dist/js/modern/defineConfig.js +26 -11
  43. package/dist/js/modern/exports/server.js +4 -1
  44. package/dist/js/modern/hooks.js +10 -3
  45. package/dist/js/modern/index.js +140 -89
  46. package/dist/js/modern/initialize/index.js +98 -51
  47. package/dist/js/modern/locale/en.js +20 -21
  48. package/dist/js/modern/locale/index.js +6 -6
  49. package/dist/js/modern/locale/zh.js +21 -22
  50. package/dist/js/modern/schema/Schema.js +6 -5
  51. package/dist/js/modern/schema/index.js +51 -100
  52. package/dist/js/modern/schema/legacy.js +96 -231
  53. package/dist/js/modern/types/config/index.js +0 -1
  54. package/dist/js/modern/types/index.js +0 -1
  55. package/dist/js/modern/types/legacyConfig/output.js +0 -1
  56. package/dist/js/modern/utils/commands.js +5 -2
  57. package/dist/js/modern/utils/config.js +102 -41
  58. package/dist/js/modern/utils/createFileWatcher.js +84 -51
  59. package/dist/js/modern/utils/createServer.js +63 -17
  60. package/dist/js/modern/utils/getSpecifiedEntries.js +46 -19
  61. package/dist/js/modern/utils/language.js +6 -3
  62. package/dist/js/modern/utils/printInstructions.js +27 -8
  63. package/dist/js/modern/utils/restart.js +43 -16
  64. package/dist/js/modern/utils/routes.js +29 -12
  65. package/dist/js/node/analyze/constants.js +54 -35
  66. package/dist/js/node/analyze/generateCode.js +290 -228
  67. package/dist/js/node/analyze/getBundleEntry.js +55 -44
  68. package/dist/js/node/analyze/getClientRoutes/getRoutes.js +132 -76
  69. package/dist/js/node/analyze/getClientRoutes/getRoutesLegacy.js +128 -74
  70. package/dist/js/node/analyze/getClientRoutes/index.js +23 -17
  71. package/dist/js/node/analyze/getClientRoutes/utils.js +44 -21
  72. package/dist/js/node/analyze/getFileSystemEntry.js +70 -39
  73. package/dist/js/node/analyze/getHtmlTemplate.js +116 -61
  74. package/dist/js/node/analyze/getServerRoutes.js +143 -137
  75. package/dist/js/node/analyze/index.js +240 -174
  76. package/dist/js/node/analyze/isDefaultExportFunction.js +55 -26
  77. package/dist/js/node/analyze/makeLegalIdentifier.js +27 -15
  78. package/dist/js/node/analyze/nestedRoutes.js +140 -67
  79. package/dist/js/node/analyze/templates.js +211 -84
  80. package/dist/js/node/analyze/utils.js +123 -62
  81. package/dist/js/node/builder/builderPlugins/compatModern.js +152 -120
  82. package/dist/js/node/builder/index.js +151 -95
  83. package/dist/js/node/builder/loaders/routerLoader.js +36 -0
  84. package/dist/js/node/builder/loaders/serverModuleLoader.js +26 -0
  85. package/dist/js/node/builder/share.js +45 -25
  86. package/dist/js/node/builder/webpackPlugins/htmlAsyncChunkPlugin.js +39 -26
  87. package/dist/js/node/builder/webpackPlugins/htmlBottomTemplate.js +47 -31
  88. package/dist/js/node/builder/webpackPlugins/routerPlugin.js +116 -90
  89. package/dist/js/node/commands/build.js +89 -52
  90. package/dist/js/node/commands/deploy.js +45 -10
  91. package/dist/js/node/commands/dev.js +115 -61
  92. package/dist/js/node/commands/index.js +19 -38
  93. package/dist/js/node/commands/inspect.js +48 -11
  94. package/dist/js/node/commands/start.js +65 -27
  95. package/dist/js/node/config/default.js +119 -118
  96. package/dist/js/node/config/index.js +25 -29
  97. package/dist/js/node/config/initial/createHtmlConfig.js +22 -6
  98. package/dist/js/node/config/initial/createOutputConfig.js +28 -13
  99. package/dist/js/node/config/initial/createSourceConfig.js +22 -6
  100. package/dist/js/node/config/initial/createToolsConfig.js +24 -10
  101. package/dist/js/node/config/initial/index.js +28 -17
  102. package/dist/js/node/config/initial/inits.js +126 -81
  103. package/dist/js/node/config/initial/transformNormalizedConfig.js +31 -15
  104. package/dist/js/node/defineConfig.js +43 -17
  105. package/dist/js/node/exports/server.js +21 -10
  106. package/dist/js/node/hooks.js +44 -29
  107. package/dist/js/node/index.js +190 -130
  108. package/dist/js/node/initialize/index.js +116 -61
  109. package/dist/js/node/locale/en.js +36 -25
  110. package/dist/js/node/locale/index.js +27 -15
  111. package/dist/js/node/locale/zh.js +37 -26
  112. package/dist/js/node/schema/Schema.js +23 -10
  113. package/dist/js/node/schema/index.js +77 -114
  114. package/dist/js/node/schema/legacy.js +117 -240
  115. package/dist/js/node/types/config/index.js +17 -16
  116. package/dist/js/node/types/index.js +19 -38
  117. package/dist/js/node/types/legacyConfig/output.js +0 -5
  118. package/dist/js/node/utils/commands.js +21 -6
  119. package/dist/js/node/utils/config.js +120 -51
  120. package/dist/js/node/utils/createFileWatcher.js +104 -60
  121. package/dist/js/node/utils/createServer.js +86 -25
  122. package/dist/js/node/utils/getSpecifiedEntries.js +64 -25
  123. package/dist/js/node/utils/language.js +24 -8
  124. package/dist/js/node/utils/printInstructions.js +47 -16
  125. package/dist/js/node/utils/restart.js +61 -21
  126. package/dist/js/node/utils/routes.js +53 -18
  127. package/dist/js/treeshaking/analyze/constants.js +28 -16
  128. package/dist/js/treeshaking/analyze/generateCode.js +604 -355
  129. package/dist/js/treeshaking/analyze/getBundleEntry.js +52 -63
  130. package/dist/js/treeshaking/analyze/getClientRoutes/getRoutes.js +214 -168
  131. package/dist/js/treeshaking/analyze/getClientRoutes/getRoutesLegacy.js +215 -169
  132. package/dist/js/treeshaking/analyze/getClientRoutes/index.js +3 -2
  133. package/dist/js/treeshaking/analyze/getClientRoutes/utils.js +19 -20
  134. package/dist/js/treeshaking/analyze/getFileSystemEntry.js +89 -86
  135. package/dist/js/treeshaking/analyze/getHtmlTemplate.js +298 -125
  136. package/dist/js/treeshaking/analyze/getServerRoutes.js +210 -146
  137. package/dist/js/treeshaking/analyze/index.js +558 -303
  138. package/dist/js/treeshaking/analyze/isDefaultExportFunction.js +45 -26
  139. package/dist/js/treeshaking/analyze/makeLegalIdentifier.js +13 -16
  140. package/dist/js/treeshaking/analyze/nestedRoutes.js +414 -160
  141. package/dist/js/treeshaking/analyze/templates.js +432 -161
  142. package/dist/js/treeshaking/analyze/utils.js +361 -80
  143. package/dist/js/treeshaking/builder/builderPlugins/compatModern.js +281 -195
  144. package/dist/js/treeshaking/builder/index.js +371 -165
  145. package/dist/js/treeshaking/builder/loaders/routerLoader.js +13 -0
  146. package/dist/js/treeshaking/builder/loaders/serverModuleLoader.js +5 -0
  147. package/dist/js/treeshaking/builder/share.js +41 -44
  148. package/dist/js/treeshaking/builder/webpackPlugins/htmlAsyncChunkPlugin.js +108 -44
  149. package/dist/js/treeshaking/builder/webpackPlugins/htmlBottomTemplate.js +70 -39
  150. package/dist/js/treeshaking/builder/webpackPlugins/routerPlugin.js +332 -112
  151. package/dist/js/treeshaking/commands/build.js +286 -88
  152. package/dist/js/treeshaking/commands/deploy.js +153 -25
  153. package/dist/js/treeshaking/commands/dev.js +318 -132
  154. package/dist/js/treeshaking/commands/index.js +1 -1
  155. package/dist/js/treeshaking/commands/inspect.js +147 -32
  156. package/dist/js/treeshaking/commands/start.js +190 -68
  157. package/dist/js/treeshaking/config/default.js +210 -199
  158. package/dist/js/treeshaking/config/index.js +3 -2
  159. package/dist/js/treeshaking/config/initial/createHtmlConfig.js +19 -31
  160. package/dist/js/treeshaking/config/initial/createOutputConfig.js +43 -67
  161. package/dist/js/treeshaking/config/initial/createSourceConfig.js +37 -40
  162. package/dist/js/treeshaking/config/initial/createToolsConfig.js +23 -38
  163. package/dist/js/treeshaking/config/initial/index.js +10 -9
  164. package/dist/js/treeshaking/config/initial/inits.js +205 -106
  165. package/dist/js/treeshaking/config/initial/transformNormalizedConfig.js +27 -34
  166. package/dist/js/treeshaking/defineConfig.js +60 -13
  167. package/dist/js/treeshaking/exports/server.js +2 -1
  168. package/dist/js/treeshaking/hooks.js +26 -25
  169. package/dist/js/treeshaking/index.js +465 -257
  170. package/dist/js/treeshaking/initialize/index.js +290 -112
  171. package/dist/js/treeshaking/locale/en.js +34 -33
  172. package/dist/js/treeshaking/locale/index.js +5 -5
  173. package/dist/js/treeshaking/locale/zh.js +34 -33
  174. package/dist/js/treeshaking/schema/Schema.js +267 -69
  175. package/dist/js/treeshaking/schema/index.js +165 -121
  176. package/dist/js/treeshaking/schema/legacy.js +323 -256
  177. package/dist/js/treeshaking/types/config/deploy.js +1 -0
  178. package/dist/js/treeshaking/types/config/dev.js +1 -0
  179. package/dist/js/treeshaking/types/config/experiments.js +1 -0
  180. package/dist/js/treeshaking/types/config/html.js +1 -0
  181. package/dist/js/treeshaking/types/config/index.js +0 -1
  182. package/dist/js/treeshaking/types/config/output.js +1 -0
  183. package/dist/js/treeshaking/types/config/performance.js +1 -0
  184. package/dist/js/treeshaking/types/config/security.js +1 -0
  185. package/dist/js/treeshaking/types/config/source.js +1 -0
  186. package/dist/js/treeshaking/types/config/tools.js +1 -0
  187. package/dist/js/treeshaking/types/hooks.js +1 -0
  188. package/dist/js/treeshaking/types/index.js +0 -1
  189. package/dist/js/treeshaking/types/legacyConfig/deploy.js +1 -0
  190. package/dist/js/treeshaking/types/legacyConfig/dev.js +1 -0
  191. package/dist/js/treeshaking/types/legacyConfig/index.js +1 -0
  192. package/dist/js/treeshaking/types/legacyConfig/output.js +1 -1
  193. package/dist/js/treeshaking/types/legacyConfig/source.js +1 -0
  194. package/dist/js/treeshaking/types/legacyConfig/tools.js +1 -0
  195. package/dist/js/treeshaking/utils/commands.js +6 -5
  196. package/dist/js/treeshaking/utils/config.js +295 -117
  197. package/dist/js/treeshaking/utils/createFileWatcher.js +278 -118
  198. package/dist/js/treeshaking/utils/createServer.js +252 -67
  199. package/dist/js/treeshaking/utils/getSpecifiedEntries.js +182 -55
  200. package/dist/js/treeshaking/utils/language.js +6 -5
  201. package/dist/js/treeshaking/utils/printInstructions.js +151 -29
  202. package/dist/js/treeshaking/utils/restart.js +184 -42
  203. package/dist/js/treeshaking/utils/routes.js +151 -27
  204. package/dist/js/treeshaking/utils/types.js +1 -0
  205. package/dist/types/analyze/constants.d.ts +2 -0
  206. package/dist/types/analyze/index.d.ts +2 -0
  207. package/dist/types/analyze/templates.d.ts +8 -7
  208. package/dist/types/analyze/utils.d.ts +9 -1
  209. package/dist/types/builder/builderPlugins/compatModern.d.ts +2 -1
  210. package/dist/types/builder/index.d.ts +2 -2
  211. package/dist/types/builder/loaders/routerLoader.d.ts +3 -0
  212. package/dist/types/builder/loaders/serverModuleLoader.d.ts +3 -0
  213. package/dist/types/builder/webpackPlugins/routerPlugin.d.ts +1 -7
  214. package/dist/types/defineConfig.d.ts +1 -0
  215. package/dist/types/index.d.ts +2 -0
  216. package/dist/types/initialize/index.d.ts +2 -0
  217. package/dist/types/types/config/index.d.ts +1 -0
  218. package/dist/types/types/config/output.d.ts +0 -1
  219. package/dist/types/types/config/source.d.ts +1 -0
  220. package/dist/types/types/config/tools.d.ts +10 -1
  221. package/dist/types/types/hooks.d.ts +2 -1
  222. package/dist/types/types/legacyConfig/dev.d.ts +1 -0
  223. package/dist/types/types/legacyConfig/output.d.ts +1 -1
  224. package/dist/types/types/legacyConfig/source.d.ts +1 -0
  225. package/dist/types/types/legacyConfig/tools.d.ts +1 -0
  226. package/dist/types/utils/config.d.ts +1 -0
  227. package/dist/types/utils/createFileWatcher.d.ts +2 -1
  228. package/dist/types/utils/createServer.d.ts +1 -0
  229. package/dist/types/utils/restart.d.ts +1 -1
  230. package/lib/types.d.ts +1 -1
  231. package/package.json +27 -23
@@ -1,69 +1,58 @@
1
- import path from 'path';
2
- import { ensureAbsolutePath, fs, findExists, MAIN_ENTRY_NAME } from '@modern-js/utils';
1
+ import path from "path";
2
+ import { ensureAbsolutePath, fs, findExists, MAIN_ENTRY_NAME } from "@modern-js/utils";
3
3
  import { getFileSystemEntry } from "./getFileSystemEntry";
4
4
  import { JS_EXTENSIONS } from "./constants";
5
- var ensureExtensions = function ensureExtensions(file) {
6
- if (!path.extname(file)) {
7
- return findExists(JS_EXTENSIONS.map(function (ext) {
8
- return "".concat(file).concat(ext);
9
- })) || file;
10
- }
11
- return file;
5
+ var ensureExtensions = function(file) {
6
+ if (!path.extname(file)) {
7
+ return findExists(JS_EXTENSIONS.map(function(ext) {
8
+ return "".concat(file).concat(ext);
9
+ })) || file;
10
+ }
11
+ return file;
12
+ };
13
+ var ifAlreadyExists = function(entrypoints, checked) {
14
+ return entrypoints.some(function(entrypoint) {
15
+ if (ensureExtensions(entrypoint.entry) === ensureExtensions(checked.entry)) {
16
+ checked.entryName = entrypoint.entryName;
17
+ return true;
18
+ }
19
+ if (entrypoint.entry.startsWith(checked.entry) || checked.entry.startsWith(entrypoint.entry)) {
20
+ throw new Error("Entry configuration conflicts\n Your configuration: ".concat(checked.entry, ".\n Default entrypoint: ").concat(entrypoint.entry, "\n Please reset source.entries or set source.disableDefaultEntries to disable the default entry rules."));
21
+ }
22
+ return false;
23
+ });
12
24
  };
13
- var ifAlreadyExists = function ifAlreadyExists(entrypoints, checked) {
14
- return entrypoints.some(function (entrypoint) {
15
- if (ensureExtensions(entrypoint.entry) === ensureExtensions(checked.entry)) {
16
- // reset entryName
17
- checked.entryName = entrypoint.entryName;
18
- return true;
25
+ var getBundleEntry = function(appContext, config) {
26
+ var appDirectory = appContext.appDirectory, packageName = appContext.packageName;
27
+ var _source = config.source, disableDefaultEntries = _source.disableDefaultEntries, entries = _source.entries, entriesDir = _source.entriesDir;
28
+ var defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
29
+ if (entries) {
30
+ Object.keys(entries).forEach(function(name) {
31
+ var value = entries[name];
32
+ var entrypoint = typeof value === "string" ? {
33
+ entryName: name,
34
+ entry: ensureAbsolutePath(appDirectory, value),
35
+ isAutoMount: true,
36
+ fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value)).isDirectory() ? {} : void 0
37
+ } : {
38
+ entryName: name,
39
+ entry: ensureAbsolutePath(appDirectory, value.entry),
40
+ isAutoMount: !value.disableMount,
41
+ fileSystemRoutes: value.enableFileSystemRoutes ? {} : void 0
42
+ };
43
+ if (!ifAlreadyExists(defaults, entrypoint)) {
44
+ defaults.push(entrypoint);
45
+ }
46
+ });
19
47
  }
20
- // filesystem routes entrypoint conflict with normal entrypoint.
21
- if (entrypoint.entry.startsWith(checked.entry) || checked.entry.startsWith(entrypoint.entry)) {
22
- throw new Error("Entry configuration conflicts\n Your configuration: ".concat(checked.entry, ".\n Default entrypoint: ").concat(entrypoint.entry, "\n Please reset source.entries or set source.disableDefaultEntries to disable the default entry rules."));
48
+ if (!disableDefaultEntries) {
49
+ var entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || "");
50
+ var found = defaults.find(function(param) {
51
+ var entryName = param.entryName, entry = param.entry, _nestedRoutesEntry = param.nestedRoutesEntry, nestedRoutesEntry = _nestedRoutesEntry === void 0 ? "" : _nestedRoutesEntry;
52
+ return entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs;
53
+ });
54
+ found && (found.entryName = MAIN_ENTRY_NAME);
23
55
  }
24
- return false;
25
- });
56
+ return defaults;
26
57
  };
27
- export var getBundleEntry = function getBundleEntry(appContext, config) {
28
- var appDirectory = appContext.appDirectory,
29
- packageName = appContext.packageName;
30
- var _config$source = config.source,
31
- disableDefaultEntries = _config$source.disableDefaultEntries,
32
- entries = _config$source.entries,
33
- entriesDir = _config$source.entriesDir;
34
- var defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
35
-
36
- // merge entrypoints from user config with directory convention.
37
- if (entries) {
38
- Object.keys(entries).forEach(function (name) {
39
- var value = entries[name];
40
- var entrypoint = typeof value === 'string' ? {
41
- entryName: name,
42
- entry: ensureAbsolutePath(appDirectory, value),
43
- isAutoMount: true,
44
- fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value)).isDirectory() ? {} : undefined
45
- } : {
46
- entryName: name,
47
- entry: ensureAbsolutePath(appDirectory, value.entry),
48
- isAutoMount: !value.disableMount,
49
- fileSystemRoutes: value.enableFileSystemRoutes ? {} : undefined
50
- };
51
- if (!ifAlreadyExists(defaults, entrypoint)) {
52
- defaults.push(entrypoint);
53
- }
54
- });
55
- }
56
- if (!disableDefaultEntries) {
57
- // find main entry point which server route is '/'.
58
- var entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || '');
59
- var found = defaults.find(function (_ref) {
60
- var entryName = _ref.entryName,
61
- entry = _ref.entry,
62
- _ref$nestedRoutesEntr = _ref.nestedRoutesEntry,
63
- nestedRoutesEntry = _ref$nestedRoutesEntr === void 0 ? '' : _ref$nestedRoutesEntr;
64
- return entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs;
65
- });
66
- found && (found.entryName = MAIN_ENTRY_NAME);
67
- }
68
- return defaults;
69
- };
58
+ export { getBundleEntry };
@@ -1,184 +1,230 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
- import _createForOfIteratorHelper from "@babel/runtime/helpers/esm/createForOfIteratorHelper";
3
- import path from 'path';
4
- import { fs } from '@modern-js/utils';
1
+ function _defineProperty(obj, key, value) {
2
+ if (key in obj) {
3
+ Object.defineProperty(obj, key, {
4
+ value: value,
5
+ enumerable: true,
6
+ configurable: true,
7
+ writable: true
8
+ });
9
+ } else {
10
+ obj[key] = value;
11
+ }
12
+ return obj;
13
+ }
14
+ function _objectSpread(target) {
15
+ for(var i = 1; i < arguments.length; i++){
16
+ var source = arguments[i] != null ? arguments[i] : {};
17
+ var ownKeys = Object.keys(source);
18
+ if (typeof Object.getOwnPropertySymbols === "function") {
19
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
20
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
21
+ }));
22
+ }
23
+ ownKeys.forEach(function(key) {
24
+ _defineProperty(target, key, source[key]);
25
+ });
26
+ }
27
+ return target;
28
+ }
29
+ function ownKeys(object, enumerableOnly) {
30
+ var keys = Object.keys(object);
31
+ if (Object.getOwnPropertySymbols) {
32
+ var symbols = Object.getOwnPropertySymbols(object);
33
+ if (enumerableOnly) {
34
+ symbols = symbols.filter(function(sym) {
35
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
36
+ });
37
+ }
38
+ keys.push.apply(keys, symbols);
39
+ }
40
+ return keys;
41
+ }
42
+ function _objectSpreadProps(target, source) {
43
+ source = source != null ? source : {};
44
+ if (Object.getOwnPropertyDescriptors) {
45
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
46
+ } else {
47
+ ownKeys(Object(source)).forEach(function(key) {
48
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
49
+ });
50
+ }
51
+ return target;
52
+ }
53
+ import path from "path";
54
+ import { fs } from "@modern-js/utils";
5
55
  import { makeLegalIdentifier } from "../makeLegalIdentifier";
6
56
  import { FILE_SYSTEM_ROUTES_COMPONENTS_DIR, FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP, FILE_SYSTEM_ROUTES_INDEX, FILE_SYSTEM_ROUTES_LAYOUT } from "../constants";
7
57
  import { replaceWithAlias } from "../utils";
8
58
  import { debug, findLayout, shouldSkip, getRouteWeight } from "./utils";
9
- var compName = function compName(srcDirectory, filePath) {
10
- var legalCompName = makeLegalIdentifier(path.relative(srcDirectory, filePath));
11
- return "Comp_".concat(legalCompName);
59
+ var compName = function(srcDirectory, filePath) {
60
+ var legalCompName = makeLegalIdentifier(path.relative(srcDirectory, filePath));
61
+ return "Comp_".concat(legalCompName);
12
62
  };
13
- var layoutNameAbbr = function layoutNameAbbr(filePath) {
14
- var prefix = 'L_';
15
- var dirName = path.dirname(filePath).split('/').pop() || '';
16
- return "".concat(prefix).concat(makeLegalIdentifier(dirName));
63
+ var layoutNameAbbr = function(filePath) {
64
+ var prefix = "L_";
65
+ var dirName = path.dirname(filePath).split("/").pop() || "";
66
+ return "".concat(prefix).concat(makeLegalIdentifier(dirName));
17
67
  };
18
68
  var parents = [];
19
-
20
- /* eslint-disable no-param-reassign */
21
- var recursiveReadDir = function recursiveReadDir(_ref) {
22
- var dir = _ref.dir,
23
- routes = _ref.routes,
24
- _ref$basePath = _ref.basePath,
25
- basePath = _ref$basePath === void 0 ? '/' : _ref$basePath,
26
- srcDirectory = _ref.srcDirectory,
27
- srcAlias = _ref.srcAlias;
28
- var hasDynamicRoute = false;
29
- var resetParent = false;
30
- var parent = parents[parents.length - 1];
31
- var layout = findLayout(dir);
32
- if (layout) {
33
- if (basePath === '/') {
34
- throw new Error("should use _app instead of _layout in ".concat(dir));
35
- } else {
36
- var alias = replaceWithAlias(srcDirectory, layout, srcAlias);
37
- var componentName = compName(srcDirectory, layout);
38
- var route = {
39
- path: "".concat(basePath.substring(0, basePath.length - 1)),
40
- children: [],
41
- _component: alias,
42
- component: componentName,
43
- parent: parent,
44
- type: 'page'
45
- };
46
- parent = route;
47
- resetParent = true;
48
- routes.push(route);
49
- parents.push(route);
50
- routes = route.children;
51
- }
52
- }
53
- var _iterator = _createForOfIteratorHelper(fs.readdirSync(dir)),
54
- _step;
55
- try {
56
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
57
- var relative = _step.value;
58
- var filePath = path.join(dir, relative);
59
- if (!shouldSkip(filePath)) {
60
- var filename = path.basename(filePath, path.extname(filePath));
61
- var _alias = replaceWithAlias(srcDirectory, filePath, srcAlias);
62
- var _componentName = compName(srcDirectory, filePath);
63
- var dynamicRouteMatched = FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP.exec(filename);
64
- if (dynamicRouteMatched) {
65
- if (hasDynamicRoute) {
66
- throw new Error("Can't set two dynamic route in one directory: ".concat(dir));
67
- } else {
68
- hasDynamicRoute = true;
69
- }
70
- }
71
- var _route = {
72
- path: "".concat(basePath).concat(dynamicRouteMatched ? ":".concat(dynamicRouteMatched[1]).concat(dynamicRouteMatched[2]) : filename),
73
- _component: _alias,
74
- component: _componentName,
75
- parent: parent,
76
- type: 'page'
77
- };
78
- if (fs.statSync(filePath).isDirectory()) {
79
- recursiveReadDir({
80
- dir: filePath,
81
- routes: routes,
82
- basePath: "".concat(_route.path, "/"),
83
- srcDirectory: srcDirectory,
84
- srcAlias: srcAlias
85
- });
86
- continue;
69
+ var recursiveReadDir = function(param) {
70
+ var dir = param.dir, routes = param.routes, _basePath = param.basePath, basePath = _basePath === void 0 ? "/" : _basePath, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias;
71
+ var hasDynamicRoute = false;
72
+ var resetParent = false;
73
+ var parent = parents[parents.length - 1];
74
+ var layout = findLayout(dir);
75
+ if (layout) {
76
+ if (basePath === "/") {
77
+ throw new Error("should use _app instead of _layout in ".concat(dir));
78
+ } else {
79
+ var alias = replaceWithAlias(srcDirectory, layout, srcAlias);
80
+ var componentName = compName(srcDirectory, layout);
81
+ var route = {
82
+ path: "".concat(basePath.substring(0, basePath.length - 1)),
83
+ children: [],
84
+ _component: alias,
85
+ component: componentName,
86
+ parent: parent,
87
+ type: "page"
88
+ };
89
+ parent = route;
90
+ resetParent = true;
91
+ routes.push(route);
92
+ parents.push(route);
93
+ routes = route.children;
87
94
  }
88
- if (filename === FILE_SYSTEM_ROUTES_LAYOUT) {
89
- continue;
90
- }
91
- if (filename === FILE_SYSTEM_ROUTES_INDEX) {
92
- _route.path = basePath === '/' ? basePath : "".concat(basePath.substring(0, basePath.length - 1));
95
+ }
96
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
97
+ try {
98
+ for(var _iterator = fs.readdirSync(dir)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
99
+ var relative = _step.value;
100
+ var filePath = path.join(dir, relative);
101
+ if (!shouldSkip(filePath)) {
102
+ var filename = path.basename(filePath, path.extname(filePath));
103
+ var alias1 = replaceWithAlias(srcDirectory, filePath, srcAlias);
104
+ var componentName1 = compName(srcDirectory, filePath);
105
+ var dynamicRouteMatched = FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP.exec(filename);
106
+ if (dynamicRouteMatched) {
107
+ if (hasDynamicRoute) {
108
+ throw new Error("Can't set two dynamic route in one directory: ".concat(dir));
109
+ } else {
110
+ hasDynamicRoute = true;
111
+ }
112
+ }
113
+ var route1 = {
114
+ path: "".concat(basePath).concat(dynamicRouteMatched ? ":".concat(dynamicRouteMatched[1]).concat(dynamicRouteMatched[2]) : filename),
115
+ _component: alias1,
116
+ component: componentName1,
117
+ parent: parent,
118
+ type: "page"
119
+ };
120
+ if (fs.statSync(filePath).isDirectory()) {
121
+ recursiveReadDir({
122
+ dir: filePath,
123
+ routes: routes,
124
+ basePath: "".concat(route1.path, "/"),
125
+ srcDirectory: srcDirectory,
126
+ srcAlias: srcAlias
127
+ });
128
+ continue;
129
+ }
130
+ if (filename === FILE_SYSTEM_ROUTES_LAYOUT) {
131
+ continue;
132
+ }
133
+ if (filename === FILE_SYSTEM_ROUTES_INDEX) {
134
+ route1.path = basePath === "/" ? basePath : "".concat(basePath.substring(0, basePath.length - 1));
135
+ }
136
+ if (filename === "404" && basePath === "/") {
137
+ route1.path = "*";
138
+ }
139
+ routes.push(route1);
140
+ }
93
141
  }
94
- if (filename === '404' && basePath === '/') {
95
- _route.path = '*';
142
+ } catch (err) {
143
+ _didIteratorError = true;
144
+ _iteratorError = err;
145
+ } finally{
146
+ try {
147
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
148
+ _iterator.return();
149
+ }
150
+ } finally{
151
+ if (_didIteratorError) {
152
+ throw _iteratorError;
153
+ }
96
154
  }
97
- routes.push(_route);
98
- }
99
155
  }
100
- } catch (err) {
101
- _iterator.e(err);
102
- } finally {
103
- _iterator.f();
104
- }
105
- if (resetParent) {
106
- parents.pop();
107
- }
108
- };
109
- /* eslint-enable no-param-reassign */
110
-
111
- var normalizeNestedRoutes = function normalizeNestedRoutes(nested, internalComponentsDir, internalDirectory, internalDirAlias) {
112
- var flat = function flat(routes) {
113
- return routes.reduce(function (memo, route) {
114
- return memo.concat(Array.isArray(route.children) ? flat(route.children) : [route]);
115
- }, []);
116
- };
117
- var generate = function generate(route) {
118
- var codes = [];
119
- var lastComponent = route.component;
120
- var imports = ["import React from 'react';", "import ".concat(lastComponent, " from '").concat(route._component, "'")];
121
-
122
- // eslint-disable-next-line no-param-reassign, no-cond-assign
123
- while (route = route.parent) {
124
- var layoutComponent = route.component;
125
- var layoutComponentAbbr = layoutNameAbbr(route._component);
126
- imports.push("import ".concat(layoutComponent, " from '").concat(route._component, "';"));
127
- var currentComponent = "".concat(layoutComponentAbbr, "_").concat(lastComponent);
128
- codes.push("const ".concat(currentComponent, " = props => <").concat(layoutComponent, " Component={").concat(lastComponent, "} {...props} />;"));
129
- lastComponent = currentComponent;
156
+ if (resetParent) {
157
+ parents.pop();
130
158
  }
131
- var file = path.resolve(internalComponentsDir, "".concat(lastComponent, ".jsx"));
132
- fs.outputFileSync(file, "".concat(imports.join('\n'), "\n").concat(codes.join('\n'), "\nexport default ").concat(lastComponent));
133
- return {
134
- component: lastComponent,
135
- _component: replaceWithAlias(internalDirectory, file, internalDirAlias)
159
+ };
160
+ var normalizeNestedRoutes = function(nested, internalComponentsDir, internalDirectory, internalDirAlias) {
161
+ var flat = function(routes) {
162
+ return routes.reduce(function(memo, route) {
163
+ return memo.concat(Array.isArray(route.children) ? flat(route.children) : [
164
+ route
165
+ ]);
166
+ }, []);
167
+ };
168
+ var generate = function(route) {
169
+ var codes = [];
170
+ var lastComponent = route.component;
171
+ var imports = [
172
+ "import React from 'react';",
173
+ "import ".concat(lastComponent, " from '").concat(route._component, "'")
174
+ ];
175
+ while(route = route.parent){
176
+ var layoutComponent = route.component;
177
+ var layoutComponentAbbr = layoutNameAbbr(route._component);
178
+ imports.push("import ".concat(layoutComponent, " from '").concat(route._component, "';"));
179
+ var currentComponent = "".concat(layoutComponentAbbr, "_").concat(lastComponent);
180
+ codes.push("const ".concat(currentComponent, " = props => <").concat(layoutComponent, " Component={").concat(lastComponent, "} {...props} />;"));
181
+ lastComponent = currentComponent;
182
+ }
183
+ var file = path.resolve(internalComponentsDir, "".concat(lastComponent, ".jsx"));
184
+ fs.outputFileSync(file, "".concat(imports.join("\n"), "\n").concat(codes.join("\n"), "\nexport default ").concat(lastComponent));
185
+ return {
186
+ component: lastComponent,
187
+ _component: replaceWithAlias(internalDirectory, file, internalDirAlias)
188
+ };
136
189
  };
137
- };
138
- var normalized = flat(nested).map(function (route) {
139
- return route.parent ? _objectSpread(_objectSpread(_objectSpread({}, route), generate(route)), {}, {
140
- parent: undefined
141
- }) : _objectSpread(_objectSpread({}, route), {}, {
142
- parent: undefined
190
+ var normalized = flat(nested).map(function(route) {
191
+ return route.parent ? _objectSpreadProps(_objectSpread({}, route, generate(route)), {
192
+ parent: void 0
193
+ }) : _objectSpreadProps(_objectSpread({}, route), {
194
+ parent: void 0
195
+ });
143
196
  });
144
- });
145
- return normalized;
197
+ return normalized;
146
198
  };
147
- export var getClientRoutes = function getClientRoutes(_ref2) {
148
- var entrypoint = _ref2.entrypoint,
149
- srcDirectory = _ref2.srcDirectory,
150
- srcAlias = _ref2.srcAlias,
151
- internalDirectory = _ref2.internalDirectory,
152
- internalDirAlias = _ref2.internalDirAlias;
153
- var entry = entrypoint.entry,
154
- entryName = entrypoint.entryName;
155
- if (!fs.existsSync(entry)) {
156
- throw new Error("generate file system routes error, ".concat(entry, " directory not found."));
157
- }
158
- if (!(fs.existsSync(entry) && fs.statSync(entry).isDirectory())) {
159
- throw new Error("generate file system routes error, ".concat(entry, " should be directory."));
160
- }
161
- var routes = [];
162
- recursiveReadDir({
163
- dir: entry,
164
- routes: routes,
165
- basePath: '/',
166
- srcDirectory: srcDirectory,
167
- srcAlias: srcAlias
168
- });
169
- var internalComponentsDir = path.resolve(internalDirectory, "".concat(entryName, "/").concat(FILE_SYSTEM_ROUTES_COMPONENTS_DIR));
170
- fs.emptyDirSync(internalComponentsDir);
171
- routes = normalizeNestedRoutes(routes, internalComponentsDir, internalDirectory, internalDirAlias);
172
- parents.length = 0;
173
-
174
- // FIXME: support more situations
175
- routes.sort(function (a, b) {
176
- var delta = getRouteWeight(a.path) - getRouteWeight(b.path);
177
- if (delta === 0) {
178
- return a.path.length - b.path.length;
199
+ var getClientRoutes = function(param) {
200
+ var entrypoint = param.entrypoint, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias, internalDirectory = param.internalDirectory, internalDirAlias = param.internalDirAlias;
201
+ var entry = entrypoint.entry, entryName = entrypoint.entryName;
202
+ if (!fs.existsSync(entry)) {
203
+ throw new Error("generate file system routes error, ".concat(entry, " directory not found."));
204
+ }
205
+ if (!(fs.existsSync(entry) && fs.statSync(entry).isDirectory())) {
206
+ throw new Error("generate file system routes error, ".concat(entry, " should be directory."));
179
207
  }
180
- return delta;
181
- });
182
- debug("fileSystem routes: %o", routes);
183
- return routes;
184
- };
208
+ var routes = [];
209
+ recursiveReadDir({
210
+ dir: entry,
211
+ routes: routes,
212
+ basePath: "/",
213
+ srcDirectory: srcDirectory,
214
+ srcAlias: srcAlias
215
+ });
216
+ var internalComponentsDir = path.resolve(internalDirectory, "".concat(entryName, "/").concat(FILE_SYSTEM_ROUTES_COMPONENTS_DIR));
217
+ fs.emptyDirSync(internalComponentsDir);
218
+ routes = normalizeNestedRoutes(routes, internalComponentsDir, internalDirectory, internalDirAlias);
219
+ parents.length = 0;
220
+ routes.sort(function(a, b) {
221
+ var delta = getRouteWeight(a.path) - getRouteWeight(b.path);
222
+ if (delta === 0) {
223
+ return a.path.length - b.path.length;
224
+ }
225
+ return delta;
226
+ });
227
+ debug("fileSystem routes: %o", routes);
228
+ return routes;
229
+ };
230
+ export { getClientRoutes };