@servicetitan/startup 30.3.1 → 31.1.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 (747) hide show
  1. package/bin/index.js +5 -6
  2. package/dist/cli/commands/build.d.ts +10 -3
  3. package/dist/cli/commands/build.d.ts.map +1 -1
  4. package/dist/cli/commands/build.js +119 -49
  5. package/dist/cli/commands/build.js.map +1 -1
  6. package/dist/cli/commands/bundle-package.d.ts +0 -2
  7. package/dist/cli/commands/bundle-package.d.ts.map +1 -1
  8. package/dist/cli/commands/bundle-package.js +54 -36
  9. package/dist/cli/commands/bundle-package.js.map +1 -1
  10. package/dist/cli/commands/clean.d.ts +6 -0
  11. package/dist/cli/commands/clean.d.ts.map +1 -0
  12. package/dist/cli/commands/clean.js +55 -0
  13. package/dist/cli/commands/clean.js.map +1 -0
  14. package/dist/cli/commands/convert-eslint-config.js +163 -107
  15. package/dist/cli/commands/convert-eslint-config.js.map +1 -1
  16. package/dist/cli/commands/eslint.d.ts.map +1 -1
  17. package/dist/cli/commands/eslint.js +43 -24
  18. package/dist/cli/commands/eslint.js.map +1 -1
  19. package/dist/cli/commands/get-command.d.ts.map +1 -1
  20. package/dist/cli/commands/get-command.js +50 -53
  21. package/dist/cli/commands/get-command.js.map +1 -1
  22. package/dist/cli/commands/get-user-commands.js +21 -11
  23. package/dist/cli/commands/get-user-commands.js.map +1 -1
  24. package/dist/cli/commands/index.d.ts +1 -1
  25. package/dist/cli/commands/index.d.ts.map +1 -1
  26. package/dist/cli/commands/index.js +31 -30
  27. package/dist/cli/commands/index.js.map +1 -1
  28. package/dist/cli/commands/init.js +74 -48
  29. package/dist/cli/commands/init.js.map +1 -1
  30. package/dist/cli/commands/install.d.ts +8 -1
  31. package/dist/cli/commands/install.d.ts.map +1 -1
  32. package/dist/cli/commands/install.js +61 -23
  33. package/dist/cli/commands/install.js.map +1 -1
  34. package/dist/cli/commands/kendo-ui-license.js +48 -31
  35. package/dist/cli/commands/kendo-ui-license.js.map +1 -1
  36. package/dist/cli/commands/lint.d.ts +3 -1
  37. package/dist/cli/commands/lint.d.ts.map +1 -1
  38. package/dist/cli/commands/lint.js +112 -73
  39. package/dist/cli/commands/lint.js.map +1 -1
  40. package/dist/cli/commands/mfe-package-clean.js +80 -57
  41. package/dist/cli/commands/mfe-package-clean.js.map +1 -1
  42. package/dist/cli/commands/mfe-package-publish.d.ts +1 -0
  43. package/dist/cli/commands/mfe-package-publish.d.ts.map +1 -1
  44. package/dist/cli/commands/mfe-package-publish.js +124 -70
  45. package/dist/cli/commands/mfe-package-publish.js.map +1 -1
  46. package/dist/cli/commands/mfe-publish.d.ts.map +1 -1
  47. package/dist/cli/commands/mfe-publish.js +83 -48
  48. package/dist/cli/commands/mfe-publish.js.map +1 -1
  49. package/dist/cli/commands/prepare-package.d.ts +1 -1
  50. package/dist/cli/commands/prepare-package.d.ts.map +1 -1
  51. package/dist/cli/commands/prepare-package.js +43 -33
  52. package/dist/cli/commands/prepare-package.js.map +1 -1
  53. package/dist/cli/commands/review/index.d.ts +3 -0
  54. package/dist/cli/commands/review/index.d.ts.map +1 -0
  55. package/dist/cli/commands/review/index.js +20 -0
  56. package/dist/cli/commands/review/index.js.map +1 -0
  57. package/dist/cli/commands/review/review.d.ts +28 -0
  58. package/dist/cli/commands/review/review.d.ts.map +1 -0
  59. package/dist/cli/commands/review/review.js +239 -0
  60. package/dist/cli/commands/review/review.js.map +1 -0
  61. package/dist/cli/commands/review/rules/index.d.ts +3 -0
  62. package/dist/cli/commands/review/rules/index.d.ts.map +1 -0
  63. package/dist/cli/commands/review/rules/index.js +30 -0
  64. package/dist/cli/commands/review/rules/index.js.map +1 -0
  65. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts +14 -0
  66. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts.map +1 -0
  67. package/dist/cli/commands/review/rules/no-typescript-entry-point.js +89 -0
  68. package/dist/cli/commands/review/rules/no-typescript-entry-point.js.map +1 -0
  69. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts +7 -0
  70. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts.map +1 -0
  71. package/dist/cli/commands/review/rules/require-explicit-side-effects.js +37 -0
  72. package/dist/cli/commands/review/rules/require-explicit-side-effects.js.map +1 -0
  73. package/dist/cli/commands/review/rules/require-npmrc.d.ts +7 -0
  74. package/dist/cli/commands/review/rules/require-npmrc.d.ts.map +1 -0
  75. package/dist/cli/commands/review/rules/require-npmrc.js +38 -0
  76. package/dist/cli/commands/review/rules/require-npmrc.js.map +1 -0
  77. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts +5 -0
  78. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts.map +1 -0
  79. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js +33 -0
  80. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js.map +1 -0
  81. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts +45 -0
  82. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts.map +1 -0
  83. package/dist/cli/commands/review/rules/require-one-collection-version.js +140 -0
  84. package/dist/cli/commands/review/rules/require-one-collection-version.js.map +1 -0
  85. package/dist/cli/commands/review/rules/require-one-package-version.d.ts +20 -0
  86. package/dist/cli/commands/review/rules/require-one-package-version.d.ts.map +1 -0
  87. package/dist/cli/commands/review/rules/require-one-package-version.js +70 -0
  88. package/dist/cli/commands/review/rules/require-one-package-version.js.map +1 -0
  89. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts +5 -0
  90. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts.map +1 -0
  91. package/dist/cli/commands/review/rules/require-one-uikit-version.js +40 -0
  92. package/dist/cli/commands/review/rules/require-one-uikit-version.js.map +1 -0
  93. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts +19 -0
  94. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts.map +1 -0
  95. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js +103 -0
  96. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js.map +1 -0
  97. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts +7 -0
  98. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts.map +1 -0
  99. package/dist/cli/commands/review/rules/require-servicetitan-scope.js +37 -0
  100. package/dist/cli/commands/review/rules/require-servicetitan-scope.js.map +1 -0
  101. package/dist/cli/commands/review/types.d.ts +72 -0
  102. package/dist/cli/commands/review/types.d.ts.map +1 -0
  103. package/dist/cli/commands/review/types.js +36 -0
  104. package/dist/cli/commands/review/types.js.map +1 -0
  105. package/dist/cli/commands/review/utils/apply-filter.d.ts +3 -0
  106. package/dist/cli/commands/review/utils/apply-filter.d.ts.map +1 -0
  107. package/dist/cli/commands/review/utils/apply-filter.js +20 -0
  108. package/dist/cli/commands/review/utils/apply-filter.js.map +1 -0
  109. package/dist/cli/commands/review/utils/collate-dependencies.d.ts +29 -0
  110. package/dist/cli/commands/review/utils/collate-dependencies.d.ts.map +1 -0
  111. package/dist/cli/commands/review/utils/collate-dependencies.js +31 -0
  112. package/dist/cli/commands/review/utils/collate-dependencies.js.map +1 -0
  113. package/dist/cli/commands/review/utils/compare-version.d.ts +9 -0
  114. package/dist/cli/commands/review/utils/compare-version.d.ts.map +1 -0
  115. package/dist/cli/commands/review/utils/compare-version.js +137 -0
  116. package/dist/cli/commands/review/utils/compare-version.js.map +1 -0
  117. package/dist/cli/commands/review/utils/format-depends-on.d.ts +2 -0
  118. package/dist/cli/commands/review/utils/format-depends-on.d.ts.map +1 -0
  119. package/dist/cli/commands/review/utils/format-depends-on.js +21 -0
  120. package/dist/cli/commands/review/utils/format-depends-on.js.map +1 -0
  121. package/dist/cli/commands/review/utils/format-location.d.ts +2 -0
  122. package/dist/cli/commands/review/utils/format-location.d.ts.map +1 -0
  123. package/dist/cli/commands/review/utils/format-location.js +25 -0
  124. package/dist/cli/commands/review/utils/format-location.js.map +1 -0
  125. package/dist/cli/commands/review/utils/get-key.d.ts +3 -0
  126. package/dist/cli/commands/review/utils/get-key.d.ts.map +1 -0
  127. package/dist/cli/commands/review/utils/get-key.js +20 -0
  128. package/dist/cli/commands/review/utils/get-key.js.map +1 -0
  129. package/dist/cli/commands/review/utils/get-max-version.d.ts +2 -0
  130. package/dist/cli/commands/review/utils/get-max-version.d.ts.map +1 -0
  131. package/dist/cli/commands/review/utils/get-max-version.js +16 -0
  132. package/dist/cli/commands/review/utils/get-max-version.js.map +1 -0
  133. package/dist/cli/commands/review/utils/indent.d.ts +2 -0
  134. package/dist/cli/commands/review/utils/indent.d.ts.map +1 -0
  135. package/dist/cli/commands/review/utils/indent.js +17 -0
  136. package/dist/cli/commands/review/utils/indent.js.map +1 -0
  137. package/dist/cli/commands/review/utils/index.d.ts +14 -0
  138. package/dist/cli/commands/review/utils/index.d.ts.map +1 -0
  139. package/dist/cli/commands/review/utils/index.js +32 -0
  140. package/dist/cli/commands/review/utils/index.js.map +1 -0
  141. package/dist/cli/commands/review/utils/is-library.d.ts +3 -0
  142. package/dist/cli/commands/review/utils/is-library.d.ts.map +1 -0
  143. package/dist/cli/commands/review/utils/is-library.js +15 -0
  144. package/dist/cli/commands/review/utils/is-library.js.map +1 -0
  145. package/dist/cli/commands/review/utils/name-to-location.d.ts +3 -0
  146. package/dist/cli/commands/review/utils/name-to-location.d.ts.map +1 -0
  147. package/dist/cli/commands/review/utils/name-to-location.js +18 -0
  148. package/dist/cli/commands/review/utils/name-to-location.js.map +1 -0
  149. package/dist/cli/commands/review/utils/pluralize.d.ts +2 -0
  150. package/dist/cli/commands/review/utils/pluralize.d.ts.map +1 -0
  151. package/dist/cli/commands/review/utils/pluralize.js +15 -0
  152. package/dist/cli/commands/review/utils/pluralize.js.map +1 -0
  153. package/dist/cli/commands/review/utils/set-version.d.ts +10 -0
  154. package/dist/cli/commands/review/utils/set-version.d.ts.map +1 -0
  155. package/dist/cli/commands/review/utils/set-version.js +33 -0
  156. package/dist/cli/commands/review/utils/set-version.js.map +1 -0
  157. package/dist/cli/commands/review/utils/summarize.d.ts +11 -0
  158. package/dist/cli/commands/review/utils/summarize.d.ts.map +1 -0
  159. package/dist/cli/commands/review/utils/summarize.js +30 -0
  160. package/dist/cli/commands/review/utils/summarize.js.map +1 -0
  161. package/dist/cli/commands/run-task.js +50 -31
  162. package/dist/cli/commands/run-task.js.map +1 -1
  163. package/dist/cli/commands/run-task.test.d.ts +2 -0
  164. package/dist/cli/commands/run-task.test.d.ts.map +1 -0
  165. package/dist/cli/commands/run-task.test.js +59 -0
  166. package/dist/cli/commands/run-task.test.js.map +1 -0
  167. package/dist/cli/commands/start.d.ts +11 -3
  168. package/dist/cli/commands/start.d.ts.map +1 -1
  169. package/dist/cli/commands/start.js +158 -70
  170. package/dist/cli/commands/start.js.map +1 -1
  171. package/dist/cli/commands/styles-check.js +73 -59
  172. package/dist/cli/commands/styles-check.js.map +1 -1
  173. package/dist/cli/commands/tests.d.ts +1 -0
  174. package/dist/cli/commands/tests.d.ts.map +1 -1
  175. package/dist/cli/commands/tests.js +45 -28
  176. package/dist/cli/commands/tests.js.map +1 -1
  177. package/dist/cli/commands/types.d.ts +1 -0
  178. package/dist/cli/commands/types.d.ts.map +1 -1
  179. package/dist/cli/commands/types.js +4 -1
  180. package/dist/cli/commands/types.js.map +1 -1
  181. package/dist/cli/index.js +43 -34
  182. package/dist/cli/index.js.map +1 -1
  183. package/dist/cli/tasks/cli-task.d.ts +0 -1
  184. package/dist/cli/tasks/cli-task.d.ts.map +1 -1
  185. package/dist/cli/tasks/cli-task.js +52 -41
  186. package/dist/cli/tasks/cli-task.js.map +1 -1
  187. package/dist/cli/tasks/swc-cli.d.js +3 -0
  188. package/dist/cli/tasks/swc-cli.d.js.map +1 -0
  189. package/dist/cli/tasks/swc-compile-package.d.ts +0 -1
  190. package/dist/cli/tasks/swc-compile-package.d.ts.map +1 -1
  191. package/dist/cli/tasks/swc-compile-package.js +78 -34
  192. package/dist/cli/tasks/swc-compile-package.js.map +1 -1
  193. package/dist/cli/tasks/task.d.ts +0 -2
  194. package/dist/cli/tasks/task.d.ts.map +1 -1
  195. package/dist/cli/tasks/task.js +60 -65
  196. package/dist/cli/tasks/task.js.map +1 -1
  197. package/dist/cli/tasks/tsc-compile-package.d.ts +0 -1
  198. package/dist/cli/tasks/tsc-compile-package.d.ts.map +1 -1
  199. package/dist/cli/tasks/tsc-compile-package.js +26 -22
  200. package/dist/cli/tasks/tsc-compile-package.js.map +1 -1
  201. package/dist/cli/tasks/tsc-compile.d.ts +0 -2
  202. package/dist/cli/tasks/tsc-compile.d.ts.map +1 -1
  203. package/dist/cli/tasks/tsc-compile.js +51 -31
  204. package/dist/cli/tasks/tsc-compile.js.map +1 -1
  205. package/dist/cli/types/cpx2.d.js +3 -0
  206. package/dist/cli/types/cpx2.d.js.map +1 -0
  207. package/dist/cli/utils/bundle.d.ts +2 -4
  208. package/dist/cli/utils/bundle.d.ts.map +1 -1
  209. package/dist/cli/utils/bundle.js +136 -74
  210. package/dist/cli/utils/bundle.js.map +1 -1
  211. package/dist/cli/utils/check-args.d.ts +6 -0
  212. package/dist/cli/utils/check-args.d.ts.map +1 -0
  213. package/dist/cli/utils/check-args.js +20 -0
  214. package/dist/cli/utils/check-args.js.map +1 -0
  215. package/dist/cli/utils/cli-git.js +23 -9
  216. package/dist/cli/utils/cli-git.js.map +1 -1
  217. package/dist/cli/utils/cli-npm.js +62 -23
  218. package/dist/cli/utils/cli-npm.js.map +1 -1
  219. package/dist/cli/utils/cli-os.js +34 -33
  220. package/dist/cli/utils/cli-os.js.map +1 -1
  221. package/dist/cli/utils/compile-less.d.ts.map +1 -1
  222. package/dist/cli/utils/compile-less.js +27 -11
  223. package/dist/cli/utils/compile-less.js.map +1 -1
  224. package/dist/cli/utils/compile-sass.d.ts.map +1 -1
  225. package/dist/cli/utils/compile-sass.js +25 -9
  226. package/dist/cli/utils/compile-sass.js.map +1 -1
  227. package/dist/cli/utils/compile.d.ts +6 -0
  228. package/dist/cli/utils/compile.d.ts.map +1 -0
  229. package/dist/cli/utils/compile.js +33 -0
  230. package/dist/cli/utils/compile.js.map +1 -0
  231. package/dist/cli/utils/copy-files.d.ts +8 -0
  232. package/dist/cli/utils/copy-files.d.ts.map +1 -0
  233. package/dist/cli/utils/copy-files.js +119 -0
  234. package/dist/cli/utils/copy-files.js.map +1 -0
  235. package/dist/cli/utils/eslint.d.ts.map +1 -1
  236. package/dist/cli/utils/eslint.js +22 -12
  237. package/dist/cli/utils/eslint.js.map +1 -1
  238. package/dist/cli/utils/get-module-type.d.ts.map +1 -1
  239. package/dist/cli/utils/get-module-type.js +12 -18
  240. package/dist/cli/utils/get-module-type.js.map +1 -1
  241. package/dist/cli/utils/index.d.ts +8 -6
  242. package/dist/cli/utils/index.d.ts.map +1 -1
  243. package/dist/cli/utils/index.js +33 -30
  244. package/dist/cli/utils/index.js.map +1 -1
  245. package/dist/cli/utils/is-module-installed.js +11 -4
  246. package/dist/cli/utils/is-module-installed.js.map +1 -1
  247. package/dist/cli/utils/lerna-exec.d.ts +4 -3
  248. package/dist/cli/utils/lerna-exec.d.ts.map +1 -1
  249. package/dist/cli/utils/lerna-exec.js +40 -19
  250. package/dist/cli/utils/lerna-exec.js.map +1 -1
  251. package/dist/cli/utils/maybe-create-git-folder.js +20 -18
  252. package/dist/cli/utils/maybe-create-git-folder.js.map +1 -1
  253. package/dist/cli/utils/pipe-stdout.d.ts +3 -0
  254. package/dist/cli/utils/pipe-stdout.d.ts.map +1 -0
  255. package/dist/cli/utils/pipe-stdout.js +19 -0
  256. package/dist/cli/utils/pipe-stdout.js.map +1 -0
  257. package/dist/cli/utils/process-tree.d.ts +14 -0
  258. package/dist/cli/utils/process-tree.d.ts.map +1 -0
  259. package/dist/cli/utils/process-tree.js +78 -0
  260. package/dist/cli/utils/process-tree.js.map +1 -0
  261. package/dist/cli/utils/publish.js +12 -6
  262. package/dist/cli/utils/publish.js.map +1 -1
  263. package/dist/cli/utils/set-node-options.d.ts +2 -1
  264. package/dist/cli/utils/set-node-options.d.ts.map +1 -1
  265. package/dist/cli/utils/set-node-options.js +39 -30
  266. package/dist/cli/utils/set-node-options.js.map +1 -1
  267. package/dist/cli/utils/ts-config.d.ts +11 -0
  268. package/dist/cli/utils/ts-config.d.ts.map +1 -0
  269. package/dist/cli/utils/ts-config.js +80 -0
  270. package/dist/cli/utils/ts-config.js.map +1 -0
  271. package/dist/cli/utils/type-check.d.ts +7 -0
  272. package/dist/cli/utils/type-check.d.ts.map +1 -0
  273. package/dist/cli/utils/type-check.js +33 -0
  274. package/dist/cli/utils/type-check.js.map +1 -0
  275. package/dist/cli/utils/watch-stdout.d.ts +3 -0
  276. package/dist/cli/utils/watch-stdout.d.ts.map +1 -0
  277. package/dist/cli/utils/watch-stdout.js +26 -0
  278. package/dist/cli/utils/watch-stdout.js.map +1 -0
  279. package/dist/index.js +20 -18
  280. package/dist/index.js.map +1 -1
  281. package/dist/jest/index.js +12 -4
  282. package/dist/jest/index.js.map +1 -1
  283. package/dist/utils/debug.js +23 -11
  284. package/dist/utils/debug.js.map +1 -1
  285. package/dist/utils/find-packages.d.ts.map +1 -1
  286. package/dist/utils/find-packages.js +46 -34
  287. package/dist/utils/find-packages.js.map +1 -1
  288. package/dist/utils/format-duration.d.ts +2 -0
  289. package/dist/utils/format-duration.d.ts.map +1 -0
  290. package/dist/utils/format-duration.js +24 -0
  291. package/dist/utils/format-duration.js.map +1 -0
  292. package/dist/utils/get-branch-configs.js +24 -8
  293. package/dist/utils/get-branch-configs.js.map +1 -1
  294. package/dist/utils/get-configuration.d.ts +11 -2
  295. package/dist/utils/get-configuration.d.ts.map +1 -1
  296. package/dist/utils/get-configuration.js +134 -52
  297. package/dist/utils/get-configuration.js.map +1 -1
  298. package/dist/utils/get-destination-folders.js +25 -18
  299. package/dist/utils/get-destination-folders.js.map +1 -1
  300. package/dist/utils/get-folders.d.ts +2 -2
  301. package/dist/utils/get-folders.d.ts.map +1 -1
  302. package/dist/utils/get-folders.js +20 -13
  303. package/dist/utils/get-folders.js.map +1 -1
  304. package/dist/utils/get-jest-config.js +65 -38
  305. package/dist/utils/get-jest-config.js.map +1 -1
  306. package/dist/utils/get-package-data.js +26 -12
  307. package/dist/utils/get-package-data.js.map +1 -1
  308. package/dist/utils/get-package-name.js +18 -8
  309. package/dist/utils/get-package-name.js.map +1 -1
  310. package/dist/utils/get-packages.d.ts +1 -1
  311. package/dist/utils/get-packages.d.ts.map +1 -1
  312. package/dist/utils/get-packages.js +72 -57
  313. package/dist/utils/get-packages.js.map +1 -1
  314. package/dist/utils/get-startup-version.js +18 -8
  315. package/dist/utils/get-startup-version.js.map +1 -1
  316. package/dist/utils/get-tsconfig.js +19 -12
  317. package/dist/utils/get-tsconfig.js.map +1 -1
  318. package/dist/utils/index.d.ts +3 -0
  319. package/dist/utils/index.d.ts.map +1 -1
  320. package/dist/utils/index.js +34 -29
  321. package/dist/utils/index.js.map +1 -1
  322. package/dist/utils/load-shared-dependencies.js +23 -17
  323. package/dist/utils/load-shared-dependencies.js.map +1 -1
  324. package/dist/utils/log-errors.d.ts +2 -0
  325. package/dist/utils/log-errors.d.ts.map +1 -0
  326. package/dist/utils/log-errors.js +36 -0
  327. package/dist/utils/log-errors.js.map +1 -0
  328. package/dist/utils/log.d.ts +0 -1
  329. package/dist/utils/log.d.ts.map +1 -1
  330. package/dist/utils/log.js +38 -43
  331. package/dist/utils/log.js.map +1 -1
  332. package/dist/utils/pick.js +11 -3
  333. package/dist/utils/pick.js.map +1 -1
  334. package/dist/utils/read-json.js +27 -11
  335. package/dist/utils/read-json.js.map +1 -1
  336. package/dist/utils/to-array.js +13 -3
  337. package/dist/utils/to-array.js.map +1 -1
  338. package/dist/webpack/configs/amd-config.js +13 -3
  339. package/dist/webpack/configs/amd-config.js.map +1 -1
  340. package/dist/webpack/configs/dev-server-config.d.ts +1 -1
  341. package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
  342. package/dist/webpack/configs/dev-server-config.js +47 -45
  343. package/dist/webpack/configs/dev-server-config.js.map +1 -1
  344. package/dist/webpack/configs/devtool-config.js +16 -7
  345. package/dist/webpack/configs/devtool-config.js.map +1 -1
  346. package/dist/webpack/configs/entry.config.d.ts.map +1 -1
  347. package/dist/webpack/configs/entry.config.js +28 -7
  348. package/dist/webpack/configs/entry.config.js.map +1 -1
  349. package/dist/webpack/configs/externals-config.js +17 -7
  350. package/dist/webpack/configs/externals-config.js.map +1 -1
  351. package/dist/webpack/configs/index.d.ts +2 -2
  352. package/dist/webpack/configs/index.d.ts.map +1 -1
  353. package/dist/webpack/configs/index.js +29 -28
  354. package/dist/webpack/configs/index.js.map +1 -1
  355. package/dist/webpack/configs/loaders/css-loader.js +22 -14
  356. package/dist/webpack/configs/loaders/css-loader.js.map +1 -1
  357. package/dist/webpack/configs/loaders/index.d.ts +1 -1
  358. package/dist/webpack/configs/loaders/index.d.ts.map +1 -1
  359. package/dist/webpack/configs/loaders/index.js +20 -19
  360. package/dist/webpack/configs/loaders/index.js.map +1 -1
  361. package/dist/webpack/configs/loaders/less-loader.js +18 -3
  362. package/dist/webpack/configs/loaders/less-loader.js.map +1 -1
  363. package/dist/webpack/configs/loaders/style-loader.js +23 -8
  364. package/dist/webpack/configs/loaders/style-loader.js.map +1 -1
  365. package/dist/webpack/configs/loaders/types.js +4 -1
  366. package/dist/webpack/configs/loaders/types.js.map +1 -1
  367. package/dist/webpack/configs/module-config.js +17 -5
  368. package/dist/webpack/configs/module-config.js.map +1 -1
  369. package/dist/webpack/configs/optimization-config.js +60 -34
  370. package/dist/webpack/configs/optimization-config.js.map +1 -1
  371. package/dist/webpack/configs/output-config.d.ts.map +1 -1
  372. package/dist/webpack/configs/output-config.js +28 -13
  373. package/dist/webpack/configs/output-config.js.map +1 -1
  374. package/dist/webpack/configs/plugins/assets-manifest-plugin.js +23 -14
  375. package/dist/webpack/configs/plugins/assets-manifest-plugin.js.map +1 -1
  376. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js +19 -9
  377. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js.map +1 -1
  378. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +19 -11
  379. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
  380. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js +17 -7
  381. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js.map +1 -1
  382. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js +13 -5
  383. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js.map +1 -1
  384. package/dist/webpack/configs/plugins/filter-warnings-plugin.js +11 -3
  385. package/dist/webpack/configs/plugins/filter-warnings-plugin.js.map +1 -1
  386. package/dist/webpack/configs/plugins/html-plugin.d.ts +1 -1
  387. package/dist/webpack/configs/plugins/html-plugin.d.ts.map +1 -1
  388. package/dist/webpack/configs/plugins/html-plugin.js +30 -22
  389. package/dist/webpack/configs/plugins/html-plugin.js.map +1 -1
  390. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js +24 -13
  391. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js.map +1 -1
  392. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js +26 -16
  393. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js.map +1 -1
  394. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js +15 -6
  395. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js.map +1 -1
  396. package/dist/webpack/configs/plugins/ignore-plugin/index.js +18 -16
  397. package/dist/webpack/configs/plugins/ignore-plugin/index.js.map +1 -1
  398. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js +22 -12
  399. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js.map +1 -1
  400. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js +11 -4
  401. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js.map +1 -1
  402. package/dist/webpack/configs/plugins/index.d.ts +0 -2
  403. package/dist/webpack/configs/plugins/index.d.ts.map +1 -1
  404. package/dist/webpack/configs/plugins/index.js +29 -29
  405. package/dist/webpack/configs/plugins/index.js.map +1 -1
  406. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js +23 -12
  407. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js.map +1 -1
  408. package/dist/webpack/configs/plugins/moment-locales-plugin.js +18 -8
  409. package/dist/webpack/configs/plugins/moment-locales-plugin.js.map +1 -1
  410. package/dist/webpack/configs/plugins/virtual-modules-plugin.js +44 -24
  411. package/dist/webpack/configs/plugins/virtual-modules-plugin.js.map +1 -1
  412. package/dist/webpack/configs/plugins/watch-run-plugin.js +23 -15
  413. package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -1
  414. package/dist/webpack/configs/plugins-config.d.ts.map +1 -1
  415. package/dist/webpack/configs/plugins-config.js +27 -21
  416. package/dist/webpack/configs/plugins-config.js.map +1 -1
  417. package/dist/webpack/configs/resolve-config.js +16 -4
  418. package/dist/webpack/configs/resolve-config.js.map +1 -1
  419. package/dist/webpack/configs/rules/css-rules.js +43 -18
  420. package/dist/webpack/configs/rules/css-rules.js.map +1 -1
  421. package/dist/webpack/configs/rules/font-rules.js +13 -5
  422. package/dist/webpack/configs/rules/font-rules.js.map +1 -1
  423. package/dist/webpack/configs/rules/image-rules.js +13 -5
  424. package/dist/webpack/configs/rules/image-rules.js.map +1 -1
  425. package/dist/webpack/configs/rules/index.d.ts +0 -1
  426. package/dist/webpack/configs/rules/index.d.ts.map +1 -1
  427. package/dist/webpack/configs/rules/index.js +24 -23
  428. package/dist/webpack/configs/rules/index.js.map +1 -1
  429. package/dist/webpack/configs/rules/js-rules.d.ts +1 -1
  430. package/dist/webpack/configs/rules/js-rules.d.ts.map +1 -1
  431. package/dist/webpack/configs/rules/js-rules.js +47 -7
  432. package/dist/webpack/configs/rules/js-rules.js.map +1 -1
  433. package/dist/webpack/configs/rules/less-rules.js +25 -9
  434. package/dist/webpack/configs/rules/less-rules.js.map +1 -1
  435. package/dist/webpack/configs/rules/scss-rules.js +25 -9
  436. package/dist/webpack/configs/rules/scss-rules.js.map +1 -1
  437. package/dist/webpack/configs/rules/svg-rules.js +40 -20
  438. package/dist/webpack/configs/rules/svg-rules.js.map +1 -1
  439. package/dist/webpack/configs/rules-config.d.ts.map +1 -1
  440. package/dist/webpack/configs/rules-config.js +34 -19
  441. package/dist/webpack/configs/rules-config.js.map +1 -1
  442. package/dist/webpack/configs/stats-config.js +14 -4
  443. package/dist/webpack/configs/stats-config.js.map +1 -1
  444. package/dist/webpack/configs/types.d.ts +1 -3
  445. package/dist/webpack/configs/types.d.ts.map +1 -1
  446. package/dist/webpack/configs/types.js +4 -1
  447. package/dist/webpack/configs/types.js.map +1 -1
  448. package/dist/webpack/configs/utils/generate-metadata.d.ts.map +1 -1
  449. package/dist/webpack/configs/utils/generate-metadata.js +44 -22
  450. package/dist/webpack/configs/utils/generate-metadata.js.map +1 -1
  451. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js +20 -11
  452. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js.map +1 -1
  453. package/dist/webpack/configs/utils/get-web-components-version.js +18 -8
  454. package/dist/webpack/configs/utils/get-web-components-version.js.map +1 -1
  455. package/dist/webpack/configs/utils/index.js +18 -16
  456. package/dist/webpack/configs/utils/index.js.map +1 -1
  457. package/dist/webpack/configs/watch-options-config.d.ts +6 -0
  458. package/dist/webpack/configs/watch-options-config.d.ts.map +1 -0
  459. package/dist/webpack/configs/watch-options-config.js +24 -0
  460. package/dist/webpack/configs/watch-options-config.js.map +1 -0
  461. package/dist/webpack/create-webpack-config.d.ts.map +1 -1
  462. package/dist/webpack/create-webpack-config.js +61 -50
  463. package/dist/webpack/create-webpack-config.js.map +1 -1
  464. package/dist/webpack/index.d.ts +1 -1
  465. package/dist/webpack/index.d.ts.map +1 -1
  466. package/dist/webpack/index.js +18 -17
  467. package/dist/webpack/index.js.map +1 -1
  468. package/dist/webpack/loaders/expose-loader/index.js +15 -15
  469. package/dist/webpack/loaders/expose-loader/index.js.map +1 -1
  470. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js +5 -6
  471. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js.map +1 -1
  472. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js +20 -13
  473. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js.map +1 -1
  474. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js +22 -11
  475. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js.map +1 -1
  476. package/dist/webpack/loaders/expose-loader/utils/index.js +20 -18
  477. package/dist/webpack/loaders/expose-loader/utils/index.js.map +1 -1
  478. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js +20 -12
  479. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js.map +1 -1
  480. package/dist/webpack/types.d.ts +1 -4
  481. package/dist/webpack/types.d.ts.map +1 -1
  482. package/dist/webpack/types.js +4 -1
  483. package/dist/webpack/types.js.map +1 -1
  484. package/dist/webpack/utils/get-caller-filename.js +14 -7
  485. package/dist/webpack/utils/get-caller-filename.js.map +1 -1
  486. package/dist/webpack/utils/{bundle.d.ts → get-module-entry-path.d.ts} +1 -1
  487. package/dist/webpack/utils/get-module-entry-path.d.ts.map +1 -0
  488. package/dist/webpack/utils/get-module-entry-path.js +21 -0
  489. package/dist/webpack/utils/get-module-entry-path.js.map +1 -0
  490. package/dist/webpack/utils/index.d.ts +1 -2
  491. package/dist/webpack/utils/index.d.ts.map +1 -1
  492. package/dist/webpack/utils/index.js +20 -19
  493. package/dist/webpack/utils/index.js.map +1 -1
  494. package/dist/webpack/utils/split-by-entry.js +17 -7
  495. package/dist/webpack/utils/split-by-entry.js.map +1 -1
  496. package/dist/webpack/utils/testing/compile.js +12 -4
  497. package/dist/webpack/utils/testing/compile.js.map +1 -1
  498. package/dist/webpack/utils/testing/execute.js +26 -13
  499. package/dist/webpack/utils/testing/execute.js.map +1 -1
  500. package/dist/webpack/utils/testing/get-compiler.js +34 -24
  501. package/dist/webpack/utils/testing/get-compiler.js.map +1 -1
  502. package/dist/webpack/utils/testing/get-errors.js +12 -4
  503. package/dist/webpack/utils/testing/get-errors.js.map +1 -1
  504. package/dist/webpack/utils/testing/get-module-source.js +18 -5
  505. package/dist/webpack/utils/testing/get-module-source.js.map +1 -1
  506. package/dist/webpack/utils/testing/get-warnings.js +12 -4
  507. package/dist/webpack/utils/testing/get-warnings.js.map +1 -1
  508. package/dist/webpack/utils/testing/index.js +28 -20
  509. package/dist/webpack/utils/testing/index.js.map +1 -1
  510. package/dist/webpack/utils/testing/normalize-errors.js +11 -3
  511. package/dist/webpack/utils/testing/normalize-errors.js.map +1 -1
  512. package/dist/webpack/utils/testing/read-asset.js +20 -11
  513. package/dist/webpack/utils/testing/read-asset.js.map +1 -1
  514. package/dist/webpack/utils/testing/read-assets.js +13 -5
  515. package/dist/webpack/utils/testing/read-assets.js.map +1 -1
  516. package/package.json +22 -23
  517. package/src/cli/commands/__tests__/build.test.ts +66 -43
  518. package/src/cli/commands/__tests__/clean.test.ts +32 -0
  519. package/src/cli/commands/__tests__/install.test.ts +50 -8
  520. package/src/cli/commands/__tests__/kendo-ui-license.test.ts +5 -5
  521. package/src/cli/commands/__tests__/lint.test.ts +4 -0
  522. package/src/cli/commands/__tests__/mfe-package-publish.test.ts +21 -2
  523. package/src/cli/commands/__tests__/mfe-publish.test.ts +19 -23
  524. package/src/cli/commands/__tests__/prepare-package.test.ts +6 -48
  525. package/src/cli/commands/__tests__/start.test.ts +77 -42
  526. package/src/cli/commands/__tests__/tests.test.ts +4 -0
  527. package/src/cli/commands/build.ts +71 -35
  528. package/src/cli/commands/bundle-package.ts +0 -4
  529. package/src/cli/commands/clean.ts +24 -0
  530. package/src/cli/commands/eslint.ts +1 -1
  531. package/src/cli/commands/get-command.ts +25 -35
  532. package/src/cli/commands/index.ts +1 -1
  533. package/src/cli/commands/install.ts +29 -8
  534. package/src/cli/commands/lint.ts +22 -17
  535. package/src/cli/commands/mfe-package-publish.ts +22 -5
  536. package/src/cli/commands/mfe-publish.ts +5 -18
  537. package/src/cli/commands/prepare-package.ts +5 -12
  538. package/src/cli/commands/review/__mocks__/expect-calls.ts +48 -0
  539. package/src/cli/commands/review/__mocks__/index.ts +1 -0
  540. package/src/cli/commands/review/__tests__/review.test.ts +483 -0
  541. package/src/cli/commands/review/index.ts +3 -0
  542. package/src/cli/commands/review/review.ts +247 -0
  543. package/src/cli/commands/review/rules/__mocks__/index.ts +3 -0
  544. package/src/cli/commands/review/rules/__mocks__/mock-config.ts +14 -0
  545. package/src/cli/commands/review/rules/__mocks__/mock-packages.ts +41 -0
  546. package/src/cli/commands/review/rules/__mocks__/mock-project.ts +11 -0
  547. package/src/cli/commands/review/rules/__tests__/no-typescript-entry-point.test.ts +166 -0
  548. package/src/cli/commands/review/rules/__tests__/require-explicit-side-effects.test.ts +113 -0
  549. package/src/cli/commands/review/rules/__tests__/require-npmrc.test.ts +71 -0
  550. package/src/cli/commands/review/rules/__tests__/require-one-anvil-uikit-contrib-version.test.ts +33 -0
  551. package/src/cli/commands/review/rules/__tests__/require-one-collection-version.test.ts +155 -0
  552. package/src/cli/commands/review/rules/__tests__/require-one-package-version.test.ts +135 -0
  553. package/src/cli/commands/review/rules/__tests__/require-one-uikit-version.ts +40 -0
  554. package/src/cli/commands/review/rules/__tests__/require-project-version-in-root-node-modules.test.ts +186 -0
  555. package/src/cli/commands/review/rules/__tests__/require-servicetitan-scope.test.ts +83 -0
  556. package/src/cli/commands/review/rules/index.ts +20 -0
  557. package/src/cli/commands/review/rules/no-typescript-entry-point.ts +78 -0
  558. package/src/cli/commands/review/rules/require-explicit-side-effects.ts +31 -0
  559. package/src/cli/commands/review/rules/require-npmrc.ts +27 -0
  560. package/src/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.ts +20 -0
  561. package/src/cli/commands/review/rules/require-one-collection-version.ts +169 -0
  562. package/src/cli/commands/review/rules/require-one-package-version.ts +76 -0
  563. package/src/cli/commands/review/rules/require-one-uikit-version.ts +27 -0
  564. package/src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts +104 -0
  565. package/src/cli/commands/review/rules/require-servicetitan-scope.ts +27 -0
  566. package/src/cli/commands/review/types.ts +72 -0
  567. package/src/cli/commands/review/utils/__tests__/compare-version.test.ts +73 -0
  568. package/src/cli/commands/review/utils/__tests__/get-max-version.test.ts +17 -0
  569. package/src/cli/commands/review/utils/__tests__/indent.test.ts +41 -0
  570. package/src/cli/commands/review/utils/__tests__/name-to-location.test.ts +39 -0
  571. package/src/cli/commands/review/utils/__tests__/set-version.test.ts +84 -0
  572. package/src/cli/commands/review/utils/apply-filter.ts +14 -0
  573. package/src/cli/commands/review/utils/collate-dependencies.ts +46 -0
  574. package/src/cli/commands/review/utils/compare-version.ts +82 -0
  575. package/src/cli/commands/review/utils/format-depends-on.ts +11 -0
  576. package/src/cli/commands/review/utils/format-location.ts +8 -0
  577. package/src/cli/commands/review/utils/get-key.ts +10 -0
  578. package/src/cli/commands/review/utils/get-max-version.ts +5 -0
  579. package/src/cli/commands/review/utils/indent.ts +8 -0
  580. package/src/cli/commands/review/utils/index.ts +13 -0
  581. package/src/cli/commands/review/utils/is-library.ts +5 -0
  582. package/src/cli/commands/review/utils/name-to-location.ts +7 -0
  583. package/src/cli/commands/review/utils/pluralize.ts +3 -0
  584. package/src/cli/commands/review/utils/set-version.ts +26 -0
  585. package/src/cli/commands/review/utils/summarize.ts +21 -0
  586. package/src/cli/commands/run-task.test.ts +60 -0
  587. package/src/cli/commands/start.ts +128 -55
  588. package/src/cli/commands/tests.ts +2 -0
  589. package/src/cli/commands/types.ts +1 -0
  590. package/src/cli/index.ts +4 -4
  591. package/src/cli/tasks/__tests__/cli-task.test.ts +16 -4
  592. package/src/cli/tasks/__tests__/swc-compile-package.test.ts +290 -0
  593. package/src/cli/tasks/__tests__/tsc-compile-package.test.ts +1 -0
  594. package/src/cli/tasks/__tests__/tsc-compile.test.ts +12 -23
  595. package/src/cli/tasks/cli-task.ts +12 -18
  596. package/src/cli/tasks/swc-cli.d.ts +12 -1
  597. package/src/cli/tasks/swc-compile-package.ts +73 -46
  598. package/src/cli/tasks/task.ts +2 -11
  599. package/src/cli/tasks/tsc-compile-package.ts +0 -4
  600. package/src/cli/tasks/tsc-compile.ts +14 -17
  601. package/src/cli/types/cpx2.d.ts +8 -1
  602. package/src/cli/utils/__tests__/bundle.test.ts +49 -8
  603. package/src/cli/utils/__tests__/check-args.test.ts +34 -0
  604. package/src/cli/utils/__tests__/compile.test.ts +59 -0
  605. package/src/cli/utils/__tests__/copy-files.test.ts +157 -0
  606. package/src/cli/utils/__tests__/get-module-type.test.ts +19 -0
  607. package/src/cli/utils/__tests__/lerna-exec.test.ts +58 -11
  608. package/src/cli/utils/__tests__/pipe-stdout.test.ts +39 -0
  609. package/src/cli/utils/__tests__/process-tree.test.ts +175 -0
  610. package/src/cli/utils/__tests__/set-node-options.test.ts +51 -6
  611. package/src/cli/utils/__tests__/type-check.test.ts +47 -0
  612. package/src/cli/utils/__tests__/watch-stdout.test.ts +68 -0
  613. package/src/cli/utils/bundle.ts +32 -23
  614. package/src/cli/utils/check-args.ts +13 -0
  615. package/src/cli/utils/compile-less.ts +0 -1
  616. package/src/cli/utils/compile-sass.ts +0 -1
  617. package/src/cli/utils/compile.ts +22 -0
  618. package/src/cli/utils/copy-files.ts +86 -0
  619. package/src/cli/utils/eslint.ts +1 -0
  620. package/src/cli/utils/get-module-type.ts +2 -20
  621. package/src/cli/utils/index.ts +8 -7
  622. package/src/cli/utils/lerna-exec.ts +17 -10
  623. package/src/cli/utils/pipe-stdout.ts +10 -0
  624. package/src/cli/utils/process-tree.ts +57 -0
  625. package/src/cli/utils/set-node-options.ts +15 -12
  626. package/src/cli/utils/ts-config.ts +64 -0
  627. package/src/cli/utils/type-check.ts +19 -0
  628. package/src/cli/utils/watch-stdout.ts +24 -0
  629. package/src/utils/__tests__/format-duration.test.ts +22 -0
  630. package/src/utils/__tests__/get-configuration.test.ts +64 -2
  631. package/src/utils/__tests__/get-packages.test.ts +58 -49
  632. package/src/utils/__tests__/log-errors.test.ts +102 -0
  633. package/src/utils/__tests__/log.test.ts +1 -86
  634. package/src/utils/find-packages.ts +12 -6
  635. package/src/utils/format-duration.ts +13 -0
  636. package/src/utils/get-configuration.ts +31 -5
  637. package/src/utils/get-folders.ts +3 -1
  638. package/src/utils/get-packages.ts +9 -16
  639. package/src/utils/index.ts +3 -0
  640. package/src/utils/log-errors.ts +29 -0
  641. package/src/utils/log.ts +0 -26
  642. package/src/webpack/__mocks__/file-rules.ts +0 -5
  643. package/src/webpack/__tests__/create-webpack-config-shared-dependencies.test.ts +0 -1
  644. package/src/webpack/__tests__/create-webpack-config-web-component.test.ts +21 -33
  645. package/src/webpack/__tests__/create-webpack-config.test.ts +60 -150
  646. package/src/webpack/configs/dev-server-config.ts +4 -27
  647. package/src/webpack/configs/devtool-config.ts +2 -2
  648. package/src/webpack/configs/entry.config.ts +7 -2
  649. package/src/webpack/configs/index.ts +2 -2
  650. package/src/webpack/configs/loaders/index.ts +1 -1
  651. package/src/webpack/configs/optimization-config.ts +8 -8
  652. package/src/webpack/configs/output-config.ts +4 -2
  653. package/src/webpack/configs/plugins/html-plugin.ts +5 -2
  654. package/src/webpack/configs/plugins/index.ts +0 -2
  655. package/src/webpack/configs/plugins/virtual-modules-plugin.ts +18 -5
  656. package/src/webpack/configs/plugins-config.ts +0 -4
  657. package/src/webpack/configs/resolve-config.ts +1 -1
  658. package/src/webpack/configs/rules/index.ts +0 -1
  659. package/src/webpack/configs/rules/js-rules.ts +27 -2
  660. package/src/webpack/configs/rules-config.ts +1 -11
  661. package/src/webpack/configs/types.ts +1 -3
  662. package/src/webpack/configs/utils/__tests__/generate-metadata.test.ts +3 -1
  663. package/src/webpack/configs/utils/generate-metadata.ts +6 -1
  664. package/src/webpack/configs/watch-options-config.ts +17 -0
  665. package/src/webpack/create-webpack-config.ts +3 -6
  666. package/src/webpack/index.ts +1 -1
  667. package/src/webpack/types.ts +1 -4
  668. package/src/webpack/utils/index.ts +1 -2
  669. package/dist/__mocks__/create-package.d.ts +0 -3
  670. package/dist/__mocks__/create-package.d.ts.map +0 -1
  671. package/dist/__mocks__/create-package.js +0 -17
  672. package/dist/__mocks__/create-package.js.map +0 -1
  673. package/dist/__mocks__/index.d.ts +0 -2
  674. package/dist/__mocks__/index.d.ts.map +0 -1
  675. package/dist/__mocks__/index.js +0 -18
  676. package/dist/__mocks__/index.js.map +0 -1
  677. package/dist/cli/utils/assets-copy.d.ts +0 -3
  678. package/dist/cli/utils/assets-copy.d.ts.map +0 -1
  679. package/dist/cli/utils/assets-copy.js +0 -25
  680. package/dist/cli/utils/assets-copy.js.map +0 -1
  681. package/dist/cli/utils/styles-copy.d.ts +0 -3
  682. package/dist/cli/utils/styles-copy.d.ts.map +0 -1
  683. package/dist/cli/utils/styles-copy.js +0 -25
  684. package/dist/cli/utils/styles-copy.js.map +0 -1
  685. package/dist/cli/utils/tcm.d.ts +0 -3
  686. package/dist/cli/utils/tcm.d.ts.map +0 -1
  687. package/dist/cli/utils/tcm.js +0 -67
  688. package/dist/cli/utils/tcm.js.map +0 -1
  689. package/dist/cli/utils/tsc.d.ts +0 -5
  690. package/dist/cli/utils/tsc.d.ts.map +0 -1
  691. package/dist/cli/utils/tsc.js +0 -37
  692. package/dist/cli/utils/tsc.js.map +0 -1
  693. package/dist/webpack/__mocks__/file-rules.d.ts +0 -3
  694. package/dist/webpack/__mocks__/file-rules.d.ts.map +0 -1
  695. package/dist/webpack/__mocks__/file-rules.js +0 -79
  696. package/dist/webpack/__mocks__/file-rules.js.map +0 -1
  697. package/dist/webpack/__mocks__/index.d.ts +0 -3
  698. package/dist/webpack/__mocks__/index.d.ts.map +0 -1
  699. package/dist/webpack/__mocks__/index.js +0 -19
  700. package/dist/webpack/__mocks__/index.js.map +0 -1
  701. package/dist/webpack/__mocks__/style-rules.d.ts +0 -8
  702. package/dist/webpack/__mocks__/style-rules.d.ts.map +0 -1
  703. package/dist/webpack/__mocks__/style-rules.js +0 -124
  704. package/dist/webpack/__mocks__/style-rules.js.map +0 -1
  705. package/dist/webpack/configs/cache-config.d.ts +0 -6
  706. package/dist/webpack/configs/cache-config.d.ts.map +0 -1
  707. package/dist/webpack/configs/cache-config.js +0 -23
  708. package/dist/webpack/configs/cache-config.js.map +0 -1
  709. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts +0 -4
  710. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts.map +0 -1
  711. package/dist/webpack/configs/plugins/provide-react-plugin.js +0 -13
  712. package/dist/webpack/configs/plugins/provide-react-plugin.js.map +0 -1
  713. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts +0 -4
  714. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts.map +0 -1
  715. package/dist/webpack/configs/plugins/ts-checker-plugin.js +0 -30
  716. package/dist/webpack/configs/plugins/ts-checker-plugin.js.map +0 -1
  717. package/dist/webpack/configs/rules/tsx-rules.d.ts +0 -4
  718. package/dist/webpack/configs/rules/tsx-rules.d.ts.map +0 -1
  719. package/dist/webpack/configs/rules/tsx-rules.js +0 -44
  720. package/dist/webpack/configs/rules/tsx-rules.js.map +0 -1
  721. package/dist/webpack/utils/bundle.d.ts.map +0 -1
  722. package/dist/webpack/utils/bundle.js +0 -19
  723. package/dist/webpack/utils/bundle.js.map +0 -1
  724. package/dist/webpack/utils/feature-cohort.d.ts +0 -5
  725. package/dist/webpack/utils/feature-cohort.d.ts.map +0 -1
  726. package/dist/webpack/utils/feature-cohort.js +0 -21
  727. package/dist/webpack/utils/feature-cohort.js.map +0 -1
  728. package/dist/webpack/utils/hash-mod.d.ts +0 -9
  729. package/dist/webpack/utils/hash-mod.d.ts.map +0 -1
  730. package/dist/webpack/utils/hash-mod.js +0 -34
  731. package/dist/webpack/utils/hash-mod.js.map +0 -1
  732. package/src/cli/tasks/__tests__/swc-compile.test.ts +0 -192
  733. package/src/cli/utils/__tests__/assets-copy.test.ts +0 -52
  734. package/src/cli/utils/__tests__/styles-copy.test.ts +0 -52
  735. package/src/cli/utils/__tests__/tcm.test.ts +0 -191
  736. package/src/cli/utils/__tests__/tsc.test.ts +0 -63
  737. package/src/cli/utils/assets-copy.ts +0 -23
  738. package/src/cli/utils/styles-copy.ts +0 -23
  739. package/src/cli/utils/tcm.ts +0 -76
  740. package/src/cli/utils/tsc.ts +0 -38
  741. package/src/webpack/configs/cache-config.ts +0 -25
  742. package/src/webpack/configs/plugins/provide-react-plugin.ts +0 -12
  743. package/src/webpack/configs/plugins/ts-checker-plugin.ts +0 -33
  744. package/src/webpack/configs/rules/tsx-rules.ts +0 -48
  745. package/src/webpack/utils/feature-cohort.ts +0 -19
  746. package/src/webpack/utils/hash-mod.ts +0 -32
  747. /package/src/webpack/utils/{bundle.ts → get-module-entry-path.ts} +0 -0
@@ -39,8 +39,18 @@ describe(`[startup] ${MFEPublish.name}`, () => {
39
39
  });
40
40
  }
41
41
 
42
- describe('with TSC package', () => {
43
- beforeEach(() => packages.push(createPackage({ type: PackageType.TSC })));
42
+ test('selects Webpack packages', async () => {
43
+ jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn()); // suppress error output
44
+ try {
45
+ await subject();
46
+ } catch {
47
+ /* ignore */
48
+ }
49
+ expect(getPackages).toHaveBeenCalledWith({ type: PackageType.Webpack });
50
+ });
51
+
52
+ describe('with no packages', () => {
53
+ beforeEach(() => (packages = []));
44
54
 
45
55
  itReportsError();
46
56
  });
@@ -73,7 +83,7 @@ describe(`[startup] ${MFEPublish.name}`, () => {
73
83
  'cmd': 'startup mfe-package-publish',
74
84
  'scope': packages.map(({ name }) => name),
75
85
  'stream': true,
76
- 'concurrency': 1,
86
+ 'parallel': 1,
77
87
  '--': [],
78
88
  });
79
89
  });
@@ -155,7 +165,7 @@ describe(`[startup] ${MFEPublish.name}`, () => {
155
165
  test('runs lernaExec with {concurrency: 0}', async () => {
156
166
  await subject();
157
167
 
158
- expect(lernaExec).toHaveBeenCalledWith(expect.objectContaining({ concurrency: 0 }));
168
+ expect(lernaExec).toHaveBeenCalledWith(expect.objectContaining({ parallel: 0 }));
159
169
  });
160
170
  });
161
171
 
@@ -184,28 +194,14 @@ describe(`[startup] ${MFEPublish.name}`, () => {
184
194
  );
185
195
  });
186
196
 
187
- describe('with "{scope: string}"', () => {
188
- beforeEach(() => (args.scope = packages[0].name));
197
+ describe('with "{scope}"', () => {
198
+ beforeEach(() => (args.scope = [packages[0].name]));
189
199
 
190
- test('publishes specified packages', async () => {
200
+ test('selects specified packages', async () => {
191
201
  await subject();
192
202
 
193
- expect(lernaExec).toHaveBeenCalledWith(
194
- expect.objectContaining({ scope: [packages[0].name] })
195
- );
196
- });
197
- });
198
-
199
- describe('with "{scope: Array<string>}"', () => {
200
- beforeEach(() => (args.scope = packages.slice(1).map(({ name }) => name)));
201
-
202
- test('publishes the specified packages', async () => {
203
- await subject();
204
-
205
- expect(lernaExec).toHaveBeenCalledWith(
206
- expect.objectContaining({
207
- scope: packages.slice(1).map(({ name }) => name),
208
- })
203
+ expect(getPackages).toHaveBeenCalledWith(
204
+ expect.objectContaining({ scope: args.scope })
209
205
  );
210
206
  });
211
207
  });
@@ -1,75 +1,33 @@
1
- import { isBundle } from '../../../utils';
2
- import {
3
- assetsCopy,
4
- assetsCopyWatch,
5
- stylesCopy,
6
- stylesCopyWatch,
7
- tcm,
8
- tcmWatch,
9
- } from '../../utils';
10
-
1
+ import { copyFiles } from '../../utils';
11
2
  import { PreparePackage } from '../prepare-package';
12
3
 
13
- jest.mock('../../../utils', () => ({
14
- ...jest.requireActual('../../../utils'),
15
- isBundle: jest.fn(),
16
- }));
17
-
18
4
  jest.mock('../../utils', () => ({
19
5
  ...jest.requireActual('../../utils'),
20
- assetsCopy: jest.fn().mockResolvedValue(undefined),
21
- assetsCopyWatch: jest.fn().mockResolvedValue(undefined),
22
- stylesCopy: jest.fn().mockResolvedValue(undefined),
23
- stylesCopyWatch: jest.fn().mockResolvedValue(undefined),
24
- tcm: jest.fn().mockResolvedValue(undefined),
25
- tcmWatch: jest.fn().mockResolvedValue(undefined),
6
+ copyFiles: jest.fn(),
26
7
  }));
27
8
 
28
9
  describe(`[startup] ${PreparePackage.name}`, () => {
29
10
  let args: ConstructorParameters<typeof PreparePackage>[0];
30
11
 
31
12
  beforeEach(() => {
32
- jest.mocked(isBundle).mockReturnValue(true);
33
13
  args = {};
34
14
  });
35
15
 
36
16
  const subject = async () => new PreparePackage(args).execute();
37
17
 
38
- test('runs tcm', async () => {
18
+ test('runs copyFiles', async () => {
39
19
  await subject();
40
20
 
41
- expect(tcm).toHaveBeenCalled();
42
- });
43
-
44
- describe('when package is not a bundle', () => {
45
- beforeEach(() => jest.mocked(isBundle).mockReturnValue(false));
46
-
47
- test('copies assets and styles', async () => {
48
- await subject();
49
-
50
- expect(assetsCopy).toHaveBeenCalled();
51
- expect(stylesCopy).toHaveBeenCalled();
52
- });
21
+ expect(copyFiles).toHaveBeenCalled();
53
22
  });
54
23
 
55
24
  describe('with "watch"', () => {
56
25
  beforeEach(() => (args.watch = true));
57
26
 
58
- test('runs tcm in watch mode', async () => {
27
+ test('runs copyFiles in watch mode', async () => {
59
28
  await subject();
60
29
 
61
- expect(tcmWatch).toHaveBeenCalled();
62
- });
63
-
64
- describe('when package is not a bundle', () => {
65
- beforeEach(() => jest.mocked(isBundle).mockReturnValue(false));
66
-
67
- test('copies assets and styles in watch mode', async () => {
68
- await subject();
69
-
70
- expect(assetsCopyWatch).toHaveBeenCalled();
71
- expect(stylesCopyWatch).toHaveBeenCalled();
72
- });
30
+ expect(copyFiles).toHaveBeenCalledWith({ watch: true });
73
31
  });
74
32
  });
75
33
  });
@@ -1,6 +1,6 @@
1
- import { Package, PackageType, getPackages } from '../../../utils';
1
+ import { Package, PackageType, getPackages, log } from '../../../utils';
2
2
  import { createPackage } from '../../../__mocks__';
3
- import { lernaExec, tsc, tscWatch } from '../../utils';
3
+ import { lernaExec, compile, typeCheck, watchStdout } from '../../utils';
4
4
 
5
5
  import { Start } from '../start';
6
6
 
@@ -8,7 +8,26 @@ jest.mock('../../../utils', () => ({
8
8
  ...jest.requireActual('../../../utils'),
9
9
  getPackages: jest.fn(),
10
10
  }));
11
- jest.mock('../../utils');
11
+ jest.mock('../../utils', () => ({
12
+ ...jest.requireActual('../../utils'),
13
+ lernaExec: jest.fn(() => Promise.resolve()),
14
+ compile: jest.fn(() =>
15
+ Object.assign(Promise.resolve(), {
16
+ stdout: {
17
+ on: jest.fn(),
18
+ off: jest.fn(),
19
+ },
20
+ })
21
+ ),
22
+ typeCheck: jest.fn(() =>
23
+ Object.assign(Promise.resolve(), {
24
+ stdout: {
25
+ on: jest.fn(),
26
+ },
27
+ })
28
+ ),
29
+ watchStdout: jest.fn(),
30
+ }));
12
31
 
13
32
  describe(`[startup] ${Start.name}`, () => {
14
33
  let args: ConstructorParameters<typeof Start>[0];
@@ -17,11 +36,15 @@ describe(`[startup] ${Start.name}`, () => {
17
36
  beforeEach(() => {
18
37
  args = {};
19
38
  packages = [];
20
- jest.resetAllMocks();
39
+ jest.clearAllMocks();
21
40
  jest.mocked(getPackages).mockImplementation(() => packages);
41
+ jest.mocked(watchStdout).mockImplementation((_process, _indicator, handler) => {
42
+ handler(packages.length);
43
+ return jest.fn();
44
+ });
22
45
  });
23
46
 
24
- const subject = async () => new Start(args).execute();
47
+ const subject = () => new Start(args).execute();
25
48
 
26
49
  function itPreparesThePackages() {
27
50
  test('prepares the package, then again in watch mode', async () => {
@@ -43,16 +66,37 @@ describe(`[startup] ${Start.name}`, () => {
43
66
  });
44
67
  }
45
68
 
69
+ function itRunsCompileAndTypeCheck({ useTsc = false }: { useTsc?: boolean } = {}) {
70
+ test('runs compile and typeCheck', async () => {
71
+ await subject();
72
+
73
+ expect(compile).toHaveBeenCalledWith({
74
+ packages: packages.map(({ name }) => name),
75
+ watch: true,
76
+ ...(useTsc ? { useTsc } : {}),
77
+ });
78
+ expect(typeCheck).toHaveBeenCalledWith({
79
+ packages: packages.map(({ name }) => name),
80
+ watch: true,
81
+ });
82
+ });
83
+ }
84
+
85
+ test('command is greedy', () => {
86
+ expect(new Start(args).greedy).toBe(true);
87
+ });
88
+
46
89
  describe('with TSC package', () => {
47
90
  beforeEach(() => packages.push(createPackage({ type: PackageType.TSC })));
48
91
 
49
92
  itPreparesThePackages();
93
+ itRunsCompileAndTypeCheck();
50
94
 
51
- test('runs tsc, then again in watch mode', async () => {
52
- await subject();
95
+ describe('with --use-tsc flag', () => {
96
+ beforeEach(() => (args['use-tsc'] = true));
53
97
 
54
- expect(tsc).toHaveBeenCalledWith(packages);
55
- expect(tscWatch).toHaveBeenCalledWith(packages);
98
+ itPreparesThePackages();
99
+ itRunsCompileAndTypeCheck({ useTsc: true });
56
100
  });
57
101
  });
58
102
 
@@ -60,6 +104,7 @@ describe(`[startup] ${Start.name}`, () => {
60
104
  beforeEach(() => packages.push(createPackage({ type: PackageType.Webpack })));
61
105
 
62
106
  itPreparesThePackages();
107
+ itRunsCompileAndTypeCheck();
63
108
 
64
109
  test('bundles the package in watch mode', async () => {
65
110
  await subject();
@@ -69,7 +114,7 @@ describe(`[startup] ${Start.name}`, () => {
69
114
  'scope': packages.map(({ name }) => name),
70
115
  'parallel': true,
71
116
  'stream': true,
72
- '--': ['--color', '--watch'],
117
+ '--': ['--watch'],
73
118
  });
74
119
  });
75
120
 
@@ -81,35 +126,7 @@ describe(`[startup] ${Start.name}`, () => {
81
126
 
82
127
  expect(lernaExec).toHaveBeenCalledWith(
83
128
  expect.objectContaining({
84
- '--': ['--color', '--watch', '--code-coverage'],
85
- })
86
- );
87
- });
88
- });
89
-
90
- describe('with "esbuild"', () => {
91
- beforeEach(() => (args.esbuild = true));
92
-
93
- test('enables esbuild loader', async () => {
94
- await subject();
95
-
96
- expect(lernaExec).toHaveBeenCalledWith(
97
- expect.objectContaining({
98
- '--': ['--color', '--watch', '--esbuild'],
99
- })
100
- );
101
- });
102
- });
103
-
104
- describe('with "experimental-bundlers"', () => {
105
- beforeEach(() => (args['experimental-bundlers'] = true));
106
-
107
- test('enables swc-loader', async () => {
108
- await subject();
109
-
110
- expect(lernaExec).toHaveBeenCalledWith(
111
- expect.objectContaining({
112
- '--': ['--color', '--watch', '--experimental-bundlers'],
129
+ '--': ['--watch', '--code-coverage'],
113
130
  })
114
131
  );
115
132
  });
@@ -123,7 +140,7 @@ describe(`[startup] ${Start.name}`, () => {
123
140
 
124
141
  expect(lernaExec).toHaveBeenCalledWith(
125
142
  expect.objectContaining({
126
- '--': ['--color', '--watch', `--config "${args.config}"`],
143
+ '--': ['--watch', `--config "${args.config}"`],
127
144
  })
128
145
  );
129
146
  });
@@ -136,7 +153,9 @@ describe(`[startup] ${Start.name}`, () => {
136
153
  test('selects scoped packages', async () => {
137
154
  await subject();
138
155
 
139
- expect(getPackages).toHaveBeenCalledWith({ scope: args.scope });
156
+ expect(getPackages).toHaveBeenCalledWith(
157
+ expect.objectContaining({ scope: args.scope })
158
+ );
140
159
  });
141
160
  });
142
161
 
@@ -146,7 +165,23 @@ describe(`[startup] ${Start.name}`, () => {
146
165
  test('selectively ignores packages', async () => {
147
166
  await subject();
148
167
 
149
- expect(getPackages).toHaveBeenCalledWith({ ignore: args.ignore });
168
+ expect(getPackages).toHaveBeenCalledWith(
169
+ expect.objectContaining({ ignore: args.ignore })
170
+ );
171
+ });
172
+ });
173
+
174
+ describe.each(['esbuild', 'experimental-bundlers'])('with "%s"', arg => {
175
+ beforeEach(() => ((args as Record<string, any>)[arg] = true));
176
+
177
+ test('logs warning', async () => {
178
+ const logSpy = jest.spyOn(log, 'warning');
179
+
180
+ await subject();
181
+
182
+ expect(logSpy).toHaveBeenCalledWith(
183
+ expect.stringContaining(`--${arg} option is obsolete`)
184
+ );
150
185
  });
151
186
  });
152
187
  });
@@ -22,6 +22,10 @@ describe(`[startup] ${Tests.name}`, () => {
22
22
 
23
23
  const subject = async () => new Tests(args).execute();
24
24
 
25
+ test('command is greedy', () => {
26
+ expect(new Tests(args).greedy).toBe(true);
27
+ });
28
+
25
29
  test('runs Jest CLI', async () => {
26
30
  await subject();
27
31
 
@@ -1,19 +1,29 @@
1
- import { getPackages, logErrors, PackageType, splitPackagesByType } from '../../utils';
2
- import { lernaExec, tsc } from '../utils';
3
- import { Command, kendoUILicense } from '.';
1
+ import { getPackages, logErrors, PackageType } from '../../utils';
2
+ import { checkArgs, compile, lernaExec, typeCheck, ProcessTree } from '../utils';
3
+ import { kendoUILicense } from './kendo-ui-license';
4
+ import { Command } from './types';
4
5
 
5
6
  interface Args {
6
7
  'cdn-path'?: string;
7
8
  'code-coverage'?: boolean;
8
9
  'config'?: string;
9
- 'esbuild'?: boolean;
10
- 'experimental-bundlers'?: boolean;
11
10
  'ignore'?: string | string[];
12
11
  'scope'?: string | string[];
13
12
  'stat'?: boolean;
13
+ 'use-tsc'?: boolean;
14
+ }
15
+
16
+ export enum BuildProcesses {
17
+ 'Compile',
18
+ 'KendoUILicense',
19
+ 'PreparePackage',
20
+ 'TypeCheck',
21
+ 'BundlePackage',
14
22
  }
15
23
 
16
24
  export class Build implements Command {
25
+ readonly greedy = true;
26
+
17
27
  constructor(private args: Args) {}
18
28
 
19
29
  description() {
@@ -22,44 +32,70 @@ export class Build implements Command {
22
32
 
23
33
  @logErrors
24
34
  async execute() {
25
- const packages = splitPackagesByType(
26
- getPackages({ scope: this.args.scope, ignore: this.args.ignore })
27
- );
28
- const packagesWithPreparation = [
29
- ...packages[PackageType.TSC],
30
- ...packages[PackageType.Webpack],
31
- ];
35
+ checkArgs(this.args, { obsolete: ['--esbuild', '--experimental-bundlers'] });
36
+
37
+ const useTsc = this.args['use-tsc'];
38
+
39
+ const packages = getPackages({
40
+ scope: this.args.scope,
41
+ ignore: this.args.ignore,
42
+ type: [PackageType.TSC, PackageType.Webpack],
43
+ });
44
+ if (packages.length === 0) {
45
+ return;
46
+ }
32
47
 
33
48
  if (this.args['cdn-path']) {
34
49
  process.env.CLIENT_CDN_PATH = this.args['cdn-path'];
35
50
  }
36
51
 
37
- if (packagesWithPreparation.length) {
38
- await lernaExec({
52
+ const scope = packages.map(({ name }) => name);
53
+
54
+ const processTree = new ProcessTree<typeof BuildProcesses>();
55
+
56
+ processTree.add(BuildProcesses.Compile, () => compile({ packages: scope, useTsc }));
57
+ processTree.add(BuildProcesses.KendoUILicense, () => kendoUILicense());
58
+ processTree.add(BuildProcesses.PreparePackage, () =>
59
+ lernaExec({
39
60
  cmd: 'startup prepare-package',
40
- scope: packagesWithPreparation.map(({ name }) => name),
61
+ scope,
41
62
  stream: true,
42
- });
43
- }
63
+ })
64
+ );
65
+ processTree.add(BuildProcesses.TypeCheck, () => typeCheck({ packages: scope }), {
66
+ dependsOn: [BuildProcesses.PreparePackage],
67
+ });
68
+ processTree.add(
69
+ BuildProcesses.BundlePackage,
70
+ () => {
71
+ const webpackScope = packages
72
+ .filter(({ type }) => type === PackageType.Webpack)
73
+ .map(({ name }) => name);
44
74
 
45
- if (packages[PackageType.TSC].length) {
46
- await tsc(packages[PackageType.TSC]);
47
- }
75
+ if (webpackScope.length === 0) {
76
+ return Promise.resolve();
77
+ }
48
78
 
49
- if (packages[PackageType.Webpack].length) {
50
- await kendoUILicense();
51
- await lernaExec({
52
- 'cmd': 'startup bundle-package',
53
- 'scope': packages[PackageType.Webpack].map(({ name }) => name),
54
- 'stream': true,
55
- '--': [
56
- ...[this.args.config ? `--config "${this.args.config}"` : undefined],
57
- ...[this.args['code-coverage'] ? '--code-coverage' : undefined],
58
- ...[this.args.esbuild ? '--esbuild' : undefined],
59
- ...[this.args['experimental-bundlers'] ? '--experimental-bundlers' : undefined],
60
- ...[this.args.stat ? '--stat' : undefined],
61
- ].filter(item => !!item) as string[],
62
- });
63
- }
79
+ return lernaExec({
80
+ 'cmd': 'startup bundle-package',
81
+ 'scope': webpackScope,
82
+ 'stream': true,
83
+ '--': [
84
+ ...[this.args.config ? `--config "${this.args.config}"` : undefined],
85
+ ...[this.args['code-coverage'] ? '--code-coverage' : undefined],
86
+ ...[this.args.stat ? '--stat' : undefined],
87
+ ].filter(item => !!item) as string[],
88
+ });
89
+ },
90
+ {
91
+ dependsOn: [
92
+ BuildProcesses.Compile,
93
+ BuildProcesses.KendoUILicense,
94
+ BuildProcesses.PreparePackage,
95
+ ],
96
+ }
97
+ );
98
+
99
+ await processTree.run();
64
100
  }
65
101
  }
@@ -9,8 +9,6 @@ interface Args {
9
9
  'code-coverage'?: boolean;
10
10
  'stat'?: boolean;
11
11
  'watch'?: boolean;
12
- 'esbuild'?: boolean;
13
- 'experimental-bundlers'?: boolean;
14
12
  }
15
13
 
16
14
  export class BundlePackage implements Command {
@@ -35,8 +33,6 @@ export class BundlePackage implements Command {
35
33
  const options = {
36
34
  config,
37
35
  codeCoverage: this.args['code-coverage'],
38
- esbuild: this.args.esbuild,
39
- experimentalBundlers: this.args['experimental-bundlers'],
40
36
  };
41
37
 
42
38
  if (!watch) {
@@ -0,0 +1,24 @@
1
+ import { exec, execSync } from 'child_process';
2
+ import { log, logErrors } from '../../utils';
3
+ import { Command } from './types';
4
+
5
+ export class Clean implements Command {
6
+ description() {
7
+ return 'resets project to fresh state';
8
+ }
9
+
10
+ @logErrors
11
+ async execute() {
12
+ ['npx nx reset', 'npx jest --clearCache', 'npm cache clear --force'].forEach(command => {
13
+ log.info(`Running: ${command}`);
14
+ execSync(command, { stdio: ['ignore', 'ignore', 'inherit'] });
15
+ });
16
+
17
+ // Use exec() to avoid error when startup dependencies are deleted while startup is running
18
+ const command = 'git clean -fdX';
19
+ log.info(`Running: ${command}`);
20
+ exec(command);
21
+
22
+ return Promise.resolve();
23
+ }
24
+ }
@@ -16,7 +16,7 @@ export class ESLintCommand implements Command {
16
16
  }
17
17
 
18
18
  @logErrors
19
- async execute(): Promise<void> {
19
+ async execute() {
20
20
  const { _: paths, fix } = this.args;
21
21
  await eslint({ fix, paths });
22
22
  }
@@ -2,6 +2,7 @@ import { CommandName } from '../../utils';
2
2
 
3
3
  import { Build } from './build';
4
4
  import { BundlePackage } from './bundle-package';
5
+ import { Clean } from './clean';
5
6
  import { ConvertEslintConfig } from './convert-eslint-config';
6
7
  import { ESLintCommand } from './eslint';
7
8
  import { Init } from './init';
@@ -12,45 +13,34 @@ import { MFEPackageClean } from './mfe-package-clean';
12
13
  import { MFEPackagePublish } from './mfe-package-publish';
13
14
  import { MFEPublish } from './mfe-publish';
14
15
  import { PreparePackage } from './prepare-package';
16
+ import { Review } from './review';
17
+ import { RunTask } from './run-task';
15
18
  import { Start } from './start';
16
19
  import { StylesCheck } from './styles-check';
17
- import { RunTask } from './run-task';
18
20
  import { Tests } from './tests';
19
21
  import { Command, Newable } from './types';
20
22
 
23
+ const commands: Record<CommandName, Newable<Command>> = {
24
+ [CommandName.build]: Build,
25
+ [CommandName['bundle-package']]: BundlePackage,
26
+ [CommandName['convert-eslint-config']]: ConvertEslintConfig,
27
+ [CommandName.clean]: Clean,
28
+ [CommandName.eslint]: ESLintCommand,
29
+ [CommandName.init]: Init,
30
+ [CommandName.install]: Install,
31
+ [CommandName['kendo-ui-license']]: KendoUILicense,
32
+ [CommandName.lint]: Lint,
33
+ [CommandName['mfe-package-clean']]: MFEPackageClean,
34
+ [CommandName['mfe-package-publish']]: MFEPackagePublish,
35
+ [CommandName['mfe-publish']]: MFEPublish,
36
+ [CommandName['prepare-package']]: PreparePackage,
37
+ [CommandName.review]: Review,
38
+ [CommandName.start]: Start,
39
+ [CommandName['styles-check']]: StylesCheck,
40
+ [CommandName.test]: Tests,
41
+ [CommandName.task]: RunTask,
42
+ };
43
+
21
44
  export function getCommand(name: CommandName): Newable<Command> | undefined {
22
- switch (name) {
23
- case CommandName.build:
24
- return Build;
25
- case CommandName['bundle-package']:
26
- return BundlePackage;
27
- case CommandName['convert-eslint-config']:
28
- return ConvertEslintConfig;
29
- case CommandName.eslint:
30
- return ESLintCommand;
31
- case CommandName.init:
32
- return Init;
33
- case CommandName.install:
34
- return Install;
35
- case CommandName['kendo-ui-license']:
36
- return KendoUILicense;
37
- case CommandName.lint:
38
- return Lint;
39
- case CommandName['mfe-package-clean']:
40
- return MFEPackageClean;
41
- case CommandName['mfe-package-publish']:
42
- return MFEPackagePublish;
43
- case CommandName['mfe-publish']:
44
- return MFEPublish;
45
- case CommandName['prepare-package']:
46
- return PreparePackage;
47
- case CommandName.start:
48
- return Start;
49
- case CommandName['styles-check']:
50
- return StylesCheck;
51
- case CommandName.test:
52
- return Tests;
53
- case CommandName.task:
54
- return RunTask;
55
- }
45
+ return commands[name];
56
46
  }
@@ -12,4 +12,4 @@ export * from './start';
12
12
  export * from './tests';
13
13
  export * from './styles-check';
14
14
  export * from './mfe-publish';
15
- export * from './types';
15
+ export type * from './types';