@elliemae/pui-cli 9.0.0-next.3 → 9.0.0-next.31
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.
- package/dist/cjs/commands/lint.js +26 -7
- package/dist/cjs/commands/start.js +1 -1
- package/dist/cjs/commands/storybook.js +2 -2
- package/dist/cjs/commands/test.js +51 -22
- package/dist/cjs/commands/utils.js +30 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/lint-config/eslint/common.cjs +3 -2
- package/dist/cjs/lint-config/eslint/typescript/common.cjs +3 -3
- package/dist/cjs/lint-config/stylelint.config.cjs +14 -13
- package/dist/cjs/monorepo/delete-merged-tags.js +1 -1
- package/dist/cjs/monorepo/set-registry-version.js +1 -1
- package/dist/cjs/monorepo/set-workspace-version.js +1 -1
- package/dist/cjs/server/csp.js +2 -1
- package/dist/cjs/server/index.js +5 -0
- package/dist/cjs/server/utils.js +11 -4
- package/dist/cjs/server/wsServer.js +129 -0
- package/dist/cjs/testing/ExtendedJSDomEnv.cjs +27 -0
- package/dist/cjs/testing/extended/axe-core/getMessageAndPass.js +37 -0
- package/dist/cjs/testing/extended/axe-core/index.js +24 -0
- package/dist/cjs/testing/extended/axe-core/reporter.js +51 -0
- package/dist/cjs/testing/extended/axe-core/shouldIgnoreNodeViolation.js +31 -0
- package/dist/cjs/testing/extended/axe-core/toHaveNoViolations.js +43 -0
- package/dist/cjs/testing/jest.config.cjs +5 -2
- package/dist/cjs/testing/jest.polyfills.cjs +28 -0
- package/dist/cjs/testing/setup-test-env.js +0 -2
- package/dist/cjs/testing/setup-tests.js +25 -4
- package/dist/cjs/testing/vitest.config.js +8 -8
- package/dist/cjs/transpile/esbuild.js +1 -1
- package/dist/cjs/update-notifier.js +1 -1
- package/dist/cjs/utils.js +1 -1
- package/dist/cjs/webpack/helpers.js +18 -6
- package/dist/cjs/webpack/webpack.base.babel.js +7 -4
- package/dist/cjs/webpack/webpack.dev.babel.js +14 -3
- package/dist/cjs/webpack/webpack.lib.base.babel.js +13 -5
- package/dist/cjs/webpack/webpack.lib.dev.babel.js +5 -11
- package/dist/cjs/webpack/webpack.lib.prod.babel.js +4 -5
- package/dist/cjs/webpack/webpack.prod.babel.js +3 -2
- package/dist/cjs/webpack/webpack.storybook.js +10 -11
- package/dist/esm/commands/lint.js +27 -7
- package/dist/esm/commands/start.js +1 -1
- package/dist/esm/commands/storybook.js +2 -2
- package/dist/esm/commands/test.js +51 -22
- package/dist/esm/commands/utils.js +30 -1
- package/dist/esm/index.js +3 -1
- package/dist/esm/lint-config/eslint/common.cjs +3 -2
- package/dist/esm/lint-config/eslint/typescript/common.cjs +3 -3
- package/dist/esm/lint-config/stylelint.config.cjs +14 -13
- package/dist/esm/monorepo/delete-merged-tags.js +1 -1
- package/dist/esm/monorepo/set-registry-version.js +1 -1
- package/dist/esm/monorepo/set-workspace-version.js +1 -1
- package/dist/esm/server/csp.js +2 -1
- package/dist/esm/server/index.js +6 -1
- package/dist/esm/server/utils.js +11 -4
- package/dist/esm/server/wsServer.js +99 -0
- package/dist/esm/testing/ExtendedJSDomEnv.cjs +27 -0
- package/dist/esm/testing/extended/axe-core/getMessageAndPass.js +17 -0
- package/dist/esm/testing/extended/axe-core/index.js +4 -0
- package/dist/esm/testing/extended/axe-core/reporter.js +31 -0
- package/dist/esm/testing/extended/axe-core/shouldIgnoreNodeViolation.js +11 -0
- package/dist/esm/testing/extended/axe-core/toHaveNoViolations.js +23 -0
- package/dist/esm/testing/jest.config.cjs +5 -2
- package/dist/esm/testing/jest.polyfills.cjs +28 -0
- package/dist/esm/testing/setup-test-env.js +0 -2
- package/dist/esm/testing/setup-tests.js +25 -4
- package/dist/esm/testing/vitest.config.js +8 -8
- package/dist/esm/transpile/esbuild.js +1 -1
- package/dist/esm/update-notifier.js +1 -1
- package/dist/esm/utils.js +1 -1
- package/dist/esm/webpack/helpers.js +18 -6
- package/dist/esm/webpack/webpack.base.babel.js +7 -4
- package/dist/esm/webpack/webpack.dev.babel.js +14 -3
- package/dist/esm/webpack/webpack.lib.base.babel.js +13 -5
- package/dist/esm/webpack/webpack.lib.dev.babel.js +6 -12
- package/dist/esm/webpack/webpack.lib.prod.babel.js +9 -6
- package/dist/esm/webpack/webpack.prod.babel.js +3 -2
- package/dist/esm/webpack/webpack.storybook.js +11 -12
- package/dist/types/babel.config.d.cts +7 -7
- package/dist/types/commands/build.d.ts +2 -2
- package/dist/types/commands/codemod.d.ts +2 -2
- package/dist/types/commands/lint.d.ts +3 -2
- package/dist/types/commands/pack.d.ts +2 -2
- package/dist/types/commands/start.d.ts +2 -2
- package/dist/types/commands/storybook.d.ts +2 -2
- package/dist/types/commands/test.d.ts +4 -2
- package/dist/types/commands/tscheck.d.ts +2 -2
- package/dist/types/commands/utils.d.ts +23 -1
- package/dist/types/commands/version.d.ts +2 -2
- package/dist/types/commands/vitest.d.ts +2 -2
- package/dist/types/index.d.ts +1 -0
- package/dist/types/lint-config/commitlint.config.d.cts +1 -1
- package/dist/types/lint-config/eslint/common.d.cts +18 -12
- package/dist/types/lint-config/eslint/non-react.d.cts +8 -1
- package/dist/types/lint-config/eslint/react.d.cts +8 -1
- package/dist/types/lint-config/eslint/typescript/common.d.cts +6 -6
- package/dist/types/lint-config/eslint/typescript/non-react.d.cts +9 -2
- package/dist/types/lint-config/eslint/typescript/react.d.cts +9 -2
- package/dist/types/lint-config/lint-staged.config.d.ts +3 -3
- package/dist/types/lint-config/prettier.config.d.cts +6 -6
- package/dist/types/lint-config/stylelint.config.d.cts +6 -6
- package/dist/types/release.config.d.cts +2 -2
- package/dist/types/server/csp.d.ts +2 -2
- package/dist/types/server/utils.d.ts +1 -0
- package/dist/types/server/wsServer.d.ts +13 -0
- package/dist/types/testing/ExtendedJSDomEnv.d.cts +5 -0
- package/dist/types/testing/extended/axe-core/getMessageAndPass.d.ts +8 -0
- package/dist/types/testing/extended/axe-core/index.d.ts +1 -0
- package/dist/types/testing/extended/axe-core/reporter.d.ts +2 -0
- package/dist/types/testing/extended/axe-core/shouldIgnoreNodeViolation.d.ts +2 -0
- package/dist/types/testing/extended/axe-core/toHaveNoViolations.d.ts +12 -0
- package/dist/types/testing/jest.config.d.cts +25 -22
- package/dist/types/testing/jest.node.config.d.cts +3 -0
- package/dist/types/testing/jest.polyfills.d.cts +1 -0
- package/dist/types/testing/mocks/axios.d.ts +7 -7
- package/dist/types/testing/mocks/pui-diagnostics.d.ts +13 -13
- package/dist/types/testing/vitest.config.d.ts +1 -1
- package/dist/types/tests/basic.test.d.ts +0 -0
- package/dist/types/transpile/esbuild.d.ts +3 -3
- package/dist/types/typedoc.d.cts +3 -3
- package/dist/types/webpack/helpers.d.ts +4 -1
- package/dist/types/webpack/webpack.storybook.d.ts +0 -1
- package/nx.json +97 -0
- package/package.json +163 -150
|
@@ -32,10 +32,19 @@ __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 (
|
|
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.cjs");
|
|
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(),
|
|
@@ -43,10 +52,11 @@ const lintCSS = async (fix = false) => {
|
|
|
43
52
|
)}`
|
|
44
53
|
);
|
|
45
54
|
};
|
|
46
|
-
const lintJS = async (
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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(
|
|
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
|
|
88
|
+
acc[browsersMapping[name]] = versionRange?.[0] ?? version;
|
|
86
89
|
return acc;
|
|
87
90
|
}, {});
|
|
88
91
|
};
|
|
@@ -206,3 +209,29 @@ const isPathExist = async (pathToCheck) => {
|
|
|
206
209
|
const isApp = async () => isPathExist(import_node_path.default.join(process.cwd(), "app"));
|
|
207
210
|
const getCIEnv = () => process.env.CI === "true";
|
|
208
211
|
const isTypeScriptEnabled = () => import_node_fs.default.existsSync(import_node_path.default.join(process.cwd(), "tsconfig.json"));
|
|
212
|
+
const getUnspecifiedOptions = (options, command) => {
|
|
213
|
+
const rawArgs = process.argv.slice(2);
|
|
214
|
+
const rawArgsMap = /* @__PURE__ */ new Map();
|
|
215
|
+
rawArgs.forEach((arg) => {
|
|
216
|
+
const [key, value] = arg.split("=");
|
|
217
|
+
const keyWithoutPrefix = key.replace(/^-{1,2}/, "");
|
|
218
|
+
rawArgsMap.set(keyWithoutPrefix, value || true);
|
|
219
|
+
});
|
|
220
|
+
const expectedOptionsMap = /* @__PURE__ */ new Map();
|
|
221
|
+
Object.entries(options).forEach(([key, value]) => {
|
|
222
|
+
expectedOptionsMap.set(key, value);
|
|
223
|
+
if (value.alias)
|
|
224
|
+
expectedOptionsMap.set(value.alias, value);
|
|
225
|
+
});
|
|
226
|
+
const unspecifiedOptions = {};
|
|
227
|
+
rawArgsMap.forEach((value, key) => {
|
|
228
|
+
if (key === command)
|
|
229
|
+
return;
|
|
230
|
+
if (key === "")
|
|
231
|
+
return;
|
|
232
|
+
if (!expectedOptionsMap.has(key)) {
|
|
233
|
+
unspecifiedOptions[key] = value;
|
|
234
|
+
}
|
|
235
|
+
});
|
|
236
|
+
return unspecifiedOptions;
|
|
237
|
+
};
|
package/dist/cjs/index.js
CHANGED
|
@@ -28,7 +28,8 @@ __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");
|
|
@@ -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
|
|
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",
|
|
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-
|
|
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:
|
|
37
|
+
project: true,
|
|
38
38
|
},
|
|
39
39
|
settings: {
|
|
40
40
|
'import/resolver': {
|
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
exports.stylelintConfig = {
|
|
2
2
|
ignoreFiles: [
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
3
|
+
"/dist/**/*",
|
|
4
|
+
"/coverage/**/*",
|
|
5
|
+
"/build/**/*",
|
|
6
|
+
"/reports/**/*",
|
|
7
|
+
"/temp/**/*",
|
|
8
|
+
"/docs/**/*",
|
|
9
|
+
"/demo/**/*",
|
|
10
|
+
"/node_modules/**/*",
|
|
11
|
+
"/vendor/**/*",
|
|
12
12
|
],
|
|
13
|
-
customSyntax:
|
|
13
|
+
customSyntax: "@stylelint/postcss-css-in-js",
|
|
14
|
+
// customSyntax: "postcss-styled-components", // '@stylelint/postcss-css-in-js' is deprecated, this may be a replacement?
|
|
14
15
|
extends: [
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
"stylelint-config-recommended",
|
|
17
|
+
"stylelint-config-styled-components",
|
|
17
18
|
],
|
|
18
|
-
rules: {
|
|
19
|
+
rules: { "selector-type-no-unknown": null, "function-no-unknown": null },
|
|
19
20
|
};
|
|
@@ -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
|
|
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`,
|
package/dist/cjs/server/csp.js
CHANGED
|
@@ -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",
|
package/dist/cjs/server/index.js
CHANGED
|
@@ -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
|
})();
|
package/dist/cjs/server/utils.js
CHANGED
|
@@ -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)(
|
|
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
|
|
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";
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var wsServer_exports = {};
|
|
30
|
+
__export(wsServer_exports, {
|
|
31
|
+
createWSServer: () => createWSServer
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(wsServer_exports);
|
|
34
|
+
var import_node_http = __toESM(require("node:http"), 1);
|
|
35
|
+
var wsLib = __toESM(require("ws"), 1);
|
|
36
|
+
const PING_INTERVAL = 3e4;
|
|
37
|
+
const DEFAULT_PORT = 5001;
|
|
38
|
+
const onSocketError = (err) => {
|
|
39
|
+
console.error(err);
|
|
40
|
+
};
|
|
41
|
+
const authenticate = (token, cb) => {
|
|
42
|
+
if (!token)
|
|
43
|
+
cb(4401);
|
|
44
|
+
else
|
|
45
|
+
cb();
|
|
46
|
+
};
|
|
47
|
+
const getAuthToken = (protocols) => {
|
|
48
|
+
const authProtocol = protocols.find(
|
|
49
|
+
(protocol) => protocol.startsWith("auth--")
|
|
50
|
+
);
|
|
51
|
+
if (!authProtocol)
|
|
52
|
+
return "";
|
|
53
|
+
return authProtocol.split("--")[1]?.trim?.();
|
|
54
|
+
};
|
|
55
|
+
const createWSServer = ({
|
|
56
|
+
port = DEFAULT_PORT,
|
|
57
|
+
pingInterval = PING_INTERVAL,
|
|
58
|
+
onOpen
|
|
59
|
+
}) => {
|
|
60
|
+
let isAlive = false;
|
|
61
|
+
const heartbeat = () => {
|
|
62
|
+
isAlive = true;
|
|
63
|
+
};
|
|
64
|
+
const httpServer = import_node_http.default.createServer();
|
|
65
|
+
const wsServer = new wsLib.WebSocketServer({ noServer: true });
|
|
66
|
+
httpServer.on("upgrade", (req, socket, head) => {
|
|
67
|
+
socket.on("error", onSocketError);
|
|
68
|
+
wsServer.handleUpgrade(req, socket, head, (ws) => {
|
|
69
|
+
const protocols = req.headers["sec-websocket-protocol"]?.split(",");
|
|
70
|
+
if (!protocols) {
|
|
71
|
+
console.error("no protocols");
|
|
72
|
+
ws.close(4401, "unauthorized");
|
|
73
|
+
socket.destroy();
|
|
74
|
+
socket.removeListener("error", onSocketError);
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
authenticate(getAuthToken(protocols) || "", (errCode) => {
|
|
78
|
+
if (errCode) {
|
|
79
|
+
switch (errCode) {
|
|
80
|
+
case 4401:
|
|
81
|
+
ws.close(errCode, "unauthorized");
|
|
82
|
+
break;
|
|
83
|
+
default:
|
|
84
|
+
ws.close(4400, "Unknown error");
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
socket.destroy();
|
|
88
|
+
socket.removeListener("error", onSocketError);
|
|
89
|
+
} else {
|
|
90
|
+
socket.removeListener("error", onSocketError);
|
|
91
|
+
wsServer.emit("connection", ws, req);
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
wsServer.on("connection", (ws) => {
|
|
97
|
+
isAlive = true;
|
|
98
|
+
ws.on("error", console.error);
|
|
99
|
+
ws.on("pong", () => {
|
|
100
|
+
heartbeat();
|
|
101
|
+
});
|
|
102
|
+
ws.on("message", (message) => {
|
|
103
|
+
console.log(
|
|
104
|
+
"message from client:",
|
|
105
|
+
JSON.parse(message)
|
|
106
|
+
);
|
|
107
|
+
ws.send(JSON.stringify(JSON.parse(message)));
|
|
108
|
+
});
|
|
109
|
+
console.log("client connected");
|
|
110
|
+
onOpen?.(ws);
|
|
111
|
+
});
|
|
112
|
+
const interval = setInterval(() => {
|
|
113
|
+
wsServer.clients.forEach((ws) => {
|
|
114
|
+
if (isAlive === false)
|
|
115
|
+
ws.terminate();
|
|
116
|
+
isAlive = false;
|
|
117
|
+
ws.ping();
|
|
118
|
+
});
|
|
119
|
+
}, pingInterval);
|
|
120
|
+
wsServer.on("close", function close() {
|
|
121
|
+
clearInterval(interval);
|
|
122
|
+
});
|
|
123
|
+
return new Promise((resolve) => {
|
|
124
|
+
httpServer.listen(port, () => {
|
|
125
|
+
console.log(`Websocket server listening on port ${port}`);
|
|
126
|
+
return resolve({ httpServer, wsServer });
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
const { TestEnvironment } = require('jest-environment-jsdom');
|
|
2
|
+
|
|
3
|
+
// ICE platform is meant to be run on node > 18
|
|
4
|
+
// "jest-environment-jsdom": "~29.6.3" is instead meant to support node >16
|
|
5
|
+
// features that are supported since node 17 & 18 are not supported in jsdom env
|
|
6
|
+
// the limitation is not relevant for us since we are already running on node 18 anyway,
|
|
7
|
+
// this "ExtendedJSDomEnv" is an extension of the
|
|
8
|
+
// jest.config.cjs
|
|
9
|
+
// {
|
|
10
|
+
// ...
|
|
11
|
+
// testEnvironment: 'jsdom'
|
|
12
|
+
// ...
|
|
13
|
+
// }
|
|
14
|
+
// that actually uses node 18 features that are not supported in "jest-environment-jsdom": "~29.6.3"
|
|
15
|
+
|
|
16
|
+
// https://github.com/facebook/jest/blob/v29.4.3/website/versioned_docs/version-29.4/Configuration.md#testenvironment-string
|
|
17
|
+
class FixJSDOMEnvironment extends TestEnvironment {
|
|
18
|
+
constructor(...args) {
|
|
19
|
+
super(...args);
|
|
20
|
+
|
|
21
|
+
// From here on we are using "node" (currently running version of it) to polyfill jsdom this.global
|
|
22
|
+
|
|
23
|
+
// FIXME https://github.com/jsdom/jsdom/issues/3363
|
|
24
|
+
if (structuredClone) this.global.structuredClone = structuredClone;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
module.exports = FixJSDOMEnvironment;
|
|
@@ -0,0 +1,37 @@
|
|
|
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 getMessageAndPass_exports = {};
|
|
20
|
+
__export(getMessageAndPass_exports, {
|
|
21
|
+
getMessageAndPass: () => getMessageAndPass
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(getMessageAndPass_exports);
|
|
24
|
+
var import_jest_matcher_utils = require("jest-matcher-utils");
|
|
25
|
+
var import_reporter = require("./reporter.js");
|
|
26
|
+
const getMessageAndPass = (violations) => {
|
|
27
|
+
const formatedViolations = (0, import_reporter.reporter)(violations);
|
|
28
|
+
const pass = formatedViolations.length === 0;
|
|
29
|
+
if (pass)
|
|
30
|
+
return { message: () => "", pass };
|
|
31
|
+
return {
|
|
32
|
+
message: () => `${(0, import_jest_matcher_utils.matcherHint)(".toHaveNoViolations")}
|
|
33
|
+
|
|
34
|
+
${formatedViolations}`,
|
|
35
|
+
pass
|
|
36
|
+
};
|
|
37
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
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 axe_core_exports = {};
|
|
20
|
+
__export(axe_core_exports, {
|
|
21
|
+
toHaveNoViolations: () => import_toHaveNoViolations.toHaveNoViolations
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(axe_core_exports);
|
|
24
|
+
var import_toHaveNoViolations = require("./toHaveNoViolations.js");
|