@servicetitan/startup 30.3.0 → 31.0.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 (725) 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 +124 -48
  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 +3 -2
  50. package/dist/cli/commands/prepare-package.d.ts.map +1 -1
  51. package/dist/cli/commands/prepare-package.js +44 -32
  52. package/dist/cli/commands/prepare-package.js.map +1 -1
  53. package/dist/cli/commands/review/__mocks__/expect-calls.d.ts +23 -0
  54. package/dist/cli/commands/review/__mocks__/expect-calls.d.ts.map +1 -0
  55. package/dist/cli/commands/review/__mocks__/index.d.ts +2 -0
  56. package/dist/cli/commands/review/__mocks__/index.d.ts.map +1 -0
  57. package/dist/cli/commands/review/index.d.ts +3 -0
  58. package/dist/cli/commands/review/index.d.ts.map +1 -0
  59. package/dist/cli/commands/review/index.js +20 -0
  60. package/dist/cli/commands/review/index.js.map +1 -0
  61. package/dist/cli/commands/review/review.d.ts +28 -0
  62. package/dist/cli/commands/review/review.d.ts.map +1 -0
  63. package/dist/cli/commands/review/review.js +239 -0
  64. package/dist/cli/commands/review/review.js.map +1 -0
  65. package/dist/cli/commands/review/rules/__mocks__/index.d.ts +4 -0
  66. package/dist/cli/commands/review/rules/__mocks__/index.d.ts.map +1 -0
  67. package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts +7 -0
  68. package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts.map +1 -0
  69. package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts +21 -0
  70. package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts.map +1 -0
  71. package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts +3 -0
  72. package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts.map +1 -0
  73. package/dist/cli/commands/review/rules/index.d.ts +3 -0
  74. package/dist/cli/commands/review/rules/index.d.ts.map +1 -0
  75. package/dist/cli/commands/review/rules/index.js +30 -0
  76. package/dist/cli/commands/review/rules/index.js.map +1 -0
  77. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts +14 -0
  78. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts.map +1 -0
  79. package/dist/cli/commands/review/rules/no-typescript-entry-point.js +89 -0
  80. package/dist/cli/commands/review/rules/no-typescript-entry-point.js.map +1 -0
  81. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts +7 -0
  82. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts.map +1 -0
  83. package/dist/cli/commands/review/rules/require-explicit-side-effects.js +37 -0
  84. package/dist/cli/commands/review/rules/require-explicit-side-effects.js.map +1 -0
  85. package/dist/cli/commands/review/rules/require-npmrc.d.ts +7 -0
  86. package/dist/cli/commands/review/rules/require-npmrc.d.ts.map +1 -0
  87. package/dist/cli/commands/review/rules/require-npmrc.js +38 -0
  88. package/dist/cli/commands/review/rules/require-npmrc.js.map +1 -0
  89. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts +5 -0
  90. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts.map +1 -0
  91. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js +33 -0
  92. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js.map +1 -0
  93. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts +45 -0
  94. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts.map +1 -0
  95. package/dist/cli/commands/review/rules/require-one-collection-version.js +140 -0
  96. package/dist/cli/commands/review/rules/require-one-collection-version.js.map +1 -0
  97. package/dist/cli/commands/review/rules/require-one-package-version.d.ts +20 -0
  98. package/dist/cli/commands/review/rules/require-one-package-version.d.ts.map +1 -0
  99. package/dist/cli/commands/review/rules/require-one-package-version.js +70 -0
  100. package/dist/cli/commands/review/rules/require-one-package-version.js.map +1 -0
  101. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts +5 -0
  102. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts.map +1 -0
  103. package/dist/cli/commands/review/rules/require-one-uikit-version.js +40 -0
  104. package/dist/cli/commands/review/rules/require-one-uikit-version.js.map +1 -0
  105. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts +19 -0
  106. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts.map +1 -0
  107. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js +103 -0
  108. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js.map +1 -0
  109. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts +7 -0
  110. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts.map +1 -0
  111. package/dist/cli/commands/review/rules/require-servicetitan-scope.js +37 -0
  112. package/dist/cli/commands/review/rules/require-servicetitan-scope.js.map +1 -0
  113. package/dist/cli/commands/review/types.d.ts +72 -0
  114. package/dist/cli/commands/review/types.d.ts.map +1 -0
  115. package/dist/cli/commands/review/types.js +36 -0
  116. package/dist/cli/commands/review/types.js.map +1 -0
  117. package/dist/cli/commands/review/utils/apply-filter.d.ts +3 -0
  118. package/dist/cli/commands/review/utils/apply-filter.d.ts.map +1 -0
  119. package/dist/cli/commands/review/utils/apply-filter.js +20 -0
  120. package/dist/cli/commands/review/utils/apply-filter.js.map +1 -0
  121. package/dist/cli/commands/review/utils/collate-dependencies.d.ts +29 -0
  122. package/dist/cli/commands/review/utils/collate-dependencies.d.ts.map +1 -0
  123. package/dist/cli/commands/review/utils/collate-dependencies.js +31 -0
  124. package/dist/cli/commands/review/utils/collate-dependencies.js.map +1 -0
  125. package/dist/cli/commands/review/utils/compare-version.d.ts +9 -0
  126. package/dist/cli/commands/review/utils/compare-version.d.ts.map +1 -0
  127. package/dist/cli/commands/review/utils/compare-version.js +137 -0
  128. package/dist/cli/commands/review/utils/compare-version.js.map +1 -0
  129. package/dist/cli/commands/review/utils/format-depends-on.d.ts +2 -0
  130. package/dist/cli/commands/review/utils/format-depends-on.d.ts.map +1 -0
  131. package/dist/cli/commands/review/utils/format-depends-on.js +21 -0
  132. package/dist/cli/commands/review/utils/format-depends-on.js.map +1 -0
  133. package/dist/cli/commands/review/utils/format-location.d.ts +2 -0
  134. package/dist/cli/commands/review/utils/format-location.d.ts.map +1 -0
  135. package/dist/cli/commands/review/utils/format-location.js +25 -0
  136. package/dist/cli/commands/review/utils/format-location.js.map +1 -0
  137. package/dist/cli/commands/review/utils/get-key.d.ts +3 -0
  138. package/dist/cli/commands/review/utils/get-key.d.ts.map +1 -0
  139. package/dist/cli/commands/review/utils/get-key.js +20 -0
  140. package/dist/cli/commands/review/utils/get-key.js.map +1 -0
  141. package/dist/cli/commands/review/utils/get-max-version.d.ts +2 -0
  142. package/dist/cli/commands/review/utils/get-max-version.d.ts.map +1 -0
  143. package/dist/cli/commands/review/utils/get-max-version.js +16 -0
  144. package/dist/cli/commands/review/utils/get-max-version.js.map +1 -0
  145. package/dist/cli/commands/review/utils/indent.d.ts +2 -0
  146. package/dist/cli/commands/review/utils/indent.d.ts.map +1 -0
  147. package/dist/cli/commands/review/utils/indent.js +17 -0
  148. package/dist/cli/commands/review/utils/indent.js.map +1 -0
  149. package/dist/cli/commands/review/utils/index.d.ts +14 -0
  150. package/dist/cli/commands/review/utils/index.d.ts.map +1 -0
  151. package/dist/cli/commands/review/utils/index.js +32 -0
  152. package/dist/cli/commands/review/utils/index.js.map +1 -0
  153. package/dist/cli/commands/review/utils/is-library.d.ts +3 -0
  154. package/dist/cli/commands/review/utils/is-library.d.ts.map +1 -0
  155. package/dist/cli/commands/review/utils/is-library.js +15 -0
  156. package/dist/cli/commands/review/utils/is-library.js.map +1 -0
  157. package/dist/cli/commands/review/utils/name-to-location.d.ts +3 -0
  158. package/dist/cli/commands/review/utils/name-to-location.d.ts.map +1 -0
  159. package/dist/cli/commands/review/utils/name-to-location.js +18 -0
  160. package/dist/cli/commands/review/utils/name-to-location.js.map +1 -0
  161. package/dist/cli/commands/review/utils/pluralize.d.ts +2 -0
  162. package/dist/cli/commands/review/utils/pluralize.d.ts.map +1 -0
  163. package/dist/cli/commands/review/utils/pluralize.js +15 -0
  164. package/dist/cli/commands/review/utils/pluralize.js.map +1 -0
  165. package/dist/cli/commands/review/utils/set-version.d.ts +10 -0
  166. package/dist/cli/commands/review/utils/set-version.d.ts.map +1 -0
  167. package/dist/cli/commands/review/utils/set-version.js +33 -0
  168. package/dist/cli/commands/review/utils/set-version.js.map +1 -0
  169. package/dist/cli/commands/review/utils/summarize.d.ts +11 -0
  170. package/dist/cli/commands/review/utils/summarize.d.ts.map +1 -0
  171. package/dist/cli/commands/review/utils/summarize.js +30 -0
  172. package/dist/cli/commands/review/utils/summarize.js.map +1 -0
  173. package/dist/cli/commands/run-task.js +50 -31
  174. package/dist/cli/commands/run-task.js.map +1 -1
  175. package/dist/cli/commands/run-task.test.d.ts +2 -0
  176. package/dist/cli/commands/run-task.test.d.ts.map +1 -0
  177. package/dist/cli/commands/start.d.ts +11 -3
  178. package/dist/cli/commands/start.d.ts.map +1 -1
  179. package/dist/cli/commands/start.js +166 -69
  180. package/dist/cli/commands/start.js.map +1 -1
  181. package/dist/cli/commands/styles-check.js +73 -59
  182. package/dist/cli/commands/styles-check.js.map +1 -1
  183. package/dist/cli/commands/tests.d.ts +1 -0
  184. package/dist/cli/commands/tests.d.ts.map +1 -1
  185. package/dist/cli/commands/tests.js +45 -28
  186. package/dist/cli/commands/tests.js.map +1 -1
  187. package/dist/cli/commands/types.d.ts +1 -0
  188. package/dist/cli/commands/types.d.ts.map +1 -1
  189. package/dist/cli/commands/types.js +4 -1
  190. package/dist/cli/commands/types.js.map +1 -1
  191. package/dist/cli/index.js +43 -34
  192. package/dist/cli/index.js.map +1 -1
  193. package/dist/cli/tasks/cli-task.d.ts +0 -1
  194. package/dist/cli/tasks/cli-task.d.ts.map +1 -1
  195. package/dist/cli/tasks/cli-task.js +52 -41
  196. package/dist/cli/tasks/cli-task.js.map +1 -1
  197. package/dist/cli/tasks/swc-compile-package.d.ts +0 -1
  198. package/dist/cli/tasks/swc-compile-package.d.ts.map +1 -1
  199. package/dist/cli/tasks/swc-compile-package.js +75 -34
  200. package/dist/cli/tasks/swc-compile-package.js.map +1 -1
  201. package/dist/cli/tasks/task.d.ts +0 -2
  202. package/dist/cli/tasks/task.d.ts.map +1 -1
  203. package/dist/cli/tasks/task.js +60 -65
  204. package/dist/cli/tasks/task.js.map +1 -1
  205. package/dist/cli/tasks/tsc-compile-package.d.ts +0 -1
  206. package/dist/cli/tasks/tsc-compile-package.d.ts.map +1 -1
  207. package/dist/cli/tasks/tsc-compile-package.js +26 -22
  208. package/dist/cli/tasks/tsc-compile-package.js.map +1 -1
  209. package/dist/cli/tasks/tsc-compile.d.ts +0 -2
  210. package/dist/cli/tasks/tsc-compile.d.ts.map +1 -1
  211. package/dist/cli/tasks/tsc-compile.js +51 -31
  212. package/dist/cli/tasks/tsc-compile.js.map +1 -1
  213. package/dist/cli/utils/bundle.d.ts +0 -2
  214. package/dist/cli/utils/bundle.d.ts.map +1 -1
  215. package/dist/cli/utils/bundle.js +118 -70
  216. package/dist/cli/utils/bundle.js.map +1 -1
  217. package/dist/cli/utils/check-args.d.ts +6 -0
  218. package/dist/cli/utils/check-args.d.ts.map +1 -0
  219. package/dist/cli/utils/check-args.js +20 -0
  220. package/dist/cli/utils/check-args.js.map +1 -0
  221. package/dist/cli/utils/cli-git.js +23 -9
  222. package/dist/cli/utils/cli-git.js.map +1 -1
  223. package/dist/cli/utils/cli-npm.js +62 -23
  224. package/dist/cli/utils/cli-npm.js.map +1 -1
  225. package/dist/cli/utils/cli-os.js +34 -33
  226. package/dist/cli/utils/cli-os.js.map +1 -1
  227. package/dist/cli/utils/compile-less.d.ts.map +1 -1
  228. package/dist/cli/utils/compile-less.js +27 -11
  229. package/dist/cli/utils/compile-less.js.map +1 -1
  230. package/dist/cli/utils/compile-sass.d.ts.map +1 -1
  231. package/dist/cli/utils/compile-sass.js +25 -9
  232. package/dist/cli/utils/compile-sass.js.map +1 -1
  233. package/dist/cli/utils/compile.d.ts +6 -0
  234. package/dist/cli/utils/compile.d.ts.map +1 -0
  235. package/dist/cli/utils/compile.js +33 -0
  236. package/dist/cli/utils/compile.js.map +1 -0
  237. package/dist/cli/utils/copy-files.d.ts +8 -0
  238. package/dist/cli/utils/copy-files.d.ts.map +1 -0
  239. package/dist/cli/utils/copy-files.js +112 -0
  240. package/dist/cli/utils/copy-files.js.map +1 -0
  241. package/dist/cli/utils/eslint.d.ts.map +1 -1
  242. package/dist/cli/utils/eslint.js +22 -12
  243. package/dist/cli/utils/eslint.js.map +1 -1
  244. package/dist/cli/utils/get-module-type.d.ts.map +1 -1
  245. package/dist/cli/utils/get-module-type.js +21 -13
  246. package/dist/cli/utils/get-module-type.js.map +1 -1
  247. package/dist/cli/utils/index.d.ts +7 -5
  248. package/dist/cli/utils/index.d.ts.map +1 -1
  249. package/dist/cli/utils/index.js +33 -30
  250. package/dist/cli/utils/index.js.map +1 -1
  251. package/dist/cli/utils/is-module-installed.js +11 -4
  252. package/dist/cli/utils/is-module-installed.js.map +1 -1
  253. package/dist/cli/utils/lerna-exec.d.ts +4 -3
  254. package/dist/cli/utils/lerna-exec.d.ts.map +1 -1
  255. package/dist/cli/utils/lerna-exec.js +40 -19
  256. package/dist/cli/utils/lerna-exec.js.map +1 -1
  257. package/dist/cli/utils/maybe-create-git-folder.js +20 -18
  258. package/dist/cli/utils/maybe-create-git-folder.js.map +1 -1
  259. package/dist/cli/utils/pipe-stdout.d.ts +3 -0
  260. package/dist/cli/utils/pipe-stdout.d.ts.map +1 -0
  261. package/dist/cli/utils/pipe-stdout.js +19 -0
  262. package/dist/cli/utils/pipe-stdout.js.map +1 -0
  263. package/dist/cli/utils/process-tree.d.ts +14 -0
  264. package/dist/cli/utils/process-tree.d.ts.map +1 -0
  265. package/dist/cli/utils/process-tree.js +78 -0
  266. package/dist/cli/utils/process-tree.js.map +1 -0
  267. package/dist/cli/utils/publish.js +12 -6
  268. package/dist/cli/utils/publish.js.map +1 -1
  269. package/dist/cli/utils/set-node-options.d.ts +2 -1
  270. package/dist/cli/utils/set-node-options.d.ts.map +1 -1
  271. package/dist/cli/utils/set-node-options.js +39 -30
  272. package/dist/cli/utils/set-node-options.js.map +1 -1
  273. package/dist/cli/utils/style-extensions.d.ts +2 -0
  274. package/dist/cli/utils/style-extensions.d.ts.map +1 -0
  275. package/dist/cli/utils/style-extensions.js +17 -0
  276. package/dist/cli/utils/style-extensions.js.map +1 -0
  277. package/dist/cli/utils/tcm.d.ts +5 -2
  278. package/dist/cli/utils/tcm.d.ts.map +1 -1
  279. package/dist/cli/utils/tcm.js +51 -46
  280. package/dist/cli/utils/tcm.js.map +1 -1
  281. package/dist/cli/utils/type-check.d.ts +7 -0
  282. package/dist/cli/utils/type-check.d.ts.map +1 -0
  283. package/dist/cli/utils/type-check.js +33 -0
  284. package/dist/cli/utils/type-check.js.map +1 -0
  285. package/dist/cli/utils/watch-stdout.d.ts +3 -0
  286. package/dist/cli/utils/watch-stdout.d.ts.map +1 -0
  287. package/dist/cli/utils/watch-stdout.js +26 -0
  288. package/dist/cli/utils/watch-stdout.js.map +1 -0
  289. package/dist/index.js +20 -18
  290. package/dist/index.js.map +1 -1
  291. package/dist/jest/index.js +12 -4
  292. package/dist/jest/index.js.map +1 -1
  293. package/dist/utils/debug.js +23 -11
  294. package/dist/utils/debug.js.map +1 -1
  295. package/dist/utils/find-packages.d.ts.map +1 -1
  296. package/dist/utils/find-packages.js +46 -34
  297. package/dist/utils/find-packages.js.map +1 -1
  298. package/dist/utils/format-duration.d.ts +2 -0
  299. package/dist/utils/format-duration.d.ts.map +1 -0
  300. package/dist/utils/format-duration.js +24 -0
  301. package/dist/utils/format-duration.js.map +1 -0
  302. package/dist/utils/get-branch-configs.js +24 -8
  303. package/dist/utils/get-branch-configs.js.map +1 -1
  304. package/dist/utils/get-configuration.d.ts +10 -2
  305. package/dist/utils/get-configuration.d.ts.map +1 -1
  306. package/dist/utils/get-configuration.js +120 -52
  307. package/dist/utils/get-configuration.js.map +1 -1
  308. package/dist/utils/get-destination-folders.js +25 -18
  309. package/dist/utils/get-destination-folders.js.map +1 -1
  310. package/dist/utils/get-folders.d.ts +2 -2
  311. package/dist/utils/get-folders.d.ts.map +1 -1
  312. package/dist/utils/get-folders.js +20 -13
  313. package/dist/utils/get-folders.js.map +1 -1
  314. package/dist/utils/get-jest-config.js +65 -38
  315. package/dist/utils/get-jest-config.js.map +1 -1
  316. package/dist/utils/get-package-data.js +26 -12
  317. package/dist/utils/get-package-data.js.map +1 -1
  318. package/dist/utils/get-package-name.js +18 -8
  319. package/dist/utils/get-package-name.js.map +1 -1
  320. package/dist/utils/get-packages.d.ts +1 -1
  321. package/dist/utils/get-packages.d.ts.map +1 -1
  322. package/dist/utils/get-packages.js +72 -57
  323. package/dist/utils/get-packages.js.map +1 -1
  324. package/dist/utils/get-startup-version.js +18 -8
  325. package/dist/utils/get-startup-version.js.map +1 -1
  326. package/dist/utils/get-tsconfig.js +19 -12
  327. package/dist/utils/get-tsconfig.js.map +1 -1
  328. package/dist/utils/index.d.ts +3 -0
  329. package/dist/utils/index.d.ts.map +1 -1
  330. package/dist/utils/index.js +34 -29
  331. package/dist/utils/index.js.map +1 -1
  332. package/dist/utils/load-shared-dependencies.js +23 -17
  333. package/dist/utils/load-shared-dependencies.js.map +1 -1
  334. package/dist/utils/log-errors.d.ts +2 -0
  335. package/dist/utils/log-errors.d.ts.map +1 -0
  336. package/dist/utils/log-errors.js +36 -0
  337. package/dist/utils/log-errors.js.map +1 -0
  338. package/dist/utils/log.d.ts +0 -1
  339. package/dist/utils/log.d.ts.map +1 -1
  340. package/dist/utils/log.js +38 -43
  341. package/dist/utils/log.js.map +1 -1
  342. package/dist/utils/pick.js +11 -3
  343. package/dist/utils/pick.js.map +1 -1
  344. package/dist/utils/read-json.js +27 -11
  345. package/dist/utils/read-json.js.map +1 -1
  346. package/dist/utils/to-array.js +13 -3
  347. package/dist/utils/to-array.js.map +1 -1
  348. package/dist/webpack/__mocks__/file-rules.d.ts.map +1 -1
  349. package/dist/webpack/configs/amd-config.js +13 -3
  350. package/dist/webpack/configs/amd-config.js.map +1 -1
  351. package/dist/webpack/configs/cache-config.js +20 -9
  352. package/dist/webpack/configs/cache-config.js.map +1 -1
  353. package/dist/webpack/configs/dev-server-config.d.ts +1 -1
  354. package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
  355. package/dist/webpack/configs/dev-server-config.js +47 -45
  356. package/dist/webpack/configs/dev-server-config.js.map +1 -1
  357. package/dist/webpack/configs/devtool-config.js +16 -7
  358. package/dist/webpack/configs/devtool-config.js.map +1 -1
  359. package/dist/webpack/configs/entry.config.d.ts.map +1 -1
  360. package/dist/webpack/configs/entry.config.js +28 -7
  361. package/dist/webpack/configs/entry.config.js.map +1 -1
  362. package/dist/webpack/configs/externals-config.js +17 -7
  363. package/dist/webpack/configs/externals-config.js.map +1 -1
  364. package/dist/webpack/configs/index.d.ts +2 -1
  365. package/dist/webpack/configs/index.d.ts.map +1 -1
  366. package/dist/webpack/configs/index.js +30 -28
  367. package/dist/webpack/configs/index.js.map +1 -1
  368. package/dist/webpack/configs/loaders/css-loader.js +22 -14
  369. package/dist/webpack/configs/loaders/css-loader.js.map +1 -1
  370. package/dist/webpack/configs/loaders/index.d.ts +1 -1
  371. package/dist/webpack/configs/loaders/index.d.ts.map +1 -1
  372. package/dist/webpack/configs/loaders/index.js +20 -19
  373. package/dist/webpack/configs/loaders/index.js.map +1 -1
  374. package/dist/webpack/configs/loaders/less-loader.js +18 -3
  375. package/dist/webpack/configs/loaders/less-loader.js.map +1 -1
  376. package/dist/webpack/configs/loaders/style-loader.js +23 -8
  377. package/dist/webpack/configs/loaders/style-loader.js.map +1 -1
  378. package/dist/webpack/configs/loaders/types.js +4 -1
  379. package/dist/webpack/configs/loaders/types.js.map +1 -1
  380. package/dist/webpack/configs/module-config.js +17 -5
  381. package/dist/webpack/configs/module-config.js.map +1 -1
  382. package/dist/webpack/configs/optimization-config.js +54 -28
  383. package/dist/webpack/configs/optimization-config.js.map +1 -1
  384. package/dist/webpack/configs/output-config.js +26 -12
  385. package/dist/webpack/configs/output-config.js.map +1 -1
  386. package/dist/webpack/configs/plugins/assets-manifest-plugin.js +23 -14
  387. package/dist/webpack/configs/plugins/assets-manifest-plugin.js.map +1 -1
  388. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js +19 -9
  389. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js.map +1 -1
  390. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +19 -11
  391. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
  392. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js +17 -7
  393. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js.map +1 -1
  394. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js +13 -5
  395. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js.map +1 -1
  396. package/dist/webpack/configs/plugins/filter-warnings-plugin.js +11 -3
  397. package/dist/webpack/configs/plugins/filter-warnings-plugin.js.map +1 -1
  398. package/dist/webpack/configs/plugins/html-plugin.js +28 -20
  399. package/dist/webpack/configs/plugins/html-plugin.js.map +1 -1
  400. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js +24 -13
  401. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js.map +1 -1
  402. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js +26 -16
  403. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js.map +1 -1
  404. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js +15 -6
  405. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js.map +1 -1
  406. package/dist/webpack/configs/plugins/ignore-plugin/index.js +18 -16
  407. package/dist/webpack/configs/plugins/ignore-plugin/index.js.map +1 -1
  408. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js +22 -12
  409. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js.map +1 -1
  410. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js +11 -4
  411. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js.map +1 -1
  412. package/dist/webpack/configs/plugins/index.d.ts +0 -2
  413. package/dist/webpack/configs/plugins/index.d.ts.map +1 -1
  414. package/dist/webpack/configs/plugins/index.js +29 -29
  415. package/dist/webpack/configs/plugins/index.js.map +1 -1
  416. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js +23 -12
  417. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js.map +1 -1
  418. package/dist/webpack/configs/plugins/moment-locales-plugin.js +18 -8
  419. package/dist/webpack/configs/plugins/moment-locales-plugin.js.map +1 -1
  420. package/dist/webpack/configs/plugins/virtual-modules-plugin.js +32 -22
  421. package/dist/webpack/configs/plugins/virtual-modules-plugin.js.map +1 -1
  422. package/dist/webpack/configs/plugins/watch-run-plugin.js +23 -15
  423. package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -1
  424. package/dist/webpack/configs/plugins-config.d.ts.map +1 -1
  425. package/dist/webpack/configs/plugins-config.js +27 -21
  426. package/dist/webpack/configs/plugins-config.js.map +1 -1
  427. package/dist/webpack/configs/resolve-config.js +16 -4
  428. package/dist/webpack/configs/resolve-config.js.map +1 -1
  429. package/dist/webpack/configs/rules/css-rules.js +43 -18
  430. package/dist/webpack/configs/rules/css-rules.js.map +1 -1
  431. package/dist/webpack/configs/rules/font-rules.js +13 -5
  432. package/dist/webpack/configs/rules/font-rules.js.map +1 -1
  433. package/dist/webpack/configs/rules/image-rules.js +13 -5
  434. package/dist/webpack/configs/rules/image-rules.js.map +1 -1
  435. package/dist/webpack/configs/rules/index.d.ts +0 -1
  436. package/dist/webpack/configs/rules/index.d.ts.map +1 -1
  437. package/dist/webpack/configs/rules/index.js +24 -23
  438. package/dist/webpack/configs/rules/index.js.map +1 -1
  439. package/dist/webpack/configs/rules/js-rules.d.ts +1 -1
  440. package/dist/webpack/configs/rules/js-rules.d.ts.map +1 -1
  441. package/dist/webpack/configs/rules/js-rules.js +47 -7
  442. package/dist/webpack/configs/rules/js-rules.js.map +1 -1
  443. package/dist/webpack/configs/rules/less-rules.js +25 -9
  444. package/dist/webpack/configs/rules/less-rules.js.map +1 -1
  445. package/dist/webpack/configs/rules/scss-rules.js +25 -9
  446. package/dist/webpack/configs/rules/scss-rules.js.map +1 -1
  447. package/dist/webpack/configs/rules/svg-rules.js +40 -20
  448. package/dist/webpack/configs/rules/svg-rules.js.map +1 -1
  449. package/dist/webpack/configs/rules-config.d.ts.map +1 -1
  450. package/dist/webpack/configs/rules-config.js +34 -19
  451. package/dist/webpack/configs/rules-config.js.map +1 -1
  452. package/dist/webpack/configs/stats-config.js +14 -4
  453. package/dist/webpack/configs/stats-config.js.map +1 -1
  454. package/dist/webpack/configs/types.d.ts +1 -3
  455. package/dist/webpack/configs/types.d.ts.map +1 -1
  456. package/dist/webpack/configs/types.js +4 -1
  457. package/dist/webpack/configs/types.js.map +1 -1
  458. package/dist/webpack/configs/utils/generate-metadata.js +40 -22
  459. package/dist/webpack/configs/utils/generate-metadata.js.map +1 -1
  460. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js +20 -11
  461. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js.map +1 -1
  462. package/dist/webpack/configs/utils/get-web-components-version.js +18 -8
  463. package/dist/webpack/configs/utils/get-web-components-version.js.map +1 -1
  464. package/dist/webpack/configs/utils/index.js +18 -16
  465. package/dist/webpack/configs/utils/index.js.map +1 -1
  466. package/dist/webpack/configs/watch-options-config.d.ts +6 -0
  467. package/dist/webpack/configs/watch-options-config.d.ts.map +1 -0
  468. package/dist/webpack/configs/watch-options-config.js +24 -0
  469. package/dist/webpack/configs/watch-options-config.js.map +1 -0
  470. package/dist/webpack/create-webpack-config.d.ts.map +1 -1
  471. package/dist/webpack/create-webpack-config.js +62 -50
  472. package/dist/webpack/create-webpack-config.js.map +1 -1
  473. package/dist/webpack/index.d.ts +1 -1
  474. package/dist/webpack/index.d.ts.map +1 -1
  475. package/dist/webpack/index.js +18 -17
  476. package/dist/webpack/index.js.map +1 -1
  477. package/dist/webpack/loaders/expose-loader/index.js +15 -15
  478. package/dist/webpack/loaders/expose-loader/index.js.map +1 -1
  479. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js +5 -6
  480. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js.map +1 -1
  481. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js +20 -13
  482. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js.map +1 -1
  483. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js +22 -11
  484. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js.map +1 -1
  485. package/dist/webpack/loaders/expose-loader/utils/index.js +20 -18
  486. package/dist/webpack/loaders/expose-loader/utils/index.js.map +1 -1
  487. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js +20 -12
  488. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js.map +1 -1
  489. package/dist/webpack/types.d.ts +0 -4
  490. package/dist/webpack/types.d.ts.map +1 -1
  491. package/dist/webpack/types.js +4 -1
  492. package/dist/webpack/types.js.map +1 -1
  493. package/dist/webpack/utils/feature-cohort.js +17 -12
  494. package/dist/webpack/utils/feature-cohort.js.map +1 -1
  495. package/dist/webpack/utils/get-caller-filename.js +14 -7
  496. package/dist/webpack/utils/get-caller-filename.js.map +1 -1
  497. package/dist/webpack/utils/{bundle.d.ts → get-module-entry-path.d.ts} +1 -1
  498. package/dist/webpack/utils/get-module-entry-path.d.ts.map +1 -0
  499. package/dist/webpack/utils/get-module-entry-path.js +21 -0
  500. package/dist/webpack/utils/get-module-entry-path.js.map +1 -0
  501. package/dist/webpack/utils/hash-mod.js +16 -11
  502. package/dist/webpack/utils/hash-mod.js.map +1 -1
  503. package/dist/webpack/utils/index.d.ts +1 -1
  504. package/dist/webpack/utils/index.d.ts.map +1 -1
  505. package/dist/webpack/utils/index.js +21 -19
  506. package/dist/webpack/utils/index.js.map +1 -1
  507. package/dist/webpack/utils/split-by-entry.js +17 -7
  508. package/dist/webpack/utils/split-by-entry.js.map +1 -1
  509. package/dist/webpack/utils/testing/compile.js +12 -4
  510. package/dist/webpack/utils/testing/compile.js.map +1 -1
  511. package/dist/webpack/utils/testing/execute.js +26 -13
  512. package/dist/webpack/utils/testing/execute.js.map +1 -1
  513. package/dist/webpack/utils/testing/get-compiler.js +34 -24
  514. package/dist/webpack/utils/testing/get-compiler.js.map +1 -1
  515. package/dist/webpack/utils/testing/get-errors.js +12 -4
  516. package/dist/webpack/utils/testing/get-errors.js.map +1 -1
  517. package/dist/webpack/utils/testing/get-module-source.js +18 -5
  518. package/dist/webpack/utils/testing/get-module-source.js.map +1 -1
  519. package/dist/webpack/utils/testing/get-warnings.js +12 -4
  520. package/dist/webpack/utils/testing/get-warnings.js.map +1 -1
  521. package/dist/webpack/utils/testing/index.js +28 -20
  522. package/dist/webpack/utils/testing/index.js.map +1 -1
  523. package/dist/webpack/utils/testing/normalize-errors.js +11 -3
  524. package/dist/webpack/utils/testing/normalize-errors.js.map +1 -1
  525. package/dist/webpack/utils/testing/read-asset.js +20 -11
  526. package/dist/webpack/utils/testing/read-asset.js.map +1 -1
  527. package/dist/webpack/utils/testing/read-assets.js +13 -5
  528. package/dist/webpack/utils/testing/read-assets.js.map +1 -1
  529. package/package.json +20 -20
  530. package/src/cli/commands/__tests__/build.test.ts +69 -44
  531. package/src/cli/commands/__tests__/clean.test.ts +32 -0
  532. package/src/cli/commands/__tests__/install.test.ts +50 -8
  533. package/src/cli/commands/__tests__/kendo-ui-license.test.ts +5 -5
  534. package/src/cli/commands/__tests__/lint.test.ts +4 -0
  535. package/src/cli/commands/__tests__/mfe-package-publish.test.ts +21 -2
  536. package/src/cli/commands/__tests__/mfe-publish.test.ts +19 -23
  537. package/src/cli/commands/__tests__/prepare-package.test.ts +17 -36
  538. package/src/cli/commands/__tests__/start.test.ts +81 -44
  539. package/src/cli/commands/__tests__/tests.test.ts +4 -0
  540. package/src/cli/commands/build.ts +73 -35
  541. package/src/cli/commands/bundle-package.ts +0 -4
  542. package/src/cli/commands/clean.ts +24 -0
  543. package/src/cli/commands/eslint.ts +1 -1
  544. package/src/cli/commands/get-command.ts +25 -35
  545. package/src/cli/commands/index.ts +1 -1
  546. package/src/cli/commands/install.ts +29 -8
  547. package/src/cli/commands/lint.ts +22 -17
  548. package/src/cli/commands/mfe-package-publish.ts +22 -5
  549. package/src/cli/commands/mfe-publish.ts +5 -18
  550. package/src/cli/commands/prepare-package.ts +8 -12
  551. package/src/cli/commands/review/__mocks__/expect-calls.ts +48 -0
  552. package/src/cli/commands/review/__mocks__/index.ts +1 -0
  553. package/src/cli/commands/review/__tests__/review.test.ts +483 -0
  554. package/src/cli/commands/review/index.ts +3 -0
  555. package/src/cli/commands/review/review.ts +247 -0
  556. package/src/cli/commands/review/rules/__mocks__/index.ts +3 -0
  557. package/src/cli/commands/review/rules/__mocks__/mock-config.ts +14 -0
  558. package/src/cli/commands/review/rules/__mocks__/mock-packages.ts +41 -0
  559. package/src/cli/commands/review/rules/__mocks__/mock-project.ts +11 -0
  560. package/src/cli/commands/review/rules/__tests__/no-typescript-entry-point.test.ts +166 -0
  561. package/src/cli/commands/review/rules/__tests__/require-explicit-side-effects.test.ts +113 -0
  562. package/src/cli/commands/review/rules/__tests__/require-npmrc.test.ts +71 -0
  563. package/src/cli/commands/review/rules/__tests__/require-one-anvil-uikit-contrib-version.test.ts +33 -0
  564. package/src/cli/commands/review/rules/__tests__/require-one-collection-version.test.ts +155 -0
  565. package/src/cli/commands/review/rules/__tests__/require-one-package-version.test.ts +135 -0
  566. package/src/cli/commands/review/rules/__tests__/require-one-uikit-version.ts +40 -0
  567. package/src/cli/commands/review/rules/__tests__/require-project-version-in-root-node-modules.test.ts +186 -0
  568. package/src/cli/commands/review/rules/__tests__/require-servicetitan-scope.test.ts +83 -0
  569. package/src/cli/commands/review/rules/index.ts +20 -0
  570. package/src/cli/commands/review/rules/no-typescript-entry-point.ts +78 -0
  571. package/src/cli/commands/review/rules/require-explicit-side-effects.ts +31 -0
  572. package/src/cli/commands/review/rules/require-npmrc.ts +27 -0
  573. package/src/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.ts +20 -0
  574. package/src/cli/commands/review/rules/require-one-collection-version.ts +169 -0
  575. package/src/cli/commands/review/rules/require-one-package-version.ts +76 -0
  576. package/src/cli/commands/review/rules/require-one-uikit-version.ts +27 -0
  577. package/src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts +104 -0
  578. package/src/cli/commands/review/rules/require-servicetitan-scope.ts +27 -0
  579. package/src/cli/commands/review/types.ts +72 -0
  580. package/src/cli/commands/review/utils/__tests__/compare-version.test.ts +73 -0
  581. package/src/cli/commands/review/utils/__tests__/get-max-version.test.ts +17 -0
  582. package/src/cli/commands/review/utils/__tests__/indent.test.ts +41 -0
  583. package/src/cli/commands/review/utils/__tests__/name-to-location.test.ts +39 -0
  584. package/src/cli/commands/review/utils/__tests__/set-version.test.ts +84 -0
  585. package/src/cli/commands/review/utils/apply-filter.ts +14 -0
  586. package/src/cli/commands/review/utils/collate-dependencies.ts +46 -0
  587. package/src/cli/commands/review/utils/compare-version.ts +82 -0
  588. package/src/cli/commands/review/utils/format-depends-on.ts +11 -0
  589. package/src/cli/commands/review/utils/format-location.ts +8 -0
  590. package/src/cli/commands/review/utils/get-key.ts +10 -0
  591. package/src/cli/commands/review/utils/get-max-version.ts +5 -0
  592. package/src/cli/commands/review/utils/indent.ts +8 -0
  593. package/src/cli/commands/review/utils/index.ts +13 -0
  594. package/src/cli/commands/review/utils/is-library.ts +5 -0
  595. package/src/cli/commands/review/utils/name-to-location.ts +7 -0
  596. package/src/cli/commands/review/utils/pluralize.ts +3 -0
  597. package/src/cli/commands/review/utils/set-version.ts +26 -0
  598. package/src/cli/commands/review/utils/summarize.ts +21 -0
  599. package/src/cli/commands/run-task.test.ts +60 -0
  600. package/src/cli/commands/start.ts +130 -55
  601. package/src/cli/commands/tests.ts +2 -0
  602. package/src/cli/commands/types.ts +1 -0
  603. package/src/cli/index.ts +4 -4
  604. package/src/cli/tasks/__tests__/cli-task.test.ts +16 -4
  605. package/src/cli/tasks/__tests__/{swc-compile.test.ts → swc-compile-package.test.ts} +75 -36
  606. package/src/cli/tasks/__tests__/tsc-compile-package.test.ts +1 -0
  607. package/src/cli/tasks/__tests__/tsc-compile.test.ts +12 -23
  608. package/src/cli/tasks/cli-task.ts +12 -18
  609. package/src/cli/tasks/swc-cli.d.ts +12 -1
  610. package/src/cli/tasks/swc-compile-package.ts +71 -45
  611. package/src/cli/tasks/task.ts +2 -11
  612. package/src/cli/tasks/tsc-compile-package.ts +0 -4
  613. package/src/cli/tasks/tsc-compile.ts +14 -17
  614. package/src/cli/types/cpx2.d.ts +8 -1
  615. package/src/cli/utils/__tests__/bundle.test.ts +1 -1
  616. package/src/cli/utils/__tests__/check-args.test.ts +34 -0
  617. package/src/cli/utils/__tests__/compile.test.ts +59 -0
  618. package/src/cli/utils/__tests__/copy-files.test.ts +157 -0
  619. package/src/cli/utils/__tests__/get-module-type.test.ts +19 -0
  620. package/src/cli/utils/__tests__/lerna-exec.test.ts +58 -11
  621. package/src/cli/utils/__tests__/pipe-stdout.test.ts +39 -0
  622. package/src/cli/utils/__tests__/process-tree.test.ts +175 -0
  623. package/src/cli/utils/__tests__/set-node-options.test.ts +51 -6
  624. package/src/cli/utils/__tests__/tcm.test.ts +90 -86
  625. package/src/cli/utils/__tests__/type-check.test.ts +47 -0
  626. package/src/cli/utils/__tests__/watch-stdout.test.ts +68 -0
  627. package/src/cli/utils/bundle.ts +5 -18
  628. package/src/cli/utils/check-args.ts +13 -0
  629. package/src/cli/utils/compile-less.ts +0 -1
  630. package/src/cli/utils/compile-sass.ts +0 -1
  631. package/src/cli/utils/compile.ts +22 -0
  632. package/src/cli/utils/copy-files.ts +76 -0
  633. package/src/cli/utils/eslint.ts +1 -0
  634. package/src/cli/utils/get-module-type.ts +4 -6
  635. package/src/cli/utils/index.ts +7 -6
  636. package/src/cli/utils/lerna-exec.ts +17 -10
  637. package/src/cli/utils/pipe-stdout.ts +10 -0
  638. package/src/cli/utils/process-tree.ts +57 -0
  639. package/src/cli/utils/set-node-options.ts +15 -12
  640. package/src/cli/utils/style-extensions.ts +1 -0
  641. package/src/cli/utils/tcm.ts +22 -32
  642. package/src/cli/utils/type-check.ts +19 -0
  643. package/src/cli/utils/watch-stdout.ts +24 -0
  644. package/src/utils/__tests__/format-duration.test.ts +22 -0
  645. package/src/utils/__tests__/get-configuration.test.ts +44 -2
  646. package/src/utils/__tests__/get-packages.test.ts +58 -49
  647. package/src/utils/__tests__/log-errors.test.ts +102 -0
  648. package/src/utils/__tests__/log.test.ts +1 -86
  649. package/src/utils/find-packages.ts +12 -6
  650. package/src/utils/format-duration.ts +13 -0
  651. package/src/utils/get-configuration.ts +19 -5
  652. package/src/utils/get-folders.ts +3 -1
  653. package/src/utils/get-packages.ts +9 -16
  654. package/src/utils/index.ts +3 -0
  655. package/src/utils/log-errors.ts +29 -0
  656. package/src/utils/log.ts +0 -26
  657. package/src/webpack/__mocks__/file-rules.ts +0 -5
  658. package/src/webpack/__tests__/create-webpack-config-web-component.test.ts +4 -5
  659. package/src/webpack/__tests__/create-webpack-config.test.ts +33 -112
  660. package/src/webpack/configs/dev-server-config.ts +4 -27
  661. package/src/webpack/configs/devtool-config.ts +2 -2
  662. package/src/webpack/configs/entry.config.ts +7 -2
  663. package/src/webpack/configs/index.ts +2 -1
  664. package/src/webpack/configs/loaders/index.ts +1 -1
  665. package/src/webpack/configs/optimization-config.ts +2 -2
  666. package/src/webpack/configs/plugins/index.ts +0 -2
  667. package/src/webpack/configs/plugins/virtual-modules-plugin.ts +3 -3
  668. package/src/webpack/configs/plugins-config.ts +0 -4
  669. package/src/webpack/configs/resolve-config.ts +1 -1
  670. package/src/webpack/configs/rules/index.ts +0 -1
  671. package/src/webpack/configs/rules/js-rules.ts +27 -2
  672. package/src/webpack/configs/rules-config.ts +1 -11
  673. package/src/webpack/configs/types.ts +1 -3
  674. package/src/webpack/configs/watch-options-config.ts +17 -0
  675. package/src/webpack/create-webpack-config.ts +3 -4
  676. package/src/webpack/index.ts +1 -1
  677. package/src/webpack/types.ts +0 -4
  678. package/src/webpack/utils/index.ts +1 -1
  679. package/dist/__mocks__/create-package.js +0 -17
  680. package/dist/__mocks__/create-package.js.map +0 -1
  681. package/dist/__mocks__/index.js +0 -18
  682. package/dist/__mocks__/index.js.map +0 -1
  683. package/dist/cli/utils/assets-copy.d.ts +0 -3
  684. package/dist/cli/utils/assets-copy.d.ts.map +0 -1
  685. package/dist/cli/utils/assets-copy.js +0 -25
  686. package/dist/cli/utils/assets-copy.js.map +0 -1
  687. package/dist/cli/utils/styles-copy.d.ts +0 -3
  688. package/dist/cli/utils/styles-copy.d.ts.map +0 -1
  689. package/dist/cli/utils/styles-copy.js +0 -25
  690. package/dist/cli/utils/styles-copy.js.map +0 -1
  691. package/dist/cli/utils/tsc.d.ts +0 -5
  692. package/dist/cli/utils/tsc.d.ts.map +0 -1
  693. package/dist/cli/utils/tsc.js +0 -37
  694. package/dist/cli/utils/tsc.js.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.js +0 -19
  698. package/dist/webpack/__mocks__/index.js.map +0 -1
  699. package/dist/webpack/__mocks__/style-rules.js +0 -124
  700. package/dist/webpack/__mocks__/style-rules.js.map +0 -1
  701. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts +0 -4
  702. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts.map +0 -1
  703. package/dist/webpack/configs/plugins/provide-react-plugin.js +0 -13
  704. package/dist/webpack/configs/plugins/provide-react-plugin.js.map +0 -1
  705. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts +0 -4
  706. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts.map +0 -1
  707. package/dist/webpack/configs/plugins/ts-checker-plugin.js +0 -30
  708. package/dist/webpack/configs/plugins/ts-checker-plugin.js.map +0 -1
  709. package/dist/webpack/configs/rules/tsx-rules.d.ts +0 -4
  710. package/dist/webpack/configs/rules/tsx-rules.d.ts.map +0 -1
  711. package/dist/webpack/configs/rules/tsx-rules.js +0 -44
  712. package/dist/webpack/configs/rules/tsx-rules.js.map +0 -1
  713. package/dist/webpack/utils/bundle.d.ts.map +0 -1
  714. package/dist/webpack/utils/bundle.js +0 -19
  715. package/dist/webpack/utils/bundle.js.map +0 -1
  716. package/src/cli/utils/__tests__/assets-copy.test.ts +0 -52
  717. package/src/cli/utils/__tests__/styles-copy.test.ts +0 -52
  718. package/src/cli/utils/__tests__/tsc.test.ts +0 -63
  719. package/src/cli/utils/assets-copy.ts +0 -23
  720. package/src/cli/utils/styles-copy.ts +0 -23
  721. package/src/cli/utils/tsc.ts +0 -38
  722. package/src/webpack/configs/plugins/provide-react-plugin.ts +0 -12
  723. package/src/webpack/configs/plugins/ts-checker-plugin.ts +0 -33
  724. package/src/webpack/configs/rules/tsx-rules.ts +0 -48
  725. /package/src/webpack/utils/{bundle.ts → get-module-entry-path.ts} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/rules/require-one-uikit-version.ts"],"sourcesContent":["import { RequireOneCollectionVersion } from './require-one-collection-version';\n\nconst UIKIT_PACKAGES = [\n '@servicetitan/ajax-handlers',\n '@servicetitan/error-boundary',\n '@servicetitan/eslint-config',\n '@servicetitan/eslint-plugin',\n '@servicetitan/eslint-plugin-folder-schema',\n '@servicetitan/folder-lint',\n '@servicetitan/hash-browser-router',\n '@servicetitan/ko-bridge',\n '@servicetitan/launchdarkly-service',\n '@servicetitan/lazy-module',\n '@servicetitan/log-service',\n '@servicetitan/react-ioc',\n '@servicetitan/restrict-imports',\n '@servicetitan/startup',\n '@servicetitan/stylelint-config',\n '@servicetitan/suppress-warnings',\n '@servicetitan/web-components',\n];\n\nexport class RequireOneUikitVersion extends RequireOneCollectionVersion {\n constructor() {\n super({ name: 'uikit', packages: UIKIT_PACKAGES });\n }\n}\n"],"names":["RequireOneUikitVersion","UIKIT_PACKAGES","RequireOneCollectionVersion","constructor","name","packages"],"mappings":";;;;+BAsBaA;;;eAAAA;;;6CAtB+B;AAE5C,MAAMC,iBAAiB;IACnB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACH;AAEM,MAAMD,+BAA+BE,wDAA2B;IACnEC,aAAc;QACV,KAAK,CAAC;YAAEC,MAAM;YAASC,UAAUJ;QAAe;IACpD;AACJ"}
@@ -0,0 +1,19 @@
1
+ import { PackageError, PackageRule, Project } from '../types';
2
+ interface Mismatch {
3
+ name: string;
4
+ projectVersions: string[];
5
+ rootVersion: string;
6
+ }
7
+ interface ErrorData {
8
+ mismatches: Mismatch[];
9
+ }
10
+ export declare class RequireProjectVersionInRootNodeModules implements PackageRule {
11
+ get id(): string;
12
+ run(project: Project): PackageError<ErrorData> | undefined;
13
+ fix({ data }: PackageError<ErrorData>, project: Project): void;
14
+ private formatDetails;
15
+ private findMismatches;
16
+ private getDependencies;
17
+ }
18
+ export {};
19
+ //# sourceMappingURL=require-project-version-in-root-node-modules.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-project-version-in-root-node-modules.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts"],"names":[],"mappings":"AAEA,OAAO,EAAe,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAK3E,UAAU,QAAQ;IACd,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,WAAW,EAAE,MAAM,CAAC;CACvB;AAED,UAAU,SAAS;IACf,UAAU,EAAE,QAAQ,EAAE,CAAC;CAC1B;AAED,qBAAa,sCAAuC,YAAW,WAAW;IACtE,IAAI,EAAE,WAEL;IAED,GAAG,CAAC,OAAO,EAAE,OAAO,GAAG,YAAY,CAAC,SAAS,CAAC,GAAG,SAAS;IAgB1D,GAAG,CAAC,EAAE,IAAI,EAAE,EAAE,YAAY,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,OAAO;IAwCvD,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,cAAc;IActB,OAAO,CAAC,eAAe;CAI1B"}
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "RequireProjectVersionInRootNodeModules", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return RequireProjectVersionInRootNodeModules;
9
+ }
10
+ });
11
+ const _chalk = /*#__PURE__*/ _interop_require_default(require("chalk"));
12
+ const _semver = require("semver");
13
+ const _types = require("../types");
14
+ const _utils = require("../utils");
15
+ const _child_process = require("child_process");
16
+ const _utils1 = require("../../../../utils");
17
+ function _interop_require_default(obj) {
18
+ return obj && obj.__esModule ? obj : {
19
+ default: obj
20
+ };
21
+ }
22
+ class RequireProjectVersionInRootNodeModules {
23
+ get id() {
24
+ return 'require-project-version-in-root-node-modules';
25
+ }
26
+ run(project) {
27
+ const mismatches = this.findMismatches(project);
28
+ if (!mismatches.length) {
29
+ return;
30
+ }
31
+ return {
32
+ id: this.id,
33
+ message: 'project has unexpected version in root node_modules',
34
+ details: this.formatDetails(mismatches),
35
+ fixable: _types.FixCategory.lockFile,
36
+ location: project.packageLock.location,
37
+ data: {
38
+ mismatches
39
+ }
40
+ };
41
+ }
42
+ fix({ data }, project) {
43
+ const { mismatches } = data !== null && data !== void 0 ? data : {};
44
+ if (!mismatches) {
45
+ return;
46
+ }
47
+ const root = project.packages.find(({ location })=>location === '.');
48
+ if (!root) {
49
+ return;
50
+ }
51
+ const dependencies = mismatches.reduce((result, { name, projectVersions })=>{
52
+ if (!(0, _utils.getKey)(root, name)) {
53
+ result[name] = (0, _utils.getMaxVersion)(projectVersions);
54
+ }
55
+ return result;
56
+ }, {});
57
+ const entries = Object.entries(dependencies);
58
+ if (entries.length === 0) {
59
+ return;
60
+ }
61
+ /* istanbul ignore next: debug only */ _utils1.log.debug(`review:${this.id}`, ()=>JSON.stringify(dependencies, null, 2));
62
+ entries.forEach(([name, version])=>(0, _child_process.execSync)(`npm pkg set dependencies["${name}"]="${version}"`, {
63
+ stdio: 'inherit'
64
+ }));
65
+ (0, _child_process.execSync)('npx startup install --fix --quiet', {
66
+ stdio: 'inherit'
67
+ });
68
+ entries.forEach(([name])=>(0, _child_process.execSync)(`npm pkg delete dependencies["${name}"]`, {
69
+ stdio: 'inherit'
70
+ }));
71
+ }
72
+ formatDetails(mismatches) {
73
+ return mismatches.map(({ name, projectVersions, rootVersion })=>{
74
+ const pkg = _chalk.default.yellow(`${name}@${rootVersion}`);
75
+ return `${pkg} does not match ${_chalk.default.yellow(projectVersions.join(', '))}`;
76
+ });
77
+ }
78
+ findMismatches(project) {
79
+ const { packageLock } = project;
80
+ return this.getDependencies(project).reduce((result, [name, versions])=>{
81
+ var _packageLock_packages_;
82
+ const rootVersion = (_packageLock_packages_ = packageLock.packages[`node_modules/${name}`]) === null || _packageLock_packages_ === void 0 ? void 0 : _packageLock_packages_.version;
83
+ if (rootVersion) {
84
+ const projectVersions = Object.keys(versions);
85
+ if (!projectVersions.some((version)=>(0, _semver.satisfies)(rootVersion, version))) {
86
+ result.push({
87
+ name,
88
+ projectVersions,
89
+ rootVersion
90
+ });
91
+ }
92
+ }
93
+ return result;
94
+ }, []);
95
+ }
96
+ getDependencies({ config, dependencies }) {
97
+ var _config_rules;
98
+ const ruleConfig = (_config_rules = config.rules) === null || _config_rules === void 0 ? void 0 : _config_rules[this.id];
99
+ return (0, _utils.applyFilter)(ruleConfig, Object.entries(dependencies), ([name])=>name);
100
+ }
101
+ }
102
+
103
+ //# sourceMappingURL=require-project-version-in-root-node-modules.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts"],"sourcesContent":["import chalk from 'chalk';\nimport { satisfies } from 'semver';\nimport { FixCategory, PackageError, PackageRule, Project } from '../types';\nimport { applyFilter, getKey, getMaxVersion } from '../utils';\nimport { execSync } from 'child_process';\nimport { log } from '../../../../utils';\n\ninterface Mismatch {\n name: string;\n projectVersions: string[];\n rootVersion: string;\n}\n\ninterface ErrorData {\n mismatches: Mismatch[];\n}\n\nexport class RequireProjectVersionInRootNodeModules implements PackageRule {\n get id() {\n return 'require-project-version-in-root-node-modules';\n }\n\n run(project: Project): PackageError<ErrorData> | undefined {\n const mismatches = this.findMismatches(project);\n if (!mismatches.length) {\n return;\n }\n\n return {\n id: this.id,\n message: 'project has unexpected version in root node_modules',\n details: this.formatDetails(mismatches),\n fixable: FixCategory.lockFile,\n location: project.packageLock.location,\n data: { mismatches },\n };\n }\n\n fix({ data }: PackageError<ErrorData>, project: Project) {\n const { mismatches } = data ?? {};\n if (!mismatches) {\n return;\n }\n\n const root = project.packages.find(({ location }) => location === '.');\n if (!root) {\n return;\n }\n\n const dependencies = mismatches.reduce<Record<string, string>>(\n (result, { name, projectVersions }) => {\n if (!getKey(root, name)) {\n result[name] = getMaxVersion(projectVersions);\n }\n return result;\n },\n {}\n );\n\n const entries = Object.entries(dependencies);\n if (entries.length === 0) {\n return;\n }\n\n /* istanbul ignore next: debug only */\n log.debug(`review:${this.id}`, () => JSON.stringify(dependencies, null, 2));\n\n entries.forEach(([name, version]) =>\n execSync(`npm pkg set dependencies[\"${name}\"]=\"${version}\"`, { stdio: 'inherit' })\n );\n\n execSync('npx startup install --fix --quiet', { stdio: 'inherit' });\n\n entries.forEach(([name]) =>\n execSync(`npm pkg delete dependencies[\"${name}\"]`, { stdio: 'inherit' })\n );\n }\n\n private formatDetails(mismatches: Mismatch[]) {\n return mismatches.map(({ name, projectVersions, rootVersion }) => {\n const pkg = chalk.yellow(`${name}@${rootVersion}`);\n return `${pkg} does not match ${chalk.yellow(projectVersions.join(', '))}`;\n });\n }\n\n private findMismatches(project: Project) {\n const { packageLock } = project;\n return this.getDependencies(project).reduce((result, [name, versions]) => {\n const rootVersion = packageLock.packages[`node_modules/${name}`]?.version;\n if (rootVersion) {\n const projectVersions = Object.keys(versions);\n if (!projectVersions.some(version => satisfies(rootVersion, version))) {\n result.push({ name, projectVersions, rootVersion });\n }\n }\n return result;\n }, [] as Mismatch[]);\n }\n\n private getDependencies({ config, dependencies }: Project) {\n const ruleConfig = config.rules?.[this.id];\n return applyFilter(ruleConfig, Object.entries(dependencies), ([name]) => name);\n }\n}\n"],"names":["RequireProjectVersionInRootNodeModules","id","run","project","mismatches","findMismatches","length","message","details","formatDetails","fixable","FixCategory","lockFile","location","packageLock","data","fix","root","packages","find","dependencies","reduce","result","name","projectVersions","getKey","getMaxVersion","entries","Object","log","debug","JSON","stringify","forEach","version","execSync","stdio","map","rootVersion","pkg","chalk","yellow","join","getDependencies","versions","keys","some","satisfies","push","config","ruleConfig","rules","applyFilter"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { PackageError, PackageRule, Project } from '../types';
2
+ export declare class RequireServiceTitanScope implements PackageRule {
3
+ get id(): string;
4
+ run({ config, packages }: Project): PackageError[];
5
+ private needsScope;
6
+ }
7
+ //# sourceMappingURL=require-servicetitan-scope.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-servicetitan-scope.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/rules/require-servicetitan-scope.ts"],"names":[],"mappings":"AAAA,OAAO,EAA0B,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAGtF,qBAAa,wBAAyB,YAAW,WAAW;IACxD,IAAI,EAAE,WAEL;IAED,GAAG,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,OAAO,GAAG,YAAY,EAAE;IAelD,OAAO,CAAC,UAAU;CAGrB"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "RequireServiceTitanScope", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return RequireServiceTitanScope;
9
+ }
10
+ });
11
+ const _types = require("../types");
12
+ const _utils = require("../utils");
13
+ class RequireServiceTitanScope {
14
+ get id() {
15
+ return 'require-servicetitan-scope';
16
+ }
17
+ run({ config, packages }) {
18
+ var _config_rules;
19
+ const ruleConfig = (_config_rules = config.rules) === null || _config_rules === void 0 ? void 0 : _config_rules[this.id];
20
+ return (0, _utils.applyFilter)(ruleConfig, packages, ({ name })=>name).reduce((result, pkg)=>{
21
+ if (this.needsScope(pkg)) {
22
+ result.push({
23
+ id: this.id,
24
+ message: `package "${pkg.name}" should have @servicetitan scope`,
25
+ severity: _types.ErrorSeverity.warning,
26
+ location: pkg.location
27
+ });
28
+ }
29
+ return result;
30
+ }, []);
31
+ }
32
+ needsScope(pkg) {
33
+ return (0, _utils.isLibrary)(pkg) && pkg.private !== true && !pkg.name.startsWith('@servicetitan/');
34
+ }
35
+ }
36
+
37
+ //# sourceMappingURL=require-servicetitan-scope.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/rules/require-servicetitan-scope.ts"],"sourcesContent":["import { ErrorSeverity, Package, PackageError, PackageRule, Project } from '../types';\nimport { applyFilter, isLibrary } from '../utils';\n\nexport class RequireServiceTitanScope implements PackageRule {\n get id() {\n return 'require-servicetitan-scope';\n }\n\n run({ config, packages }: Project): PackageError[] {\n const ruleConfig = config.rules?.[this.id];\n return applyFilter(ruleConfig, packages, ({ name }) => name).reduce((result, pkg) => {\n if (this.needsScope(pkg)) {\n result.push({\n id: this.id,\n message: `package \"${pkg.name}\" should have @servicetitan scope`,\n severity: ErrorSeverity.warning,\n location: pkg.location,\n });\n }\n return result;\n }, [] as PackageError[]);\n }\n\n private needsScope(pkg: Package) {\n return isLibrary(pkg) && pkg.private !== true && !pkg.name.startsWith('@servicetitan/');\n }\n}\n"],"names":["RequireServiceTitanScope","id","run","config","packages","ruleConfig","rules","applyFilter","name","reduce","result","pkg","needsScope","push","message","severity","ErrorSeverity","warning","location","isLibrary","private","startsWith"],"mappings":";;;;+BAGaA;;;eAAAA;;;uBAH8D;uBACpC;AAEhC,MAAMA;IACT,IAAIC,KAAK;QACL,OAAO;IACX;IAEAC,IAAI,EAAEC,MAAM,EAAEC,QAAQ,EAAW,EAAkB;YAC5BD;QAAnB,MAAME,cAAaF,gBAAAA,OAAOG,KAAK,cAAZH,oCAAAA,aAAc,CAAC,IAAI,CAACF,EAAE,CAAC;QAC1C,OAAOM,IAAAA,kBAAW,EAACF,YAAYD,UAAU,CAAC,EAAEI,IAAI,EAAE,GAAKA,MAAMC,MAAM,CAAC,CAACC,QAAQC;YACzE,IAAI,IAAI,CAACC,UAAU,CAACD,MAAM;gBACtBD,OAAOG,IAAI,CAAC;oBACRZ,IAAI,IAAI,CAACA,EAAE;oBACXa,SAAS,CAAC,SAAS,EAAEH,IAAIH,IAAI,CAAC,iCAAiC,CAAC;oBAChEO,UAAUC,oBAAa,CAACC,OAAO;oBAC/BC,UAAUP,IAAIO,QAAQ;gBAC1B;YACJ;YACA,OAAOR;QACX,GAAG,EAAE;IACT;IAEQE,WAAWD,GAAY,EAAE;QAC7B,OAAOQ,IAAAA,gBAAS,EAACR,QAAQA,IAAIS,OAAO,KAAK,QAAQ,CAACT,IAAIH,IAAI,CAACa,UAAU,CAAC;IAC1E;AACJ"}
@@ -0,0 +1,72 @@
1
+ export declare abstract class PackageRule {
2
+ abstract get id(): string;
3
+ abstract run(project: Project): PackageError | PackageError[] | undefined;
4
+ abstract fix?(error: PackageError, project: Project): void;
5
+ }
6
+ export interface Project {
7
+ config: ReviewConfiguration;
8
+ dependencies: Dependencies;
9
+ packageLock: {
10
+ packages: Record<string, {
11
+ version: string;
12
+ }>;
13
+ location: string;
14
+ };
15
+ packages: Package[];
16
+ }
17
+ /**
18
+ * Maps package name to versions and dependents of those versions.
19
+ */
20
+ export interface Dependencies {
21
+ [packageName: string]: {
22
+ [version: string]: string[];
23
+ };
24
+ }
25
+ /**
26
+ * Subset of package.json used by rules
27
+ */
28
+ export interface Package {
29
+ cli?: CliOptions;
30
+ dependencies?: Record<string, string>;
31
+ devDependencies?: Record<string, string>;
32
+ exports?: string | Record<string, string | Record<string, string>> | null;
33
+ location: string;
34
+ main?: string;
35
+ module?: string;
36
+ name: string;
37
+ private?: boolean;
38
+ sideEffects?: any;
39
+ workspaces?: string[];
40
+ }
41
+ interface CliOptions {
42
+ webpack?: false | Record<string, any>;
43
+ }
44
+ export interface PackageError<T = any> {
45
+ data?: T;
46
+ details?: string | string[];
47
+ fixable?: FixCategory;
48
+ id: string;
49
+ location?: string;
50
+ message: string;
51
+ severity?: ErrorSeverity;
52
+ }
53
+ export declare enum ErrorSeverity {
54
+ error = 1,
55
+ warning = 2
56
+ }
57
+ export declare enum FixCategory {
58
+ isolated = "isolated",// fix examines and changes at most one dependency or package.json, if any
59
+ normal = "normal",// fix potentially examines and changes multiple dependencies
60
+ lockFile = "lockFile"
61
+ }
62
+ export interface ReviewConfiguration {
63
+ rules?: {
64
+ [id: string]: RuleConfiguration;
65
+ };
66
+ }
67
+ export type RuleConfiguration = Level | [Level] | [Level, {
68
+ exclude?: string[];
69
+ }];
70
+ export type Level = 'warn' | 'error' | 'off';
71
+ export {};
72
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/cli/commands/review/types.ts"],"names":[],"mappings":"AAAA,8BAAsB,WAAW;IAC7B,QAAQ,KAAK,EAAE,IAAI,MAAM,CAAC;IAC1B,QAAQ,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,GAAG,YAAY,GAAG,YAAY,EAAE,GAAG,SAAS;IACzE,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,GAAG,IAAI;CAC7D;AAED,MAAM,WAAW,OAAO;IACpB,MAAM,EAAE,mBAAmB,CAAC;IAC5B,YAAY,EAAE,YAAY,CAAC;IAE3B,WAAW,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,OAAO,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IACjF,QAAQ,EAAE,OAAO,EAAE,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IACzB,CAAC,WAAW,EAAE,MAAM,GAAG;QACnB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC/B,CAAC;CACL;AAED;;GAEG;AACH,MAAM,WAAW,OAAO;IACpB,GAAG,CAAC,EAAE,UAAU,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC;IAC1E,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,GAAG,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB;AAED,UAAU,UAAU;IAChB,OAAO,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CACzC;AAED,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,GAAG;IACjC,IAAI,CAAC,EAAE,CAAC,CAAC;IACT,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC5B,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,aAAa,CAAC;CAC5B;AAED,oBAAY,aAAa;IACrB,KAAK,IAAI;IACT,OAAO,IAAI;CACd;AAED,oBAAY,WAAW;IACnB,QAAQ,aAAa,CAAE,0EAA0E;IACjG,MAAM,WAAW,CAAE,6DAA6D;IAChF,QAAQ,aAAa;CACxB;AAED,MAAM,WAAW,mBAAmB;IAChC,KAAK,CAAC,EAAE;QAAE,CAAC,EAAE,EAAE,MAAM,GAAG,iBAAiB,CAAA;KAAE,CAAC;CAC/C;AAED,MAAM,MAAM,iBAAiB,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE;IAAE,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC,CAAC;AAElF,MAAM,MAAM,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,KAAK,CAAC"}
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get ErrorSeverity () {
13
+ return ErrorSeverity;
14
+ },
15
+ get FixCategory () {
16
+ return FixCategory;
17
+ },
18
+ get PackageRule () {
19
+ return PackageRule;
20
+ }
21
+ });
22
+ class PackageRule {
23
+ }
24
+ var ErrorSeverity = /*#__PURE__*/ function(ErrorSeverity) {
25
+ ErrorSeverity[ErrorSeverity["error"] = 1] = "error";
26
+ ErrorSeverity[ErrorSeverity["warning"] = 2] = "warning";
27
+ return ErrorSeverity;
28
+ }({});
29
+ var FixCategory = /*#__PURE__*/ function(FixCategory) {
30
+ FixCategory["isolated"] = "isolated";
31
+ FixCategory["normal"] = "normal";
32
+ FixCategory["lockFile"] = "lockFile";
33
+ return FixCategory;
34
+ }({});
35
+
36
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/cli/commands/review/types.ts"],"sourcesContent":["export abstract class PackageRule {\n abstract get id(): string;\n abstract run(project: Project): PackageError | PackageError[] | undefined;\n abstract fix?(error: PackageError, project: Project): void;\n}\n\nexport interface Project {\n config: ReviewConfiguration;\n dependencies: Dependencies;\n // Only using this subset of package-lock.json\n packageLock: { packages: Record<string, { version: string }>; location: string };\n packages: Package[];\n}\n\n/**\n * Maps package name to versions and dependents of those versions.\n */\nexport interface Dependencies {\n [packageName: string]: {\n [version: string]: string[];\n };\n}\n\n/**\n * Subset of package.json used by rules\n */\nexport interface Package {\n cli?: CliOptions;\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n exports?: string | Record<string, string | Record<string, string>> | null;\n location: string;\n main?: string;\n module?: string;\n name: string;\n private?: boolean;\n sideEffects?: any;\n workspaces?: string[];\n}\n\ninterface CliOptions {\n webpack?: false | Record<string, any>;\n}\n\nexport interface PackageError<T = any> {\n data?: T;\n details?: string | string[];\n fixable?: FixCategory;\n id: string;\n location?: string;\n message: string;\n severity?: ErrorSeverity;\n}\n\nexport enum ErrorSeverity {\n error = 1,\n warning = 2,\n}\n\nexport enum FixCategory {\n isolated = 'isolated', // fix examines and changes at most one dependency or package.json, if any\n normal = 'normal', // fix potentially examines and changes multiple dependencies\n lockFile = 'lockFile', // fix examines and changes package-lock.json\n}\n\nexport interface ReviewConfiguration {\n rules?: { [id: string]: RuleConfiguration };\n}\n\nexport type RuleConfiguration = Level | [Level] | [Level, { exclude?: string[] }];\n\nexport type Level = 'warn' | 'error' | 'off';\n"],"names":["ErrorSeverity","FixCategory","PackageRule"],"mappings":";;;;;;;;;;;QAsDYA;eAAAA;;QAKAC;eAAAA;;QA3DUC;eAAAA;;;AAAf,MAAeA;AAItB;AAkDO,IAAA,AAAKF,uCAAAA;;;WAAAA;;AAKL,IAAA,AAAKC,qCAAAA;;;;WAAAA"}
@@ -0,0 +1,3 @@
1
+ import { RuleConfiguration } from '../types';
2
+ export declare function applyFilter<T>(config: RuleConfiguration | undefined, items: T[], getName: (item: T) => string): T[];
3
+ //# sourceMappingURL=apply-filter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-filter.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/utils/apply-filter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAE7C,wBAAgB,WAAW,CAAC,CAAC,EACzB,MAAM,EAAE,iBAAiB,GAAG,SAAS,EACrC,KAAK,EAAE,CAAC,EAAE,EACV,OAAO,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,MAAM,OAQ/B"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "applyFilter", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return applyFilter;
9
+ }
10
+ });
11
+ function applyFilter(config, items, getName) {
12
+ const { exclude } = Array.isArray(config) && config[1] || {}; // eslint-disable-line @typescript-eslint/prefer-nullish-coalescing
13
+ if (Array.isArray(exclude) && exclude.length > 0) {
14
+ const set = new Set(exclude);
15
+ return items.filter((item)=>!set.has(getName(item)));
16
+ }
17
+ return items;
18
+ }
19
+
20
+ //# sourceMappingURL=apply-filter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/utils/apply-filter.ts"],"sourcesContent":["import { RuleConfiguration } from '../types';\n\nexport function applyFilter<T>(\n config: RuleConfiguration | undefined,\n items: T[],\n getName: (item: T) => string\n) {\n const { exclude } = (Array.isArray(config) && config[1]) || {}; // eslint-disable-line @typescript-eslint/prefer-nullish-coalescing\n if (Array.isArray(exclude) && exclude.length > 0) {\n const set = new Set(exclude);\n return items.filter(item => !set.has(getName(item)));\n }\n return items;\n}\n"],"names":["applyFilter","config","items","getName","exclude","Array","isArray","length","set","Set","filter","item","has"],"mappings":";;;;+BAEgBA;;;eAAAA;;;AAAT,SAASA,YACZC,MAAqC,EACrCC,KAAU,EACVC,OAA4B;IAE5B,MAAM,EAAEC,OAAO,EAAE,GAAG,AAACC,MAAMC,OAAO,CAACL,WAAWA,MAAM,CAAC,EAAE,IAAK,CAAC,GAAG,mEAAmE;IACnI,IAAII,MAAMC,OAAO,CAACF,YAAYA,QAAQG,MAAM,GAAG,GAAG;QAC9C,MAAMC,MAAM,IAAIC,IAAIL;QACpB,OAAOF,MAAMQ,MAAM,CAACC,CAAAA,OAAQ,CAACH,IAAII,GAAG,CAACT,QAAQQ;IACjD;IACA,OAAOT;AACX"}
@@ -0,0 +1,29 @@
1
+ import { Dependencies, Package } from '../types';
2
+ /**
3
+ * Collates all dependencies and devDependencies from an array of packages into a Dependencies map.
4
+ *
5
+ * For each package, this function collects both `dependencies` and `devDependencies`.
6
+ * It groups package names by dependency and version, resulting in a structure that shows
7
+ * which packages depend on which versions of each dependency.
8
+ *
9
+ * @param {Package[]} packages The array of Package objects to process.
10
+ * @returns {Dependencies} An object mapping dependency names to version maps,
11
+ * where each version maps to an array of package names that depend on that version.
12
+ *
13
+ * @example
14
+ * // Given:
15
+ * packages = [
16
+ * { name: 'foo', dependencies: { lodash: '^4.17.21' } },
17
+ * { name: 'bar', devDependencies: { lodash: '^4.17.21' } },
18
+ * { name: 'baz', dependencies: { lodash: '^4.17.20' } }
19
+ * ]
20
+ * // collateDependencies(packages) returns:
21
+ * {
22
+ * lodash: {
23
+ * '^4.17.21': ['foo', 'bar'],
24
+ * '^4.17.20': ['baz']
25
+ * }
26
+ * }
27
+ */
28
+ export declare function collateDependencies(packages: Package[]): Dependencies;
29
+ //# sourceMappingURL=collate-dependencies.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collate-dependencies.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/utils/collate-dependencies.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAEjD;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,YAAY,CAgBrE"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "collateDependencies", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return collateDependencies;
9
+ }
10
+ });
11
+ const _semver = require("semver");
12
+ function collateDependencies(packages) {
13
+ return packages.reduce((result, { name, dependencies = {}, devDependencies = {} })=>{
14
+ [
15
+ ...Object.entries(dependencies),
16
+ ...Object.entries(devDependencies)
17
+ ].forEach(([dependency, version])=>{
18
+ if ((0, _semver.validRange)(version)) {
19
+ var _result, _dependency, _result_dependency, _version;
20
+ var _;
21
+ (_ = (_result = result)[_dependency = dependency]) !== null && _ !== void 0 ? _ : _result[_dependency] = {};
22
+ var _1;
23
+ (_1 = (_result_dependency = result[dependency])[_version = version]) !== null && _1 !== void 0 ? _1 : _result_dependency[_version] = [];
24
+ result[dependency][version].push(name);
25
+ }
26
+ });
27
+ return result;
28
+ }, {});
29
+ }
30
+
31
+ //# sourceMappingURL=collate-dependencies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/utils/collate-dependencies.ts"],"sourcesContent":["import { validRange } from 'semver';\nimport { Dependencies, Package } from '../types';\n\n/**\n * Collates all dependencies and devDependencies from an array of packages into a Dependencies map.\n *\n * For each package, this function collects both `dependencies` and `devDependencies`.\n * It groups package names by dependency and version, resulting in a structure that shows\n * which packages depend on which versions of each dependency.\n *\n * @param {Package[]} packages The array of Package objects to process.\n * @returns {Dependencies} An object mapping dependency names to version maps,\n * where each version maps to an array of package names that depend on that version.\n *\n * @example\n * // Given:\n * packages = [\n * { name: 'foo', dependencies: { lodash: '^4.17.21' } },\n * { name: 'bar', devDependencies: { lodash: '^4.17.21' } },\n * { name: 'baz', dependencies: { lodash: '^4.17.20' } }\n * ]\n * // collateDependencies(packages) returns:\n * {\n * lodash: {\n * '^4.17.21': ['foo', 'bar'],\n * '^4.17.20': ['baz']\n * }\n * }\n */\nexport function collateDependencies(packages: Package[]): Dependencies {\n return packages.reduce<Dependencies>(\n (result, { name, dependencies = {}, devDependencies = {} }) => {\n [...Object.entries(dependencies), ...Object.entries(devDependencies)].forEach(\n ([dependency, version]) => {\n if (validRange(version)) {\n result[dependency] ??= {};\n result[dependency][version] ??= [];\n result[dependency][version].push(name);\n }\n }\n );\n return result;\n },\n {}\n );\n}\n"],"names":["collateDependencies","packages","reduce","result","name","dependencies","devDependencies","Object","entries","forEach","dependency","version","validRange","push"],"mappings":";;;;+BA6BgBA;;;eAAAA;;;wBA7BW;AA6BpB,SAASA,oBAAoBC,QAAmB;IACnD,OAAOA,SAASC,MAAM,CAClB,CAACC,QAAQ,EAAEC,IAAI,EAAEC,eAAe,CAAC,CAAC,EAAEC,kBAAkB,CAAC,CAAC,EAAE;QACtD;eAAIC,OAAOC,OAAO,CAACH;eAAkBE,OAAOC,OAAO,CAACF;SAAiB,CAACG,OAAO,CACzE,CAAC,CAACC,YAAYC,QAAQ;YAClB,IAAIC,IAAAA,kBAAU,EAACD,UAAU;oBACrBR,SAAOO,aACPP,oBAAmBQ;;gBADnBR,MAAAA,UAAAA,OAAM,CAACO,cAAAA,WAAW,iCAAlBP,OAAM,CAACO,YAAW,GAAK,CAAC;;gBACxBP,OAAAA,qBAAAA,MAAM,CAACO,WAAW,CAAA,CAACC,WAAAA,QAAQ,mCAA3BR,kBAAkB,CAACQ,SAAQ,GAAK,EAAE;gBAClCR,MAAM,CAACO,WAAW,CAACC,QAAQ,CAACE,IAAI,CAACT;YACrC;QACJ;QAEJ,OAAOD;IACX,GACA,CAAC;AAET"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Compare two semver strings.
3
+ * @returns
4
+ * - `0` if a == b
5
+ * - `>0` if a is semantically greater than b (e.g., "^1.0.0" is greater than "~1.0.0")
6
+ * - `<0` if a is semantically less than b (e.g., "<1" is less than "<=1")
7
+ */
8
+ export declare function compareVersion(a: string, b: string): number;
9
+ //# sourceMappingURL=compare-version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compare-version.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/utils/compare-version.ts"],"names":[],"mappings":"AAUA;;;;;;GAMG;AACH,wBAAgB,cAAc,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,UAalD"}
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "compareVersion", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return compareVersion;
9
+ }
10
+ });
11
+ const _semver = /*#__PURE__*/ _interop_require_wildcard(require("semver"));
12
+ function _getRequireWildcardCache(nodeInterop) {
13
+ if (typeof WeakMap !== "function") return null;
14
+ var cacheBabelInterop = new WeakMap();
15
+ var cacheNodeInterop = new WeakMap();
16
+ return (_getRequireWildcardCache = function(nodeInterop) {
17
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
18
+ })(nodeInterop);
19
+ }
20
+ function _interop_require_wildcard(obj, nodeInterop) {
21
+ if (!nodeInterop && obj && obj.__esModule) {
22
+ return obj;
23
+ }
24
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
25
+ return {
26
+ default: obj
27
+ };
28
+ }
29
+ var cache = _getRequireWildcardCache(nodeInterop);
30
+ if (cache && cache.has(obj)) {
31
+ return cache.get(obj);
32
+ }
33
+ var newObj = {
34
+ __proto__: null
35
+ };
36
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
37
+ for(var key in obj){
38
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
39
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
40
+ if (desc && (desc.get || desc.set)) {
41
+ Object.defineProperty(newObj, key, desc);
42
+ } else {
43
+ newObj[key] = obj[key];
44
+ }
45
+ }
46
+ }
47
+ newObj.default = obj;
48
+ if (cache) {
49
+ cache.set(obj, newObj);
50
+ }
51
+ return newObj;
52
+ }
53
+ const REGEX_PREFIX = /^(\D{1,2})/;
54
+ const REGEX_N_DOT_X = /^\D*\d\.x/; // E.g., 1.x
55
+ const REGEX_N_DOT_N_DOT_X = /^\D*\d\.\d\.x/; // E.g., 1.0.x
56
+ const prefixOrder = Object.fromEntries([
57
+ '<',
58
+ '<=',
59
+ '=',
60
+ '',
61
+ '~',
62
+ '^',
63
+ '>=',
64
+ '>'
65
+ ].map((prefix, index)=>[
66
+ prefix,
67
+ index
68
+ ]));
69
+ function compareVersion(a, b) {
70
+ const max = {
71
+ a: maxVersion(a),
72
+ b: maxVersion(b)
73
+ };
74
+ if (!(max.a && max.b)) {
75
+ return a.localeCompare(b);
76
+ }
77
+ const min = {
78
+ a: _semver.minVersion(a),
79
+ b: _semver.minVersion(b)
80
+ };
81
+ const result = _semver.compare(max.a, max.b) || // e.g., ^1.0.0 gt ~1.0.0
82
+ comparePrefix(a, b) || // e.g., ^1 gt 1.x
83
+ (min.a && min.b ? _semver.compare(min.a, min.b) : 0) || // e.g., ^1.1.1 gt ^1.0.0
84
+ a.length - b.length; // >=1.0.0 gt >=1
85
+ return result > 0 ? 1 : result < 0 ? -1 : 0;
86
+ }
87
+ function comparePrefix(a, b) {
88
+ return prefixOrder[getPrefix(a)] - prefixOrder[getPrefix(b)];
89
+ }
90
+ function getPrefix(version, { infer = false } = {}) {
91
+ var _REGEX_PREFIX_exec;
92
+ if (infer) {
93
+ if (REGEX_N_DOT_X.test(version)) {
94
+ return '^';
95
+ }
96
+ if (REGEX_N_DOT_N_DOT_X.test(version)) {
97
+ return '~';
98
+ }
99
+ }
100
+ var _REGEX_PREFIX_exec__trim;
101
+ return (_REGEX_PREFIX_exec__trim = (_REGEX_PREFIX_exec = REGEX_PREFIX.exec(version)) === null || _REGEX_PREFIX_exec === void 0 ? void 0 : _REGEX_PREFIX_exec[1].trim()) !== null && _REGEX_PREFIX_exec__trim !== void 0 ? _REGEX_PREFIX_exec__trim : '';
102
+ }
103
+ function maxVersion(str) {
104
+ if (!_semver.validRange(str)) {
105
+ return;
106
+ }
107
+ const v = _semver.coerce(str);
108
+ if (!v) {
109
+ return;
110
+ }
111
+ const prefix = getPrefix(str, {
112
+ infer: true
113
+ });
114
+ if (prefix === '<') {
115
+ if (v.patch) {
116
+ return new _semver.SemVer(`${v.major}.${v.minor}.${v.patch - 1}`);
117
+ }
118
+ if (v.minor) {
119
+ return new _semver.SemVer(`${v.major}.${v.minor - 1}.999`);
120
+ }
121
+ if (v.major) {
122
+ return new _semver.SemVer(`${v.major - 1}.999.999`);
123
+ }
124
+ }
125
+ if (prefix === '~') {
126
+ return new _semver.SemVer(`${v.major}.${v.minor}.999`);
127
+ }
128
+ if (prefix === '^') {
129
+ return new _semver.SemVer(`${v.major}.999.999`);
130
+ }
131
+ if (prefix === '>=' || prefix === '>') {
132
+ return new _semver.SemVer('999.999.999');
133
+ }
134
+ return v;
135
+ }
136
+
137
+ //# sourceMappingURL=compare-version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/utils/compare-version.ts"],"sourcesContent":["import * as semver from 'semver';\n\nconst REGEX_PREFIX = /^(\\D{1,2})/;\nconst REGEX_N_DOT_X = /^\\D*\\d\\.x/; // E.g., 1.x\nconst REGEX_N_DOT_N_DOT_X = /^\\D*\\d\\.\\d\\.x/; // E.g., 1.0.x\n\nconst prefixOrder = Object.fromEntries(\n ['<', '<=', '=', '', '~', '^', '>=', '>'].map((prefix, index) => [prefix, index])\n);\n\n/**\n * Compare two semver strings.\n * @returns\n * - `0` if a == b\n * - `>0` if a is semantically greater than b (e.g., \"^1.0.0\" is greater than \"~1.0.0\")\n * - `<0` if a is semantically less than b (e.g., \"<1\" is less than \"<=1\")\n */\nexport function compareVersion(a: string, b: string) {\n const max = { a: maxVersion(a), b: maxVersion(b) };\n if (!(max.a && max.b)) {\n return a.localeCompare(b);\n }\n\n const min = { a: semver.minVersion(a), b: semver.minVersion(b) };\n const result =\n semver.compare(max.a, max.b) || // e.g., ^1.0.0 gt ~1.0.0\n comparePrefix(a, b) || // e.g., ^1 gt 1.x\n (min.a && min.b ? semver.compare(min.a, min.b) : 0) || // e.g., ^1.1.1 gt ^1.0.0\n a.length - b.length; // >=1.0.0 gt >=1\n return result > 0 ? 1 : result < 0 ? -1 : 0;\n}\n\nfunction comparePrefix(a: string, b: string) {\n return prefixOrder[getPrefix(a)] - prefixOrder[getPrefix(b)];\n}\n\nfunction getPrefix(version: string, { infer = false }: { infer?: boolean } = {}) {\n if (infer) {\n if (REGEX_N_DOT_X.test(version)) {\n return '^';\n }\n if (REGEX_N_DOT_N_DOT_X.test(version)) {\n return '~';\n }\n }\n return REGEX_PREFIX.exec(version)?.[1].trim() ?? '';\n}\n\nfunction maxVersion(str: string) {\n if (!semver.validRange(str)) {\n return;\n }\n\n const v = semver.coerce(str);\n if (!v) {\n return;\n }\n\n const prefix = getPrefix(str, { infer: true });\n if (prefix === '<') {\n if (v.patch) {\n return new semver.SemVer(`${v.major}.${v.minor}.${v.patch - 1}`);\n }\n if (v.minor) {\n return new semver.SemVer(`${v.major}.${v.minor - 1}.999`);\n }\n if (v.major) {\n return new semver.SemVer(`${v.major - 1}.999.999`);\n }\n }\n if (prefix === '~') {\n return new semver.SemVer(`${v.major}.${v.minor}.999`);\n }\n if (prefix === '^') {\n return new semver.SemVer(`${v.major}.999.999`);\n }\n if (prefix === '>=' || prefix === '>') {\n return new semver.SemVer('999.999.999');\n }\n\n return v;\n}\n"],"names":["compareVersion","REGEX_PREFIX","REGEX_N_DOT_X","REGEX_N_DOT_N_DOT_X","prefixOrder","Object","fromEntries","map","prefix","index","a","b","max","maxVersion","localeCompare","min","semver","minVersion","result","compare","comparePrefix","length","getPrefix","version","infer","test","exec","trim","str","validRange","v","coerce","patch","SemVer","major","minor"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function formatDependsOn(dependents: string[], dependency: string): string;
2
+ //# sourceMappingURL=format-depends-on.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"format-depends-on.d.ts","sourceRoot":"","sources":["../../../../../src/cli/commands/review/utils/format-depends-on.ts"],"names":[],"mappings":"AAEA,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,UAAU,EAAE,MAAM,UAQvE"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "formatDependsOn", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return formatDependsOn;
9
+ }
10
+ });
11
+ const collator = new Intl.Collator();
12
+ function formatDependsOn(dependents, dependency) {
13
+ const { length } = dependents;
14
+ if (length === 1) {
15
+ return `${dependents[0]} depends on ${dependency}`;
16
+ }
17
+ const sorted = dependents.toSorted((a, b)=>collator.compare(a, b));
18
+ return `${sorted.slice(0, -1).join(', ')} and ${sorted[length - 1]} depend on ${dependency}`;
19
+ }
20
+
21
+ //# sourceMappingURL=format-depends-on.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/cli/commands/review/utils/format-depends-on.ts"],"sourcesContent":["const collator = new Intl.Collator();\n\nexport function formatDependsOn(dependents: string[], dependency: string) {\n const { length } = dependents;\n if (length === 1) {\n return `${dependents[0]} depends on ${dependency}`;\n }\n\n const sorted = dependents.toSorted((a, b) => collator.compare(a, b));\n return `${sorted.slice(0, -1).join(', ')} and ${sorted[length - 1]} depend on ${dependency}`;\n}\n"],"names":["formatDependsOn","collator","Intl","Collator","dependents","dependency","length","sorted","toSorted","a","b","compare","slice","join"],"mappings":";;;;+BAEgBA;;;eAAAA;;;AAFhB,MAAMC,WAAW,IAAIC,KAAKC,QAAQ;AAE3B,SAASH,gBAAgBI,UAAoB,EAAEC,UAAkB;IACpE,MAAM,EAAEC,MAAM,EAAE,GAAGF;IACnB,IAAIE,WAAW,GAAG;QACd,OAAO,GAAGF,UAAU,CAAC,EAAE,CAAC,YAAY,EAAEC,YAAY;IACtD;IAEA,MAAME,SAASH,WAAWI,QAAQ,CAAC,CAACC,GAAGC,IAAMT,SAASU,OAAO,CAACF,GAAGC;IACjE,OAAO,GAAGH,OAAOK,KAAK,CAAC,GAAG,CAAC,GAAGC,IAAI,CAAC,MAAM,KAAK,EAAEN,MAAM,CAACD,SAAS,EAAE,CAAC,WAAW,EAAED,YAAY;AAChG"}