@elliemae/pui-cli 9.0.0-next.4 → 9.0.0-next.41

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 (183) hide show
  1. package/app.tsconfig.json +1 -1
  2. package/dist/cjs/commands/lint.js +27 -8
  3. package/dist/cjs/commands/start.js +1 -1
  4. package/dist/cjs/commands/storybook.js +2 -2
  5. package/dist/cjs/commands/test.js +51 -22
  6. package/dist/cjs/commands/utils.js +33 -2
  7. package/dist/cjs/index.cjs +0 -2
  8. package/dist/cjs/index.js +4 -2
  9. package/dist/cjs/lint-config/eslint/common.cjs +3 -2
  10. package/dist/cjs/lint-config/eslint/typescript/common.cjs +3 -3
  11. package/dist/cjs/lint-config/stylelint.config.js +45 -0
  12. package/dist/cjs/monorepo/delete-merged-tags.js +1 -1
  13. package/dist/cjs/monorepo/set-registry-version.js +1 -1
  14. package/dist/cjs/monorepo/set-workspace-version.js +1 -1
  15. package/dist/cjs/pui-config.js +1 -1
  16. package/dist/cjs/release.config.js +46 -0
  17. package/dist/cjs/server/csp.js +2 -1
  18. package/dist/cjs/server/index.js +5 -0
  19. package/dist/cjs/server/utils.js +11 -4
  20. package/dist/cjs/server/wsServer.js +129 -0
  21. package/dist/cjs/testing/ExtendedJSDomEnv.cjs +27 -0
  22. package/dist/cjs/testing/extended/axe-core/getMessageAndPass.js +37 -0
  23. package/dist/cjs/testing/extended/axe-core/index.js +24 -0
  24. package/dist/cjs/testing/extended/axe-core/reporter.js +51 -0
  25. package/dist/cjs/testing/extended/axe-core/shouldIgnoreNodeViolation.js +31 -0
  26. package/dist/cjs/testing/extended/axe-core/toHaveNoViolations.js +43 -0
  27. package/dist/cjs/testing/jest.config.cjs +5 -2
  28. package/dist/cjs/testing/jest.polyfills.cjs +30 -0
  29. package/dist/cjs/testing/setup-test-env.js +0 -2
  30. package/dist/cjs/testing/setup-tests.js +26 -4
  31. package/dist/cjs/testing/vitest.config.js +8 -8
  32. package/dist/cjs/transpile/.swcrc +1 -1
  33. package/dist/cjs/transpile/esbuild.js +4 -4
  34. package/dist/cjs/update-notifier.js +1 -1
  35. package/dist/cjs/utils.js +1 -1
  36. package/dist/cjs/webpack/helpers.js +20 -8
  37. package/dist/cjs/webpack/webpack.base.babel.js +13 -27
  38. package/dist/cjs/webpack/webpack.dev.babel.js +14 -3
  39. package/dist/cjs/webpack/webpack.lib.base.babel.js +13 -5
  40. package/dist/cjs/webpack/webpack.lib.dev.babel.js +8 -12
  41. package/dist/cjs/webpack/webpack.lib.prod.babel.js +7 -6
  42. package/dist/cjs/webpack/webpack.prod.babel.js +3 -2
  43. package/dist/cjs/webpack/webpack.storybook.js +10 -11
  44. package/dist/esm/commands/lint.js +28 -8
  45. package/dist/esm/commands/start.js +1 -1
  46. package/dist/esm/commands/storybook.js +2 -2
  47. package/dist/esm/commands/test.js +51 -22
  48. package/dist/esm/commands/utils.js +33 -2
  49. package/dist/esm/index.cjs +0 -2
  50. package/dist/esm/index.js +4 -2
  51. package/dist/esm/lint-config/eslint/common.cjs +3 -2
  52. package/dist/esm/lint-config/eslint/typescript/common.cjs +3 -3
  53. package/dist/esm/lint-config/stylelint.config.js +25 -0
  54. package/dist/esm/monorepo/delete-merged-tags.js +1 -1
  55. package/dist/esm/monorepo/set-registry-version.js +1 -1
  56. package/dist/esm/monorepo/set-workspace-version.js +1 -1
  57. package/dist/esm/pui-config.js +1 -1
  58. package/dist/esm/release.config.js +26 -0
  59. package/dist/esm/server/csp.js +2 -1
  60. package/dist/esm/server/index.js +6 -1
  61. package/dist/esm/server/utils.js +11 -4
  62. package/dist/esm/server/wsServer.js +99 -0
  63. package/dist/esm/testing/ExtendedJSDomEnv.cjs +27 -0
  64. package/dist/esm/testing/extended/axe-core/getMessageAndPass.js +17 -0
  65. package/dist/esm/testing/extended/axe-core/index.js +4 -0
  66. package/dist/esm/testing/extended/axe-core/reporter.js +31 -0
  67. package/dist/esm/testing/extended/axe-core/shouldIgnoreNodeViolation.js +11 -0
  68. package/dist/esm/testing/extended/axe-core/toHaveNoViolations.js +23 -0
  69. package/dist/esm/testing/jest.config.cjs +5 -2
  70. package/dist/esm/testing/jest.polyfills.cjs +30 -0
  71. package/dist/esm/testing/setup-test-env.js +0 -2
  72. package/dist/esm/testing/setup-tests.js +26 -4
  73. package/dist/esm/testing/vitest.config.js +8 -8
  74. package/dist/esm/transpile/.swcrc +1 -1
  75. package/dist/esm/transpile/esbuild.js +4 -4
  76. package/dist/esm/update-notifier.js +1 -1
  77. package/dist/esm/utils.js +1 -1
  78. package/dist/esm/webpack/helpers.js +20 -8
  79. package/dist/esm/webpack/webpack.base.babel.js +13 -27
  80. package/dist/esm/webpack/webpack.dev.babel.js +14 -3
  81. package/dist/esm/webpack/webpack.lib.base.babel.js +13 -5
  82. package/dist/esm/webpack/webpack.lib.dev.babel.js +9 -13
  83. package/dist/esm/webpack/webpack.lib.prod.babel.js +12 -7
  84. package/dist/esm/webpack/webpack.prod.babel.js +3 -2
  85. package/dist/esm/webpack/webpack.storybook.js +11 -12
  86. package/dist/types/docusaurus.config.d.ts +2 -0
  87. package/dist/types/{babel.config.d.cts → lib/babel.config.d.cts} +7 -7
  88. package/dist/types/{commands → lib/commands}/build.d.ts +2 -2
  89. package/dist/types/{commands → lib/commands}/codemod.d.ts +2 -2
  90. package/dist/types/{commands → lib/commands}/lint.d.ts +3 -2
  91. package/dist/types/{commands → lib/commands}/pack.d.ts +2 -2
  92. package/dist/types/{commands → lib/commands}/start.d.ts +2 -2
  93. package/dist/types/{commands → lib/commands}/storybook.d.ts +2 -2
  94. package/dist/types/{commands → lib/commands}/test.d.ts +4 -2
  95. package/dist/types/{commands → lib/commands}/tscheck.d.ts +2 -2
  96. package/dist/types/lib/commands/utils.d.ts +39 -0
  97. package/dist/types/{commands → lib/commands}/version.d.ts +2 -2
  98. package/dist/types/{commands → lib/commands}/vitest.d.ts +2 -2
  99. package/dist/types/{index.d.cts → lib/index.d.cts} +1 -2
  100. package/dist/types/{index.d.ts → lib/index.d.ts} +3 -1
  101. package/dist/types/{lint-config → lib/lint-config}/commitlint.config.d.cts +1 -1
  102. package/dist/types/{lint-config → lib/lint-config}/eslint/common.d.cts +18 -12
  103. package/dist/types/{lint-config → lib/lint-config}/eslint/non-react.d.cts +8 -1
  104. package/dist/types/{lint-config → lib/lint-config}/eslint/react.d.cts +8 -1
  105. package/dist/types/{lint-config → lib/lint-config}/eslint/typescript/common.d.cts +6 -6
  106. package/dist/types/{lint-config → lib/lint-config}/eslint/typescript/non-react.d.cts +9 -2
  107. package/dist/types/{lint-config → lib/lint-config}/eslint/typescript/react.d.cts +9 -2
  108. package/dist/types/lib/lint-config/lint-staged.config.d.ts +5 -0
  109. package/dist/types/lib/lint-config/prettier.config.d.cts +8 -0
  110. package/dist/types/lib/lint-config/stylelint.config.d.ts +13 -0
  111. package/dist/types/lib/release.config.d.ts +10 -0
  112. package/dist/types/{server → lib/server}/csp.d.ts +2 -2
  113. package/dist/types/{server → lib/server}/utils.d.ts +1 -0
  114. package/dist/types/lib/server/wsServer.d.ts +13 -0
  115. package/dist/types/lib/testing/ExtendedJSDomEnv.d.cts +5 -0
  116. package/dist/types/lib/testing/extended/axe-core/getMessageAndPass.d.ts +8 -0
  117. package/dist/types/lib/testing/extended/axe-core/index.d.ts +1 -0
  118. package/dist/types/lib/testing/extended/axe-core/reporter.d.ts +2 -0
  119. package/dist/types/lib/testing/extended/axe-core/shouldIgnoreNodeViolation.d.ts +2 -0
  120. package/dist/types/lib/testing/extended/axe-core/toHaveNoViolations.d.ts +12 -0
  121. package/dist/types/lib/testing/jest.config.d.cts +44 -0
  122. package/dist/types/{testing → lib/testing}/jest.node.config.d.cts +3 -0
  123. package/dist/types/lib/testing/mocks/axios.d.ts +17 -0
  124. package/dist/types/{testing → lib/testing}/mocks/pui-diagnostics.d.ts +13 -13
  125. package/dist/types/lib/testing/setup-tests.d.ts +1 -0
  126. package/dist/types/lib/testing/vitest.config.d.ts +1 -0
  127. package/dist/types/lib/tests/basic.test.d.ts +0 -0
  128. package/dist/types/{transpile → lib/transpile}/esbuild.d.ts +3 -3
  129. package/dist/types/lib/typedoc.d.cts +3 -0
  130. package/dist/types/{webpack → lib/webpack}/helpers.d.ts +4 -1
  131. package/dist/types/{webpack → lib/webpack}/webpack.storybook.d.ts +0 -1
  132. package/nx.json +97 -0
  133. package/package.json +189 -178
  134. package/dist/cjs/lint-config/stylelint.config.cjs +0 -19
  135. package/dist/cjs/release.config.cjs +0 -24
  136. package/dist/esm/lint-config/stylelint.config.cjs +0 -19
  137. package/dist/esm/release.config.cjs +0 -24
  138. package/dist/types/commands/utils.d.ts +0 -17
  139. package/dist/types/lint-config/lint-staged.config.d.ts +0 -5
  140. package/dist/types/lint-config/prettier.config.d.cts +0 -8
  141. package/dist/types/lint-config/stylelint.config.d.cts +0 -10
  142. package/dist/types/release.config.d.cts +0 -7
  143. package/dist/types/testing/jest.config.d.cts +0 -41
  144. package/dist/types/testing/mocks/axios.d.ts +0 -17
  145. package/dist/types/testing/vitest.config.d.ts +0 -1
  146. package/dist/types/typedoc.d.cts +0 -3
  147. /package/dist/types/{cli.d.ts → lib/cli.d.ts} +0 -0
  148. /package/dist/types/{commands → lib/commands}/gendoc.d.ts +0 -0
  149. /package/dist/types/{dummy.d.ts → lib/dummy.d.ts} +0 -0
  150. /package/dist/types/{monorepo → lib/monorepo}/delete-merged-tags.d.ts +0 -0
  151. /package/dist/types/{monorepo → lib/monorepo}/set-registry-version.d.ts +0 -0
  152. /package/dist/types/{monorepo → lib/monorepo}/set-workspace-version.d.ts +0 -0
  153. /package/dist/types/{monorepo → lib/monorepo}/utils.d.cts +0 -0
  154. /package/dist/types/{monorepo → lib/monorepo}/utils.d.ts +0 -0
  155. /package/dist/types/{pui-config.d.ts → lib/pui-config.d.ts} +0 -0
  156. /package/dist/types/{server → lib/server}/appRoutes.d.ts +0 -0
  157. /package/dist/types/{server → lib/server}/index.d.ts +0 -0
  158. /package/dist/types/{server → lib/server}/logger.d.ts +0 -0
  159. /package/dist/types/{server → lib/server}/middlewares.d.ts +0 -0
  160. /package/dist/types/{testing/setup-react-env.d.ts → lib/testing/jest.polyfills.d.cts} +0 -0
  161. /package/dist/types/{testing → lib/testing}/mocks/cssModule.d.ts +0 -0
  162. /package/dist/types/{testing → lib/testing}/mocks/html.d.ts +0 -0
  163. /package/dist/types/{testing → lib/testing}/mocks/image.d.ts +0 -0
  164. /package/dist/types/{testing → lib/testing}/mocks/matchMedia.d.ts +0 -0
  165. /package/dist/types/{testing → lib/testing}/mocks/pui-app-loader.d.ts +0 -0
  166. /package/dist/types/{testing → lib/testing}/mocks/pui-user-monitoring.d.ts +0 -0
  167. /package/dist/types/{testing → lib/testing}/mocks/retry-axios.d.ts +0 -0
  168. /package/dist/types/{testing → lib/testing}/mocks/svg.d.ts +0 -0
  169. /package/dist/types/{testing → lib/testing}/mocks/webpack-hmr.d.ts +0 -0
  170. /package/dist/types/{testing → lib/testing}/resolver.d.cts +0 -0
  171. /package/dist/types/{testing/setup-test-env.d.ts → lib/testing/setup-react-env.d.ts} +0 -0
  172. /package/dist/types/{testing/setup-tests.d.ts → lib/testing/setup-test-env.d.ts} +0 -0
  173. /package/dist/types/{transpile → lib/transpile}/react-shim.d.ts +0 -0
  174. /package/dist/types/{transpile → lib/transpile}/swcrc.config.d.cts +0 -0
  175. /package/dist/types/{update-notifier.d.ts → lib/update-notifier.d.ts} +0 -0
  176. /package/dist/types/{utils.d.cts → lib/utils.d.cts} +0 -0
  177. /package/dist/types/{utils.d.ts → lib/utils.d.ts} +0 -0
  178. /package/dist/types/{webpack → lib/webpack}/webpack.base.babel.d.ts +0 -0
  179. /package/dist/types/{webpack → lib/webpack}/webpack.dev.babel.d.ts +0 -0
  180. /package/dist/types/{webpack → lib/webpack}/webpack.lib.base.babel.d.ts +0 -0
  181. /package/dist/types/{webpack → lib/webpack}/webpack.lib.dev.babel.d.ts +0 -0
  182. /package/dist/types/{webpack → lib/webpack}/webpack.lib.prod.babel.d.ts +0 -0
  183. /package/dist/types/{webpack → lib/webpack}/webpack.prod.babel.d.ts +0 -0
package/app.tsconfig.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "compilerOptions": {
3
3
  "lib": ["dom", "dom.iterable", "esnext"],
4
4
  "module": "esnext",
5
- "target": "es2020",
5
+ "target": "es2022",
6
6
  "allowJs": true,
7
7
  "allowSyntheticDefaultImports": true,
8
8
  "esModuleInterop": true,
@@ -32,21 +32,31 @@ __export(lint_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(lint_exports);
34
34
  var import_node_path = __toESM(require("node:path"), 1);
35
+ var import_node_util = require("node:util");
35
36
  var import_yargs = __toESM(require("yargs"), 1);
36
37
  var import_utils = require("./utils.js");
37
- const lintCSS = async (fix = false) => {
38
- const fixIssues = fix ? "--fix" : "";
38
+ const lintCSS = async (args) => {
39
+ const fixIssues = args.fix ? "--fix" : "";
40
+ if (args.debug) {
41
+ const configPath = import_node_path.default.join(process.cwd(), "stylelint.config.mjs");
42
+ const config = await import(configPath);
43
+ (0, import_utils.logInfo)("stylelint version:");
44
+ await (0, import_utils.exec)(`stylelint ./{lib,app}/**/*.{js,jsx,ts,tsx} --version`);
45
+ (0, import_utils.logInfo)("stylelint config:");
46
+ (0, import_utils.logInfo)((0, import_node_util.inspect)(config, { depth: null }));
47
+ }
39
48
  await (0, import_utils.exec)(
40
49
  `stylelint ./{lib,app}/**/*.{js,jsx,ts,tsx} ${fixIssues} ${!(0, import_utils.getCIEnv)() ? "--color" : "--no-color"} --allow-empty-input --config ${import_node_path.default.join(
41
50
  process.cwd(),
42
- "stylelint.config.cjs"
51
+ "stylelint.config.mjs"
43
52
  )}`
44
53
  );
45
54
  };
46
- const lintJS = async (fix = false) => {
47
- const fixIssues = fix ? "--fix" : "";
55
+ const lintJS = async (args) => {
56
+ const fixIssues = args.fix ? "--fix" : "";
57
+ const debugFlags = args.debug ? "--env-info --debug" : "";
48
58
  await (0, import_utils.exec)(
49
- `eslint ${!(0, import_utils.getCIEnv)() ? "--color" : "--no-color"} ${fixIssues} .`
59
+ `eslint ${!(0, import_utils.getCIEnv)() ? "--color" : "--no-color"} ${fixIssues} ${debugFlags} .`
50
60
  );
51
61
  };
52
62
  const cmdArgs = {
@@ -64,6 +74,11 @@ const cmdArgs = {
64
74
  boolean: true,
65
75
  alias: "fix",
66
76
  default: false
77
+ },
78
+ debug: {
79
+ boolean: true,
80
+ alias: "debug",
81
+ default: false
67
82
  }
68
83
  };
69
84
  const lintCmd = {
@@ -73,10 +88,12 @@ const lintCmd = {
73
88
  await (0, import_utils.exec)("tsc --noEmit --emitDeclarationOnly false");
74
89
  try {
75
90
  await (0, import_utils.exec)("rimraf ./reports/eslint.json");
76
- await lintJS(argv.fix);
91
+ await lintJS({ ...argv });
77
92
  (0, import_utils.logSuccess)("JS linting completed");
78
93
  } catch (err) {
79
94
  (0, import_utils.logError)("JS linting failed");
95
+ if (argv.debug)
96
+ (0, import_utils.logError)(err);
80
97
  (0, import_yargs.default)().exit(-1, err);
81
98
  return;
82
99
  }
@@ -84,10 +101,12 @@ const lintCmd = {
84
101
  if (argv.css) {
85
102
  try {
86
103
  await (0, import_utils.exec)("rimraf ./reports/stylelint.json");
87
- await lintCSS(argv.fix);
104
+ await lintCSS({ ...argv });
88
105
  (0, import_utils.logSuccess)("CSS linting completed");
89
106
  } catch (err) {
90
107
  (0, import_utils.logError)("CSS linting failed");
108
+ if (argv.debug)
109
+ (0, import_utils.logError)(err);
91
110
  (0, import_yargs.default)().exit(-1, err);
92
111
  }
93
112
  }
@@ -39,7 +39,7 @@ const import_meta = {};
39
39
  const __dirname = import_node_path.default.dirname((0, import_node_url.fileURLToPath)(import_meta.url));
40
40
  const startProdServer = async () => {
41
41
  await (0, import_utils.exec)(
42
- `cross-env NODE_ENV=production ts-node --esm ${import_node_path.default.resolve(
42
+ `cross-env NODE_ENV=production tsx ${import_node_path.default.resolve(
43
43
  __dirname,
44
44
  "../server/index.js"
45
45
  )} --color always`
@@ -36,12 +36,12 @@ var import_utils = require("./utils.js");
36
36
  const buildStoryBook = async (outputDir = "demo", isDoc = false) => {
37
37
  const additionalParams = isDoc ? `--docs -o ${outputDir}/docs` : `-o ${outputDir}`;
38
38
  await (0, import_utils.exec)(
39
- `cross-env NODE_ENV=production build-storybook --quiet ${additionalParams}`
39
+ `cross-env NODE_ENV=production storybook build --quiet ${additionalParams}`
40
40
  );
41
41
  };
42
42
  const startStoryBook = async (isDoc = false) => {
43
43
  await (0, import_utils.exec)(
44
- `cross-env NODE_ENV=development STORYBOOK_BUILD=true start-storybook ${isDoc ? "--docs" : ""} -p 11000 --quiet`
44
+ `cross-env STORYBOOK_BUILD=true storybook dev ${isDoc ? "--docs" : ""} -p 11000 --quiet`
45
45
  );
46
46
  };
47
47
  const cmdArgs = {
@@ -33,14 +33,6 @@ __export(test_exports, {
33
33
  module.exports = __toCommonJS(test_exports);
34
34
  var import_yargs = __toESM(require("yargs"), 1);
35
35
  var import_utils = require("./utils.js");
36
- const test = async (commandOptions) => {
37
- await (0, import_utils.exec)(`cross-env NODE_ENV=test jest ${commandOptions}`);
38
- };
39
- const debugTest = async () => {
40
- await (0, import_utils.exec)(
41
- `node --inspect-brk ./node_modules/jest-cli/bin/jest.js --runInBand --watch`
42
- );
43
- };
44
36
  const cmdArgs = {
45
37
  fix: {
46
38
  boolean: true,
@@ -71,24 +63,61 @@ const cmdArgs = {
71
63
  boolean: true,
72
64
  alias: "s",
73
65
  default: false
66
+ },
67
+ coverage: {
68
+ string: true,
69
+ // we want to support "CI" | "false" | "true"
70
+ default: "true"
71
+ },
72
+ maxWorkers: {
73
+ string: true,
74
+ default: "50%"
74
75
  }
75
76
  };
77
+ const getJestFlags = (argv) => {
78
+ const flagsArray = [
79
+ argv.maxWorkers ? `--maxWorkers=${argv.maxWorkers}` : ""
80
+ ];
81
+ const isCi = (0, import_utils.getCIEnv)();
82
+ switch (`${argv.coverage}`) {
83
+ case "CI":
84
+ if (isCi) {
85
+ flagsArray.push("--coverage");
86
+ }
87
+ break;
88
+ case "false":
89
+ break;
90
+ case "true":
91
+ default:
92
+ flagsArray.push("--coverage");
93
+ break;
94
+ }
95
+ if (argv.fix)
96
+ flagsArray.push("-u");
97
+ else if (argv.watch)
98
+ flagsArray.push("--watchAll");
99
+ if (argv.passWithNoTests)
100
+ flagsArray.push("--passWithNoTests");
101
+ if (argv.findReleatedTests)
102
+ flagsArray.push("--bail --findRelatedTests");
103
+ if (argv.silent)
104
+ flagsArray.push("--silent");
105
+ if (isCi)
106
+ flagsArray.push("--ci --no-colors");
107
+ return flagsArray.join(" ");
108
+ };
109
+ const test = async (argv) => {
110
+ const jestFlags = getJestFlags(argv);
111
+ await (0, import_utils.exec)(`cross-env NODE_ENV=test jest ${jestFlags}`);
112
+ };
113
+ const debugTest = async () => {
114
+ await (0, import_utils.exec)(
115
+ `node --inspect-brk ./node_modules/jest-cli/bin/jest.js --runInBand --watch`
116
+ );
117
+ };
76
118
  const testCmd = {
77
119
  // eslint-disable-next-line max-statements
78
120
  handler: async (argv) => {
79
- let commandOptions = "--coverage --maxWorkers=50%";
80
- if (argv.fix)
81
- commandOptions = "-u";
82
- else if (argv.watch)
83
- commandOptions = "--watchAll";
84
- if ((0, import_utils.getCIEnv)())
85
- commandOptions += " --ci --no-colors";
86
- if (argv.passWithNoTests)
87
- commandOptions += " --passWithNoTests";
88
- if (argv.findReleatedTests)
89
- commandOptions += " --bail --findRelatedTests";
90
- if (argv.silent)
91
- commandOptions += " --silent";
92
121
  try {
93
122
  if ((0, import_utils.getCIEnv)()) {
94
123
  await (0, import_utils.exec)("rimraf ./reports");
@@ -96,7 +125,7 @@ const testCmd = {
96
125
  if (argv.debug) {
97
126
  await debugTest();
98
127
  } else {
99
- await test(commandOptions);
128
+ await test(argv);
100
129
  }
101
130
  (0, import_utils.logSuccess)("Unit test execution completed");
102
131
  } catch (err) {
@@ -31,12 +31,14 @@ __export(utils_exports, {
31
31
  copyBuildAssetsToVersionedFolder: () => copyBuildAssetsToVersionedFolder,
32
32
  exec: () => exec,
33
33
  getCIEnv: () => getCIEnv,
34
+ getUnspecifiedOptions: () => getUnspecifiedOptions,
34
35
  isApp: () => isApp,
35
36
  isPathExist: () => isPathExist,
36
37
  isTypeScriptEnabled: () => isTypeScriptEnabled,
37
38
  logError: () => logError,
38
39
  logInfo: () => logInfo,
39
40
  logSuccess: () => logSuccess,
41
+ logWarning: () => logWarning,
40
42
  writeAppInfo: () => writeAppInfo
41
43
  });
42
44
  module.exports = __toCommonJS(utils_exports);
@@ -61,6 +63,7 @@ const browsersMapping = {
61
63
  };
62
64
  const exec = async (command, options = { stdio: "inherit" }) => (0, import_execa.execaCommand)(command, options);
63
65
  const logInfo = console.log;
66
+ const logWarning = (...args) => console.log(import_chalk.default.yellow(...args));
64
67
  const logSuccess = (...args) => console.log(import_chalk.default.green(...args));
65
68
  const logError = console.error;
66
69
  const readPackageLock = async () => {
@@ -82,7 +85,7 @@ const getSupportedBrowsers = async () => {
82
85
  return browserVersions.reduce((acc, nameVersion) => {
83
86
  const [name, version] = nameVersion.split(" ");
84
87
  const versionRange = version.split("-");
85
- acc[browsersMapping[name]] = versionRange && versionRange[0] || version;
88
+ acc[browsersMapping[name]] = versionRange?.[0] ?? version;
86
89
  return acc;
87
90
  }, {});
88
91
  };
@@ -152,7 +155,9 @@ const updateManifestWithVersionInfo = async (dest) => {
152
155
  const updateRuntimeFile = async (src, dest, version) => {
153
156
  const latestJSFolder = "latest/js";
154
157
  const pipe = (0, import_node_util.promisify)(import_node_stream.pipeline);
155
- const results = await (0, import_fast_glob.default)([import_node_path.default.join(src, "runtime~app.*.js")]);
158
+ const results = await (0, import_fast_glob.default)([
159
+ import_node_path.default.join(src, "runtime~app.*.js").replace(/\\/g, "/")
160
+ ]);
156
161
  if (!results?.length)
157
162
  throw new Error("Runtime file not found");
158
163
  const runtimeFilePath = results[0];
@@ -206,3 +211,29 @@ const isPathExist = async (pathToCheck) => {
206
211
  const isApp = async () => isPathExist(import_node_path.default.join(process.cwd(), "app"));
207
212
  const getCIEnv = () => process.env.CI === "true";
208
213
  const isTypeScriptEnabled = () => import_node_fs.default.existsSync(import_node_path.default.join(process.cwd(), "tsconfig.json"));
214
+ const getUnspecifiedOptions = (options, command) => {
215
+ const rawArgs = process.argv.slice(2);
216
+ const rawArgsMap = /* @__PURE__ */ new Map();
217
+ rawArgs.forEach((arg) => {
218
+ const [key, value] = arg.split("=");
219
+ const keyWithoutPrefix = key.replace(/^-{1,2}/, "");
220
+ rawArgsMap.set(keyWithoutPrefix, value || true);
221
+ });
222
+ const expectedOptionsMap = /* @__PURE__ */ new Map();
223
+ Object.entries(options).forEach(([key, value]) => {
224
+ expectedOptionsMap.set(key, value);
225
+ if (value.alias)
226
+ expectedOptionsMap.set(value.alias, value);
227
+ });
228
+ const unspecifiedOptions = {};
229
+ rawArgsMap.forEach((value, key) => {
230
+ if (key === command)
231
+ return;
232
+ if (key === "")
233
+ return;
234
+ if (!expectedOptionsMap.has(key)) {
235
+ unspecifiedOptions[key] = value;
236
+ }
237
+ });
238
+ return unspecifiedOptions;
239
+ };
@@ -5,7 +5,6 @@ const {
5
5
  const {
6
6
  esReactConfig: eslintConfig,
7
7
  } = require('./lint-config/eslint/react.cjs');
8
- const { stylelintConfig } = require('./lint-config/stylelint.config.cjs');
9
8
  const { prettierConfig } = require('./lint-config/prettier.config.cjs');
10
9
  const { commitlintConfig } = require('./lint-config/commitlint.config.cjs');
11
10
  const { jestConfig } = require('./testing/jest.config.cjs');
@@ -15,7 +14,6 @@ module.exports = {
15
14
  babelConfig,
16
15
  eslintBaseConfig,
17
16
  eslintConfig,
18
- stylelintConfig,
19
17
  prettierConfig,
20
18
  commitlintConfig,
21
19
  jestConfig,
package/dist/cjs/index.js CHANGED
@@ -28,13 +28,14 @@ __export(lib_exports, {
28
28
  loadRoutes: () => import_appRoutes.loadRoutes,
29
29
  prettierConfig: () => import_prettier_config.prettierConfig,
30
30
  stylelintConfig: () => import_stylelint_config.stylelintConfig,
31
- vitestConfig: () => import_vitest_config.vitestConfig
31
+ vitestConfig: () => import_vitest_config.vitestConfig,
32
+ webpackFinal: () => import_webpack_storybook.webpackFinal
32
33
  });
33
34
  module.exports = __toCommonJS(lib_exports);
34
35
  var import_babel_config = require("./babel.config.cjs");
35
36
  var import_non_react = require("./lint-config/eslint/non-react.cjs");
36
37
  var import_react = require("./lint-config/eslint/react.cjs");
37
- var import_stylelint_config = require("./lint-config/stylelint.config.cjs");
38
+ var import_stylelint_config = require("./lint-config/stylelint.config.js");
38
39
  var import_prettier_config = require("./lint-config/prettier.config.cjs");
39
40
  var import_commitlint_config = require("./lint-config/commitlint.config.cjs");
40
41
  var import_jest_config = require("./testing/jest.config.cjs");
@@ -42,3 +43,4 @@ var import_vitest_config = require("./testing/vitest.config.js");
42
43
  var import_jest_node_config = require("./testing/jest.node.config.cjs");
43
44
  var import_lint_staged_config = require("./lint-config/lint-staged.config.js");
44
45
  var import_appRoutes = require("./server/appRoutes.js");
46
+ var import_webpack_storybook = require("./webpack/webpack.storybook.js");
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable max-lines */
2
- const prettierOptions = require("../prettier.config.cjs");
2
+ const { prettierConfig } = require("../prettier.config.cjs");
3
3
  // const webpackConfig = require('../../webpack/webpack.prod.babel');
4
4
 
5
5
  exports.baseExtends = [
@@ -26,7 +26,7 @@ exports.baseOverrides = [
26
26
  ];
27
27
 
28
28
  const baseRules = {
29
- "prettier/prettier": ["error", prettierOptions],
29
+ "prettier/prettier": ["error", prettierConfig],
30
30
  "arrow-body-style": [2, "as-needed"],
31
31
  "class-methods-use-this": 0,
32
32
  "import/imports-first": 0,
@@ -152,6 +152,7 @@ exports.baseConfig = {
152
152
  },
153
153
  ignorePatterns: [
154
154
  "/build/**/*",
155
+ "/node_modules/**/*",
155
156
  "/dist/**/*",
156
157
  "/reports/**/*",
157
158
  "/coverage/**/*",
@@ -1,9 +1,9 @@
1
1
  const { baseExtends, basePlugins } = require('../common.cjs');
2
2
 
3
3
  exports.tsBaseExtends = [
4
- 'plugin:@typescript-eslint/recommended',
5
4
  'plugin:import/typescript',
6
- 'plugin:@typescript-eslint/recommended-requiring-type-checking',
5
+ 'plugin:@typescript-eslint/recommended-type-checked',
6
+ 'plugin:@typescript-eslint/stylistic-type-checked',
7
7
  ].concat(baseExtends);
8
8
 
9
9
  exports.tsBaseRules = {
@@ -34,7 +34,7 @@ exports.tsBaseConfig = {
34
34
  plugins: ['@typescript-eslint'].concat(basePlugins),
35
35
  parserOptions: {
36
36
  tsconfigRootDir: process.cwd(),
37
- project: 'tsconfig.json',
37
+ project: true,
38
38
  },
39
39
  settings: {
40
40
  'import/resolver': {
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var stylelint_config_exports = {};
20
+ __export(stylelint_config_exports, {
21
+ stylelintConfig: () => stylelintConfig
22
+ });
23
+ module.exports = __toCommonJS(stylelint_config_exports);
24
+ const stylelintConfig = {
25
+ ignoreFiles: [
26
+ "/dist/**/*",
27
+ "/coverage/**/*",
28
+ "/build/**/*",
29
+ "/reports/**/*",
30
+ "/temp/**/*",
31
+ "/docs/**/*",
32
+ "/demo/**/*",
33
+ "/node_modules/**/*",
34
+ "/vendor/**/*"
35
+ ],
36
+ extends: ["stylelint-config-standard"],
37
+ customSyntax: "postcss-styled-syntax",
38
+ rules: {
39
+ "selector-type-no-unknown": null,
40
+ "function-no-unknown": null,
41
+ "value-no-vendor-prefix": true,
42
+ "property-no-vendor-prefix": true,
43
+ "no-empty-source": null
44
+ }
45
+ };
@@ -26,7 +26,7 @@ const cwd = process.cwd();
26
26
  const execaOptions = { cwd, stdio: "inherit" };
27
27
  const semVerRegEx = /^v?(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/;
28
28
  const isSemVersion = (tagName) => semVerRegEx.test(tagName);
29
- const branchName = (process.env.BRANCH_NAME || "master").toLowerCase();
29
+ const branchName = (process.env.BRANCH_NAME ?? "master").toLowerCase();
30
30
  const branchTags = {
31
31
  master: /^v?(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)$/,
32
32
  next: /^v.*-next\.(0|[1-9]\d*)/,
@@ -35,7 +35,7 @@ var import_promises = require("node:fs/promises");
35
35
  var import_fast_glob = __toESM(require("fast-glob"), 1);
36
36
  var import_normalize_path = __toESM(require("normalize-path"), 1);
37
37
  var import_utils = require("./utils.js");
38
- const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() || "");
38
+ const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() ?? "");
39
39
  const setRegistryVersion = async () => {
40
40
  const files = await (0, import_fast_glob.default)([
41
41
  `${monorepoRoot}/libs/*/package.json`,
@@ -35,7 +35,7 @@ var import_promises = require("node:fs/promises");
35
35
  var import_fast_glob = __toESM(require("fast-glob"), 1);
36
36
  var import_normalize_path = __toESM(require("normalize-path"), 1);
37
37
  var import_utils = require("./utils.js");
38
- const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() || "");
38
+ const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() ?? "");
39
39
  const setWorkspaceVersion = async () => {
40
40
  const files = await (0, import_fast_glob.default)([
41
41
  `${monorepoRoot}/libs/*/package.json`,
@@ -36,7 +36,7 @@ var import_node_fs = __toESM(require("node:fs"), 1);
36
36
  var import_merge = __toESM(require("lodash/merge"), 1);
37
37
  const baseConfig = {
38
38
  esBuild: {
39
- target: "es2020"
39
+ target: "es2022"
40
40
  }
41
41
  };
42
42
  const getPUIConfig = () => {
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var release_config_exports = {};
20
+ __export(release_config_exports, {
21
+ default: () => release_config_default
22
+ });
23
+ module.exports = __toCommonJS(release_config_exports);
24
+ var release_config_default = {
25
+ branches: [
26
+ "+([0-9])?(.{+([0-9]),x}).x",
27
+ "master",
28
+ "next-major",
29
+ { name: "beta", prerelease: true },
30
+ { name: "alpha", prerelease: true },
31
+ { name: "hotfix", prerelease: true },
32
+ { name: "next", prerelease: true }
33
+ ],
34
+ plugins: [
35
+ "@semantic-release/commit-analyzer",
36
+ "@semantic-release/release-notes-generator",
37
+ [
38
+ "@semantic-release/changelog",
39
+ {
40
+ changelogTitle: "# Changelog\n\nAll notable changes to this project will be documented in this file. See\n[Conventional Commits](https://conventionalcommits.org) for commit guidelines."
41
+ }
42
+ ],
43
+ "@semantic-release/npm",
44
+ "@semantic-release/github"
45
+ ]
46
+ };
@@ -34,13 +34,14 @@ __export(csp_exports, {
34
34
  module.exports = __toCommonJS(csp_exports);
35
35
  var import_node_fs = __toESM(require("node:fs"), 1);
36
36
  var import_node_path = __toESM(require("node:path"), 1);
37
+ var import_crypto = __toESM(require("crypto"), 1);
37
38
  var import_express = __toESM(require("express"), 1);
38
39
  var import_helmet_csp = __toESM(require("helmet-csp"), 1);
39
- var import_crypto = __toESM(require("crypto"), 1);
40
40
  const CSP_REPORT_URI = "/diagnostics/v1/csp";
41
41
  const sources = [
42
42
  "'self'",
43
43
  "http://localhost:*",
44
+ "ws://localhost:*",
44
45
  "*.elliemae.io",
45
46
  "*.elliemae.com",
46
47
  "*.elliservices.com",
@@ -26,6 +26,7 @@ var import_logger = require("./logger.js");
26
26
  var import_middlewares = require("./middlewares.js");
27
27
  var import_utils = require("./utils.js");
28
28
  var import_appRoutes = require("./appRoutes.js");
29
+ var import_wsServer = require("./wsServer.js");
29
30
  (async function startServer() {
30
31
  const app = (0, import_express.default)();
31
32
  (0, import_middlewares.setupDefaultMiddlewares)(app);
@@ -37,4 +38,8 @@ var import_appRoutes = require("./appRoutes.js");
37
38
  import_logger.logger.error(err);
38
39
  process.exit(1);
39
40
  });
41
+ const { wsServer } = await (0, import_wsServer.createWSServer)({
42
+ port: import_utils.wsPort
43
+ });
44
+ app.locals.wsServer = wsServer;
40
45
  })();
@@ -30,14 +30,21 @@ var utils_exports = {};
30
30
  __export(utils_exports, {
31
31
  getCWD: () => getCWD,
32
32
  host: () => host,
33
- port: () => port
33
+ port: () => port,
34
+ wsPort: () => wsPort
34
35
  });
35
36
  module.exports = __toCommonJS(utils_exports);
36
37
  var import_minimist = __toESM(require("minimist"), 1);
37
- const argv = (0, import_minimist.default)(process.argv.slice(2));
38
+ const argv = (0, import_minimist.default)(
39
+ process.argv.slice(2)
40
+ );
38
41
  const getCWD = () => process.cwd();
39
42
  const port = parseInt(
40
- argv.port || process.env.port || process.env.PORT || "3000",
43
+ argv.port ?? process.env.port ?? process.env.PORT ?? "3000",
44
+ 10
45
+ );
46
+ const host = argv.host ?? process.env.HOST ?? "localhost";
47
+ const wsPort = parseInt(
48
+ argv.wsport ?? process.env.wsport ?? process.env.WSPORT ?? "5000",
41
49
  10
42
50
  );
43
- const host = argv.host || process.env.HOST || "localhost";