@elliemae/pui-cli 7.0.0-alpha.2 → 7.0.0-alpha.5

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 (89) hide show
  1. package/dist/cjs/babel/babel.config.cjs +101 -0
  2. package/dist/cjs/index.cjs +19 -0
  3. package/dist/cjs/lint/commitlint.config.cjs +1 -0
  4. package/dist/cjs/lint/eslint/common.cjs +160 -0
  5. package/dist/cjs/lint/eslint/non-react.cjs +14 -0
  6. package/dist/cjs/lint/eslint/react.cjs +26 -0
  7. package/dist/cjs/lint/eslint/typescript/common.cjs +43 -0
  8. package/dist/cjs/lint/eslint/typescript/non-react.cjs +12 -0
  9. package/dist/cjs/lint/eslint/typescript/react.cjs +19 -0
  10. package/dist/cjs/lint/prettier.config.cjs +8 -0
  11. package/dist/cjs/lint/stylelint.config.cjs +19 -0
  12. package/dist/cjs/monorepo/set-registry-version.js +1 -1
  13. package/dist/cjs/monorepo/set-workspace-version.js +1 -1
  14. package/dist/cjs/monorepo/utils.cjs +29 -0
  15. package/dist/cjs/release/release.config.cjs +31 -0
  16. package/dist/cjs/server/util/app-routes.cjs +10 -0
  17. package/dist/cjs/server/util/index.js +2 -8
  18. package/dist/cjs/testing/jest.config.cjs +102 -0
  19. package/dist/cjs/testing/jest.node.config.cjs +8 -0
  20. package/dist/cjs/testing/mocks/axios.cjs +15 -0
  21. package/dist/cjs/testing/mocks/cssModule.cjs +1 -0
  22. package/dist/cjs/testing/mocks/html.cjs +1 -0
  23. package/dist/cjs/testing/mocks/image.cjs +1 -0
  24. package/dist/cjs/testing/mocks/matchMedia.cjs +24 -0
  25. package/dist/cjs/testing/mocks/pui-app-loader.cjs +1 -0
  26. package/dist/cjs/testing/mocks/pui-diagnostics.cjs +28 -0
  27. package/dist/cjs/testing/mocks/pui-user-monitoring.cjs +3 -0
  28. package/dist/cjs/testing/mocks/retry-axios.cjs +3 -0
  29. package/dist/cjs/testing/mocks/svg.cjs +5 -0
  30. package/dist/cjs/testing/mocks/webpack-hmr.cjs +1 -0
  31. package/dist/cjs/testing/resolver.cjs +47 -0
  32. package/dist/cjs/transpile/.swcrc +11 -0
  33. package/dist/cjs/transpile/esbuild.js +2 -1
  34. package/dist/cjs/transpile/swcrc.config.cjs +13 -0
  35. package/dist/cjs/utils.cjs +20 -0
  36. package/dist/cjs/webpack/helpers.js +1 -1
  37. package/dist/cjs/webpack/webpack.base.babel.js +2 -2
  38. package/dist/cjs/webpack/webpack.dev.babel.js +7 -3
  39. package/dist/cjs/webpack/webpack.storybook.cjs +87 -0
  40. package/dist/esm/babel/babel.config.cjs +101 -0
  41. package/dist/esm/index.cjs +19 -0
  42. package/dist/esm/lint/commitlint.config.cjs +1 -0
  43. package/dist/esm/lint/eslint/common.cjs +160 -0
  44. package/dist/esm/lint/eslint/non-react.cjs +14 -0
  45. package/dist/esm/lint/eslint/react.cjs +26 -0
  46. package/dist/esm/lint/eslint/typescript/common.cjs +43 -0
  47. package/dist/esm/lint/eslint/typescript/non-react.cjs +12 -0
  48. package/dist/esm/lint/eslint/typescript/react.cjs +19 -0
  49. package/dist/esm/lint/prettier.config.cjs +8 -0
  50. package/dist/esm/lint/stylelint.config.cjs +19 -0
  51. package/dist/esm/monorepo/set-registry-version.js +1 -1
  52. package/dist/esm/monorepo/set-workspace-version.js +1 -1
  53. package/dist/esm/monorepo/utils.cjs +29 -0
  54. package/dist/esm/release/release.config.cjs +31 -0
  55. package/dist/esm/server/util/app-routes.cjs +10 -0
  56. package/dist/esm/server/util/index.js +2 -8
  57. package/dist/esm/testing/jest.config.cjs +102 -0
  58. package/dist/esm/testing/jest.node.config.cjs +8 -0
  59. package/dist/esm/testing/mocks/axios.cjs +15 -0
  60. package/dist/esm/testing/mocks/cssModule.cjs +1 -0
  61. package/dist/esm/testing/mocks/html.cjs +1 -0
  62. package/dist/esm/testing/mocks/image.cjs +1 -0
  63. package/dist/esm/testing/mocks/matchMedia.cjs +24 -0
  64. package/dist/esm/testing/mocks/pui-app-loader.cjs +1 -0
  65. package/dist/esm/testing/mocks/pui-diagnostics.cjs +28 -0
  66. package/dist/esm/testing/mocks/pui-user-monitoring.cjs +3 -0
  67. package/dist/esm/testing/mocks/retry-axios.cjs +3 -0
  68. package/dist/esm/testing/mocks/svg.cjs +5 -0
  69. package/dist/esm/testing/mocks/webpack-hmr.cjs +1 -0
  70. package/dist/esm/testing/resolver.cjs +47 -0
  71. package/dist/esm/transpile/.swcrc +11 -0
  72. package/dist/esm/transpile/esbuild.js +2 -1
  73. package/dist/esm/transpile/swcrc.config.cjs +13 -0
  74. package/dist/esm/utils.cjs +20 -0
  75. package/dist/esm/webpack/helpers.js +1 -1
  76. package/dist/esm/webpack/webpack.base.babel.js +3 -3
  77. package/dist/esm/webpack/webpack.dev.babel.js +6 -3
  78. package/dist/esm/webpack/webpack.storybook.cjs +87 -0
  79. package/dist/types/index.d.cts +9 -0
  80. package/dist/types/lint/stylelint.config.d.cts +1 -0
  81. package/dist/types/monorepo/utils.d.cts +1 -0
  82. package/dist/types/server/util/app-routes.d.cts +1 -0
  83. package/dist/types/testing/jest.config.d.cts +2 -3
  84. package/dist/types/testing/jest.node.config.d.cts +2 -3
  85. package/dist/types/webpack/webpack.dev.babel.d.ts +2 -1
  86. package/package.json +4 -3
  87. package/dist/cjs/monorepo/utils.js +0 -34
  88. package/dist/esm/monorepo/utils.js +0 -12
  89. package/dist/types/monorepo/utils.d.ts +0 -1
@@ -0,0 +1,101 @@
1
+ const { isApp } = require('../utils.cjs');
2
+
3
+ const nodeEnvPreset = {
4
+ modules: process.env.ES_MODULES === 'false' ? 'commonjs' : false,
5
+ targets: {
6
+ node: 'current',
7
+ },
8
+ };
9
+
10
+ const webEnvPreset = {
11
+ modules: process.env.ES_MODULES === 'false' ? 'commonjs' : false,
12
+ useBuiltIns: 'usage',
13
+ corejs: { version: '3.19', proposals: true },
14
+ };
15
+
16
+ const presetEnvOptions =
17
+ process.env.TARGET_ENV === 'node' ? nodeEnvPreset : webEnvPreset;
18
+
19
+ const config = {
20
+ ignore: [/\/core-js/],
21
+ sourceType: 'unambiguous',
22
+ presets: [
23
+ ['@babel/preset-env', presetEnvOptions],
24
+ ['@babel/preset-react', { runtime: 'automatic' }],
25
+ '@babel/preset-typescript',
26
+ ],
27
+ plugins: [
28
+ [
29
+ 'babel-plugin-module-resolver',
30
+ {
31
+ alias: {
32
+ '@': isApp() ? './app' : './lib',
33
+ },
34
+ stripExtensions: [],
35
+ },
36
+ ],
37
+ ['babel-plugin-styled-components', { displayName: true }],
38
+ ['@babel/plugin-transform-runtime', { regenerator: true }],
39
+ '@babel/plugin-proposal-class-properties',
40
+ '@babel/plugin-syntax-dynamic-import',
41
+ '@babel/plugin-proposal-export-default-from',
42
+ 'lodash',
43
+ 'date-fns',
44
+ ],
45
+ env: {
46
+ development: {
47
+ plugins: [
48
+ ['babel-plugin-styled-components', { displayName: true }],
49
+ '@babel/plugin-transform-react-jsx-source',
50
+ ],
51
+ },
52
+ production: {
53
+ plugins: [
54
+ ['babel-plugin-styled-components', { displayName: false, pure: true }],
55
+ ['transform-remove-console', { exclude: ['error', 'warn'] }],
56
+ 'transform-react-remove-prop-types',
57
+ '@babel/plugin-transform-react-inline-elements',
58
+ '@babel/plugin-transform-react-constant-elements',
59
+ ],
60
+ },
61
+ test: {
62
+ plugins: [
63
+ ['babel-plugin-styled-components', { displayName: true }],
64
+ '@babel/plugin-transform-modules-commonjs',
65
+ 'dynamic-import-node',
66
+ [
67
+ 'babel-plugin-transform-strip-block',
68
+ {
69
+ requireDirective: true,
70
+ identifiers: [{ start: 'block:start', end: 'block:end' }],
71
+ },
72
+ ],
73
+ 'babel-plugin-import-remove-resource-query',
74
+ ],
75
+ },
76
+ },
77
+ };
78
+
79
+ if (process.env.MODULE_EXTENSIONS === 'true') {
80
+ config.plugins.push('babel-plugin-add-import-extension');
81
+ }
82
+
83
+ if (
84
+ process.env.STORYBOOK_BUILD !== 'true' &&
85
+ process.env.TARGET_ENV !== 'node'
86
+ ) {
87
+ config.env?.development?.plugins?.push?.('react-refresh/babel');
88
+ }
89
+
90
+ // ToDo: Once ECC team migrates from webpack 3 to webpack 5 remove this strip-block plugin from commonjs output. without this they are receiving error when import.meta is used in app sdk
91
+ if (process.env.ES_MODULES === 'false') {
92
+ config.plugins.push([
93
+ 'babel-plugin-transform-strip-block',
94
+ {
95
+ requireDirective: true,
96
+ identifiers: [{ start: 'block:start', end: 'block:end' }],
97
+ },
98
+ ]);
99
+ }
100
+
101
+ exports.babelConfig = config;
@@ -0,0 +1,19 @@
1
+ const { babelConfig } = require('./babel/babel.config.cjs');
2
+ const { esConfig: eslintBaseConfig } = require('./lint/eslint/non-react.cjs');
3
+ const { esReactConfig: eslintConfig } = require('./lint/eslint/react.cjs');
4
+ const { stylelintConfig } = require('./lint/stylelint.config.cjs');
5
+ const { prettierConfig } = require('./lint/prettier.config.cjs');
6
+ const { commitlintConfig } = require('./lint/commitlint.config.cjs');
7
+ const { jestConfig } = require('./testing/jest.config.cjs');
8
+ const { jestNodeConfig } = require('./testing/jest.node.config.cjs');
9
+
10
+ module.exports = {
11
+ babelConfig,
12
+ eslintBaseConfig,
13
+ eslintConfig,
14
+ stylelintConfig,
15
+ prettierConfig,
16
+ commitlintConfig,
17
+ jestConfig,
18
+ jestNodeConfig,
19
+ };
@@ -0,0 +1 @@
1
+ exports.commitlintConfig = { extends: ['@commitlint/config-conventional'] };
@@ -0,0 +1,160 @@
1
+ /* eslint-disable max-lines */
2
+ const prettierOptions = require('../prettier.config.cjs');
3
+ // const webpackConfig = require('../../webpack/webpack.prod.babel');
4
+
5
+ exports.baseExtends = [
6
+ 'plugin:eslint-comments/recommended',
7
+ 'plugin:import/recommended',
8
+ 'plugin:prettier/recommended',
9
+ 'plugin:jest/recommended',
10
+ 'plugin:jsdoc/recommended',
11
+ 'plugin:wdio/recommended',
12
+ 'plugin:testing-library/dom',
13
+ 'plugin:storybook/recommended',
14
+ ];
15
+
16
+ const basePlugins = ['testing-library', 'jest', 'jsdoc', 'wdio', 'import'];
17
+ exports.basePlugins = basePlugins;
18
+
19
+ exports.baseOverrides = [
20
+ {
21
+ files: ['*.func.spec.js', '*.visual.spec.js'],
22
+ rules: {
23
+ 'jest/valid-expect': 'off',
24
+ },
25
+ },
26
+ ];
27
+
28
+ const baseRules = {
29
+ 'prettier/prettier': ['error', prettierOptions],
30
+ 'arrow-body-style': [2, 'as-needed'],
31
+ 'class-methods-use-this': 0,
32
+ 'import/imports-first': 0,
33
+ 'import/newline-after-import': 0,
34
+ 'import/no-dynamic-require': 0,
35
+ 'import/no-extraneous-dependencies': 0,
36
+ 'import/no-named-as-default': 0,
37
+ 'import/no-unresolved': [
38
+ 2,
39
+ { caseSensitive: true, caseSensitiveStrict: true },
40
+ ], // Tip: https://github.com/import-js/eslint-plugin-import/issues/1868
41
+ 'import/no-webpack-loader-syntax': 0,
42
+ 'import/prefer-default-export': 0,
43
+ 'import/extensions': [
44
+ 2,
45
+ 'never',
46
+ {
47
+ json: 'ignorePackages',
48
+ js: 'ignorePackages',
49
+ },
50
+ ],
51
+ indent: [
52
+ 2,
53
+ 2,
54
+ {
55
+ SwitchCase: 1,
56
+ },
57
+ ],
58
+ 'max-lines': ['error', { max: 120, skipComments: true }],
59
+ complexity: ['error', { max: 10 }],
60
+ 'max-depth': ['error', { max: 4 }],
61
+ 'max-lines-per-function': 0,
62
+ 'max-nested-callbacks': ['error', { max: 3 }],
63
+ 'max-params': ['error', { max: 3 }],
64
+ 'max-statements': ['error', { max: 20 }],
65
+ 'max-len': 0,
66
+ 'newline-per-chained-call': 0,
67
+ 'no-confusing-arrow': 0,
68
+ 'no-console': 1,
69
+ 'no-param-reassign': ['error', { props: false }],
70
+ 'no-unused-vars': 2,
71
+ 'no-use-before-define': 0,
72
+ 'prefer-template': 2,
73
+ 'require-yield': 0,
74
+ 'jsdoc/require-jsdoc': 0,
75
+ 'eslint-comments/disable-enable-pair': 0,
76
+ };
77
+
78
+ exports.baseRules = baseRules;
79
+
80
+ const reactRules = {
81
+ 'jsx-a11y/aria-props': 2,
82
+ 'jsx-a11y/heading-has-content': 0,
83
+ 'jsx-a11y/label-has-associated-control': [
84
+ 2,
85
+ {
86
+ // NOTE: If this error triggers, either disable it or add
87
+ // your custom components, labels and attributes via these options
88
+ // See https://github.com/evcohen/eslint-plugin-jsx-a11y/blob/master/docs/rules/label-has-associated-control.md
89
+ controlComponents: ['Input'],
90
+ },
91
+ ],
92
+ 'jsx-a11y/label-has-for': 0,
93
+ 'jsx-a11y/mouse-events-have-key-events': 2,
94
+ 'jsx-a11y/role-has-required-aria-props': 2,
95
+ 'jsx-a11y/role-supports-aria-props': 2,
96
+ 'react/destructuring-assignment': 0,
97
+ 'react-hooks/rules-of-hooks': 'error',
98
+ 'react/jsx-closing-tag-location': 0,
99
+ 'react/forbid-prop-types': 0,
100
+ 'react/jsx-first-prop-new-line': [2, 'multiline'],
101
+ 'react/jsx-no-target-blank': 0,
102
+ 'react/jsx-props-no-spreading': 0,
103
+ 'react/jsx-uses-vars': 2,
104
+ 'react/require-default-props': 0,
105
+ 'react/require-extension': 0,
106
+ 'react/self-closing-comp': 0,
107
+ 'react/sort-comp': 0,
108
+ 'react/react-in-jsx-scope': 0,
109
+ 'react/jsx-filename-extension': [
110
+ 1,
111
+ { extensions: ['.js', '.jsx', '.tsx', '.mdx'] },
112
+ ],
113
+ 'react/function-component-definition': [
114
+ 2,
115
+ { namedComponents: 'arrow-function' },
116
+ ],
117
+ 'redux-saga/no-yield-in-race': 2,
118
+ 'redux-saga/yield-effects': 2,
119
+ };
120
+ exports.reactRules = reactRules;
121
+
122
+ exports.baseConfig = {
123
+ parser: '@babel/eslint-parser',
124
+ plugins: basePlugins,
125
+ env: {
126
+ jest: true,
127
+ browser: true,
128
+ node: true,
129
+ es2021: true,
130
+ },
131
+ parserOptions: {
132
+ sourceType: 'module',
133
+ ecmaFeatures: {
134
+ jsx: true,
135
+ },
136
+ },
137
+ settings: {
138
+ react: {
139
+ version: 'detect',
140
+ },
141
+ jest: {
142
+ version: 28,
143
+ },
144
+ // 'import/resolver': {
145
+ // webpack: {
146
+ // config: webpackConfig,
147
+ // },
148
+ // },
149
+ },
150
+ ignorePatterns: [
151
+ '/build/**/*',
152
+ '/dist/**/*',
153
+ '/reports/**/*',
154
+ '/coverage/**/*',
155
+ '/demo/**/*',
156
+ '/docs/**/*',
157
+ '/temp/**/*',
158
+ '**/vendor/*.js',
159
+ ],
160
+ };
@@ -0,0 +1,14 @@
1
+ const {
2
+ baseExtends,
3
+ baseRules,
4
+ baseOverrides,
5
+ baseConfig,
6
+ } = require('./common.cjs');
7
+ const { tsConfig } = require('./typescript/non-react.cjs');
8
+
9
+ exports.esConfig = {
10
+ ...baseConfig,
11
+ extends: ['airbnb-base'].concat(baseExtends),
12
+ rules: baseRules,
13
+ overrides: baseOverrides.concat([tsConfig]),
14
+ };
@@ -0,0 +1,26 @@
1
+ const {
2
+ baseExtends,
3
+ baseRules,
4
+ baseOverrides,
5
+ baseConfig,
6
+ reactRules,
7
+ } = require('./common.cjs');
8
+ const { tsReactConfig } = require('./typescript/react.cjs');
9
+
10
+ exports.esReactConfig = {
11
+ ...baseConfig,
12
+ extends: ['airbnb', 'airbnb/hooks', 'plugin:redux-saga/recommended'].concat(
13
+ baseExtends,
14
+ ),
15
+ rules: {
16
+ ...baseRules,
17
+ ...reactRules,
18
+ },
19
+ overrides: baseOverrides.concat([
20
+ tsReactConfig,
21
+ {
22
+ files: '*.mdx',
23
+ extends: 'plugin:mdx/recommended',
24
+ },
25
+ ]),
26
+ };
@@ -0,0 +1,43 @@
1
+ const { baseExtends, basePlugins } = require('../common.cjs');
2
+
3
+ exports.tsBaseExtends = [
4
+ 'plugin:@typescript-eslint/recommended',
5
+ 'plugin:import/typescript',
6
+ 'plugin:@typescript-eslint/recommended-requiring-type-checking',
7
+ ].concat(baseExtends);
8
+
9
+ exports.tsBaseRules = {
10
+ '@typescript-eslint/explicit-module-boundary-types': 'off',
11
+ '@typescript-eslint/explicit-function-return-type': 'off',
12
+ '@typescript-eslint/no-use-before-define': [
13
+ 'error',
14
+ { functions: false, classes: true, variables: true, typedefs: true },
15
+ ],
16
+ 'max-lines': ['error', { max: 200, skipComments: true }],
17
+ '@typescript-eslint/unbound-method': [
18
+ 'error',
19
+ {
20
+ ignoreStatic: true,
21
+ },
22
+ ],
23
+ };
24
+
25
+ exports.tsBaseConfig = {
26
+ files: ['*.ts', '*.tsx'],
27
+ parser: '@typescript-eslint/parser',
28
+ plugins: ['@typescript-eslint'].concat(basePlugins),
29
+ parserOptions: {
30
+ tsconfigRootDir: process.cwd(),
31
+ project: 'tsconfig.json',
32
+ },
33
+ settings: {
34
+ 'import/resolver': {
35
+ typescript: {
36
+ alwaysTryTypes: true,
37
+ },
38
+ },
39
+ 'import/parsers': {
40
+ '@typescript-eslint/parser': ['.ts', '.tsx'],
41
+ },
42
+ },
43
+ };
@@ -0,0 +1,12 @@
1
+ /* eslint-disable max-lines */
2
+ const { baseRules } = require('../common.cjs');
3
+ const { tsBaseExtends, tsBaseRules, tsBaseConfig } = require('./common.cjs');
4
+
5
+ exports.tsConfig = {
6
+ ...tsBaseConfig,
7
+ extends: ['airbnb-base', 'airbnb-typescript/base'].concat(tsBaseExtends),
8
+ rules: {
9
+ ...baseRules,
10
+ ...tsBaseRules,
11
+ },
12
+ };
@@ -0,0 +1,19 @@
1
+ /* eslint-disable max-lines */
2
+ const { baseRules, reactRules } = require('../common.cjs');
3
+ const { tsBaseExtends, tsBaseRules, tsBaseConfig } = require('./common.cjs');
4
+
5
+ exports.tsReactConfig = {
6
+ ...tsBaseConfig,
7
+ extends: [
8
+ 'airbnb',
9
+ 'airbnb/hooks',
10
+ 'plugin:redux-saga/recommended',
11
+ 'airbnb-typescript',
12
+ ].concat(tsBaseExtends),
13
+ rules: {
14
+ ...baseRules,
15
+ ...tsBaseRules,
16
+ ...reactRules,
17
+ 'react/prop-types': 0,
18
+ },
19
+ };
@@ -0,0 +1,8 @@
1
+ exports.prettierConfig = {
2
+ printWidth: 80,
3
+ tabWidth: 2,
4
+ useTabs: false,
5
+ semi: true,
6
+ singleQuote: true,
7
+ trailingComma: 'all',
8
+ };
@@ -0,0 +1,19 @@
1
+ exports.stylelintConfig = {
2
+ ignoreFiles: [
3
+ '/dist/**/*',
4
+ '/coverage/**/*',
5
+ '/build/**/*',
6
+ '/reports/**/*',
7
+ '/temp/**/*',
8
+ '/docs/**/*',
9
+ '/demo/**/*',
10
+ '/node_modules/**/*',
11
+ '/vendor/**/*',
12
+ ],
13
+ customSyntax: '@stylelint/postcss-css-in-js',
14
+ extends: [
15
+ 'stylelint-config-recommended',
16
+ 'stylelint-config-styled-components',
17
+ ],
18
+ rules: { 'selector-type-no-unknown': null, 'no-extra-semicolons': null, 'function-no-unknown': null },
19
+ };
@@ -26,7 +26,7 @@ module.exports = __toCommonJS(set_registry_version_exports);
26
26
  var import_promises = require("node:fs/promises");
27
27
  var import_fast_glob = __toESM(require("fast-glob"), 1);
28
28
  var import_normalize_path = __toESM(require("normalize-path"), 1);
29
- var import_utils = require("./utils.js");
29
+ var import_utils = require("./utils.cjs");
30
30
  const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() || "");
31
31
  const setRegistryVersion = async () => {
32
32
  const files = await (0, import_fast_glob.default)([
@@ -26,7 +26,7 @@ module.exports = __toCommonJS(set_workspace_version_exports);
26
26
  var import_promises = require("node:fs/promises");
27
27
  var import_fast_glob = __toESM(require("fast-glob"), 1);
28
28
  var import_normalize_path = __toESM(require("normalize-path"), 1);
29
- var import_utils = require("./utils.js");
29
+ var import_utils = require("./utils.cjs");
30
30
  const monorepoRoot = (0, import_normalize_path.default)((0, import_utils.findMonoRepoRoot)() || "");
31
31
  const setWorkspaceVersion = async () => {
32
32
  const files = await (0, import_fast_glob.default)([
@@ -0,0 +1,29 @@
1
+ const path = require('path');
2
+ const { execSync } = require('child_process');
3
+
4
+ const WORKSPACE_DIR_ENV_VAR = 'NPM_CONFIG_WORKSPACE_DIR';
5
+ const WORKSPACE_MANIFEST_FILENAME = 'pnpm-workspace.yaml';
6
+
7
+ const getPNPMWorkspaceLocation = (cwd) => {
8
+ let location = null;
9
+ for (const fileName of [WORKSPACE_MANIFEST_FILENAME, 'pnpm-workspace.yml']){
10
+ try {
11
+ const result = execSync(`find-up ${fileName}`, { cwd });
12
+ location = result.toString().trim();
13
+ break;
14
+ } catch (err) {
15
+ // ignore
16
+ }
17
+ };
18
+ return location;
19
+ };
20
+
21
+ exports.findMonoRepoRoot = (cwd = process.cwd()) => {
22
+ const workspaceManifestDirEnvVar =
23
+ process.env[WORKSPACE_DIR_ENV_VAR] ??
24
+ process.env[WORKSPACE_DIR_ENV_VAR.toLowerCase()];
25
+ const workspaceManifestLocation = workspaceManifestDirEnvVar
26
+ ? path.join(workspaceManifestDirEnvVar, 'pnpm-workspace.yaml')
27
+ : getPNPMWorkspaceLocation(cwd);
28
+ return workspaceManifestLocation && path.dirname(workspaceManifestLocation);
29
+ };
@@ -0,0 +1,31 @@
1
+ module.exports = {
2
+ branches: [
3
+ '+([0-9])?(.{+([0-9]),x}).x',
4
+ 'master',
5
+ 'next-major',
6
+ { name: 'beta', prerelease: true },
7
+ { name: 'alpha', prerelease: true },
8
+ { name: 'hotfix', prerelease: true },
9
+ { name: 'next', prerelease: true },
10
+ ],
11
+ plugins: [
12
+ '@semantic-release/commit-analyzer',
13
+ '@semantic-release/release-notes-generator',
14
+ [
15
+ '@semantic-release/changelog',
16
+ {
17
+ changelogTitle:
18
+ '# Changelog\n\nAll notable changes to this project will be documented in this file. See\n[Conventional Commits](https://conventionalcommits.org) for commit guidelines.',
19
+ },
20
+ ],
21
+ '@semantic-release/npm',
22
+ '@semantic-release/github',
23
+ [
24
+ '@semantic-release/exec',
25
+ {
26
+ successCmd:
27
+ 'scmutil get slack-release-notes && scmutil get contributors',
28
+ },
29
+ ],
30
+ ],
31
+ };
@@ -0,0 +1,10 @@
1
+ exports.initRoute = (routeFile, app) => {
2
+ // eslint-disable-next-line global-require
3
+ const init = require(routeFile);
4
+ try {
5
+ init(app);
6
+ } catch (err) {
7
+ // eslint-disable-next-line no-console
8
+ console.error(`unable to load routes from ${routeFile}. ${err.message}`);
9
+ }
10
+ }
@@ -29,6 +29,7 @@ module.exports = __toCommonJS(util_exports);
29
29
  var import_fs = __toESM(require("fs"), 1);
30
30
  var import_path = __toESM(require("path"), 1);
31
31
  var import_minimist = __toESM(require("minimist"), 1);
32
+ var import_app_routes = require("./app-routes.cjs");
32
33
  const argv = (0, import_minimist.default)(process.argv.slice(2));
33
34
  const getCWD = () => process.cwd();
34
35
  const allJS = /\.js$/;
@@ -55,14 +56,7 @@ const loadRoutes = (app) => {
55
56
  const routeFiles = getServerRouteFiles(import_path.default.join(getCWD(), "server/routes"));
56
57
  routeFiles.push(...getServiceEndpoints(import_path.default.join(getCWD(), "app")));
57
58
  routeFiles.push(...getServiceEndpoints(import_path.default.join(getCWD(), "lib")));
58
- routeFiles.forEach(async (routeFile) => {
59
- const init = await import(routeFile);
60
- try {
61
- init(app);
62
- } catch (err) {
63
- console.error(`unable to load routes from ${routeFile}. ${err.message}`);
64
- }
65
- });
59
+ routeFiles.forEach((routeFile) => (0, import_app_routes.initRoute)(routeFile, app));
66
60
  };
67
61
  const port = parseInt(argv.port || process.env.port || process.env.PORT || "3000", 10);
68
62
  const host = argv.host || process.env.HOST;
@@ -0,0 +1,102 @@
1
+ const path = require('path');
2
+ const normalizePath = require('normalize-path');
3
+ const { getAppConfig, basePath } = require('../utils.cjs');
4
+ const { swcrcConfig } = require('../transpile/swcrc.config.cjs');
5
+ const { findMonoRepoRoot } = require('../monorepo/utils.cjs');
6
+
7
+ let isReactModule = true;
8
+ try {
9
+ /* eslint-disable global-require, import/no-unresolved */
10
+ require('react');
11
+ require('styled-components');
12
+ /* eslint-enable global-require, import/no-unresolved */
13
+ } catch (err) {
14
+ isReactModule = false;
15
+ }
16
+
17
+ const getMockFilePath = (fileName) =>
18
+ normalizePath(path.resolve(__dirname, './mocks', fileName));
19
+
20
+ const getNodeModulesPath = (fileName) => {
21
+ const monorepoRoot = findMonoRepoRoot(process.cwd());
22
+ return normalizePath(
23
+ monorepoRoot
24
+ ? path.join(monorepoRoot, 'node_modules', fileName)
25
+ : `<rootDir>/node_modules/${fileName}`,
26
+ );
27
+ };
28
+
29
+ const jestConfig = {
30
+ collectCoverageFrom: [
31
+ 'app/**/*.{js,ts,jsx,tsx}',
32
+ 'lib/**/*.{js,ts,jsx,tsx}',
33
+ '!app/**/*.d.ts',
34
+ '!lib/**/*.d.ts',
35
+ '!app/**/*.test.{js,ts,jsx,tsx}',
36
+ '!lib/**/*.test.{js,ts,jsx,tsx}',
37
+ '!app/**/*.stories.{js,ts,jsx,tsx}',
38
+ '!lib/**/*.stories.{js,ts,jsx,tsx}',
39
+ '!app/**/*.endpoint.{js,ts,jsx,tsx}',
40
+ '!lib/**/*.endpoint.{js,ts,jsx,tsx}',
41
+ '!app/*/RbGenerated*/*.{js,ts,jsx,tsx}',
42
+ '!app/index.{js,ts,jsx,tsx}',
43
+ '!app/global-styles.{js,ts,jsx,tsx}',
44
+ '!app/**/loadable.{js,ts,jsx,tsx}',
45
+ '!lib/**/loadable.{js,ts,jsx,tsx}',
46
+ ],
47
+ coverageThreshold: {
48
+ // Todo: enable the coverage threshold later
49
+ // global: {
50
+ // statements: 95,
51
+ // branches: 90,
52
+ // functions: 95,
53
+ // lines: 95,
54
+ // },
55
+ },
56
+ coverageDirectory: 'reports',
57
+ coverageReporters: ['lcov', 'html', 'text-summary'],
58
+ moduleDirectories: ['node_modules', 'app', 'lib'],
59
+ moduleNameMapper: {
60
+ '.*\\webpack-hmr(.[t|j]s)?$': getMockFilePath('webpack-hmr.cjs'),
61
+ '.*\\.(css|scss)$': getMockFilePath('cssModule.cjs'),
62
+ '.*\\.(jpg|jpeg|png|gif|eot|otf|webp|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga|ico)$':
63
+ getMockFilePath('image.cjs'),
64
+ '.*\\.svg(?:\\?[a-zA-Z]+)?$': getMockFilePath('svg.cjs'),
65
+ '.*\\.html$(?:\\?[a-zA-Z]+)?$': getMockFilePath('html.cjs'),
66
+ '@elliemae/pui-user-monitoring': getMockFilePath('pui-user-monitoring.cjs'),
67
+ '@elliemae/pui-app-loader': getMockFilePath('pui-app-loader.cjs'),
68
+ '@elliemae/pui-diagnostics': getMockFilePath('pui-diagnostics.cjs'),
69
+ 'react-spring/web': getNodeModulesPath('react-spring/web.cjs.js'),
70
+ 'react-spring/renderprops': getNodeModulesPath(
71
+ 'react-spring/renderprops.cjs.js',
72
+ ),
73
+ },
74
+ moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx', 'json', 'node'],
75
+ setupFilesAfterEnv: [path.resolve(__dirname, './setup-tests.js')],
76
+ setupFiles: ['raf/polyfill', 'whatwg-fetch'],
77
+ testRegex: '(app|lib).*/tests/.*\\.test\\.[jt]sx?$',
78
+ snapshotSerializers: [],
79
+ testResultsProcessor: 'jest-sonar-reporter',
80
+ resolver: path.resolve(__dirname, './resolver.cjs'),
81
+ transform: {
82
+ '^.+\\.[jt]sx?$': ['@swc/jest', swcrcConfig],
83
+ },
84
+ transformIgnorePatterns: [
85
+ 'node_modules/(?!(.*@elliemae/pui-cli|lodash-es|react-select|react-dates)/)',
86
+ ],
87
+ globals: {
88
+ APP_CONFIG: getAppConfig(),
89
+ __webpack_public_path__: '/',
90
+ },
91
+ testEnvironmentOptions: {
92
+ url: `http://localhost:3111${basePath}`,
93
+ },
94
+ testEnvironment: 'jsdom',
95
+ };
96
+
97
+ if (isReactModule && jestConfig.setupFilesAfterEnv)
98
+ jestConfig.setupFilesAfterEnv.push(
99
+ path.resolve(__dirname, './setup-react-env.js'),
100
+ );
101
+
102
+ exports.jestConfig = jestConfig;
@@ -0,0 +1,8 @@
1
+ const { jestConfig } = require('./jest.config.cjs');
2
+ exports.jestNodeConfig = {
3
+ ...jestConfig,
4
+ testEnvironment: 'node',
5
+ transformIgnorePatterns: [],
6
+ setupFiles: [],
7
+ setupFilesAfterEnv: [],
8
+ };
@@ -0,0 +1,15 @@
1
+ module.exports = {
2
+ defaults: {},
3
+ interceptors: {
4
+ request: {
5
+ use: jest.fn(),
6
+ },
7
+ response: {
8
+ use: jest.fn(),
9
+ },
10
+ },
11
+ create: jest.fn().mockReturnThis(),
12
+ get: jest.fn().mockResolvedValue({ data: {} }),
13
+ post: jest.fn().mockResolvedValue({ data: {} }),
14
+ put: jest.fn().mockResolvedValue({ data: {} }),
15
+ };