@ronas-it/nx-generators 0.8.0 → 0.8.1
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/README.md +14 -0
- package/generators.json +5 -0
- package/package.json +1 -1
- package/src/generators/code-checks/generator.js +1 -1
- package/src/generators/code-checks/generator.js.map +1 -1
- package/src/generators/entity-api/generator.js +12 -13
- package/src/generators/entity-api/generator.js.map +1 -1
- package/src/generators/form/generator.js +9 -68
- package/src/generators/form/generator.js.map +1 -1
- package/src/generators/form/utils/add-form-usage.d.ts +1 -0
- package/src/generators/form/utils/add-form-usage.js +67 -0
- package/src/generators/form/utils/add-form-usage.js.map +1 -0
- package/src/generators/form/utils/get-form-utils-directory.d.ts +1 -0
- package/src/generators/form/utils/get-form-utils-directory.js +24 -0
- package/src/generators/form/utils/get-form-utils-directory.js.map +1 -0
- package/src/generators/form/utils/index.d.ts +3 -0
- package/src/generators/form/utils/index.js +7 -0
- package/src/generators/form/utils/index.js.map +1 -0
- package/src/generators/form/utils/update-index.d.ts +2 -0
- package/src/generators/form/utils/update-index.js +18 -0
- package/src/generators/form/utils/update-index.js.map +1 -0
- package/src/generators/lib-tags/generator.d.ts +4 -0
- package/src/generators/lib-tags/generator.js +53 -0
- package/src/generators/lib-tags/generator.js.map +1 -0
- package/src/generators/lib-tags/interfaces/context.d.ts +6 -0
- package/src/generators/lib-tags/interfaces/context.js +3 -0
- package/src/generators/lib-tags/interfaces/context.js.map +1 -0
- package/src/generators/lib-tags/interfaces/index.d.ts +1 -0
- package/src/generators/lib-tags/interfaces/index.js +5 -0
- package/src/generators/lib-tags/interfaces/index.js.map +1 -0
- package/src/generators/lib-tags/schema.d.ts +3 -0
- package/src/generators/lib-tags/schema.json +14 -0
- package/src/generators/lib-tags/utils/check-lib-tags.d.ts +4 -0
- package/src/generators/lib-tags/utils/check-lib-tags.js +81 -0
- package/src/generators/lib-tags/utils/check-lib-tags.js.map +1 -0
- package/src/generators/lib-tags/utils/index.d.ts +1 -0
- package/src/generators/lib-tags/utils/index.js +5 -0
- package/src/generators/lib-tags/utils/index.js.map +1 -0
- package/src/generators/react-lib/generator.js +4 -4
- package/src/generators/react-lib/generator.js.map +1 -1
- package/src/shared/generators/store/expo-app/lib-files/shared/data-access/store/src/store.ts.template +1 -1
- package/src/shared/generators/store/next-app/lib-files/shared/data-access/store/src/store.ts.template +1 -1
- package/src/shared/utils/cli-utils.js +4 -2
- package/src/shared/utils/cli-utils.js.map +1 -1
- package/src/shared/utils/config-utils.d.ts +15 -0
- package/src/shared/utils/config-utils.js +75 -14
- package/src/shared/utils/config-utils.js.map +1 -1
- package/src/shared/utils/constants.d.ts +3 -0
- package/src/shared/utils/constants.js +7 -0
- package/src/shared/utils/constants.js.map +1 -0
- package/src/shared/utils/index.d.ts +1 -0
- package/src/shared/utils/index.js +1 -0
- package/src/shared/utils/index.js.map +1 -1
- /package/src/generators/entity-api/files/models/{entity.ts.template → __entityFileName__.ts.template} +0 -0
- /package/src/generators/form/files/{form.ts.template → __fileName__.ts.template} +0 -0
package/README.md
CHANGED
|
@@ -194,6 +194,20 @@ or
|
|
|
194
194
|
npx nx g form profile-settings ProfileSettings
|
|
195
195
|
```
|
|
196
196
|
|
|
197
|
+
### 9. `lib-tags`
|
|
198
|
+
|
|
199
|
+
Checks and configures [NX library tags](https://nx.dev/features/enforce-module-boundaries). If your project does not already use library tags, you can add them using this generator.
|
|
200
|
+
|
|
201
|
+
#### Options
|
|
202
|
+
|
|
203
|
+
1. `silent` (optional) - disables all logs
|
|
204
|
+
|
|
205
|
+
#### Example
|
|
206
|
+
|
|
207
|
+
```sh
|
|
208
|
+
npx nx g lib-tags
|
|
209
|
+
```
|
|
210
|
+
|
|
197
211
|
### Note
|
|
198
212
|
|
|
199
213
|
Each generator accepts the `--help` argument to see generator instructions.
|
package/generators.json
CHANGED
|
@@ -49,6 +49,11 @@
|
|
|
49
49
|
"factory": "./src/generators/form/generator",
|
|
50
50
|
"schema": "./src/generators/form/schema.json",
|
|
51
51
|
"description": "form generator"
|
|
52
|
+
},
|
|
53
|
+
"lib-tags": {
|
|
54
|
+
"factory": "./src/generators/lib-tags/generator",
|
|
55
|
+
"schema": "./src/generators/lib-tags/schema.json",
|
|
56
|
+
"description": "lib-tags generator"
|
|
52
57
|
}
|
|
53
58
|
}
|
|
54
59
|
}
|
package/package.json
CHANGED
|
@@ -9,8 +9,8 @@ const dependencies_1 = require("../../shared/dependencies");
|
|
|
9
9
|
const config_1 = require("./config");
|
|
10
10
|
const scripts_1 = require("./scripts");
|
|
11
11
|
function codeChecksGenerator(tree, options) {
|
|
12
|
+
var _a, _b;
|
|
12
13
|
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
13
|
-
var _a, _b;
|
|
14
14
|
const projectRoot = '.';
|
|
15
15
|
// Delete files
|
|
16
16
|
tree.delete('.eslintrc.json');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/code-checks/generator.ts"],"names":[],"mappings":";;;;AAAA,iDAAyC;AACzC,6BAA6B;AAC7B,uCAQoB;AACpB,4DAA4D;AAC5D,qCAA8B;AAE9B,uCAAgC;AAEhC,SAAsB,mBAAmB,CAAC,IAAU,EAAE,OAAkC;;;QACtF,MAAM,WAAW,GAAG,GAAG,CAAC;QAExB,eAAe;QACf,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAE3B,4BAA4B;QAC5B,IAAA,wBAAQ,EAAC,uBAAuB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QAExD,MAAM,WAAW,GAAG,IAAA,iBAAQ,EAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QACnD,WAAW,CAAC,aAAa,CAAC,GAAG,gBAAM,CAAC,aAAa,CAAC,CAAC;QACnD,WAAW,CAAC,OAAO,mCAAQ,iBAAO,GAAK,WAAW,CAAC,OAAO,CAAE,CAAC;QAC7D,IAAA,kBAAS,EAAC,IAAI,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;QAE7C,4BAA4B;QAC5B,MAAM,YAAY,GAAG,IAAA,iBAAQ,EAAC,IAAI,EAAE,oBAAoB,CAAC,CAAC;QAC1D,YAAY,CAAC,eAAe,mCAAQ,gBAAM,CAAC,QAAQ,GAAK,YAAY,CAAC,eAAe,CAAE,CAAC;QACvF,IAAA,kBAAS,EAAC,IAAI,EAAE,oBAAoB,EAAE,YAAY,CAAC,CAAC;QAEpD,oBAAoB;QACpB,MAAM,gBAAgB,GAAG,CAAA,MAAA,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,0CAAE,QAAQ,EAAE,IAAG,kBAAkB,CAAC;QAClF,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAE3C,uBAAuB;QACvB,MAAM,mBAAmB,GAAG,CAAA,MAAA,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,0CAAE,QAAQ,EAAE,IAAG,mCAAmC,CAAC;QACzG,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,mBAAmB,CAAC,CAAC;QAEjD,YAAY;QACZ,IAAA,sBAAa,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAEzE,iCAAiC;QACjC,IAAA,qCAA4B,EAC1B,IAAI,EACJ,EAAE,EACF,8BAAe,CAAC,aAAa,CAAC,CAC/B,CAAC;QAEF,MAAM,IAAA,oBAAW,EAAC,IAAI,CAAC,CAAC;QAExB,OAAO,GAAG,EAAE;YACV,IAAA,4BAAmB,EAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/code-checks/generator.ts"],"names":[],"mappings":";;;;AAAA,iDAAyC;AACzC,6BAA6B;AAC7B,uCAQoB;AACpB,4DAA4D;AAC5D,qCAA8B;AAE9B,uCAAgC;AAEhC,SAAsB,mBAAmB,CAAC,IAAU,EAAE,OAAkC;;;QACtF,MAAM,WAAW,GAAG,GAAG,CAAC;QAExB,eAAe;QACf,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAE3B,4BAA4B;QAC5B,IAAA,wBAAQ,EAAC,uBAAuB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QAExD,MAAM,WAAW,GAAG,IAAA,iBAAQ,EAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QACnD,WAAW,CAAC,aAAa,CAAC,GAAG,gBAAM,CAAC,aAAa,CAAC,CAAC;QACnD,WAAW,CAAC,OAAO,mCAAQ,iBAAO,GAAK,WAAW,CAAC,OAAO,CAAE,CAAC;QAC7D,IAAA,kBAAS,EAAC,IAAI,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;QAE7C,4BAA4B;QAC5B,MAAM,YAAY,GAAG,IAAA,iBAAQ,EAAC,IAAI,EAAE,oBAAoB,CAAC,CAAC;QAC1D,YAAY,CAAC,eAAe,mCAAQ,gBAAM,CAAC,QAAQ,GAAK,YAAY,CAAC,eAAe,CAAE,CAAC;QACvF,IAAA,kBAAS,EAAC,IAAI,EAAE,oBAAoB,EAAE,YAAY,CAAC,CAAC;QAEpD,oBAAoB;QACpB,MAAM,gBAAgB,GAAG,CAAA,MAAA,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,0CAAE,QAAQ,EAAE,IAAG,kBAAkB,CAAC;QAClF,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAE3C,uBAAuB;QACvB,MAAM,mBAAmB,GAAG,CAAA,MAAA,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,0CAAE,QAAQ,EAAE,IAAG,mCAAmC,CAAC;QACzG,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,mBAAmB,CAAC,CAAC;QAEjD,YAAY;QACZ,IAAA,sBAAa,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAEzE,iCAAiC;QACjC,IAAA,qCAA4B,EAC1B,IAAI,EACJ,EAAE,EACF,8BAAe,CAAC,aAAa,CAAC,CAC/B,CAAC;QAEF,MAAM,IAAA,oBAAW,EAAC,IAAI,CAAC,CAAC;QAExB,OAAO,GAAG,EAAE;YACV,IAAA,4BAAmB,EAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC;;CACH;AA3CD,kDA2CC;AAED,kBAAe,mBAAmB,CAAC"}
|
|
@@ -22,13 +22,13 @@ function entityApiGenerator(tree, options) {
|
|
|
22
22
|
if (apiClientLibsPaths.length > 1) {
|
|
23
23
|
apiClientLibsPaths[0] = yield autocomplete({
|
|
24
24
|
message: 'Select the api client library path:',
|
|
25
|
-
source: (input) => (0, utils_1.filterSource)(input, apiClientLibsPaths)
|
|
25
|
+
source: (input) => (0, utils_1.filterSource)(input, apiClientLibsPaths),
|
|
26
26
|
});
|
|
27
27
|
}
|
|
28
28
|
if (apiLibsPaths.length > 1) {
|
|
29
29
|
apiLibsPaths[0] = yield autocomplete({
|
|
30
30
|
message: 'Select the api library path:',
|
|
31
|
-
source: (input) => (0, utils_1.filterSource)(input, apiLibsPaths)
|
|
31
|
+
source: (input) => (0, utils_1.filterSource)(input, apiLibsPaths),
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
const apiDirectory = (0, utils_1.searchAliasPath)(apiLibsPaths[0]);
|
|
@@ -37,7 +37,8 @@ function entityApiGenerator(tree, options) {
|
|
|
37
37
|
const libRootPath = `${libPath}/lib`;
|
|
38
38
|
options.name = options.name || (yield (0, utils_1.askQuestion)('Enter the name of the entity (e.g: User): '));
|
|
39
39
|
const apiName = (0, lodash_1.kebabCase)(options.name);
|
|
40
|
-
options.baseEndpoint =
|
|
40
|
+
options.baseEndpoint =
|
|
41
|
+
options.baseEndpoint || (yield (0, utils_1.askQuestion)('Enter the base endpoint (e.g: /users): ', `/${apiName}`));
|
|
41
42
|
const apiPath = `${libRootPath}/${apiName}`;
|
|
42
43
|
const entityName = (0, lodash_1.startCase)((0, lodash_1.camelCase)(apiName)).replace(/\s+/g, '');
|
|
43
44
|
(0, devkit_1.generateFiles)(tree, path.join(__dirname, `files`), apiPath, Object.assign(Object.assign({}, options), { apiName: (0, lodash_1.camelCase)(options.name), entityName, entityFileName: apiName, apiClientDirectory, baseEndpoint: options.baseEndpoint.startsWith('/') ? options.baseEndpoint : `/${options.baseEndpoint}` }));
|
|
@@ -51,7 +52,7 @@ function entityApiGenerator(tree, options) {
|
|
|
51
52
|
if (storeLibsPaths.length > 1) {
|
|
52
53
|
storeLibsPaths[0] = yield autocomplete({
|
|
53
54
|
message: 'Select the store library path:',
|
|
54
|
-
source: (input) => (0, utils_1.filterSource)(input, storeLibsPaths)
|
|
55
|
+
source: (input) => (0, utils_1.filterSource)(input, storeLibsPaths),
|
|
55
56
|
});
|
|
56
57
|
}
|
|
57
58
|
// Update redux store
|
|
@@ -59,22 +60,20 @@ function entityApiGenerator(tree, options) {
|
|
|
59
60
|
const project = new ts_morph_1.Project({
|
|
60
61
|
manipulationSettings: {
|
|
61
62
|
indentationText: ts_morph_1.IndentationText.TwoSpaces,
|
|
62
|
-
quoteKind: ts_morph_1.QuoteKind.Single
|
|
63
|
-
}
|
|
63
|
+
quoteKind: ts_morph_1.QuoteKind.Single,
|
|
64
|
+
},
|
|
64
65
|
});
|
|
65
66
|
const store = project.addSourceFileAtPath(`${storeLibsPaths[0]}/store.ts`);
|
|
66
|
-
|
|
67
|
-
const apiImportsDeclaration = store.getImportDeclarationOrThrow((node) => node.getModuleSpecifierValue() === apiDirectory);
|
|
68
|
-
apiImportsDeclaration.addNamedImport(apiNameDeclaration);
|
|
67
|
+
(0, utils_1.addNamedImport)(apiNameDeclaration, apiDirectory, store);
|
|
69
68
|
const rootReducer = store.getVariableDeclarationOrThrow('rootReducer');
|
|
70
|
-
rootReducer.getInitializerIfKindOrThrow(ts_morph_1.SyntaxKind.ObjectLiteralExpression)
|
|
71
|
-
.addProperty({
|
|
69
|
+
rootReducer.getInitializerIfKindOrThrow(ts_morph_1.SyntaxKind.ObjectLiteralExpression).addProperty({
|
|
72
70
|
name: `[${apiNameDeclaration}.reducerPath]`,
|
|
73
71
|
initializer: `${apiNameDeclaration}.reducer`,
|
|
74
|
-
kind: ts_morph_1.StructureKind.PropertyAssignment
|
|
72
|
+
kind: ts_morph_1.StructureKind.PropertyAssignment,
|
|
75
73
|
});
|
|
76
74
|
const middlewares = store.getVariableDeclarationOrThrow('middlewares');
|
|
77
|
-
middlewares
|
|
75
|
+
middlewares
|
|
76
|
+
.getInitializerIfKindOrThrow(ts_morph_1.SyntaxKind.ArrayLiteralExpression)
|
|
78
77
|
.addElement(`${apiNameDeclaration}.middleware`);
|
|
79
78
|
project.saveSync();
|
|
80
79
|
yield (0, devkit_1.formatFiles)(tree);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/entity-api/generator.ts"],"names":[],"mappings":";;;;AAAA,uCAA8D;AAC9D,uCAA0F;AAC1F,6BAA6B;AAC7B,mCAAyD;AAEzD,
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/entity-api/generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,70 +5,8 @@ const tslib_1 = require("tslib");
|
|
|
5
5
|
const devkit_1 = require("@nx/devkit");
|
|
6
6
|
const path = require("path");
|
|
7
7
|
const utils_1 = require("../../shared/utils");
|
|
8
|
-
const fs_1 = require("fs");
|
|
9
|
-
const lodash_1 = require("lodash");
|
|
10
8
|
const dependencies_1 = require("../../shared/dependencies");
|
|
11
|
-
const
|
|
12
|
-
function getFormUtilsDirectory() {
|
|
13
|
-
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
14
|
-
const { default: autocomplete } = yield (0, utils_1.dynamicImport)('inquirer-autocomplete-standalone');
|
|
15
|
-
const utilsLibsPaths = (0, utils_1.getNxLibsPaths)([utils_1.LibraryType.UTILS]);
|
|
16
|
-
const formUtilsLibsPaths = (0, utils_1.searchNxLibsPaths)(utilsLibsPaths, 'utils/form/src', 'endsWith');
|
|
17
|
-
if (!formUtilsLibsPaths.length) {
|
|
18
|
-
throw new Error('Could not find a library with the form utilities.');
|
|
19
|
-
}
|
|
20
|
-
if (formUtilsLibsPaths.length > 1) {
|
|
21
|
-
formUtilsLibsPaths[0] = yield autocomplete({
|
|
22
|
-
message: 'Select the path of the library with the form utilities: ',
|
|
23
|
-
source: (input) => (0, utils_1.filterSource)(input, formUtilsLibsPaths)
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
return (0, utils_1.searchAliasPath)(formUtilsLibsPaths[0]);
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
function updateIndex(formsPath, fileName, tree) {
|
|
30
|
-
const formsIndexFilePath = `${formsPath}/index.ts`;
|
|
31
|
-
const newIndexContent = `export * from './${(0, lodash_1.kebabCase)(fileName)}';\n`;
|
|
32
|
-
if (!(0, fs_1.existsSync)(formsIndexFilePath)) {
|
|
33
|
-
tree.write(formsIndexFilePath, newIndexContent);
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
(0, utils_1.appendFileContent)(formsIndexFilePath, newIndexContent, tree);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
function getFormUsageCode(formClassName) {
|
|
40
|
-
return `const formSchema = new ${formClassName}();
|
|
41
|
-
const form = useForm<${formClassName}>({
|
|
42
|
-
defaultValues: formSchema.formValues,
|
|
43
|
-
resolver: yupResolver<any>(${formClassName}.validationSchema)
|
|
44
|
-
});\n\n`;
|
|
45
|
-
}
|
|
46
|
-
function addFormUsage(libPath, placeOfUse, formClassName) {
|
|
47
|
-
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
48
|
-
const project = new ts_morph_1.Project({
|
|
49
|
-
manipulationSettings: {
|
|
50
|
-
indentationText: ts_morph_1.IndentationText.TwoSpaces,
|
|
51
|
-
quoteKind: ts_morph_1.QuoteKind.Single
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
const files = project.addSourceFilesAtPaths([`${libPath}/lib/**/*.tsx`, `${libPath}/lib/**/*.ts`]);
|
|
55
|
-
const file = files.find((file) => file.getFunction(placeOfUse) || file.getVariableDeclaration(placeOfUse));
|
|
56
|
-
if (!file) {
|
|
57
|
-
throw new Error('Could not find the place where the form should be used.');
|
|
58
|
-
}
|
|
59
|
-
const pathToForm = file.getFilePath().includes('components')
|
|
60
|
-
? '../../forms'
|
|
61
|
-
: file.getFilePath().includes('hooks')
|
|
62
|
-
? '../forms'
|
|
63
|
-
: './forms';
|
|
64
|
-
(0, utils_1.addNamedImport)(formClassName, pathToForm, file);
|
|
65
|
-
(0, utils_1.addNamedImport)('useForm', 'react-hook-form', file);
|
|
66
|
-
(0, utils_1.addNamedImport)('yupResolver', '@hookform/resolvers/yup', file);
|
|
67
|
-
const component = file.getFunction(placeOfUse) || file.getVariableDeclaration(placeOfUse).getInitializerIfKindOrThrow(ts_morph_1.SyntaxKind.FunctionExpression);
|
|
68
|
-
component.setBodyText(`${getFormUsageCode(formClassName)}${component.getBodyText()}`);
|
|
69
|
-
project.saveSync();
|
|
70
|
-
});
|
|
71
|
-
}
|
|
9
|
+
const utils_2 = require("./utils");
|
|
72
10
|
function formGenerator(tree, options) {
|
|
73
11
|
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
74
12
|
// Get input data
|
|
@@ -85,14 +23,17 @@ function formGenerator(tree, options) {
|
|
|
85
23
|
const placeOfUse = options.placeOfUse;
|
|
86
24
|
// Generate form class
|
|
87
25
|
const formsPath = `${libPath}/lib/forms`;
|
|
88
|
-
const
|
|
26
|
+
const formFilePath = `${formsPath}/${fileName}.ts`;
|
|
27
|
+
if (tree.exists(formFilePath)) {
|
|
28
|
+
throw new Error('The form already exists');
|
|
29
|
+
}
|
|
30
|
+
const formUtilsDirectory = yield (0, utils_2.getFormUtilsDirectory)();
|
|
89
31
|
const formClassName = `${(0, utils_1.formatName)(fileName, true)}FormSchema`;
|
|
90
|
-
(0, devkit_1.generateFiles)(tree, path.join(__dirname, `files`), formsPath, { className: formClassName, formUtilsDirectory });
|
|
91
|
-
|
|
92
|
-
updateIndex(formsPath, fileName, tree);
|
|
32
|
+
(0, devkit_1.generateFiles)(tree, path.join(__dirname, `files`), formsPath, { className: formClassName, fileName, formUtilsDirectory });
|
|
33
|
+
(0, utils_2.updateIndex)(formsPath, fileName, tree);
|
|
93
34
|
// Add form usage
|
|
94
35
|
if (placeOfUse) {
|
|
95
|
-
yield addFormUsage(libPath, placeOfUse, formClassName);
|
|
36
|
+
yield (0, utils_2.addFormUsage)(libPath, placeOfUse, formClassName);
|
|
96
37
|
}
|
|
97
38
|
yield (0, devkit_1.formatFiles)(tree);
|
|
98
39
|
// Install dependencies
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/form/generator.ts"],"names":[],"mappings":";;;;AAAA,uCAAiH;AACjH,6BAA6B;AAE7B,
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/form/generator.ts"],"names":[],"mappings":";;;;AAAA,uCAAiH;AACjH,6BAA6B;AAE7B,8CAA+G;AAC/G,4DAAyD;AACzD,mCAA2E;AAE3E,SAAsB,aAAa,CAAC,IAAU,EAAE,OAA4B;;QAC1E,iBAAiB;QACjB,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,qBAAa,EAAoD,kCAAkC,CAAC,CAAC;QAC7I,MAAM,kBAAkB,GAAG,IAAA,sBAAc,EAAC,CAAC,mBAAW,CAAC,QAAQ,EAAE,mBAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QAClF,MAAM,OAAO,GAAG,MAAM,YAAY,CAAC;YACjC,OAAO,EAAE,0BAA0B;YACnC,MAAM,EAAE,CAAO,KAAK,EAAE,EAAE;gBACtB,MAAM,mBAAmB,GAAG,IAAA,yBAAiB,EAAC,kBAAkB,EAAE,KAAK,CAAC,CAAA;gBAExE,OAAO,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;YAC7D,CAAC,CAAA;SACF,CAAC,CAAC;QACH,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;QAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QAEtC,sBAAsB;QACtB,MAAM,SAAS,GAAG,GAAG,OAAO,YAAY,CAAC;QACzC,MAAM,YAAY,GAAG,GAAG,SAAS,IAAI,QAAQ,KAAK,CAAC;QACnD,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QAED,MAAM,kBAAkB,GAAG,MAAM,IAAA,6BAAqB,GAAE,CAAC;QACzD,MAAM,aAAa,GAAG,GAAG,IAAA,kBAAU,EAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;QAChE,IAAA,sBAAa,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,aAAa,EAAE,QAAQ,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAC1H,IAAA,mBAAW,EAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;QAEvC,iBAAiB;QACjB,IAAI,UAAU,EAAE,CAAC;YACf,MAAM,IAAA,oBAAY,EAAC,OAAO,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;QACzD,CAAC;QAED,MAAM,IAAA,oBAAW,EAAC,IAAI,CAAC,CAAC;QAExB,uBAAuB;QACvB,IAAA,qCAA4B,EAAC,IAAI,EAAE,2BAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC1D,OAAO,GAAG,EAAE;YACV,IAAA,4BAAmB,EAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC;IACJ,CAAC;CAAA;AAvCD,sCAuCC;AAED,kBAAe,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function addFormUsage(libPath: string, placeOfUseName: string, formClassName: string): Promise<void>;
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.addFormUsage = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const ts_morph_1 = require("ts-morph");
|
|
6
|
+
const utils_1 = require("../../../shared/utils");
|
|
7
|
+
function getFormUsageCode(formClassName) {
|
|
8
|
+
return `const formSchema = new ${formClassName}();
|
|
9
|
+
const form = useForm({
|
|
10
|
+
defaultValues: formSchema.formValues,
|
|
11
|
+
resolver: yupResolver(${formClassName}.validationSchema)
|
|
12
|
+
});\n\n`;
|
|
13
|
+
}
|
|
14
|
+
function getForwardRefFunction(variable) {
|
|
15
|
+
const callExpressionInitializer = variable.getInitializerIfKind(ts_morph_1.SyntaxKind.CallExpression);
|
|
16
|
+
const hasForwardRef = (callExpressionInitializer === null || callExpressionInitializer === void 0 ? void 0 : callExpressionInitializer.getExpression().getText()) === 'forwardRef';
|
|
17
|
+
if (!hasForwardRef) {
|
|
18
|
+
throw new Error('Could not find forwardRef');
|
|
19
|
+
}
|
|
20
|
+
const argument = callExpressionInitializer.getArguments()[0];
|
|
21
|
+
const hasComponentFunction = argument && [ts_morph_1.SyntaxKind.FunctionExpression, ts_morph_1.SyntaxKind.ArrowFunction].includes(argument.getKind());
|
|
22
|
+
if (!hasComponentFunction) {
|
|
23
|
+
throw new Error('Could not find a component function in forwardRef');
|
|
24
|
+
}
|
|
25
|
+
return argument.asKind(argument.getKind() === ts_morph_1.SyntaxKind.FunctionExpression ? ts_morph_1.SyntaxKind.FunctionExpression : ts_morph_1.SyntaxKind.ArrowFunction);
|
|
26
|
+
}
|
|
27
|
+
function getPlaceOfUse(file, placeOfUseName) {
|
|
28
|
+
const placeOfUseFunction = file.getFunction(placeOfUseName);
|
|
29
|
+
if (placeOfUseFunction) {
|
|
30
|
+
return placeOfUseFunction;
|
|
31
|
+
}
|
|
32
|
+
const variable = file.getVariableDeclaration(placeOfUseName);
|
|
33
|
+
if (!variable) {
|
|
34
|
+
throw new Error(`Could not find the place where the form should be used (${placeOfUseName}).`);
|
|
35
|
+
}
|
|
36
|
+
return variable.getInitializerIfKind(ts_morph_1.SyntaxKind.FunctionExpression)
|
|
37
|
+
|| variable.getInitializerIfKind(ts_morph_1.SyntaxKind.ArrowFunction)
|
|
38
|
+
|| getForwardRefFunction(variable);
|
|
39
|
+
}
|
|
40
|
+
function addFormUsage(libPath, placeOfUseName, formClassName) {
|
|
41
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const project = new ts_morph_1.Project({
|
|
43
|
+
manipulationSettings: {
|
|
44
|
+
indentationText: ts_morph_1.IndentationText.TwoSpaces,
|
|
45
|
+
quoteKind: ts_morph_1.QuoteKind.Single
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
const files = project.addSourceFilesAtPaths([`${libPath}/lib/**/*.tsx`, `${libPath}/lib/**/*.ts`]);
|
|
49
|
+
const file = files.find((file) => file.getFunction(placeOfUseName) || file.getVariableDeclaration(placeOfUseName));
|
|
50
|
+
if (!file) {
|
|
51
|
+
throw new Error('Could not find the place where the form should be used.');
|
|
52
|
+
}
|
|
53
|
+
const pathToForm = file.getFilePath().includes('components')
|
|
54
|
+
? '../../forms'
|
|
55
|
+
: file.getFilePath().includes('hooks')
|
|
56
|
+
? '../forms'
|
|
57
|
+
: './forms';
|
|
58
|
+
(0, utils_1.addNamedImport)(formClassName, pathToForm, file);
|
|
59
|
+
(0, utils_1.addNamedImport)('useForm', 'react-hook-form', file);
|
|
60
|
+
(0, utils_1.addNamedImport)('yupResolver', '@hookform/resolvers/yup', file);
|
|
61
|
+
const placeOfUse = getPlaceOfUse(file, placeOfUseName);
|
|
62
|
+
placeOfUse.setBodyText(`${getFormUsageCode(formClassName)}${placeOfUse.getBodyText()}`);
|
|
63
|
+
project.saveSync();
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
exports.addFormUsage = addFormUsage;
|
|
67
|
+
//# sourceMappingURL=add-form-usage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-form-usage.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/form/utils/add-form-usage.ts"],"names":[],"mappings":";;;;AAAA,uCAUkB;AAClB,iDAAuD;AAEvD,SAAS,gBAAgB,CAAC,aAAqB;IAC7C,OAAO,0BAA0B,aAAa;;;0BAGtB,aAAa;QAC/B,CAAA;AACR,CAAC;AAED,SAAS,qBAAqB,CAAC,QAA6B;IAC1D,MAAM,yBAAyB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,qBAAU,CAAC,cAAc,CAAC,CAAC;IAC3F,MAAM,aAAa,GAAG,CAAA,yBAAyB,aAAzB,yBAAyB,uBAAzB,yBAAyB,CAAE,aAAa,GAAG,OAAO,EAAE,MAAK,YAAY,CAAA;IAC3F,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,QAAQ,GAAG,yBAAyB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,MAAM,oBAAoB,GAAG,QAAQ,IAAI,CAAC,qBAAU,CAAC,kBAAkB,EAAE,qBAAU,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAA;IAC/H,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,qBAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAU,CAAC,aAAa,CAAC,CAAC;AAC1I,CAAC;AAED,SAAS,aAAa,CAAC,IAAgB,EAAE,cAAsB;IAC7D,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAC5D,IAAI,kBAAkB,EAAE,CAAC;QACvB,OAAO,kBAAkB,CAAC;IAC5B,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;IAC7D,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,2DAA2D,cAAc,IAAI,CAAC,CAAC;IACjG,CAAC;IAED,OAAO,QAAQ,CAAC,oBAAoB,CAAC,qBAAU,CAAC,kBAAkB,CAAC;WAC9D,QAAQ,CAAC,oBAAoB,CAAC,qBAAU,CAAC,aAAa,CAAC;WACvD,qBAAqB,CAAC,QAAQ,CAAC,CAAC;AACvC,CAAC;AAED,SAAsB,YAAY,CAAC,OAAe,EAAE,cAAsB,EAAE,aAAqB;;QAC/F,MAAM,OAAO,GAAG,IAAI,kBAAO,CAAC;YAC1B,oBAAoB,EAAE;gBACpB,eAAe,EAAE,0BAAe,CAAC,SAAS;gBAC1C,SAAS,EAAE,oBAAS,CAAC,MAAM;aAC5B;SACF,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC,GAAG,OAAO,eAAe,EAAE,GAAG,OAAO,cAAc,CAAC,CAAC,CAAC;QACnG,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC,CAAC;QACnH,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;QAC7E,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;YAC1D,CAAC,CAAC,aAAa;YACf,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACpC,CAAC,CAAC,UAAU;gBACZ,CAAC,CAAC,SAAS,CAAC;QAChB,IAAA,sBAAc,EAAC,aAAa,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;QAChD,IAAA,sBAAc,EAAC,SAAS,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;QACnD,IAAA,sBAAc,EAAC,aAAa,EAAE,yBAAyB,EAAE,IAAI,CAAC,CAAC;QAE/D,MAAM,UAAU,GAAG,aAAa,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QACvD,UAAU,CAAC,WAAW,CAAC,GAAG,gBAAgB,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QAExF,OAAO,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;CAAA;AA1BD,oCA0BC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getFormUtilsDirectory(): Promise<string>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getFormUtilsDirectory = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const utils_1 = require("../../../shared/utils");
|
|
6
|
+
function getFormUtilsDirectory() {
|
|
7
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
8
|
+
const { default: autocomplete } = yield (0, utils_1.dynamicImport)('inquirer-autocomplete-standalone');
|
|
9
|
+
const utilsLibsPaths = (0, utils_1.getNxLibsPaths)([utils_1.LibraryType.UTILS]);
|
|
10
|
+
const formUtilsLibsPaths = (0, utils_1.searchNxLibsPaths)(utilsLibsPaths, 'utils/form/src', 'endsWith');
|
|
11
|
+
if (!formUtilsLibsPaths.length) {
|
|
12
|
+
throw new Error('Could not find a library with the form utilities.');
|
|
13
|
+
}
|
|
14
|
+
if (formUtilsLibsPaths.length > 1) {
|
|
15
|
+
formUtilsLibsPaths[0] = yield autocomplete({
|
|
16
|
+
message: 'Select the path of the library with the form utilities: ',
|
|
17
|
+
source: (input) => (0, utils_1.filterSource)(input, formUtilsLibsPaths)
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
return (0, utils_1.searchAliasPath)(formUtilsLibsPaths[0]);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
exports.getFormUtilsDirectory = getFormUtilsDirectory;
|
|
24
|
+
//# sourceMappingURL=get-form-utils-directory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-form-utils-directory.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/form/utils/get-form-utils-directory.ts"],"names":[],"mappings":";;;;AAAA,iDAO+B;AAE/B,SAAsB,qBAAqB;;QACzC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,qBAAa,EAAoD,kCAAkC,CAAC,CAAC;QAE7I,MAAM,cAAc,GAAG,IAAA,sBAAc,EAAC,CAAC,mBAAW,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3D,MAAM,kBAAkB,GAAG,IAAA,yBAAiB,EAAC,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;QAE3F,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,kBAAkB,CAAC,CAAC,CAAC,GAAG,MAAM,YAAY,CAAC;gBACzC,OAAO,EAAE,0DAA0D;gBACnE,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAA,oBAAY,EAAC,KAAK,EAAE,kBAAkB,CAAC;aAC3D,CAAC,CAAC;QACL,CAAC;QAED,OAAO,IAAA,uBAAe,EAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;CAAA;AAlBD,sDAkBC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./get-form-utils-directory"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./update-index"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./add-form-usage"), exports);
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/form/utils/index.ts"],"names":[],"mappings":";;;AAAA,qEAA2C;AAC3C,yDAA+B;AAC/B,2DAAiC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.updateIndex = void 0;
|
|
4
|
+
const lodash_1 = require("lodash");
|
|
5
|
+
const fs_1 = require("fs");
|
|
6
|
+
const utils_1 = require("../../../shared/utils");
|
|
7
|
+
function updateIndex(formsPath, fileName, tree) {
|
|
8
|
+
const formsIndexFilePath = `${formsPath}/index.ts`;
|
|
9
|
+
const newIndexContent = `export * from './${(0, lodash_1.kebabCase)(fileName)}';\n`;
|
|
10
|
+
if (!(0, fs_1.existsSync)(formsIndexFilePath)) {
|
|
11
|
+
tree.write(formsIndexFilePath, newIndexContent);
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
(0, utils_1.appendFileContent)(formsIndexFilePath, newIndexContent, tree);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.updateIndex = updateIndex;
|
|
18
|
+
//# sourceMappingURL=update-index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update-index.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/form/utils/update-index.ts"],"names":[],"mappings":";;;AACA,mCAAmC;AACnC,2BAAgC;AAChC,iDAA0D;AAE1D,SAAgB,WAAW,CAAC,SAAiB,EAAE,QAAgB,EAAE,IAAU;IACzE,MAAM,kBAAkB,GAAG,GAAG,SAAS,WAAW,CAAC;IACnD,MAAM,eAAe,GAAG,oBAAoB,IAAA,kBAAS,EAAC,QAAQ,CAAC,MAAM,CAAC;IACtE,IAAI,CAAC,IAAA,eAAU,EAAC,kBAAkB,CAAC,EAAE,CAAC;QACpC,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;IAClD,CAAC;SAAM,CAAC;QACN,IAAA,yBAAiB,EAAC,kBAAkB,EAAE,eAAe,EAAE,IAAI,CAAC,CAAC;IAC/D,CAAC;AACH,CAAC;AARD,kCAQC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.libTagsGenerator = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const devkit_1 = require("@nx/devkit");
|
|
6
|
+
const child_process_1 = require("child_process");
|
|
7
|
+
const utils_1 = require("../../shared/utils");
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const utils_2 = require("./utils");
|
|
10
|
+
const context = {
|
|
11
|
+
config: {},
|
|
12
|
+
rules: [],
|
|
13
|
+
log: console.log
|
|
14
|
+
};
|
|
15
|
+
function libTagsGenerator(tree, options) {
|
|
16
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
17
|
+
const hasUnstagedChanges = (0, child_process_1.execSync)('git status -s').toString('utf8');
|
|
18
|
+
if (hasUnstagedChanges) {
|
|
19
|
+
const shouldContinue = (yield (0, utils_1.askQuestion)('You have unstaged changes. Are you sure you want to continue? (y/n): ')) === 'y';
|
|
20
|
+
if (!shouldContinue) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
if (options.silent) {
|
|
25
|
+
context.log = lodash_1.noop;
|
|
26
|
+
}
|
|
27
|
+
// #1 Check eslint config nx-boundaries rule
|
|
28
|
+
devkit_1.output.log({ title: devkit_1.output.bold('1. Checking eslint config nx-boundaries rule...') });
|
|
29
|
+
context.config = (0, utils_1.verifyEsLintConfig)(tree);
|
|
30
|
+
// #2 Check projects tags
|
|
31
|
+
devkit_1.output.log({ title: devkit_1.output.bold('2. Checking projects tags...') });
|
|
32
|
+
const projects = (0, devkit_1.getProjects)(tree);
|
|
33
|
+
const applications = [];
|
|
34
|
+
const libraries = [];
|
|
35
|
+
context.rules = (0, utils_1.getNxRules)(context.config);
|
|
36
|
+
projects.forEach((project) => {
|
|
37
|
+
if (project.projectType === 'application') {
|
|
38
|
+
applications.push(project);
|
|
39
|
+
}
|
|
40
|
+
if (project.projectType === 'library' && project.root.startsWith('libs')) {
|
|
41
|
+
libraries.push(project);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
applications.forEach((application) => (0, utils_2.checkApplicationTags)(application, tree, context));
|
|
45
|
+
context.config = (0, utils_1.readESLintConfig)(tree).config;
|
|
46
|
+
context.rules = (0, utils_1.getNxRules)(context.config);
|
|
47
|
+
libraries.forEach((library) => (0, utils_2.checkLibraryTags)(library, tree, context));
|
|
48
|
+
yield (0, devkit_1.formatFiles)(tree);
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
exports.libTagsGenerator = libTagsGenerator;
|
|
52
|
+
exports.default = libTagsGenerator;
|
|
53
|
+
//# sourceMappingURL=generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/lib-tags/generator.ts"],"names":[],"mappings":";;;;AAAA,uCAA0F;AAE1F,iDAAyC;AACzC,8CAAmG;AACnG,mCAA8B;AAC9B,mCAAiE;AAGjE,MAAM,OAAO,GAAmB;IAC9B,MAAM,EAAE,EAAE;IACV,KAAK,EAAE,EAAE;IACT,GAAG,EAAE,OAAO,CAAC,GAAG;CACjB,CAAC;AAEF,SAAsB,gBAAgB,CACpC,IAAU,EACV,OAA+B;;QAE/B,MAAM,kBAAkB,GAAG,IAAA,wBAAQ,EAAC,eAAe,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAEtE,IAAI,kBAAkB,EAAE,CAAC;YACvB,MAAM,cAAc,GAAG,CAAA,MAAM,IAAA,mBAAW,EAAC,uEAAuE,CAAC,MAAK,GAAG,CAAC;YAE1H,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,OAAO;YACT,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,GAAG,GAAG,aAAI,CAAC;QACrB,CAAC;QAED,4CAA4C;QAC5C,eAAM,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,eAAM,CAAC,IAAI,CAAC,iDAAiD,CAAC,EAAE,CAAC,CAAC;QACtF,OAAO,CAAC,MAAM,GAAG,IAAA,0BAAkB,EAAC,IAAI,CAAC,CAAC;QAE1C,yBAAyB;QACzB,eAAM,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,eAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC;QACnE,MAAM,QAAQ,GAAG,IAAA,oBAAW,EAAC,IAAI,CAAC,CAAC;QACnC,MAAM,YAAY,GAAgC,EAAE,CAAC;QACrD,MAAM,SAAS,GAAgC,EAAE,CAAC;QAElD,OAAO,CAAC,KAAK,GAAG,IAAA,kBAAU,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAE3C,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3B,IAAI,OAAO,CAAC,WAAW,KAAK,aAAa,EAAE,CAAC;gBAC1C,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC7B,CAAC;YAED,IAAI,OAAO,CAAC,WAAW,KAAK,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzE,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,YAAY,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAA,4BAAoB,EAAC,WAAW,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;QAExF,OAAO,CAAC,MAAM,GAAG,IAAA,wBAAgB,EAAC,IAAI,CAAC,CAAC,MAAM,CAAC;QAC/C,OAAO,CAAC,KAAK,GAAG,IAAA,kBAAU,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAE3C,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAA,wBAAgB,EAAC,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;QAEzE,MAAM,IAAA,oBAAW,EAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;CAAA;AAhDD,4CAgDC;AAED,kBAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/lib-tags/interfaces/context.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './context';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/lib-tags/interfaces/index.ts"],"names":[],"mappings":";;;AAAA,oDAA0B"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { ProjectConfiguration, Tree } from '@nx/devkit';
|
|
2
|
+
import { LibTagsContext } from '../interfaces';
|
|
3
|
+
export declare const checkApplicationTags: (project: ProjectConfiguration, tree: Tree, context: LibTagsContext) => void;
|
|
4
|
+
export declare const checkLibraryTags: (project: ProjectConfiguration, tree: Tree, context: LibTagsContext) => void;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.checkLibraryTags = exports.checkApplicationTags = void 0;
|
|
4
|
+
const devkit_1 = require("@nx/devkit");
|
|
5
|
+
const utils_1 = require("../../../shared/utils");
|
|
6
|
+
const getTagFromLibPath = (libPath, type) => {
|
|
7
|
+
const projectAppTag = libPath.split('/')[1];
|
|
8
|
+
switch (type) {
|
|
9
|
+
case 'app':
|
|
10
|
+
return projectAppTag;
|
|
11
|
+
case 'scope':
|
|
12
|
+
return projectAppTag === utils_1.constants.sharedValue ? utils_1.constants.sharedValue : libPath.split('/')[2];
|
|
13
|
+
case 'type':
|
|
14
|
+
return projectAppTag === utils_1.constants.sharedValue ? libPath.split('/')[2] : libPath.split('/')[3];
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
const verifyLibraryTag = (project, tree, tag, tagType, context, ruleNotFoundCallback) => {
|
|
18
|
+
const defaultRuleNotFoundCallback = () => {
|
|
19
|
+
throw new Error(`Missing ${tagType} tag rule for ${tag}. Please add it to the ESLint config file.`);
|
|
20
|
+
};
|
|
21
|
+
if (tag) {
|
|
22
|
+
const tagRule = context.rules.find((rule) => rule.sourceTag === tag);
|
|
23
|
+
if (!tagRule) {
|
|
24
|
+
const callback = ruleNotFoundCallback || defaultRuleNotFoundCallback;
|
|
25
|
+
callback();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
context.log(`Missing ${tagType} tag for ${project.name}. Adding...`);
|
|
30
|
+
project = (0, devkit_1.readProjectConfiguration)(tree, project.name);
|
|
31
|
+
const tag = getTagFromLibPath(project.root, tagType);
|
|
32
|
+
if (tagType === 'type') {
|
|
33
|
+
const typeTagRule = context.rules.find((rule) => rule.sourceTag === `type:${tag}`);
|
|
34
|
+
if (!typeTagRule) {
|
|
35
|
+
throw new Error(`Missing type tag rule for ${tag}. Please add it to the ESLint config file.`);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
(0, devkit_1.updateProjectConfiguration)(tree, project.name, Object.assign(Object.assign({}, project), { tags: [...project.tags, `${tagType}:${tag}`] }));
|
|
39
|
+
if (tagType === 'scope') {
|
|
40
|
+
(0, utils_1.addNxScopeTag)(tree, tag);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const checkApplicationTags = (project, tree, context) => {
|
|
45
|
+
const { tags } = project;
|
|
46
|
+
const appTag = tags.find((tag) => tag.startsWith('app:'));
|
|
47
|
+
const hasTypeTag = tags.includes('type:app');
|
|
48
|
+
if (appTag) {
|
|
49
|
+
const appTagRule = context.rules.find((rule) => rule.sourceTag === appTag);
|
|
50
|
+
if (!appTagRule) {
|
|
51
|
+
context.log(`Missing app tag rule for ${appTag}. Adding...\n`);
|
|
52
|
+
(0, utils_1.addNxAppTag)(tree, appTag.replace('app:', ''));
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
context.log(`Missing app tag for ${project.name}. Adding...`);
|
|
57
|
+
const projectAppTag = project.root.split('/').pop();
|
|
58
|
+
(0, devkit_1.updateProjectConfiguration)(tree, project.name, Object.assign(Object.assign({}, project), { tags: [...project.tags, `app:${projectAppTag}`] }));
|
|
59
|
+
(0, utils_1.addNxAppTag)(tree, projectAppTag);
|
|
60
|
+
}
|
|
61
|
+
if (!hasTypeTag) {
|
|
62
|
+
context.log(`Missing type tag for ${project.name}. Adding...`);
|
|
63
|
+
project = (0, devkit_1.readProjectConfiguration)(tree, project.name);
|
|
64
|
+
(0, devkit_1.updateProjectConfiguration)(tree, project.name, Object.assign(Object.assign({}, project), { tags: [...project.tags, 'type:app'] }));
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
exports.checkApplicationTags = checkApplicationTags;
|
|
68
|
+
const checkLibraryTags = (project, tree, context) => {
|
|
69
|
+
const { tags } = project;
|
|
70
|
+
const appTag = tags.find((tag) => tag.startsWith('app:'));
|
|
71
|
+
const scopeTag = tags.find((tag) => tag.startsWith('scope:'));
|
|
72
|
+
const typeTag = tags.find((tag) => tag.startsWith('type:'));
|
|
73
|
+
verifyLibraryTag(project, tree, appTag, 'app', context);
|
|
74
|
+
verifyLibraryTag(project, tree, scopeTag, 'scope', context, () => {
|
|
75
|
+
context.log(`Missing scope tag rule for ${scopeTag}. Adding...`);
|
|
76
|
+
(0, utils_1.addNxScopeTag)(tree, scopeTag.replace('scope:', ''));
|
|
77
|
+
});
|
|
78
|
+
verifyLibraryTag(project, tree, typeTag, 'type', context);
|
|
79
|
+
};
|
|
80
|
+
exports.checkLibraryTags = checkLibraryTags;
|
|
81
|
+
//# sourceMappingURL=check-lib-tags.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-lib-tags.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/lib-tags/utils/check-lib-tags.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './check-lib-tags';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../plugin/src/generators/lib-tags/utils/index.ts"],"names":[],"mappings":";;;AAAA,2DAAiC"}
|
|
@@ -20,7 +20,7 @@ function reactLibGenerator(tree, options) {
|
|
|
20
20
|
options.app = options.app || (yield autocomplete({
|
|
21
21
|
message: 'Select the application: ',
|
|
22
22
|
source: (input) => tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const entries = [...projects, { name:
|
|
23
|
+
const entries = [...projects, { name: utils_1.constants.sharedValue, path: utils_1.constants.sharedValue }].map((project) => ({
|
|
24
24
|
name: `${project.name} (${project.path})`,
|
|
25
25
|
value: project.path.replace('apps/', '')
|
|
26
26
|
}));
|
|
@@ -30,8 +30,8 @@ function reactLibGenerator(tree, options) {
|
|
|
30
30
|
return entries.filter((entry) => entry.name.toLowerCase().includes(input.toLowerCase()));
|
|
31
31
|
})
|
|
32
32
|
}));
|
|
33
|
-
const isSharedLib = options.app ===
|
|
34
|
-
options.scope = options.scope || (isSharedLib ? '' : yield (0, utils_1.askQuestion)(
|
|
33
|
+
const isSharedLib = options.app === utils_1.constants.sharedValue;
|
|
34
|
+
options.scope = options.scope || (isSharedLib ? '' : yield (0, utils_1.askQuestion)(`Enter the scope (e.g: profile) or '${utils_1.constants.sharedValue}': `));
|
|
35
35
|
options.type = options.type || (yield autocomplete({
|
|
36
36
|
message: 'Select the library type: ',
|
|
37
37
|
source: (input) => (0, utils_1.filterSource)(input, Object.values(utils_1.LibraryType))
|
|
@@ -40,7 +40,7 @@ function reactLibGenerator(tree, options) {
|
|
|
40
40
|
if ([utils_1.LibraryType.FEATURES, utils_1.LibraryType.UI].includes(options.type) && !(0, lodash_1.isBoolean)(options.withComponent)) {
|
|
41
41
|
options.withComponent = (yield (0, utils_1.askQuestion)('Generate component inside lib folder? (y/n): ')) === 'y';
|
|
42
42
|
}
|
|
43
|
-
const scopeTag = options.scope ||
|
|
43
|
+
const scopeTag = options.scope || utils_1.constants.sharedValue;
|
|
44
44
|
const tags = [`app:${options.app}`, `scope:${scopeTag}`, `type:${options.type}`];
|
|
45
45
|
const libPath = path.normalize(`libs/${options.app}/${options.scope}/${options.type}/${options.name}`);
|
|
46
46
|
const command = `npx nx g @nx/expo:lib --skipPackageJson --unitTestRunner=none --tags="${tags.join(', ')}" --projectNameAndRootFormat=derived ${libPath}`;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/react-lib/generator.ts"],"names":[],"mappings":";;;;AAAA,uCAA2E;AAC3E,6BAA6B;AAE7B,iDAAyC;AACzC,
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../plugin/src/generators/react-lib/generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,7 +10,7 @@ export type AppState = AppStateFromRootReducer<typeof rootReducer>;
|
|
|
10
10
|
|
|
11
11
|
const rootReducer = {};
|
|
12
12
|
|
|
13
|
-
const middlewares = []
|
|
13
|
+
const middlewares: Array<Middleware> = [];
|
|
14
14
|
|
|
15
15
|
const reactotron = setupReactotron('my-app');
|
|
16
16
|
const enhancers = reactotron ? [reactotron.createEnhancer()] : [];
|
|
@@ -8,7 +8,7 @@ export type AppState = AppStateFromRootReducer<typeof rootReducer>;
|
|
|
8
8
|
|
|
9
9
|
const rootReducer = {};
|
|
10
10
|
|
|
11
|
-
const middlewares = []
|
|
11
|
+
const middlewares: Array<Middleware> = [];
|
|
12
12
|
|
|
13
13
|
const initStore = createStoreInitializer({
|
|
14
14
|
rootReducer: rootReducer as unknown as Reducer<AppState>,
|
|
@@ -55,13 +55,15 @@ const searchAliasPath = (input) => {
|
|
|
55
55
|
};
|
|
56
56
|
exports.searchAliasPath = searchAliasPath;
|
|
57
57
|
const filterSource = (input, source) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
58
|
-
const filteredData = input
|
|
58
|
+
const filteredData = input
|
|
59
|
+
? source.filter((pathname) => pathname.toLowerCase().includes(input.toLowerCase()))
|
|
60
|
+
: source;
|
|
59
61
|
return filteredData.map((path) => ({ value: path }));
|
|
60
62
|
});
|
|
61
63
|
exports.filterSource = filterSource;
|
|
62
64
|
const appendFileContent = (path, endContent, tree) => {
|
|
63
65
|
const content = tree.read(path, 'utf-8');
|
|
64
|
-
const contentUpdate = content + endContent;
|
|
66
|
+
const contentUpdate = (content || '') + endContent;
|
|
65
67
|
tree.write(path, contentUpdate);
|
|
66
68
|
};
|
|
67
69
|
exports.appendFileContent = appendFileContent;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli-utils.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/cli-utils.ts"],"names":[],"mappings":";;;;AAAA,qCAAqC;AACrC,yBAAyB;AAGlB,MAAM,WAAW,GAAG,CAAC,QAAgB,EAAE,aAAsB,EAAmB,EAAE;IACvF,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC;QAClC,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,MAAM,EAAE,OAAO,CAAC,MAAM;KACvB,CAAC,CAAC;IAEH,IAAI,aAAa,EAAE,CAAC;QAClB,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACxB,iCAAiC;QACjC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAC7B,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;QAC/B,EAAE,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,CAAC,MAAM,CAAC,CAAC;IAClB,CAAC,CAAC,CACH,CAAC;AACJ,CAAC,CAAC;AAlBW,QAAA,WAAW,eAkBtB;AAEF,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,wBAAS,CAAA;IACT,0CAA2B,CAAA;IAC3B,oCAAqB,CAAA;IACrB,8BAAe,CAAA;AACjB,CAAC,EALW,WAAW,2BAAX,WAAW,QAKtB;AAED,MAAM,cAAc,GAAG,GAAG,EAAE;IAC1B,IAAI,QAAQ,CAAC;IAEb,IAAI,EAAE,CAAC,UAAU,CAAC,oBAAoB,CAAC,EAAE,CAAC;QACxC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC,CAAC;IACvE,CAAC;SAAM,CAAC;QACN,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,OAAO,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC;AACxC,CAAC,
|
|
1
|
+
{"version":3,"file":"cli-utils.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/cli-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,19 @@
|
|
|
1
1
|
import { Tree } from '@nx/devkit';
|
|
2
|
+
export interface Constraint {
|
|
3
|
+
sourceTag: string;
|
|
4
|
+
onlyDependOnLibsWithTags: Array<string>;
|
|
5
|
+
}
|
|
6
|
+
export declare const getNxRulesEntry: (config: Record<string, any>) => {
|
|
7
|
+
files: Array<string>;
|
|
8
|
+
rules: Record<string, any>;
|
|
9
|
+
};
|
|
10
|
+
export declare const getNxRulesStatus: (config: Record<string, any>) => string;
|
|
11
|
+
export declare const getNxRules: (config: Record<string, any>) => Array<Constraint>;
|
|
12
|
+
export declare const readESLintConfig: (tree: Tree) => {
|
|
13
|
+
config: Record<string, any>;
|
|
14
|
+
path: string;
|
|
15
|
+
};
|
|
2
16
|
export declare const addNxAppTag: (tree: Tree, appDirectory: string) => void;
|
|
3
17
|
export declare const addNxScopeTag: (tree: Tree, scope: string) => void;
|
|
4
18
|
export declare const getImportPathPrefix: (tree: Tree) => string;
|
|
19
|
+
export declare const verifyEsLintConfig: (tree: Tree) => Record<string, any>;
|
|
@@ -1,22 +1,47 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getImportPathPrefix = exports.addNxScopeTag = exports.addNxAppTag = void 0;
|
|
3
|
+
exports.verifyEsLintConfig = exports.getImportPathPrefix = exports.addNxScopeTag = exports.addNxAppTag = exports.readESLintConfig = exports.getNxRules = exports.getNxRulesStatus = exports.getNxRulesEntry = void 0;
|
|
4
4
|
const devkit_1 = require("@nx/devkit");
|
|
5
|
-
const
|
|
6
|
-
const
|
|
5
|
+
const lodash_1 = require("lodash");
|
|
6
|
+
const defaultEsLintConfigPath = '.eslintrc.json';
|
|
7
|
+
const getNxRulesEntry = (config) => {
|
|
7
8
|
var _a;
|
|
8
9
|
if (!config) {
|
|
9
10
|
throw new Error('ESLint config not found');
|
|
10
11
|
}
|
|
11
12
|
const entryWithRules = (_a = config.overrides) === null || _a === void 0 ? void 0 : _a.find((entry) => !!entry.rules['@nx/enforce-module-boundaries']);
|
|
12
13
|
if (!entryWithRules) {
|
|
13
|
-
throw new Error(`ESLint: can't find '@nx/enforce-module-boundaries' rule
|
|
14
|
+
throw new Error(`ESLint: can't find '@nx/enforce-module-boundaries' rule`);
|
|
14
15
|
}
|
|
15
|
-
return entryWithRules
|
|
16
|
+
return entryWithRules;
|
|
17
|
+
};
|
|
18
|
+
exports.getNxRulesEntry = getNxRulesEntry;
|
|
19
|
+
const getNxRulesStatus = (config) => {
|
|
20
|
+
return (0, exports.getNxRulesEntry)(config).rules['@nx/enforce-module-boundaries'][0];
|
|
21
|
+
};
|
|
22
|
+
exports.getNxRulesStatus = getNxRulesStatus;
|
|
23
|
+
const getNxRules = (config) => {
|
|
24
|
+
return (0, exports.getNxRulesEntry)(config).rules['@nx/enforce-module-boundaries'][1].depConstraints;
|
|
16
25
|
};
|
|
26
|
+
exports.getNxRules = getNxRules;
|
|
17
27
|
const readESLintConfig = (tree) => {
|
|
18
|
-
|
|
28
|
+
var _a;
|
|
29
|
+
let path = defaultEsLintConfigPath;
|
|
30
|
+
const checkConfigExists = (path) => {
|
|
31
|
+
if (!tree.exists(path)) {
|
|
32
|
+
throw new Error(`ESLint config not found: ${path}`);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
checkConfigExists(path);
|
|
36
|
+
let config = (0, devkit_1.readJson)(tree, path);
|
|
37
|
+
if ((_a = config.extends) === null || _a === void 0 ? void 0 : _a.length) {
|
|
38
|
+
path = config.extends[0];
|
|
39
|
+
checkConfigExists(path);
|
|
40
|
+
config = (0, devkit_1.readJson)(tree, config.extends[0]);
|
|
41
|
+
}
|
|
42
|
+
return { config, path };
|
|
19
43
|
};
|
|
44
|
+
exports.readESLintConfig = readESLintConfig;
|
|
20
45
|
const getNpmScope = (tree) => {
|
|
21
46
|
const { name } = tree.exists('package.json')
|
|
22
47
|
? (0, devkit_1.readJson)(tree, 'package.json')
|
|
@@ -24,21 +49,25 @@ const getNpmScope = (tree) => {
|
|
|
24
49
|
return (name === null || name === void 0 ? void 0 : name.startsWith('@')) ? name.split('/')[0].substring(1) : undefined;
|
|
25
50
|
};
|
|
26
51
|
const addNxAppTag = (tree, appDirectory) => {
|
|
27
|
-
const config = readESLintConfig(tree);
|
|
28
|
-
const constraints = getNxRules(config);
|
|
52
|
+
const { config, path } = (0, exports.readESLintConfig)(tree);
|
|
53
|
+
const constraints = (0, exports.getNxRules)(config);
|
|
54
|
+
const doesTagExist = !!constraints.find((constraint) => constraint.sourceTag === `app:${appDirectory}`);
|
|
55
|
+
if (doesTagExist) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
29
58
|
constraints.push({ sourceTag: `app:${appDirectory}`, onlyDependOnLibsWithTags: [`app:${appDirectory}`, 'app:shared'] });
|
|
30
|
-
(0, devkit_1.writeJson)(tree,
|
|
59
|
+
(0, devkit_1.writeJson)(tree, path, config);
|
|
31
60
|
};
|
|
32
61
|
exports.addNxAppTag = addNxAppTag;
|
|
33
62
|
const addNxScopeTag = (tree, scope) => {
|
|
34
|
-
const config = readESLintConfig(tree);
|
|
35
|
-
const constraints = getNxRules(config);
|
|
36
|
-
const
|
|
37
|
-
if (
|
|
63
|
+
const { config, path } = (0, exports.readESLintConfig)(tree);
|
|
64
|
+
const constraints = (0, exports.getNxRules)(config);
|
|
65
|
+
const doesTagExist = !!constraints.find((constraint) => constraint.sourceTag === `scope:${scope}`);
|
|
66
|
+
if (doesTagExist) {
|
|
38
67
|
return;
|
|
39
68
|
}
|
|
40
69
|
constraints.push({ sourceTag: `scope:${scope}`, onlyDependOnLibsWithTags: [`scope:${scope}`, 'scope:shared'] });
|
|
41
|
-
(0, devkit_1.writeJson)(tree,
|
|
70
|
+
(0, devkit_1.writeJson)(tree, path, config);
|
|
42
71
|
};
|
|
43
72
|
exports.addNxScopeTag = addNxScopeTag;
|
|
44
73
|
const getImportPathPrefix = (tree) => {
|
|
@@ -46,4 +75,36 @@ const getImportPathPrefix = (tree) => {
|
|
|
46
75
|
return npmScope ? `${npmScope === '@' ? '' : '@'}${npmScope}` : '';
|
|
47
76
|
};
|
|
48
77
|
exports.getImportPathPrefix = getImportPathPrefix;
|
|
78
|
+
const verifyEsLintConfig = (tree) => {
|
|
79
|
+
const { config, path } = (0, exports.readESLintConfig)(tree);
|
|
80
|
+
const importantTags = ['app:shared', 'scope:shared', 'type:app', 'type:data-access', 'type:features', 'type:ui', 'type:utils'];
|
|
81
|
+
if (!config || (0, lodash_1.isEmpty)(config)) {
|
|
82
|
+
throw new Error(`Failed to load ESLint config: ${path}`);
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
const rulesEntry = (0, exports.getNxRulesEntry)(config).rules['@nx/enforce-module-boundaries'];
|
|
86
|
+
const tags = rulesEntry[1].depConstraints.map((rule) => rule.sourceTag);
|
|
87
|
+
const areRulesDisabled = rulesEntry[1].depConstraints.find((rule) => rule.sourceTag === '*' && rule.onlyDependOnLibsWithTags.includes('*'));
|
|
88
|
+
const areRulesBroken = !importantTags.every((tag) => tags.includes(tag));
|
|
89
|
+
if (rulesEntry[0] !== 'error') {
|
|
90
|
+
rulesEntry[0] = 'error';
|
|
91
|
+
}
|
|
92
|
+
if (areRulesDisabled || areRulesBroken) {
|
|
93
|
+
const esLintConfigTemplate = (0, devkit_1.readJson)(tree, 'plugin/src/generators/code-checks/files/.eslintrc.json.template');
|
|
94
|
+
const templateRules = (0, exports.getNxRulesEntry)(esLintConfigTemplate);
|
|
95
|
+
rulesEntry[1] = templateRules.rules['@nx/enforce-module-boundaries'][1];
|
|
96
|
+
(0, devkit_1.writeJson)(tree, path, config);
|
|
97
|
+
}
|
|
98
|
+
// TODO: use custom errors
|
|
99
|
+
}
|
|
100
|
+
catch (_a) {
|
|
101
|
+
devkit_1.output.warn({ title: devkit_1.output.bold('ESLint config has no @nx/enforce-module-boundaries rule. Updating rules...') });
|
|
102
|
+
const esLintConfigTemplate = (0, devkit_1.readJson)(tree, 'plugin/src/generators/code-checks/files/.eslintrc.json.template');
|
|
103
|
+
const templateRules = (0, exports.getNxRulesEntry)(esLintConfigTemplate);
|
|
104
|
+
config.overrides.push(templateRules);
|
|
105
|
+
(0, devkit_1.writeJson)(tree, path, config);
|
|
106
|
+
}
|
|
107
|
+
return config;
|
|
108
|
+
};
|
|
109
|
+
exports.verifyEsLintConfig = verifyEsLintConfig;
|
|
49
110
|
//# sourceMappingURL=config-utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config-utils.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/config-utils.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"config-utils.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/config-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,SAAS,GAAG;IACvB,WAAW,EAAE,QAAQ;CACtB,CAAC"}
|
|
@@ -6,4 +6,5 @@ tslib_1.__exportStar(require("./cli-utils"), exports);
|
|
|
6
6
|
tslib_1.__exportStar(require("./dynamic-import"), exports);
|
|
7
7
|
tslib_1.__exportStar(require("./config-utils"), exports);
|
|
8
8
|
tslib_1.__exportStar(require("./ts-utils"), exports);
|
|
9
|
+
tslib_1.__exportStar(require("./constants"), exports);
|
|
9
10
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/index.ts"],"names":[],"mappings":";;;AAAA,yDAA+B;AAC/B,sDAA4B;AAC5B,2DAAiC;AACjC,yDAA+B;AAC/B,qDAA2B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../plugin/src/shared/utils/index.ts"],"names":[],"mappings":";;;AAAA,yDAA+B;AAC/B,sDAA4B;AAC5B,2DAAiC;AACjC,yDAA+B;AAC/B,qDAA2B;AAC3B,sDAA4B"}
|
|
File without changes
|
|
File without changes
|