@nx/angular 16.8.0-beta.4 → 16.8.0-beta.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.
- package/mf/mf.js +31 -36
- package/package.json +10 -10
- package/plugins/component-testing.js +48 -40
- package/src/builders/module-federation-dev-server/module-federation-dev-server.impl.js +4 -6
- package/src/builders/module-federation-dev-ssr/module-federation-dev-ssr.impl.js +4 -6
- package/src/builders/utilities/buildable-libs.js +1 -2
- package/src/builders/utilities/module-federation.js +2 -3
- package/src/builders/utilities/webpack.js +16 -21
- package/src/builders/webpack-browser/webpack-browser.impl.js +13 -13
- package/src/builders/webpack-dev-server/lib/normalize-options.js +8 -1
- package/src/builders/webpack-dev-server/webpack-dev-server.impl.js +24 -18
- package/src/builders/webpack-server/webpack-server.impl.js +5 -7
- package/src/executors/browser-esbuild/browser-esbuild.impl.js +19 -23
- package/src/executors/browser-esbuild/lib/buildable-libs.js +1 -2
- package/src/executors/delegate-build/delegate-build.impl.js +9 -12
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ng-package/entry-point/compile-ngc.transform.js +4 -7
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ng-package/entry-point/entry-point.transform.js +4 -5
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ng-package/entry-point/write-package.transform.js +158 -156
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ng-package/options.di.js +6 -3
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ngc/compile-source-files.js +118 -118
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/styles/stylesheet-processor.js +96 -103
- package/src/executors/ng-packagr-lite/ng-packagr-adjustments/ts/cache-compiler-host.js +20 -12
- package/src/executors/ng-packagr-lite/ng-packagr-lite.impl.js +18 -21
- package/src/executors/package/ng-packagr-adjustments/ng-package/entry-point/compile-ngc.transform.js +6 -9
- package/src/executors/package/ng-packagr-adjustments/ng-package/options.di.js +6 -3
- package/src/executors/package/ng-packagr-adjustments/ngc/compile-source-files.js +122 -122
- package/src/executors/package/ng-packagr-adjustments/styles/stylesheet-processor.js +96 -103
- package/src/executors/package/ng-packagr-adjustments/ts/cache-compiler-host.js +21 -13
- package/src/executors/package/ng-packagr-adjustments/utils/ng-compiler-cli.js +5 -8
- package/src/executors/package/package.impl.js +33 -38
- package/src/executors/utilities/angular-version-utils.js +1 -1
- package/src/executors/utilities/tailwindcss.js +2 -2
- package/src/executors/utilities/typescript.js +23 -28
- package/src/generators/add-linting/add-linting.js +76 -74
- package/src/generators/add-linting/lib/create-eslint-configuration.js +12 -4
- package/src/generators/application/application.js +56 -55
- package/src/generators/application/lib/add-e2e.js +36 -40
- package/src/generators/application/lib/add-linting.js +12 -15
- package/src/generators/application/lib/add-proxy-config.js +4 -1
- package/src/generators/application/lib/add-unit-test-runner.js +15 -18
- package/src/generators/application/lib/create-files.js +44 -47
- package/src/generators/application/lib/enable-strict-type-checking.js +2 -2
- package/src/generators/application/lib/normalize-options.js +37 -25
- package/src/generators/application/lib/set-app-strict-default.js +1 -2
- package/src/generators/application/lib/update-editor-tsconfig.js +1 -2
- package/src/generators/component/component.js +40 -43
- package/src/generators/component/lib/normalize-options.js +15 -5
- package/src/generators/component-cypress-spec/component-cypress-spec.js +25 -28
- package/src/generators/component-story/component-story.js +19 -22
- package/src/generators/convert-to-with-mf/convert-to-with-mf.js +19 -22
- package/src/generators/convert-to-with-mf/lib/get-webpack-config-path.js +3 -4
- package/src/generators/convert-tslint-to-eslint/convert-tslint-to-eslint.js +103 -106
- package/src/generators/cypress-component-configuration/cypress-component-configuration.js +59 -62
- package/src/generators/directive/directive.js +21 -24
- package/src/generators/directive/lib/normalize-options.js +11 -5
- package/src/generators/host/host.js +77 -67
- package/src/generators/host/lib/add-ssr.js +32 -35
- package/src/generators/init/init.js +101 -92
- package/src/generators/library/lib/add-standalone-component.js +18 -13
- package/src/generators/library/lib/enable-strict-type-checking.js +17 -5
- package/src/generators/library/lib/normalize-options.js +68 -53
- package/src/generators/library/library.js +89 -92
- package/src/generators/library-secondary-entry-point/lib/add-files.js +5 -1
- package/src/generators/library-secondary-entry-point/lib/normalize-options.js +6 -3
- package/src/generators/library-secondary-entry-point/lib/update-linting-file-patterns.js +1 -2
- package/src/generators/library-secondary-entry-point/library-secondary-entry-point.js +6 -9
- package/src/generators/move/lib/normalize-schema.js +5 -1
- package/src/generators/move/lib/update-module-name.js +1 -1
- package/src/generators/move/lib/update-ng-package.js +1 -2
- package/src/generators/move/lib/update-secondary-entry-points.js +1 -2
- package/src/generators/move/move.js +9 -12
- package/src/generators/ng-add/migrate-from-angular-cli.js +54 -53
- package/src/generators/ng-add/migrators/builders/angular-devkit-karma.migrator.js +4 -3
- package/src/generators/ng-add/migrators/builders/angular-devkit-ng-packagr.migrator.js +11 -12
- package/src/generators/ng-add/migrators/builders/angular-eslint-lint.migrator.js +39 -42
- package/src/generators/ng-add/migrators/builders/builder.migrator.js +1 -2
- package/src/generators/ng-add/migrators/migrator.js +7 -11
- package/src/generators/ng-add/migrators/projects/app.migrator.js +39 -43
- package/src/generators/ng-add/migrators/projects/e2e.migrator.js +115 -91
- package/src/generators/ng-add/migrators/projects/lib.migrator.js +23 -31
- package/src/generators/ng-add/migrators/projects/project.migrator.js +10 -14
- package/src/generators/ng-add/ng-add.js +5 -8
- package/src/generators/ng-add/utilities/dependencies.js +2 -3
- package/src/generators/ng-add/utilities/format-files-task.js +1 -1
- package/src/generators/ng-add/utilities/projects.js +1 -1
- package/src/generators/ng-add/utilities/workspace.js +25 -36
- package/src/generators/ngrx/lib/add-imports-to-module.js +1 -2
- package/src/generators/ngrx/lib/add-ngrx-to-package-json.js +1 -3
- package/src/generators/ngrx/lib/generate-files.js +11 -2
- package/src/generators/ngrx/lib/normalize-options.js +9 -4
- package/src/generators/ngrx/lib/validate-options.js +3 -3
- package/src/generators/ngrx/ngrx.js +18 -21
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.actions.ts__tmpl__ +1 -1
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.effects.spec.ts__tmpl__ +2 -2
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.effects.ts__tmpl__ +2 -2
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.facade.spec.ts__tmpl__ +6 -6
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.facade.ts__tmpl__ +3 -3
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.reducer.spec.ts__tmpl__ +3 -3
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.reducer.ts__tmpl__ +2 -2
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.selectors.spec.ts__tmpl__ +3 -3
- package/src/generators/ngrx-feature-store/files/base/__directory__/__fileName__.selectors.ts__tmpl__ +1 -1
- package/src/generators/ngrx-feature-store/files/no-inject/__directory__/__fileName__.effects.ts__tmpl__ +2 -2
- package/src/generators/ngrx-feature-store/files/no-inject/__directory__/__fileName__.facade.ts__tmpl__ +3 -3
- package/src/generators/ngrx-feature-store/lib/add-exports-barrel.js +4 -1
- package/src/generators/ngrx-feature-store/lib/add-imports.js +1 -1
- package/src/generators/ngrx-feature-store/lib/add-ngrx-to-package-json.js +1 -3
- package/src/generators/ngrx-feature-store/lib/generate-files.js +20 -4
- package/src/generators/ngrx-feature-store/lib/normalize-options.d.ts +1 -0
- package/src/generators/ngrx-feature-store/lib/normalize-options.js +22 -3
- package/src/generators/ngrx-feature-store/lib/validate-options.js +2 -2
- package/src/generators/ngrx-feature-store/ngrx-feature-store.js +18 -21
- package/src/generators/ngrx-root-store/lib/add-ngrx-to-package-json.js +8 -6
- package/src/generators/ngrx-root-store/lib/normalize-options.js +8 -4
- package/src/generators/ngrx-root-store/lib/validate-options.js +2 -2
- package/src/generators/ngrx-root-store/ngrx-root-store.js +27 -30
- package/src/generators/pipe/lib/normalize-options.js +9 -3
- package/src/generators/pipe/pipe.js +21 -24
- package/src/generators/remote/lib/add-ssr.js +46 -47
- package/src/generators/remote/lib/find-next-available-port.js +1 -2
- package/src/generators/remote/remote.js +52 -49
- package/src/generators/scam/lib/convert-component-to-scam.js +1 -2
- package/src/generators/scam/lib/normalize-options.js +11 -4
- package/src/generators/scam/scam.js +15 -12
- package/src/generators/scam-directive/lib/normalize-options.js +12 -4
- package/src/generators/scam-directive/scam-directive.js +13 -10
- package/src/generators/scam-pipe/lib/normalize-options.js +12 -4
- package/src/generators/scam-pipe/scam-pipe.js +13 -10
- package/src/generators/scam-to-standalone/scam-to-standalone.js +23 -26
- package/src/generators/setup-mf/lib/add-cypress-workaround.js +1 -1
- package/src/generators/setup-mf/lib/add-remote-to-host.js +4 -1
- package/src/generators/setup-mf/lib/change-build-target.js +10 -4
- package/src/generators/setup-mf/lib/generate-config.js +1 -1
- package/src/generators/setup-mf/lib/get-remotes-with-ports.js +1 -2
- package/src/generators/setup-mf/lib/normalize-options.js +5 -2
- package/src/generators/setup-mf/lib/set-tsconfig-target.js +7 -1
- package/src/generators/setup-mf/lib/setup-host-if-dynamic.js +1 -2
- package/src/generators/setup-mf/lib/setup-serve-target.js +10 -3
- package/src/generators/setup-mf/setup-mf.js +32 -35
- package/src/generators/setup-ssr/lib/generate-files.js +8 -5
- package/src/generators/setup-ssr/lib/normalize-options.js +9 -10
- package/src/generators/setup-ssr/lib/update-project-config.js +21 -17
- package/src/generators/setup-ssr/setup-ssr.js +26 -27
- package/src/generators/setup-tailwind/lib/add-tailwind-config-path-to-project.js +6 -4
- package/src/generators/setup-tailwind/lib/detect-tailwind-installed-version.js +1 -2
- package/src/generators/setup-tailwind/lib/normalize-options.js +4 -1
- package/src/generators/setup-tailwind/lib/update-application-styles.js +5 -6
- package/src/generators/setup-tailwind/setup-tailwind.js +20 -23
- package/src/generators/stories/lib/get-e2e-project.js +1 -1
- package/src/generators/stories/stories.js +43 -50
- package/src/generators/storybook-configuration/lib/assert-compatible-storybook-version.js +1 -1
- package/src/generators/storybook-configuration/lib/generate-stories.js +10 -13
- package/src/generators/storybook-configuration/lib/generate-storybook-configuration.js +12 -15
- package/src/generators/storybook-configuration/storybook-configuration.js +20 -16
- package/src/generators/utils/create-ts-config.js +1 -1
- package/src/generators/utils/entry-point.js +1 -2
- package/src/generators/utils/export-scam.js +1 -1
- package/src/generators/utils/insert-ngmodule-import.js +1 -1
- package/src/generators/utils/path.js +3 -3
- package/src/generators/utils/project.js +2 -3
- package/src/generators/utils/selector.js +1 -1
- package/src/generators/utils/storybook-ast/component-info.js +1 -2
- package/src/generators/utils/storybook-ast/entry-point.js +1 -2
- package/src/generators/utils/storybook-ast/module-info.js +1 -2
- package/src/generators/utils/storybook-ast/tree-utilities.js +1 -1
- package/src/generators/utils/testing.js +141 -139
- package/src/generators/utils/validations.js +1 -1
- package/src/generators/utils/version-utils.js +5 -7
- package/src/generators/web-worker/lib/normalize-options.js +6 -3
- package/src/generators/web-worker/web-worker.js +25 -28
- package/src/migrations/update-14-2-0/remove-show-circular-dependencies-option.js +10 -13
- package/src/migrations/update-14-2-0/update-angular-cli.js +14 -18
- package/src/migrations/update-14-2-0/update-libraries-secondary-entrypoints.js +22 -26
- package/src/migrations/update-14-2-0/update-ngcc-target.js +10 -14
- package/src/migrations/update-14-2-0/update-router-initial-navigation.js +31 -39
- package/src/migrations/update-14-2-0/update-tsconfig-target.js +48 -56
- package/src/migrations/update-14-5-0/migrate-mfe-to-mf.js +14 -17
- package/src/migrations/update-14-5-2/update-angular-cli.js +14 -18
- package/src/migrations/update-14-6-0/update-angular-cli.js +14 -18
- package/src/migrations/update-15-0-0/add-karma-inputs.js +27 -32
- package/src/migrations/update-15-0-0/switch-to-jasmine-marbles.js +62 -68
- package/src/migrations/update-15-2-0/remove-browserlist-config.js +34 -37
- package/src/migrations/update-15-2-0/remove-platform-server-exports.js +49 -52
- package/src/migrations/update-15-2-0/update-angular-cli.js +14 -18
- package/src/migrations/update-15-2-0/update-karma-main-file.js +11 -12
- package/src/migrations/update-15-2-0/update-typescript-target.js +40 -39
- package/src/migrations/update-15-2-0/update-workspace-config.js +16 -19
- package/src/migrations/update-15-5-0/update-angular-cli.js +14 -18
- package/src/migrations/update-15-7-0/install-required-packages.js +26 -28
- package/src/migrations/update-15-8-0/update-angular-cli.js +14 -18
- package/src/migrations/update-15-9-0/update-file-server-executor.js +31 -35
- package/src/migrations/update-15-9-0/update-testing-tsconfig.js +17 -22
- package/src/migrations/update-16-0-0/remove-karma-defaults.js +15 -18
- package/src/migrations/update-16-0-0/remove-library-generator-simple-module-name-option.js +22 -25
- package/src/migrations/update-16-0-0/remove-protractor-defaults.js +15 -18
- package/src/migrations/update-16-0-0-add-nx-packages/update-16-0-0-add-nx-packages.js +3 -6
- package/src/migrations/update-16-1-0/extract-standalone-config-from-bootstrap.js +38 -42
- package/src/migrations/update-16-1-0/remove-ngcc-invocation.js +15 -19
- package/src/migrations/update-16-1-0/remove-render-module-platform-server-exports.js +49 -52
- package/src/migrations/update-16-1-0/update-angular-cli.js +14 -18
- package/src/migrations/update-16-1-0/update-server-executor-config.js +13 -16
- package/src/migrations/update-16-2-0/switch-data-persistence-operators-imports-to-ngrx-router-store.js +25 -29
- package/src/migrations/update-16-4-0/rename-angular-eslint-accesibility-rules.js +13 -16
- package/src/migrations/update-16-4-0/update-angular-cli.js +14 -18
- package/src/migrations/update-16-6-0/explicitly-set-projects-to-update-buildable-deps.js +19 -24
- package/src/migrations/update-16-7-0/update-angular-cli.js +14 -18
- package/src/migrations/utils/projects.js +9 -15
- package/src/utils/get-mf-projects.js +1 -2
- package/src/utils/mf/utils.js +43 -44
- package/src/utils/mf/with-module-federation-ssr.js +39 -24
- package/src/utils/mf/with-module-federation.js +40 -21
- package/src/utils/nx-devkit/ast-utils.js +2 -3
- package/src/utils/version-utils.js +2 -4
|
@@ -5,9 +5,8 @@ const devkit_1 = require("@nx/devkit");
|
|
|
5
5
|
const semver_1 = require("@nx/devkit/src/utils/semver");
|
|
6
6
|
const semver_2 = require("semver");
|
|
7
7
|
function detectTailwindInstalledVersion(tree) {
|
|
8
|
-
var _a;
|
|
9
8
|
const { dependencies, devDependencies } = (0, devkit_1.readJson)(tree, 'package.json');
|
|
10
|
-
const tailwindVersion =
|
|
9
|
+
const tailwindVersion = dependencies?.tailwindcss ?? devDependencies?.tailwindcss;
|
|
11
10
|
if (!tailwindVersion) {
|
|
12
11
|
return undefined;
|
|
13
12
|
}
|
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.normalizeOptions = void 0;
|
|
4
4
|
function normalizeOptions(options) {
|
|
5
|
-
return
|
|
5
|
+
return {
|
|
6
|
+
...options,
|
|
7
|
+
buildTarget: options.buildTarget || 'build',
|
|
8
|
+
};
|
|
6
9
|
}
|
|
7
10
|
exports.normalizeOptions = normalizeOptions;
|
|
@@ -23,20 +23,19 @@ function updateApplicationStyles(tree, options, project) {
|
|
|
23
23
|
}
|
|
24
24
|
exports.updateApplicationStyles = updateApplicationStyles;
|
|
25
25
|
function findStylesEntryPoint(tree, options, project) {
|
|
26
|
-
var _a, _b, _c, _d, _e, _f;
|
|
27
26
|
// first check for common names
|
|
28
27
|
const possibleStylesEntryPoints = [
|
|
29
|
-
(0, devkit_1.joinPathFragments)(
|
|
30
|
-
(0, devkit_1.joinPathFragments)(
|
|
31
|
-
(0, devkit_1.joinPathFragments)(
|
|
32
|
-
(0, devkit_1.joinPathFragments)(
|
|
28
|
+
(0, devkit_1.joinPathFragments)(project.sourceRoot ?? project.root, 'styles.css'),
|
|
29
|
+
(0, devkit_1.joinPathFragments)(project.sourceRoot ?? project.root, 'styles.scss'),
|
|
30
|
+
(0, devkit_1.joinPathFragments)(project.sourceRoot ?? project.root, 'styles.sass'),
|
|
31
|
+
(0, devkit_1.joinPathFragments)(project.sourceRoot ?? project.root, 'styles.less'),
|
|
33
32
|
];
|
|
34
33
|
let stylesEntryPoint = possibleStylesEntryPoints.find((s) => tree.exists(s));
|
|
35
34
|
if (stylesEntryPoint) {
|
|
36
35
|
return stylesEntryPoint;
|
|
37
36
|
}
|
|
38
37
|
// then check for the specified styles in the build configuration if it exists
|
|
39
|
-
const styles =
|
|
38
|
+
const styles = project.targets?.[options.buildTarget].options?.styles;
|
|
40
39
|
if (!styles) {
|
|
41
40
|
return undefined;
|
|
42
41
|
}
|
|
@@ -1,32 +1,29 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.setupTailwindGenerator = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
4
|
const devkit_1 = require("@nx/devkit");
|
|
6
5
|
const lib_1 = require("./lib");
|
|
7
|
-
function setupTailwindGenerator(tree, rawOptions) {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
if (
|
|
14
|
-
|
|
15
|
-
installTask = (0, lib_1.addTailwindRequiredPackages)(tree);
|
|
16
|
-
}
|
|
6
|
+
async function setupTailwindGenerator(tree, rawOptions) {
|
|
7
|
+
const options = (0, lib_1.normalizeOptions)(rawOptions);
|
|
8
|
+
const project = (0, devkit_1.readProjectConfiguration)(tree, options.project);
|
|
9
|
+
const tailwindInstalledVersion = (0, lib_1.detectTailwindInstalledVersion)(tree);
|
|
10
|
+
let installTask = () => { };
|
|
11
|
+
if (!options.skipPackageJson) {
|
|
12
|
+
if (tailwindInstalledVersion === undefined) {
|
|
13
|
+
installTask = (0, lib_1.addTailwindRequiredPackages)(tree);
|
|
17
14
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
15
|
+
}
|
|
16
|
+
(0, lib_1.addTailwindConfig)(tree, options, project, tailwindInstalledVersion ?? '3');
|
|
17
|
+
if (project.projectType === 'application') {
|
|
18
|
+
(0, lib_1.updateApplicationStyles)(tree, options, project);
|
|
19
|
+
}
|
|
20
|
+
else if (project.projectType === 'library') {
|
|
21
|
+
(0, lib_1.addTailwindConfigPathToProject)(tree, options, project);
|
|
22
|
+
}
|
|
23
|
+
if (!options.skipFormat) {
|
|
24
|
+
await (0, devkit_1.formatFiles)(tree);
|
|
25
|
+
}
|
|
26
|
+
return installTask;
|
|
30
27
|
}
|
|
31
28
|
exports.setupTailwindGenerator = setupTailwindGenerator;
|
|
32
29
|
exports.default = setupTailwindGenerator;
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.angularStoriesGenerator = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
4
|
const devkit_1 = require("@nx/devkit");
|
|
6
5
|
const component_cypress_spec_1 = require("../component-cypress-spec/component-cypress-spec");
|
|
7
6
|
const component_story_1 = require("../component-story/component-story");
|
|
@@ -11,64 +10,58 @@ const get_e2e_project_1 = require("./lib/get-e2e-project");
|
|
|
11
10
|
const module_info_1 = require("../utils/storybook-ast/module-info");
|
|
12
11
|
const minimatch = require("minimatch");
|
|
13
12
|
const versions_1 = require("../../utils/versions");
|
|
14
|
-
function angularStoriesGenerator(tree, options) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
const
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
13
|
+
async function angularStoriesGenerator(tree, options) {
|
|
14
|
+
const e2eProjectName = options.cypressProject ?? `${options.name}-e2e`;
|
|
15
|
+
const e2eProject = (0, get_e2e_project_1.getE2EProject)(tree, e2eProjectName);
|
|
16
|
+
const entryPoints = (0, entry_point_1.getProjectEntryPoints)(tree, options.name);
|
|
17
|
+
const componentsInfo = [];
|
|
18
|
+
for (const entryPoint of entryPoints) {
|
|
19
|
+
const moduleFilePaths = (0, module_info_1.getModuleFilePaths)(tree, entryPoint);
|
|
20
|
+
componentsInfo.push(...(0, component_info_1.getComponentsInfo)(tree, entryPoint, moduleFilePaths, options.name), ...(0, component_info_1.getStandaloneComponentsInfo)(tree, entryPoint));
|
|
21
|
+
}
|
|
22
|
+
if (options.generateCypressSpecs && !e2eProject) {
|
|
23
|
+
devkit_1.logger.info(`There was no e2e project "${e2eProjectName}" found, so cypress specs will not be generated. Pass "--cypressProject" to specify a different e2e project name.`);
|
|
24
|
+
}
|
|
25
|
+
const componentInfos = componentsInfo.filter((f) => !options.ignorePaths?.some((pattern) => {
|
|
26
|
+
const shouldIgnorePath = minimatch((0, devkit_1.joinPathFragments)(f.moduleFolderPath, f.path, `${f.componentFileName}.ts`), pattern);
|
|
27
|
+
return shouldIgnorePath;
|
|
28
|
+
}));
|
|
29
|
+
for (const info of componentInfos) {
|
|
30
|
+
if (info === undefined) {
|
|
31
|
+
continue;
|
|
24
32
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
return shouldIgnorePath;
|
|
33
|
-
}));
|
|
33
|
+
await (0, component_story_1.default)(tree, {
|
|
34
|
+
projectPath: info.moduleFolderPath,
|
|
35
|
+
componentName: info.name,
|
|
36
|
+
componentPath: info.path,
|
|
37
|
+
componentFileName: info.componentFileName,
|
|
38
|
+
interactionTests: options.interactionTests ?? true,
|
|
39
|
+
skipFormat: true,
|
|
34
40
|
});
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
}
|
|
39
|
-
yield (0, component_story_1.default)(tree, {
|
|
41
|
+
if (options.generateCypressSpecs && e2eProject) {
|
|
42
|
+
await (0, component_cypress_spec_1.default)(tree, {
|
|
43
|
+
projectName: options.name,
|
|
40
44
|
projectPath: info.moduleFolderPath,
|
|
45
|
+
cypressProject: options.cypressProject,
|
|
41
46
|
componentName: info.name,
|
|
42
47
|
componentPath: info.path,
|
|
43
48
|
componentFileName: info.componentFileName,
|
|
44
|
-
|
|
49
|
+
specDirectory: (0, devkit_1.joinPathFragments)(info.entryPointName, info.path),
|
|
45
50
|
skipFormat: true,
|
|
46
51
|
});
|
|
47
|
-
if (options.generateCypressSpecs && e2eProject) {
|
|
48
|
-
yield (0, component_cypress_spec_1.default)(tree, {
|
|
49
|
-
projectName: options.name,
|
|
50
|
-
projectPath: info.moduleFolderPath,
|
|
51
|
-
cypressProject: options.cypressProject,
|
|
52
|
-
componentName: info.name,
|
|
53
|
-
componentPath: info.path,
|
|
54
|
-
componentFileName: info.componentFileName,
|
|
55
|
-
specDirectory: (0, devkit_1.joinPathFragments)(info.entryPointName, info.path),
|
|
56
|
-
skipFormat: true,
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
const tasks = [];
|
|
61
|
-
if (options.interactionTests) {
|
|
62
|
-
const { interactionTestsDependencies, addInteractionsInAddons } = (0, devkit_1.ensurePackage)('@nx/storybook', versions_1.nxVersion);
|
|
63
|
-
const projectConfiguration = (0, devkit_1.readProjectConfiguration)(tree, options.name);
|
|
64
|
-
addInteractionsInAddons(tree, projectConfiguration);
|
|
65
|
-
tasks.push((0, devkit_1.addDependenciesToPackageJson)(tree, {}, interactionTestsDependencies()));
|
|
66
|
-
}
|
|
67
|
-
if (!options.skipFormat) {
|
|
68
|
-
yield (0, devkit_1.formatFiles)(tree);
|
|
69
52
|
}
|
|
70
|
-
|
|
71
|
-
|
|
53
|
+
}
|
|
54
|
+
const tasks = [];
|
|
55
|
+
if (options.interactionTests) {
|
|
56
|
+
const { interactionTestsDependencies, addInteractionsInAddons } = (0, devkit_1.ensurePackage)('@nx/storybook', versions_1.nxVersion);
|
|
57
|
+
const projectConfiguration = (0, devkit_1.readProjectConfiguration)(tree, options.name);
|
|
58
|
+
addInteractionsInAddons(tree, projectConfiguration);
|
|
59
|
+
tasks.push((0, devkit_1.addDependenciesToPackageJson)(tree, {}, interactionTestsDependencies()));
|
|
60
|
+
}
|
|
61
|
+
if (!options.skipFormat) {
|
|
62
|
+
await (0, devkit_1.formatFiles)(tree);
|
|
63
|
+
}
|
|
64
|
+
return (0, devkit_1.runTasksInSerial)(...tasks);
|
|
72
65
|
}
|
|
73
66
|
exports.angularStoriesGenerator = angularStoriesGenerator;
|
|
74
67
|
exports.default = angularStoriesGenerator;
|
|
@@ -7,7 +7,7 @@ function assertCompatibleStorybookVersion() {
|
|
|
7
7
|
try {
|
|
8
8
|
storybookVersion = require(require.resolve('@storybook/angular/package.json')).version;
|
|
9
9
|
}
|
|
10
|
-
catch
|
|
10
|
+
catch { }
|
|
11
11
|
if (storybookVersion && (0, semver_1.lt)(storybookVersion, '6.4.0-rc.1')) {
|
|
12
12
|
throw new Error('Incompatible Storybook Version: Please use a version of @storybook/angular higher than 6.4.0-rc.1');
|
|
13
13
|
}
|
|
@@ -1,22 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.generateStories = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
4
|
const project_name_1 = require("@nx/cypress/src/utils/project-name");
|
|
6
5
|
const devkit_1 = require("@nx/devkit");
|
|
7
6
|
const stories_1 = require("../../stories/stories");
|
|
8
|
-
function generateStories(tree, options) {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
skipFormat: true,
|
|
19
|
-
});
|
|
7
|
+
async function generateStories(tree, options) {
|
|
8
|
+
const project = (0, devkit_1.readProjectConfiguration)(tree, options.name);
|
|
9
|
+
const e2eProjectName = (0, project_name_1.getE2eProjectName)(options.name, project.root, options.cypressDirectory);
|
|
10
|
+
await (0, stories_1.angularStoriesGenerator)(tree, {
|
|
11
|
+
name: options.name,
|
|
12
|
+
generateCypressSpecs: options.configureCypress && options.generateCypressSpecs,
|
|
13
|
+
cypressProject: e2eProjectName,
|
|
14
|
+
ignorePaths: options.ignorePaths,
|
|
15
|
+
interactionTests: options.interactionTests,
|
|
16
|
+
skipFormat: true,
|
|
20
17
|
});
|
|
21
18
|
}
|
|
22
19
|
exports.generateStories = generateStories;
|
|
@@ -1,23 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.generateStorybookConfiguration = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
4
|
const devkit_1 = require("@nx/devkit");
|
|
6
5
|
const versions_1 = require("../../../utils/versions");
|
|
7
|
-
function generateStorybookConfiguration(tree, options) {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
skipFormat: true,
|
|
20
|
-
});
|
|
6
|
+
async function generateStorybookConfiguration(tree, options) {
|
|
7
|
+
const { configurationGenerator } = (0, devkit_1.ensurePackage)('@nx/storybook', versions_1.nxVersion);
|
|
8
|
+
return await configurationGenerator(tree, {
|
|
9
|
+
name: options.name,
|
|
10
|
+
uiFramework: '@storybook/angular',
|
|
11
|
+
configureCypress: options.configureCypress,
|
|
12
|
+
linter: options.linter,
|
|
13
|
+
cypressDirectory: options.cypressDirectory,
|
|
14
|
+
tsConfiguration: options.tsConfiguration,
|
|
15
|
+
interactionTests: options.interactionTests,
|
|
16
|
+
configureStaticServe: options.configureStaticServe,
|
|
17
|
+
skipFormat: true,
|
|
21
18
|
});
|
|
22
19
|
}
|
|
23
20
|
exports.generateStorybookConfiguration = generateStorybookConfiguration;
|
|
@@ -1,29 +1,33 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.storybookConfigurationGenerator = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
4
|
const devkit_1 = require("@nx/devkit");
|
|
6
5
|
const assert_compatible_storybook_version_1 = require("./lib/assert-compatible-storybook-version");
|
|
7
6
|
const generate_stories_1 = require("./lib/generate-stories");
|
|
8
7
|
const generate_storybook_configuration_1 = require("./lib/generate-storybook-configuration");
|
|
9
8
|
const validate_options_1 = require("./lib/validate-options");
|
|
10
9
|
// TODO(v18): remove Cypress
|
|
11
|
-
function storybookConfigurationGenerator(tree, options) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
yield (0, generate_stories_1.generateStories)(tree, Object.assign(Object.assign({}, options), { interactionTests: (_c = options.interactionTests) !== null && _c !== void 0 ? _c : true, skipFormat: true }));
|
|
19
|
-
}
|
|
20
|
-
if (!options.skipFormat) {
|
|
21
|
-
yield (0, devkit_1.formatFiles)(tree);
|
|
22
|
-
}
|
|
23
|
-
return () => {
|
|
24
|
-
storybookGeneratorInstallTask();
|
|
25
|
-
};
|
|
10
|
+
async function storybookConfigurationGenerator(tree, options) {
|
|
11
|
+
(0, assert_compatible_storybook_version_1.assertCompatibleStorybookVersion)();
|
|
12
|
+
(0, validate_options_1.validateOptions)(options);
|
|
13
|
+
const storybookGeneratorInstallTask = await (0, generate_storybook_configuration_1.generateStorybookConfiguration)(tree, {
|
|
14
|
+
...options,
|
|
15
|
+
interactionTests: options.interactionTests ?? true,
|
|
16
|
+
tsConfiguration: options.tsConfiguration ?? true, // default is true
|
|
26
17
|
});
|
|
18
|
+
if (options.generateStories) {
|
|
19
|
+
await (0, generate_stories_1.generateStories)(tree, {
|
|
20
|
+
...options,
|
|
21
|
+
interactionTests: options.interactionTests ?? true,
|
|
22
|
+
skipFormat: true,
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
if (!options.skipFormat) {
|
|
26
|
+
await (0, devkit_1.formatFiles)(tree);
|
|
27
|
+
}
|
|
28
|
+
return () => {
|
|
29
|
+
storybookGeneratorInstallTask();
|
|
30
|
+
};
|
|
27
31
|
}
|
|
28
32
|
exports.storybookConfigurationGenerator = storybookConfigurationGenerator;
|
|
29
33
|
exports.default = storybookConfigurationGenerator;
|
|
@@ -24,7 +24,7 @@ function createTsConfig(host, projectRoot, type, options, relativePathToRootTsCo
|
|
|
24
24
|
// inline tsconfig.base.json into the project
|
|
25
25
|
if (options.rootProject) {
|
|
26
26
|
json.compileOnSave = false;
|
|
27
|
-
json.compilerOptions =
|
|
27
|
+
json.compilerOptions = { ...js_1.tsConfigBaseOptions, ...json.compilerOptions };
|
|
28
28
|
json.exclude = ['node_modules', 'tmp'];
|
|
29
29
|
}
|
|
30
30
|
else {
|
|
@@ -4,10 +4,9 @@ exports.locateLibraryEntryPointFromDirectory = void 0;
|
|
|
4
4
|
const devkit_1 = require("@nx/devkit");
|
|
5
5
|
const path_1 = require("path");
|
|
6
6
|
function locateLibraryEntryPointFromDirectory(tree, directory, projectRoot, projectSourceRoot) {
|
|
7
|
-
var _a, _b;
|
|
8
7
|
const ngPackageJsonPath = (0, devkit_1.joinPathFragments)(directory, 'ng-package.json');
|
|
9
8
|
let entryPointFile = tree.exists(ngPackageJsonPath)
|
|
10
|
-
? (
|
|
9
|
+
? (0, devkit_1.readJson)(tree, ngPackageJsonPath).lib?.entryFile ?? 'src/public_api.ts'
|
|
11
10
|
: null;
|
|
12
11
|
if (entryPointFile) {
|
|
13
12
|
return (0, devkit_1.joinPathFragments)(directory, entryPointFile);
|
|
@@ -9,7 +9,7 @@ function exportScam(tree, options) {
|
|
|
9
9
|
return;
|
|
10
10
|
}
|
|
11
11
|
const { projectType, root, sourceRoot } = (0, devkit_1.readProjectConfiguration)(tree, options.project);
|
|
12
|
-
const projectSourceRoot = sourceRoot
|
|
12
|
+
const projectSourceRoot = sourceRoot ?? (0, devkit_1.joinPathFragments)(root, 'src');
|
|
13
13
|
if (projectType === 'application') {
|
|
14
14
|
devkit_1.logger.warn('--export=true was ignored as the project the SCAM is being generated in is not a library.');
|
|
15
15
|
return;
|
|
@@ -135,5 +135,5 @@ function findPropertyAssignment(ngModuleOptions, propertyName) {
|
|
|
135
135
|
}
|
|
136
136
|
let tsUtils;
|
|
137
137
|
function getTsEsLintTypeUtils() {
|
|
138
|
-
return tsUtils
|
|
138
|
+
return tsUtils ?? require('@typescript-eslint/type-utils');
|
|
139
139
|
}
|
|
@@ -16,11 +16,11 @@ function getRelativeImportToFile(sourceFilePath, targetFilePath) {
|
|
|
16
16
|
}
|
|
17
17
|
exports.getRelativeImportToFile = getRelativeImportToFile;
|
|
18
18
|
function normalizeNameAndPaths(tree, options) {
|
|
19
|
-
var _a;
|
|
20
19
|
const { root, sourceRoot, projectType } = (0, devkit_1.readProjectConfiguration)(tree, options.project);
|
|
21
|
-
const projectSourceRoot = sourceRoot
|
|
20
|
+
const projectSourceRoot = sourceRoot ?? (0, devkit_1.joinPathFragments)(root, 'src');
|
|
22
21
|
const { name, path: namePath } = (0, names_1.parseNameWithPath)(options.name);
|
|
23
|
-
const path =
|
|
22
|
+
const path = options.path ??
|
|
23
|
+
(0, devkit_1.joinPathFragments)(projectSourceRoot, projectType === 'application' ? 'app' : 'lib', namePath);
|
|
24
24
|
const directory = options.flat
|
|
25
25
|
? (0, devkit_1.normalizePath)(path)
|
|
26
26
|
: (0, devkit_1.joinPathFragments)(path, name);
|
|
@@ -39,8 +39,7 @@ Valid selector prefixes must start with a letter, and must contain only alphanum
|
|
|
39
39
|
}
|
|
40
40
|
exports.normalizeNewProjectPrefix = normalizeNewProjectPrefix;
|
|
41
41
|
function getProjectPrefix(tree, project) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
.prefix) !== null && _a !== void 0 ? _a : (0, get_npm_scope_1.getNpmScope)(tree));
|
|
42
|
+
return ((0, devkit_1.readProjectConfiguration)(tree, project)
|
|
43
|
+
.prefix ?? (0, get_npm_scope_1.getNpmScope)(tree));
|
|
45
44
|
}
|
|
46
45
|
exports.getProjectPrefix = getProjectPrefix;
|
|
@@ -5,7 +5,7 @@ const devkit_1 = require("@nx/devkit");
|
|
|
5
5
|
const get_npm_scope_1 = require("@nx/js/src/utils/package-json/get-npm-scope");
|
|
6
6
|
function buildSelector(tree, name, prefix, projectPrefix, casing) {
|
|
7
7
|
let selector = name;
|
|
8
|
-
prefix
|
|
8
|
+
prefix ??= projectPrefix ?? (0, get_npm_scope_1.getNpmScope)(tree);
|
|
9
9
|
if (prefix) {
|
|
10
10
|
selector = `${prefix}-${selector}`;
|
|
11
11
|
}
|
|
@@ -30,9 +30,8 @@ exports.getComponentsInfo = getComponentsInfo;
|
|
|
30
30
|
function getStandaloneComponentsInfo(tree, entryPoint) {
|
|
31
31
|
const componentsInfo = [];
|
|
32
32
|
(0, devkit_1.visitNotIgnoredFiles)(tree, entryPoint.path, (filePath) => {
|
|
33
|
-
var _a;
|
|
34
33
|
const normalizedFilePath = (0, devkit_1.normalizePath)(filePath);
|
|
35
|
-
if (
|
|
34
|
+
if (entryPoint.excludeDirs?.some((excludeDir) => normalizedFilePath.startsWith(excludeDir))) {
|
|
36
35
|
return;
|
|
37
36
|
}
|
|
38
37
|
if ((0, path_1.extname)(normalizedFilePath) !== '.ts' ||
|
|
@@ -46,12 +46,11 @@ function collectLibrarySecondaryEntryPoints(tree, root, entryPointPaths) {
|
|
|
46
46
|
});
|
|
47
47
|
}
|
|
48
48
|
function normalizeMainEntryPointSourceRoot(tree, root, sourceRoot, projectType) {
|
|
49
|
-
var _a;
|
|
50
49
|
const projectTypeDir = projectType === 'application' ? 'app' : 'lib';
|
|
51
50
|
if (sourceRoot) {
|
|
52
51
|
return [(0, devkit_1.joinPathFragments)(sourceRoot, projectTypeDir), sourceRoot].find((path) => tree.exists(path));
|
|
53
52
|
}
|
|
54
|
-
return
|
|
53
|
+
return getSourcePath(tree, root, projectTypeDir) ?? root;
|
|
55
54
|
}
|
|
56
55
|
function getSourcePath(tree, basePath, projectTypeDir) {
|
|
57
56
|
const candidatePaths = [
|
|
@@ -23,9 +23,8 @@ exports.getModuleDeclaredComponents = getModuleDeclaredComponents;
|
|
|
23
23
|
function getModuleFilePaths(tree, entryPoint) {
|
|
24
24
|
let moduleFilePaths = [];
|
|
25
25
|
(0, devkit_1.visitNotIgnoredFiles)(tree, entryPoint.path, (filePath) => {
|
|
26
|
-
var _a;
|
|
27
26
|
const normalizedFilePath = (0, devkit_1.normalizePath)(filePath);
|
|
28
|
-
if (
|
|
27
|
+
if (entryPoint.excludeDirs?.some((excludeDir) => normalizedFilePath.startsWith(excludeDir))) {
|
|
29
28
|
return;
|
|
30
29
|
}
|
|
31
30
|
if ((0, path_1.extname)(normalizedFilePath) === '.ts' &&
|