@elliemae/pui-cli 8.29.1 → 8.29.3
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/babel.config.cjs +97 -0
- package/dist/cjs/commands/utils.js +1 -1
- package/dist/cjs/index.cjs +23 -0
- package/dist/cjs/jsdoc.conf.json +17 -0
- package/dist/cjs/lint-config/commitlint.config.cjs +1 -0
- package/dist/cjs/lint-config/eslint/common.cjs +164 -0
- package/dist/cjs/lint-config/eslint/non-react.cjs +14 -0
- package/dist/cjs/lint-config/eslint/react.cjs +26 -0
- package/dist/cjs/lint-config/eslint/typescript/common.cjs +49 -0
- package/dist/cjs/lint-config/eslint/typescript/non-react.cjs +12 -0
- package/dist/cjs/lint-config/eslint/typescript/react.cjs +19 -0
- package/dist/cjs/lint-config/prettier.config.cjs +8 -0
- package/dist/cjs/lint-config/stylelint.config.cjs +20 -0
- package/dist/cjs/monorepo/set-registry-version.js +3 -3
- package/dist/cjs/monorepo/set-workspace-version.js +3 -3
- package/dist/cjs/monorepo/utils.cjs +30 -0
- package/dist/cjs/release.config.cjs +24 -0
- package/dist/cjs/testing/jest.config.cjs +110 -0
- package/dist/cjs/testing/jest.node.config.cjs +8 -0
- package/dist/cjs/testing/resolver.cjs +47 -0
- package/dist/cjs/transpile/.swcrc +11 -0
- package/dist/cjs/transpile/esbuild.js +3 -3
- package/dist/cjs/transpile/swcrc.config.cjs +13 -0
- package/dist/cjs/typedoc.cjs +12 -0
- package/dist/cjs/utils.cjs +23 -0
- package/dist/cjs/webpack/webpack.lib.dev.babel.js +1 -1
- package/dist/cjs/webpack/webpack.lib.prod.babel.js +1 -1
- package/dist/esm/babel.config.cjs +97 -0
- package/dist/esm/commands/utils.js +1 -1
- package/dist/esm/index.cjs +23 -0
- package/dist/esm/jsdoc.conf.json +17 -0
- package/dist/esm/lint-config/commitlint.config.cjs +1 -0
- package/dist/esm/lint-config/eslint/common.cjs +164 -0
- package/dist/esm/lint-config/eslint/non-react.cjs +14 -0
- package/dist/esm/lint-config/eslint/react.cjs +26 -0
- package/dist/esm/lint-config/eslint/typescript/common.cjs +49 -0
- package/dist/esm/lint-config/eslint/typescript/non-react.cjs +12 -0
- package/dist/esm/lint-config/eslint/typescript/react.cjs +19 -0
- package/dist/esm/lint-config/prettier.config.cjs +8 -0
- package/dist/esm/lint-config/stylelint.config.cjs +20 -0
- package/dist/esm/monorepo/set-registry-version.js +3 -3
- package/dist/esm/monorepo/set-workspace-version.js +3 -3
- package/dist/esm/monorepo/utils.cjs +30 -0
- package/dist/esm/release.config.cjs +24 -0
- package/dist/esm/testing/jest.config.cjs +110 -0
- package/dist/esm/testing/jest.node.config.cjs +8 -0
- package/dist/esm/testing/resolver.cjs +47 -0
- package/dist/esm/transpile/.swcrc +11 -0
- package/dist/esm/transpile/esbuild.js +3 -3
- package/dist/esm/transpile/swcrc.config.cjs +13 -0
- package/dist/esm/typedoc.cjs +12 -0
- package/dist/esm/utils.cjs +23 -0
- package/dist/esm/webpack/webpack.lib.dev.babel.js +1 -1
- package/dist/esm/webpack/webpack.lib.prod.babel.js +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,97 @@
|
|
|
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.22', 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 (
|
|
80
|
+
process.env.STORYBOOK_BUILD !== 'true' &&
|
|
81
|
+
process.env.TARGET_ENV !== 'node'
|
|
82
|
+
) {
|
|
83
|
+
config.env?.development?.plugins?.push?.('react-refresh/babel');
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// 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
|
|
87
|
+
if (process.env.ES_MODULES === 'false') {
|
|
88
|
+
config.plugins.push([
|
|
89
|
+
'babel-plugin-transform-strip-block',
|
|
90
|
+
{
|
|
91
|
+
requireDirective: true,
|
|
92
|
+
identifiers: [{ start: 'block:start', end: 'block:end' }],
|
|
93
|
+
},
|
|
94
|
+
]);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
exports.babelConfig = config;
|
|
@@ -155,7 +155,7 @@ const updateRuntimeFile = async (src, dest, version) => {
|
|
|
155
155
|
const latestJSFolder = "latest/js";
|
|
156
156
|
const pipe = (0, import_node_util.promisify)(import_node_stream.pipeline);
|
|
157
157
|
const results = await (0, import_fast_glob.default)([
|
|
158
|
-
|
|
158
|
+
import_node_path.default.join(import_fast_glob.default.convertPathToPattern(src), "runtime~app.*.js")
|
|
159
159
|
]);
|
|
160
160
|
if (!results?.length)
|
|
161
161
|
throw new Error("Runtime file not found");
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
const { babelConfig } = require('./babel.config.cjs');
|
|
2
|
+
const {
|
|
3
|
+
esConfig: eslintBaseConfig,
|
|
4
|
+
} = require('./lint-config/eslint/non-react.cjs');
|
|
5
|
+
const {
|
|
6
|
+
esReactConfig: eslintConfig,
|
|
7
|
+
} = require('./lint-config/eslint/react.cjs');
|
|
8
|
+
const { stylelintConfig } = require('./lint-config/stylelint.config.cjs');
|
|
9
|
+
const { prettierConfig } = require('./lint-config/prettier.config.cjs');
|
|
10
|
+
const { commitlintConfig } = require('./lint-config/commitlint.config.cjs');
|
|
11
|
+
const { jestConfig } = require('./testing/jest.config.cjs');
|
|
12
|
+
const { jestNodeConfig } = require('./testing/jest.node.config.cjs');
|
|
13
|
+
|
|
14
|
+
module.exports = {
|
|
15
|
+
babelConfig,
|
|
16
|
+
eslintBaseConfig,
|
|
17
|
+
eslintConfig,
|
|
18
|
+
stylelintConfig,
|
|
19
|
+
prettierConfig,
|
|
20
|
+
commitlintConfig,
|
|
21
|
+
jestConfig,
|
|
22
|
+
jestNodeConfig,
|
|
23
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"plugins": ["plugins/markdown"],
|
|
3
|
+
"opts": {
|
|
4
|
+
"template": "node_modules/docdash"
|
|
5
|
+
},
|
|
6
|
+
"docdash": {
|
|
7
|
+
"sort": true,
|
|
8
|
+
"search": true,
|
|
9
|
+
"collapse": true,
|
|
10
|
+
"wrap": true
|
|
11
|
+
},
|
|
12
|
+
"templates": {
|
|
13
|
+
"default": {
|
|
14
|
+
"includeDate": false
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
exports.commitlintConfig = { extends: ['@commitlint/config-conventional'] };
|
|
@@ -0,0 +1,164 @@
|
|
|
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
|
+
babelOptions: {
|
|
137
|
+
plugins: ["@babel/plugin-syntax-import-assertions"],
|
|
138
|
+
},
|
|
139
|
+
},
|
|
140
|
+
settings: {
|
|
141
|
+
react: {
|
|
142
|
+
version: "detect",
|
|
143
|
+
},
|
|
144
|
+
jest: {
|
|
145
|
+
version: 28,
|
|
146
|
+
},
|
|
147
|
+
"import/resolver": {
|
|
148
|
+
node: {
|
|
149
|
+
extensions: [".js", ".jsx", ".ts", ".tsx"],
|
|
150
|
+
},
|
|
151
|
+
},
|
|
152
|
+
},
|
|
153
|
+
ignorePatterns: [
|
|
154
|
+
"/build/**/*",
|
|
155
|
+
"/node_modules/**/*",
|
|
156
|
+
"/dist/**/*",
|
|
157
|
+
"/reports/**/*",
|
|
158
|
+
"/coverage/**/*",
|
|
159
|
+
"/demo/**/*",
|
|
160
|
+
"/docs/**/*",
|
|
161
|
+
"/temp/**/*",
|
|
162
|
+
"**/vendor/*.js",
|
|
163
|
+
],
|
|
164
|
+
};
|
|
@@ -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,49 @@
|
|
|
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
|
+
'@typescript-eslint/no-floating-promises': [
|
|
24
|
+
'error',
|
|
25
|
+
{
|
|
26
|
+
ignoreIIFE: true,
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
exports.tsBaseConfig = {
|
|
32
|
+
files: ['*.ts', '*.tsx'],
|
|
33
|
+
parser: '@typescript-eslint/parser',
|
|
34
|
+
plugins: ['@typescript-eslint'].concat(basePlugins),
|
|
35
|
+
parserOptions: {
|
|
36
|
+
tsconfigRootDir: process.cwd(),
|
|
37
|
+
project: 'tsconfig.json',
|
|
38
|
+
},
|
|
39
|
+
settings: {
|
|
40
|
+
'import/resolver': {
|
|
41
|
+
typescript: {
|
|
42
|
+
alwaysTryTypes: true,
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
'import/parsers': {
|
|
46
|
+
'@typescript-eslint/parser': ['.ts', '.tsx'],
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
};
|
|
@@ -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,20 @@
|
|
|
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
|
+
// customSyntax: "postcss-styled-components", // '@stylelint/postcss-css-in-js' is deprecated, this may be a replacement?
|
|
15
|
+
extends: [
|
|
16
|
+
"stylelint-config-recommended",
|
|
17
|
+
"stylelint-config-styled-components",
|
|
18
|
+
],
|
|
19
|
+
rules: { "selector-type-no-unknown": null, "function-no-unknown": null },
|
|
20
|
+
};
|
|
@@ -38,9 +38,9 @@ var import_utils = require("./utils.js");
|
|
|
38
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
|
-
|
|
42
|
-
|
|
43
|
-
|
|
41
|
+
`${monorepoRoot}/libs/*/package.json`,
|
|
42
|
+
`${monorepoRoot}/apps/*/package.json`,
|
|
43
|
+
`${monorepoRoot}/package.json`
|
|
44
44
|
]);
|
|
45
45
|
await Promise.all(
|
|
46
46
|
files.map(async (file) => {
|
|
@@ -38,9 +38,9 @@ var import_utils = require("./utils.js");
|
|
|
38
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
|
-
|
|
42
|
-
|
|
43
|
-
|
|
41
|
+
`${monorepoRoot}/libs/*/package.json`,
|
|
42
|
+
`${monorepoRoot}/apps/*/package.json`,
|
|
43
|
+
`${monorepoRoot}/package.json`
|
|
44
44
|
]);
|
|
45
45
|
await Promise.all(
|
|
46
46
|
files.map(async (file) => {
|
|
@@ -0,0 +1,30 @@
|
|
|
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
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
10
|
+
for (const fileName of [WORKSPACE_MANIFEST_FILENAME, 'pnpm-workspace.yml']) {
|
|
11
|
+
try {
|
|
12
|
+
const result = execSync(`npx find-up ${fileName}`, { cwd });
|
|
13
|
+
location = result.toString().trim();
|
|
14
|
+
break;
|
|
15
|
+
} catch (err) {
|
|
16
|
+
// ignore
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return location;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
exports.findMonoRepoRoot = (cwd = process.cwd()) => {
|
|
23
|
+
const workspaceManifestDirEnvVar =
|
|
24
|
+
process.env[WORKSPACE_DIR_ENV_VAR] ??
|
|
25
|
+
process.env[WORKSPACE_DIR_ENV_VAR.toLowerCase()];
|
|
26
|
+
const workspaceManifestLocation = workspaceManifestDirEnvVar
|
|
27
|
+
? path.join(workspaceManifestDirEnvVar, 'pnpm-workspace.yaml')
|
|
28
|
+
: getPNPMWorkspaceLocation(cwd);
|
|
29
|
+
return workspaceManifestLocation && path.dirname(workspaceManifestLocation);
|
|
30
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,110 @@
|
|
|
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
|
+
d3: '<rootDir>/node_modules/d3/dist/d3.min.js',
|
|
61
|
+
'^d3-(.*)$': '<rootDir>/node_modules/d3-$1/dist/d3-$1.min.js',
|
|
62
|
+
'.*\\webpack-hmr(.[t|j]s)?$': getMockFilePath('webpack-hmr.js'),
|
|
63
|
+
'.*\\.(css|scss)$': getMockFilePath('cssModule.js'),
|
|
64
|
+
'.*\\.(jpg|jpeg|png|gif|eot|otf|webp|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga|ico)$':
|
|
65
|
+
getMockFilePath('image.js'),
|
|
66
|
+
'.*\\.svg(?:\\?[a-zA-Z]+)?$': getMockFilePath('svg.js'),
|
|
67
|
+
'.*\\.html(?:\\?[a-zA-Z]+)?$': getMockFilePath('html.js'),
|
|
68
|
+
'@elliemae/pui-user-monitoring': getMockFilePath('pui-user-monitoring.js'),
|
|
69
|
+
'@elliemae/pui-app-loader': getMockFilePath('pui-app-loader.js'),
|
|
70
|
+
'@elliemae/pui-diagnostics': getMockFilePath('pui-diagnostics.js'),
|
|
71
|
+
'react-spring/web': getNodeModulesPath('react-spring/web.cjs.js'),
|
|
72
|
+
'react-spring/renderprops': getNodeModulesPath(
|
|
73
|
+
'react-spring/renderprops.cjs.js',
|
|
74
|
+
),
|
|
75
|
+
},
|
|
76
|
+
moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx', 'json', 'node'],
|
|
77
|
+
setupFilesAfterEnv: [path.resolve(__dirname, './setup-tests.js')],
|
|
78
|
+
setupFiles: ['raf/polyfill', 'whatwg-fetch'],
|
|
79
|
+
testRegex: '(app|lib).*/tests/.*\\.test\\.[jt]sx?$',
|
|
80
|
+
snapshotSerializers: [],
|
|
81
|
+
testResultsProcessor: 'jest-sonar-reporter',
|
|
82
|
+
resolver: path.resolve(__dirname, './resolver.cjs'),
|
|
83
|
+
transform: {
|
|
84
|
+
'^.+\\.[jt]sx?$': ['@swc/jest', swcrcConfig],
|
|
85
|
+
},
|
|
86
|
+
transformIgnorePatterns: [
|
|
87
|
+
'node_modules/(?!(.*@elliemae/pui-cli|lodash-es|react-select|react-dates|d3|internmap|delaunator|robust-predicates)/)',
|
|
88
|
+
],
|
|
89
|
+
globals: {
|
|
90
|
+
APP_CONFIG: getAppConfig(),
|
|
91
|
+
__webpack_public_path__: '/',
|
|
92
|
+
},
|
|
93
|
+
testEnvironmentOptions: {
|
|
94
|
+
url: `http://localhost:3111${basePath}`,
|
|
95
|
+
resources: 'usable',
|
|
96
|
+
},
|
|
97
|
+
testEnvironment: 'jsdom',
|
|
98
|
+
watchPlugins: [
|
|
99
|
+
'jest-watch-typeahead/filename',
|
|
100
|
+
'jest-watch-typeahead/testname',
|
|
101
|
+
],
|
|
102
|
+
testTimeout: 5000,
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
if (isReactModule && jestConfig.setupFilesAfterEnv)
|
|
106
|
+
jestConfig.setupFilesAfterEnv.push(
|
|
107
|
+
path.resolve(__dirname, './setup-react-env.js'),
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
exports.jestConfig = jestConfig;
|