@schematics/angular 17.0.0-next.3 → 17.0.0-next.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/app-shell/index.js +30 -52
  2. package/app-shell/schema.d.ts +0 -16
  3. package/app-shell/schema.js +1 -1
  4. package/app-shell/schema.json +0 -21
  5. package/application/files/standalone-files/src/app/app.config.ts.template +1 -1
  6. package/application/index.js +3 -6
  7. package/application/schema.d.ts +1 -1
  8. package/application/schema.js +1 -1
  9. package/application/schema.json +2 -3
  10. package/collection.json +4 -4
  11. package/config/index.js +2 -2
  12. package/environments/index.js +6 -4
  13. package/ng-new/schema.d.ts +1 -1
  14. package/ng-new/schema.js +1 -1
  15. package/ng-new/schema.json +1 -1
  16. package/package.json +3 -3
  17. package/pipe/index.js +2 -2
  18. package/{universal → server}/files/root/tsconfig.server.json.template +1 -1
  19. package/{universal/files/src/app/__rootModuleFileName__.template → server/files/src/app/app.module.server.ts.template} +1 -1
  20. package/server/files/src/main.server.ts.template +1 -0
  21. package/{universal → server}/index.d.ts +2 -2
  22. package/server/index.js +182 -0
  23. package/{universal → server}/schema.d.ts +0 -12
  24. package/server/schema.js +5 -0
  25. package/server/schema.json +23 -0
  26. package/service-worker/index.js +30 -25
  27. package/third_party/github.com/Microsoft/TypeScript/lib/typescript.d.ts +276 -251
  28. package/third_party/github.com/Microsoft/TypeScript/lib/typescript.js +11696 -9251
  29. package/utility/change.js +20 -6
  30. package/utility/generate-from-files.js +4 -4
  31. package/utility/json-file.js +5 -1
  32. package/utility/latest-versions/package.json +3 -3
  33. package/utility/standalone/code_block.js +26 -28
  34. package/utility/standalone/util.js +4 -2
  35. package/utility/workspace-models.d.ts +2 -1
  36. package/utility/workspace-models.js +3 -2
  37. package/utility/workspace.js +2 -1
  38. package/web-worker/index.js +3 -4
  39. package/workspace/files/tsconfig.json.template +1 -0
  40. package/universal/files/src/__main@stripTsExtension__.ts.template +0 -2
  41. package/universal/index.js +0 -141
  42. package/universal/schema.js +0 -5
  43. package/universal/schema.json +0 -40
  44. /package/{universal → server}/files/standalone-src/app/app.config.server.ts.template +0 -0
  45. /package/{universal → server}/files/standalone-src/main.server.ts.template +0 -0
package/config/index.js CHANGED
@@ -51,7 +51,7 @@ function addKarmaConfig(options) {
51
51
  if (testTarget.builder !== utility_1.AngularBuilder.Karma) {
52
52
  throw new schematics_1.SchematicsException(`Cannot add a karma configuration as builder for "test" target in project does not use "${utility_1.AngularBuilder.Karma}".`);
53
53
  }
54
- testTarget.options ?? (testTarget.options = {});
54
+ testTarget.options ??= {};
55
55
  testTarget.options.karmaConfig = path_1.posix.join(project.root, 'karma.conf.js');
56
56
  // If scoped project (i.e. "@foo/bar"), convert dir to "foo/bar".
57
57
  let folderName = options.project.startsWith('@') ? options.project.slice(1) : options.project;
@@ -68,4 +68,4 @@ function addKarmaConfig(options) {
68
68
  ]));
69
69
  });
70
70
  }
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zY2hlbWF0aWNzL2FuZ3VsYXIvY29uZmlnL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7O0FBRUgsMkRBVW9DO0FBQ3BDLHlEQUE2RjtBQUM3RiwrQkFBcUM7QUFDckMsNENBQStEO0FBQy9ELHFDQUF1RTtBQUV2RSxtQkFBeUIsT0FBc0I7SUFDN0MsUUFBUSxPQUFPLENBQUMsSUFBSSxFQUFFO1FBQ3BCLEtBQUssYUFBVSxDQUFDLEtBQUs7WUFDbkIsT0FBTyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsS0FBSyxhQUFVLENBQUMsWUFBWTtZQUMxQixPQUFPLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hDO1lBQ0UsTUFBTSxJQUFJLGdDQUFtQixDQUFDLElBQUksT0FBTyxDQUFDLElBQUksMENBQTBDLENBQUMsQ0FBQztLQUM3RjtBQUNILENBQUM7QUFURCw0QkFTQztBQUVELFNBQVMscUJBQXFCLENBQUMsT0FBc0I7SUFDbkQsT0FBTyxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUU7UUFDcEIsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFBLHVCQUFhLEVBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hELElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDWixNQUFNLElBQUksZ0NBQW1CLENBQUMsaUJBQWlCLE9BQU8sQ0FBQyxPQUFPLHNCQUFzQixDQUFDLENBQUM7U0FDdkY7UUFFRCxPQUFPLElBQUEsc0JBQVMsRUFDZCxJQUFBLGtCQUFLLEVBQUMsSUFBQSxnQkFBRyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3BCLElBQUEsbUJBQU0sRUFBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1lBQ3JELElBQUEsMkJBQWMsRUFBQyxFQUFFLENBQUM7WUFDbEIsSUFBQSxpQkFBSSxFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7U0FDbkIsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQsU0FBUyxjQUFjLENBQUMsT0FBc0I7SUFDNUMsT0FBTyxJQUFBLHlCQUFlLEVBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtRQUNuQyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNaLE1BQU0sSUFBSSxnQ0FBbUIsQ0FBQyxpQkFBaUIsT0FBTyxDQUFDLE9BQU8sc0JBQXNCLENBQUMsQ0FBQztTQUN2RjtRQUVELE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixNQUFNLElBQUksZ0NBQW1CLENBQzNCLHVDQUF1QyxPQUFPLENBQUMsT0FBTyxJQUFJO2dCQUN4RCxpRUFBaUUsQ0FDcEUsQ0FBQztTQUNIO1FBRUQsSUFBSSxVQUFVLENBQUMsT0FBTyxLQUFLLHdCQUFjLENBQUMsS0FBSyxFQUFFO1lBQy9DLE1BQU0sSUFBSSxnQ0FBbUIsQ0FDM0IsMEZBQTBGLHdCQUFjLENBQUMsS0FBSyxJQUFJLENBQ25ILENBQUM7U0FDSDtRQUVELFVBQVUsQ0FBQyxPQUFPLEtBQWxCLFVBQVUsQ0FBQyxPQUFPLEdBQUssRUFBRSxFQUFDO1FBQzFCLFVBQVUsQ0FBQyxPQUFPLENBQUMsV0FBVyxHQUFHLFlBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQztRQUUxRSxpRUFBaUU7UUFDakUsSUFBSSxVQUFVLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDO1FBQzlGLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUM1QixVQUFVLEdBQUcsb0JBQU8sQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUM7U0FDNUM7UUFFRCxPQUFPLElBQUEsc0JBQVMsRUFDZCxJQUFBLGtCQUFLLEVBQUMsSUFBQSxnQkFBRyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3BCLElBQUEsbUJBQU0sRUFBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1lBQ25ELElBQUEsMkJBQWMsRUFBQztnQkFDYiwyQkFBMkIsRUFBRSxJQUFBLG1DQUEyQixFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQ3RFLFVBQVU7YUFDWCxDQUFDO1lBQ0YsSUFBQSxpQkFBSSxFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7U0FDbkIsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtcbiAgUnVsZSxcbiAgU2NoZW1hdGljc0V4Y2VwdGlvbixcbiAgYXBwbHksXG4gIGFwcGx5VGVtcGxhdGVzLFxuICBmaWx0ZXIsXG4gIG1lcmdlV2l0aCxcbiAgbW92ZSxcbiAgc3RyaW5ncyxcbiAgdXJsLFxufSBmcm9tICdAYW5ndWxhci1kZXZraXQvc2NoZW1hdGljcyc7XG5pbXBvcnQgeyBBbmd1bGFyQnVpbGRlciwgcmVhZFdvcmtzcGFjZSwgdXBkYXRlV29ya3NwYWNlIH0gZnJvbSAnQHNjaGVtYXRpY3MvYW5ndWxhci91dGlsaXR5JztcbmltcG9ydCB7IHBvc2l4IGFzIHBhdGggfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IHJlbGF0aXZlUGF0aFRvV29ya3NwYWNlUm9vdCB9IGZyb20gJy4uL3V0aWxpdHkvcGF0aHMnO1xuaW1wb3J0IHsgU2NoZW1hIGFzIENvbmZpZ09wdGlvbnMsIFR5cGUgYXMgQ29uZmlnVHlwZSB9IGZyb20gJy4vc2NoZW1hJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKG9wdGlvbnM6IENvbmZpZ09wdGlvbnMpOiBSdWxlIHtcbiAgc3dpdGNoIChvcHRpb25zLnR5cGUpIHtcbiAgICBjYXNlIENvbmZpZ1R5cGUuS2FybWE6XG4gICAgICByZXR1cm4gYWRkS2FybWFDb25maWcob3B0aW9ucyk7XG4gICAgY2FzZSBDb25maWdUeXBlLkJyb3dzZXJzbGlzdDpcbiAgICAgIHJldHVybiBhZGRCcm93c2Vyc2xpc3RDb25maWcob3B0aW9ucyk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKGBcIiR7b3B0aW9ucy50eXBlfVwiIGlzIGFuIHVua25vd24gY29uZmlndXJhdGlvbiBmaWxlIHR5cGUuYCk7XG4gIH1cbn1cblxuZnVuY3Rpb24gYWRkQnJvd3NlcnNsaXN0Q29uZmlnKG9wdGlvbnM6IENvbmZpZ09wdGlvbnMpOiBSdWxlIHtcbiAgcmV0dXJuIGFzeW5jIChob3N0KSA9PiB7XG4gICAgY29uc3Qgd29ya3NwYWNlID0gYXdhaXQgcmVhZFdvcmtzcGFjZShob3N0KTtcbiAgICBjb25zdCBwcm9qZWN0ID0gd29ya3NwYWNlLnByb2plY3RzLmdldChvcHRpb25zLnByb2plY3QpO1xuICAgIGlmICghcHJvamVjdCkge1xuICAgICAgdGhyb3cgbmV3IFNjaGVtYXRpY3NFeGNlcHRpb24oYFByb2plY3QgbmFtZSBcIiR7b3B0aW9ucy5wcm9qZWN0fVwiIGRvZXNuJ3Qgbm90IGV4aXN0LmApO1xuICAgIH1cblxuICAgIHJldHVybiBtZXJnZVdpdGgoXG4gICAgICBhcHBseSh1cmwoJy4vZmlsZXMnKSwgW1xuICAgICAgICBmaWx0ZXIoKHApID0+IHAuZW5kc1dpdGgoJy5icm93c2Vyc2xpc3RyYy50ZW1wbGF0ZScpKSxcbiAgICAgICAgYXBwbHlUZW1wbGF0ZXMoe30pLFxuICAgICAgICBtb3ZlKHByb2plY3Qucm9vdCksXG4gICAgICBdKSxcbiAgICApO1xuICB9O1xufVxuXG5mdW5jdGlvbiBhZGRLYXJtYUNvbmZpZyhvcHRpb25zOiBDb25maWdPcHRpb25zKTogUnVsZSB7XG4gIHJldHVybiB1cGRhdGVXb3Jrc3BhY2UoKHdvcmtzcGFjZSkgPT4ge1xuICAgIGNvbnN0IHByb2plY3QgPSB3b3Jrc3BhY2UucHJvamVjdHMuZ2V0KG9wdGlvbnMucHJvamVjdCk7XG4gICAgaWYgKCFwcm9qZWN0KSB7XG4gICAgICB0aHJvdyBuZXcgU2NoZW1hdGljc0V4Y2VwdGlvbihgUHJvamVjdCBuYW1lIFwiJHtvcHRpb25zLnByb2plY3R9XCIgZG9lc24ndCBub3QgZXhpc3QuYCk7XG4gICAgfVxuXG4gICAgY29uc3QgdGVzdFRhcmdldCA9IHByb2plY3QudGFyZ2V0cy5nZXQoJ3Rlc3QnKTtcbiAgICBpZiAoIXRlc3RUYXJnZXQpIHtcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKFxuICAgICAgICBgTm8gXCJ0ZXN0XCIgdGFyZ2V0IGZvdW5kIGZvciBwcm9qZWN0IFwiJHtvcHRpb25zLnByb2plY3R9XCIuYCArXG4gICAgICAgICAgJyBBIFwidGVzdFwiIHRhcmdldCBpcyByZXF1aXJlZCB0byBnZW5lcmF0ZSBhIGthcm1hIGNvbmZpZ3VyYXRpb24uJyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgaWYgKHRlc3RUYXJnZXQuYnVpbGRlciAhPT0gQW5ndWxhckJ1aWxkZXIuS2FybWEpIHtcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKFxuICAgICAgICBgQ2Fubm90IGFkZCBhIGthcm1hIGNvbmZpZ3VyYXRpb24gYXMgYnVpbGRlciBmb3IgXCJ0ZXN0XCIgdGFyZ2V0IGluIHByb2plY3QgZG9lcyBub3QgdXNlIFwiJHtBbmd1bGFyQnVpbGRlci5LYXJtYX1cIi5gLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICB0ZXN0VGFyZ2V0Lm9wdGlvbnMgPz89IHt9O1xuICAgIHRlc3RUYXJnZXQub3B0aW9ucy5rYXJtYUNvbmZpZyA9IHBhdGguam9pbihwcm9qZWN0LnJvb3QsICdrYXJtYS5jb25mLmpzJyk7XG5cbiAgICAvLyBJZiBzY29wZWQgcHJvamVjdCAoaS5lLiBcIkBmb28vYmFyXCIpLCBjb252ZXJ0IGRpciB0byBcImZvby9iYXJcIi5cbiAgICBsZXQgZm9sZGVyTmFtZSA9IG9wdGlvbnMucHJvamVjdC5zdGFydHNXaXRoKCdAJykgPyBvcHRpb25zLnByb2plY3Quc2xpY2UoMSkgOiBvcHRpb25zLnByb2plY3Q7XG4gICAgaWYgKC9bQS1aXS8udGVzdChmb2xkZXJOYW1lKSkge1xuICAgICAgZm9sZGVyTmFtZSA9IHN0cmluZ3MuZGFzaGVyaXplKGZvbGRlck5hbWUpO1xuICAgIH1cblxuICAgIHJldHVybiBtZXJnZVdpdGgoXG4gICAgICBhcHBseSh1cmwoJy4vZmlsZXMnKSwgW1xuICAgICAgICBmaWx0ZXIoKHApID0+IHAuZW5kc1dpdGgoJ2thcm1hLmNvbmYuanMudGVtcGxhdGUnKSksXG4gICAgICAgIGFwcGx5VGVtcGxhdGVzKHtcbiAgICAgICAgICByZWxhdGl2ZVBhdGhUb1dvcmtzcGFjZVJvb3Q6IHJlbGF0aXZlUGF0aFRvV29ya3NwYWNlUm9vdChwcm9qZWN0LnJvb3QpLFxuICAgICAgICAgIGZvbGRlck5hbWUsXG4gICAgICAgIH0pLFxuICAgICAgICBtb3ZlKHByb2plY3Qucm9vdCksXG4gICAgICBdKSxcbiAgICApO1xuICB9KTtcbn1cbiJdfQ==
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zY2hlbWF0aWNzL2FuZ3VsYXIvY29uZmlnL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7O0FBRUgsMkRBVW9DO0FBQ3BDLHlEQUE2RjtBQUM3RiwrQkFBcUM7QUFDckMsNENBQStEO0FBQy9ELHFDQUF1RTtBQUV2RSxtQkFBeUIsT0FBc0I7SUFDN0MsUUFBUSxPQUFPLENBQUMsSUFBSSxFQUFFO1FBQ3BCLEtBQUssYUFBVSxDQUFDLEtBQUs7WUFDbkIsT0FBTyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsS0FBSyxhQUFVLENBQUMsWUFBWTtZQUMxQixPQUFPLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hDO1lBQ0UsTUFBTSxJQUFJLGdDQUFtQixDQUFDLElBQUksT0FBTyxDQUFDLElBQUksMENBQTBDLENBQUMsQ0FBQztLQUM3RjtBQUNILENBQUM7QUFURCw0QkFTQztBQUVELFNBQVMscUJBQXFCLENBQUMsT0FBc0I7SUFDbkQsT0FBTyxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUU7UUFDcEIsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFBLHVCQUFhLEVBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hELElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDWixNQUFNLElBQUksZ0NBQW1CLENBQUMsaUJBQWlCLE9BQU8sQ0FBQyxPQUFPLHNCQUFzQixDQUFDLENBQUM7U0FDdkY7UUFFRCxPQUFPLElBQUEsc0JBQVMsRUFDZCxJQUFBLGtCQUFLLEVBQUMsSUFBQSxnQkFBRyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3BCLElBQUEsbUJBQU0sRUFBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1lBQ3JELElBQUEsMkJBQWMsRUFBQyxFQUFFLENBQUM7WUFDbEIsSUFBQSxpQkFBSSxFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7U0FDbkIsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQsU0FBUyxjQUFjLENBQUMsT0FBc0I7SUFDNUMsT0FBTyxJQUFBLHlCQUFlLEVBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtRQUNuQyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNaLE1BQU0sSUFBSSxnQ0FBbUIsQ0FBQyxpQkFBaUIsT0FBTyxDQUFDLE9BQU8sc0JBQXNCLENBQUMsQ0FBQztTQUN2RjtRQUVELE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixNQUFNLElBQUksZ0NBQW1CLENBQzNCLHVDQUF1QyxPQUFPLENBQUMsT0FBTyxJQUFJO2dCQUN4RCxpRUFBaUUsQ0FDcEUsQ0FBQztTQUNIO1FBRUQsSUFBSSxVQUFVLENBQUMsT0FBTyxLQUFLLHdCQUFjLENBQUMsS0FBSyxFQUFFO1lBQy9DLE1BQU0sSUFBSSxnQ0FBbUIsQ0FDM0IsMEZBQTBGLHdCQUFjLENBQUMsS0FBSyxJQUFJLENBQ25ILENBQUM7U0FDSDtRQUVELFVBQVUsQ0FBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQzFCLFVBQVUsQ0FBQyxPQUFPLENBQUMsV0FBVyxHQUFHLFlBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQztRQUUxRSxpRUFBaUU7UUFDakUsSUFBSSxVQUFVLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDO1FBQzlGLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUM1QixVQUFVLEdBQUcsb0JBQU8sQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUM7U0FDNUM7UUFFRCxPQUFPLElBQUEsc0JBQVMsRUFDZCxJQUFBLGtCQUFLLEVBQUMsSUFBQSxnQkFBRyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3BCLElBQUEsbUJBQU0sRUFBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1lBQ25ELElBQUEsMkJBQWMsRUFBQztnQkFDYiwyQkFBMkIsRUFBRSxJQUFBLG1DQUEyQixFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQ3RFLFVBQVU7YUFDWCxDQUFDO1lBQ0YsSUFBQSxpQkFBSSxFQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7U0FDbkIsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtcbiAgUnVsZSxcbiAgU2NoZW1hdGljc0V4Y2VwdGlvbixcbiAgYXBwbHksXG4gIGFwcGx5VGVtcGxhdGVzLFxuICBmaWx0ZXIsXG4gIG1lcmdlV2l0aCxcbiAgbW92ZSxcbiAgc3RyaW5ncyxcbiAgdXJsLFxufSBmcm9tICdAYW5ndWxhci1kZXZraXQvc2NoZW1hdGljcyc7XG5pbXBvcnQgeyBBbmd1bGFyQnVpbGRlciwgcmVhZFdvcmtzcGFjZSwgdXBkYXRlV29ya3NwYWNlIH0gZnJvbSAnQHNjaGVtYXRpY3MvYW5ndWxhci91dGlsaXR5JztcbmltcG9ydCB7IHBvc2l4IGFzIHBhdGggfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IHJlbGF0aXZlUGF0aFRvV29ya3NwYWNlUm9vdCB9IGZyb20gJy4uL3V0aWxpdHkvcGF0aHMnO1xuaW1wb3J0IHsgU2NoZW1hIGFzIENvbmZpZ09wdGlvbnMsIFR5cGUgYXMgQ29uZmlnVHlwZSB9IGZyb20gJy4vc2NoZW1hJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKG9wdGlvbnM6IENvbmZpZ09wdGlvbnMpOiBSdWxlIHtcbiAgc3dpdGNoIChvcHRpb25zLnR5cGUpIHtcbiAgICBjYXNlIENvbmZpZ1R5cGUuS2FybWE6XG4gICAgICByZXR1cm4gYWRkS2FybWFDb25maWcob3B0aW9ucyk7XG4gICAgY2FzZSBDb25maWdUeXBlLkJyb3dzZXJzbGlzdDpcbiAgICAgIHJldHVybiBhZGRCcm93c2Vyc2xpc3RDb25maWcob3B0aW9ucyk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKGBcIiR7b3B0aW9ucy50eXBlfVwiIGlzIGFuIHVua25vd24gY29uZmlndXJhdGlvbiBmaWxlIHR5cGUuYCk7XG4gIH1cbn1cblxuZnVuY3Rpb24gYWRkQnJvd3NlcnNsaXN0Q29uZmlnKG9wdGlvbnM6IENvbmZpZ09wdGlvbnMpOiBSdWxlIHtcbiAgcmV0dXJuIGFzeW5jIChob3N0KSA9PiB7XG4gICAgY29uc3Qgd29ya3NwYWNlID0gYXdhaXQgcmVhZFdvcmtzcGFjZShob3N0KTtcbiAgICBjb25zdCBwcm9qZWN0ID0gd29ya3NwYWNlLnByb2plY3RzLmdldChvcHRpb25zLnByb2plY3QpO1xuICAgIGlmICghcHJvamVjdCkge1xuICAgICAgdGhyb3cgbmV3IFNjaGVtYXRpY3NFeGNlcHRpb24oYFByb2plY3QgbmFtZSBcIiR7b3B0aW9ucy5wcm9qZWN0fVwiIGRvZXNuJ3Qgbm90IGV4aXN0LmApO1xuICAgIH1cblxuICAgIHJldHVybiBtZXJnZVdpdGgoXG4gICAgICBhcHBseSh1cmwoJy4vZmlsZXMnKSwgW1xuICAgICAgICBmaWx0ZXIoKHApID0+IHAuZW5kc1dpdGgoJy5icm93c2Vyc2xpc3RyYy50ZW1wbGF0ZScpKSxcbiAgICAgICAgYXBwbHlUZW1wbGF0ZXMoe30pLFxuICAgICAgICBtb3ZlKHByb2plY3Qucm9vdCksXG4gICAgICBdKSxcbiAgICApO1xuICB9O1xufVxuXG5mdW5jdGlvbiBhZGRLYXJtYUNvbmZpZyhvcHRpb25zOiBDb25maWdPcHRpb25zKTogUnVsZSB7XG4gIHJldHVybiB1cGRhdGVXb3Jrc3BhY2UoKHdvcmtzcGFjZSkgPT4ge1xuICAgIGNvbnN0IHByb2plY3QgPSB3b3Jrc3BhY2UucHJvamVjdHMuZ2V0KG9wdGlvbnMucHJvamVjdCk7XG4gICAgaWYgKCFwcm9qZWN0KSB7XG4gICAgICB0aHJvdyBuZXcgU2NoZW1hdGljc0V4Y2VwdGlvbihgUHJvamVjdCBuYW1lIFwiJHtvcHRpb25zLnByb2plY3R9XCIgZG9lc24ndCBub3QgZXhpc3QuYCk7XG4gICAgfVxuXG4gICAgY29uc3QgdGVzdFRhcmdldCA9IHByb2plY3QudGFyZ2V0cy5nZXQoJ3Rlc3QnKTtcbiAgICBpZiAoIXRlc3RUYXJnZXQpIHtcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKFxuICAgICAgICBgTm8gXCJ0ZXN0XCIgdGFyZ2V0IGZvdW5kIGZvciBwcm9qZWN0IFwiJHtvcHRpb25zLnByb2plY3R9XCIuYCArXG4gICAgICAgICAgJyBBIFwidGVzdFwiIHRhcmdldCBpcyByZXF1aXJlZCB0byBnZW5lcmF0ZSBhIGthcm1hIGNvbmZpZ3VyYXRpb24uJyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgaWYgKHRlc3RUYXJnZXQuYnVpbGRlciAhPT0gQW5ndWxhckJ1aWxkZXIuS2FybWEpIHtcbiAgICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKFxuICAgICAgICBgQ2Fubm90IGFkZCBhIGthcm1hIGNvbmZpZ3VyYXRpb24gYXMgYnVpbGRlciBmb3IgXCJ0ZXN0XCIgdGFyZ2V0IGluIHByb2plY3QgZG9lcyBub3QgdXNlIFwiJHtBbmd1bGFyQnVpbGRlci5LYXJtYX1cIi5gLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICB0ZXN0VGFyZ2V0Lm9wdGlvbnMgPz89IHt9O1xuICAgIHRlc3RUYXJnZXQub3B0aW9ucy5rYXJtYUNvbmZpZyA9IHBhdGguam9pbihwcm9qZWN0LnJvb3QsICdrYXJtYS5jb25mLmpzJyk7XG5cbiAgICAvLyBJZiBzY29wZWQgcHJvamVjdCAoaS5lLiBcIkBmb28vYmFyXCIpLCBjb252ZXJ0IGRpciB0byBcImZvby9iYXJcIi5cbiAgICBsZXQgZm9sZGVyTmFtZSA9IG9wdGlvbnMucHJvamVjdC5zdGFydHNXaXRoKCdAJykgPyBvcHRpb25zLnByb2plY3Quc2xpY2UoMSkgOiBvcHRpb25zLnByb2plY3Q7XG4gICAgaWYgKC9bQS1aXS8udGVzdChmb2xkZXJOYW1lKSkge1xuICAgICAgZm9sZGVyTmFtZSA9IHN0cmluZ3MuZGFzaGVyaXplKGZvbGRlck5hbWUpO1xuICAgIH1cblxuICAgIHJldHVybiBtZXJnZVdpdGgoXG4gICAgICBhcHBseSh1cmwoJy4vZmlsZXMnKSwgW1xuICAgICAgICBmaWx0ZXIoKHApID0+IHAuZW5kc1dpdGgoJ2thcm1hLmNvbmYuanMudGVtcGxhdGUnKSksXG4gICAgICAgIGFwcGx5VGVtcGxhdGVzKHtcbiAgICAgICAgICByZWxhdGl2ZVBhdGhUb1dvcmtzcGFjZVJvb3Q6IHJlbGF0aXZlUGF0aFRvV29ya3NwYWNlUm9vdChwcm9qZWN0LnJvb3QpLFxuICAgICAgICAgIGZvbGRlck5hbWUsXG4gICAgICAgIH0pLFxuICAgICAgICBtb3ZlKHByb2plY3Qucm9vdCksXG4gICAgICBdKSxcbiAgICApO1xuICB9KTtcbn1cbiJdfQ==
@@ -53,11 +53,13 @@ function log(type, text) {
53
53
  return (_, context) => context.logger[type](text);
54
54
  }
55
55
  function* generateConfigurationEnvironments(buildTarget, serverTarget, sourceRoot, projectName) {
56
- if (!buildTarget.builder.startsWith(utility_1.AngularBuilder.Browser)) {
56
+ if (buildTarget.builder !== utility_1.AngularBuilder.Browser &&
57
+ buildTarget.builder !== utility_1.AngularBuilder.BrowserEsbuild &&
58
+ buildTarget.builder !== utility_1.AngularBuilder.Application) {
57
59
  yield log('warn', `"build" target found for project "${projectName}" has a third-party builder "${buildTarget.builder}".` +
58
60
  ' The generated project options may not be compatible with this builder.');
59
61
  }
60
- if (serverTarget && !serverTarget.builder.startsWith(utility_1.AngularBuilder.Server)) {
62
+ if (serverTarget && serverTarget.builder !== utility_1.AngularBuilder.Server) {
61
63
  yield log('warn', `"server" target found for project "${projectName}" has a third-party builder "${buildTarget.builder}".` +
62
64
  ' The generated project options may not be compatible with this builder.');
63
65
  }
@@ -80,7 +82,7 @@ function* generateConfigurationEnvironments(buildTarget, serverTarget, sourceRoo
80
82
  }
81
83
  const configurationFilePath = path_1.posix.join(sourceRoot, ENVIRONMENTS_DIRECTORY, `environment.${name}.ts`);
82
84
  // Add file replacement option entry for the configuration environment file
83
- const replacements = (configurationOptions['fileReplacements'] ?? (configurationOptions['fileReplacements'] = []));
85
+ const replacements = (configurationOptions['fileReplacements'] ??= []);
84
86
  const existing = replacements.find((value) => value.replace === defaultFilePath);
85
87
  if (existing) {
86
88
  if (existing.with === configurationFilePath) {
@@ -101,4 +103,4 @@ function* generateConfigurationEnvironments(buildTarget, serverTarget, sourceRoo
101
103
  }
102
104
  }
103
105
  }
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/environments/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { Rule, SchematicsException, chain } from '@angular-devkit/schematics';\nimport { AngularBuilder, TargetDefinition, updateWorkspace } from '@schematics/angular/utility';\nimport { posix as path } from 'path';\nimport { Schema as EnvironmentOptions } from './schema';\n\nconst ENVIRONMENTS_DIRECTORY = 'environments';\nconst ENVIRONMENT_FILE_CONTENT = 'export const environment = {};\\n';\n\nexport default function (options: EnvironmentOptions): Rule {\n  return updateWorkspace((workspace) => {\n    const project = workspace.projects.get(options.project);\n    if (!project) {\n      throw new SchematicsException(`Project name \"${options.project}\" doesn't not exist.`);\n    }\n\n    const type = project.extensions['projectType'];\n    if (type !== 'application') {\n      return log(\n        'error',\n        'Only application project types are support by this schematic.' + type\n          ? ` Project \"${options.project}\" has a \"projectType\" of \"${type}\".`\n          : ` Project \"${options.project}\" has no \"projectType\" defined.`,\n      );\n    }\n\n    const buildTarget = project.targets.get('build');\n    if (!buildTarget) {\n      return log(\n        'error',\n        `No \"build\" target found for project \"${options.project}\".` +\n          ' A \"build\" target is required to generate environment files.',\n      );\n    }\n\n    const serverTarget = project.targets.get('server');\n\n    const sourceRoot = project.sourceRoot ?? path.join(project.root, 'src');\n\n    // The generator needs to be iterated prior to returning to ensure all workspace changes that occur\n    // within the generator are present for `updateWorkspace` when it writes the workspace file.\n    return chain([\n      ...generateConfigurationEnvironments(buildTarget, serverTarget, sourceRoot, options.project),\n    ]);\n  });\n}\n\nfunction createIfMissing(path: string): Rule {\n  return (tree, context) => {\n    if (tree.exists(path)) {\n      context.logger.info(`Skipping creation of already existing environment file \"${path}\".`);\n    } else {\n      tree.create(path, ENVIRONMENT_FILE_CONTENT);\n    }\n  };\n}\n\nfunction log(type: 'info' | 'warn' | 'error', text: string): Rule {\n  return (_, context) => context.logger[type](text);\n}\n\nfunction* generateConfigurationEnvironments(\n  buildTarget: TargetDefinition,\n  serverTarget: TargetDefinition | undefined,\n  sourceRoot: string,\n  projectName: string,\n): Iterable<Rule> {\n  if (!buildTarget.builder.startsWith(AngularBuilder.Browser)) {\n    yield log(\n      'warn',\n      `\"build\" target found for project \"${projectName}\" has a third-party builder \"${buildTarget.builder}\".` +\n        ' The generated project options may not be compatible with this builder.',\n    );\n  }\n\n  if (serverTarget && !serverTarget.builder.startsWith(AngularBuilder.Server)) {\n    yield log(\n      'warn',\n      `\"server\" target found for project \"${projectName}\" has a third-party builder \"${buildTarget.builder}\".` +\n        ' The generated project options may not be compatible with this builder.',\n    );\n  }\n\n  // Create default environment file\n  const defaultFilePath = path.join(sourceRoot, ENVIRONMENTS_DIRECTORY, 'environment.ts');\n  yield createIfMissing(defaultFilePath);\n\n  const configurationEntries = [\n    ...Object.entries(buildTarget.configurations ?? {}),\n    ...Object.entries(serverTarget?.configurations ?? {}),\n  ];\n\n  const addedFiles = new Set<string>();\n  for (const [name, configurationOptions] of configurationEntries) {\n    if (!configurationOptions) {\n      // Invalid configuration\n      continue;\n    }\n\n    // Default configuration will use the default environment file\n    if (name === buildTarget.defaultConfiguration) {\n      continue;\n    }\n\n    const configurationFilePath = path.join(\n      sourceRoot,\n      ENVIRONMENTS_DIRECTORY,\n      `environment.${name}.ts`,\n    );\n\n    // Add file replacement option entry for the configuration environment file\n    const replacements = (configurationOptions['fileReplacements'] ??= []) as {\n      replace: string;\n      with: string;\n    }[];\n    const existing = replacements.find((value) => value.replace === defaultFilePath);\n    if (existing) {\n      if (existing.with === configurationFilePath) {\n        yield log(\n          'info',\n          `Skipping addition of already existing file replacements option for \"${defaultFilePath}\" to \"${configurationFilePath}\".`,\n        );\n      } else {\n        yield log(\n          'warn',\n          `Configuration \"${name}\" has a file replacements option for \"${defaultFilePath}\" but with a different replacement.` +\n            ` Expected \"${configurationFilePath}\" but found \"${existing.with}\". This may result in unexpected build behavior.`,\n        );\n      }\n    } else {\n      replacements.push({ replace: defaultFilePath, with: configurationFilePath });\n    }\n\n    // Create configuration specific environment file if not already added\n    if (!addedFiles.has(configurationFilePath)) {\n      addedFiles.add(configurationFilePath);\n      yield createIfMissing(configurationFilePath);\n    }\n  }\n}\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/environments/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { Rule, SchematicsException, chain } from '@angular-devkit/schematics';\nimport { AngularBuilder, TargetDefinition, updateWorkspace } from '@schematics/angular/utility';\nimport { posix as path } from 'path';\nimport { Schema as EnvironmentOptions } from './schema';\n\nconst ENVIRONMENTS_DIRECTORY = 'environments';\nconst ENVIRONMENT_FILE_CONTENT = 'export const environment = {};\\n';\n\nexport default function (options: EnvironmentOptions): Rule {\n  return updateWorkspace((workspace) => {\n    const project = workspace.projects.get(options.project);\n    if (!project) {\n      throw new SchematicsException(`Project name \"${options.project}\" doesn't not exist.`);\n    }\n\n    const type = project.extensions['projectType'];\n    if (type !== 'application') {\n      return log(\n        'error',\n        'Only application project types are support by this schematic.' + type\n          ? ` Project \"${options.project}\" has a \"projectType\" of \"${type}\".`\n          : ` Project \"${options.project}\" has no \"projectType\" defined.`,\n      );\n    }\n\n    const buildTarget = project.targets.get('build');\n    if (!buildTarget) {\n      return log(\n        'error',\n        `No \"build\" target found for project \"${options.project}\".` +\n          ' A \"build\" target is required to generate environment files.',\n      );\n    }\n\n    const serverTarget = project.targets.get('server');\n\n    const sourceRoot = project.sourceRoot ?? path.join(project.root, 'src');\n\n    // The generator needs to be iterated prior to returning to ensure all workspace changes that occur\n    // within the generator are present for `updateWorkspace` when it writes the workspace file.\n    return chain([\n      ...generateConfigurationEnvironments(buildTarget, serverTarget, sourceRoot, options.project),\n    ]);\n  });\n}\n\nfunction createIfMissing(path: string): Rule {\n  return (tree, context) => {\n    if (tree.exists(path)) {\n      context.logger.info(`Skipping creation of already existing environment file \"${path}\".`);\n    } else {\n      tree.create(path, ENVIRONMENT_FILE_CONTENT);\n    }\n  };\n}\n\nfunction log(type: 'info' | 'warn' | 'error', text: string): Rule {\n  return (_, context) => context.logger[type](text);\n}\n\nfunction* generateConfigurationEnvironments(\n  buildTarget: TargetDefinition,\n  serverTarget: TargetDefinition | undefined,\n  sourceRoot: string,\n  projectName: string,\n): Iterable<Rule> {\n  if (\n    buildTarget.builder !== AngularBuilder.Browser &&\n    buildTarget.builder !== AngularBuilder.BrowserEsbuild &&\n    buildTarget.builder !== AngularBuilder.Application\n  ) {\n    yield log(\n      'warn',\n      `\"build\" target found for project \"${projectName}\" has a third-party builder \"${buildTarget.builder}\".` +\n        ' The generated project options may not be compatible with this builder.',\n    );\n  }\n\n  if (serverTarget && serverTarget.builder !== AngularBuilder.Server) {\n    yield log(\n      'warn',\n      `\"server\" target found for project \"${projectName}\" has a third-party builder \"${buildTarget.builder}\".` +\n        ' The generated project options may not be compatible with this builder.',\n    );\n  }\n\n  // Create default environment file\n  const defaultFilePath = path.join(sourceRoot, ENVIRONMENTS_DIRECTORY, 'environment.ts');\n  yield createIfMissing(defaultFilePath);\n\n  const configurationEntries = [\n    ...Object.entries(buildTarget.configurations ?? {}),\n    ...Object.entries(serverTarget?.configurations ?? {}),\n  ];\n\n  const addedFiles = new Set<string>();\n  for (const [name, configurationOptions] of configurationEntries) {\n    if (!configurationOptions) {\n      // Invalid configuration\n      continue;\n    }\n\n    // Default configuration will use the default environment file\n    if (name === buildTarget.defaultConfiguration) {\n      continue;\n    }\n\n    const configurationFilePath = path.join(\n      sourceRoot,\n      ENVIRONMENTS_DIRECTORY,\n      `environment.${name}.ts`,\n    );\n\n    // Add file replacement option entry for the configuration environment file\n    const replacements = (configurationOptions['fileReplacements'] ??= []) as {\n      replace: string;\n      with: string;\n    }[];\n    const existing = replacements.find((value) => value.replace === defaultFilePath);\n    if (existing) {\n      if (existing.with === configurationFilePath) {\n        yield log(\n          'info',\n          `Skipping addition of already existing file replacements option for \"${defaultFilePath}\" to \"${configurationFilePath}\".`,\n        );\n      } else {\n        yield log(\n          'warn',\n          `Configuration \"${name}\" has a file replacements option for \"${defaultFilePath}\" but with a different replacement.` +\n            ` Expected \"${configurationFilePath}\" but found \"${existing.with}\". This may result in unexpected build behavior.`,\n        );\n      }\n    } else {\n      replacements.push({ replace: defaultFilePath, with: configurationFilePath });\n    }\n\n    // Create configuration specific environment file if not already added\n    if (!addedFiles.has(configurationFilePath)) {\n      addedFiles.add(configurationFilePath);\n      yield createIfMissing(configurationFilePath);\n    }\n  }\n}\n"]}
@@ -51,7 +51,7 @@ export interface Schema {
51
51
  */
52
52
  prefix?: string;
53
53
  /**
54
- * Generate a routing module for the initial project.
54
+ * Enable routing in the initial project.
55
55
  */
56
56
  routing?: boolean;
57
57
  /**
package/ng-new/schema.js CHANGED
@@ -32,4 +32,4 @@ var ViewEncapsulation;
32
32
  ViewEncapsulation["None"] = "None";
33
33
  ViewEncapsulation["ShadowDom"] = "ShadowDom";
34
34
  })(ViewEncapsulation || (exports.ViewEncapsulation = ViewEncapsulation = {}));
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc2NoZW1hdGljcy9hbmd1bGFyL25nLW5ldy9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLG1GQUFtRjtBQUNuRixvRkFBb0Y7OztBQTBHcEY7O0dBRUc7QUFDSCxJQUFZLGNBS1g7QUFMRCxXQUFZLGNBQWM7SUFDdEIsK0JBQWEsQ0FBQTtJQUNiLDZCQUFXLENBQUE7SUFDWCwrQkFBYSxDQUFBO0lBQ2IsK0JBQWEsQ0FBQTtBQUNqQixDQUFDLEVBTFcsY0FBYyw4QkFBZCxjQUFjLFFBS3pCO0FBRUQ7O0dBRUc7QUFDSCxJQUFZLEtBS1g7QUFMRCxXQUFZLEtBQUs7SUFDYixvQkFBVyxDQUFBO0lBQ1gsc0JBQWEsQ0FBQTtJQUNiLHNCQUFhLENBQUE7SUFDYixzQkFBYSxDQUFBO0FBQ2pCLENBQUMsRUFMVyxLQUFLLHFCQUFMLEtBQUssUUFLaEI7QUFFRDs7R0FFRztBQUNILElBQVksaUJBSVg7QUFKRCxXQUFZLGlCQUFpQjtJQUN6QiwwQ0FBcUIsQ0FBQTtJQUNyQixrQ0FBYSxDQUFBO0lBQ2IsNENBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUpXLGlCQUFpQixpQ0FBakIsaUJBQWlCLFFBSTVCIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyBwcm9qZWN0IGJ5IGNvbWJpbmluZyB0aGUgd29ya3NwYWNlIGFuZCBhcHBsaWNhdGlvbiBzY2hlbWF0aWNzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYSB7XG4gICAgLyoqXG4gICAgICogSW5pdGlhbCBnaXQgcmVwb3NpdG9yeSBjb21taXQgaW5mb3JtYXRpb24uXG4gICAgICovXG4gICAgY29tbWl0PzogQ29tbWl0VW5pb247XG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGluaXRpYWwgYXBwbGljYXRpb24gcHJvamVjdCBpbiB0aGUgJ3NyYycgZm9sZGVyIG9mIHRoZSBuZXcgd29ya3NwYWNlLiBXaGVuXG4gICAgICogZmFsc2UsIGNyZWF0ZXMgYW4gZW1wdHkgd29ya3NwYWNlIHdpdGggbm8gaW5pdGlhbCBhcHBsaWNhdGlvbi4gWW91IGNhbiB0aGVuIHVzZSB0aGVcbiAgICAgKiBnZW5lcmF0ZSBhcHBsaWNhdGlvbiBjb21tYW5kIHNvIHRoYXQgYWxsIGFwcGxpY2F0aW9ucyBhcmUgY3JlYXRlZCBpbiB0aGUgcHJvamVjdHMgZm9sZGVyLlxuICAgICAqL1xuICAgIGNyZWF0ZUFwcGxpY2F0aW9uPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBUaGUgZGlyZWN0b3J5IG5hbWUgdG8gY3JlYXRlIHRoZSB3b3Jrc3BhY2UgaW4uXG4gICAgICovXG4gICAgZGlyZWN0b3J5Pzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEluY2x1ZGUgc3R5bGVzIGlubGluZSBpbiB0aGUgY29tcG9uZW50IFRTIGZpbGUuIEJ5IGRlZmF1bHQsIGFuIGV4dGVybmFsIHN0eWxlcyBmaWxlIGlzXG4gICAgICogY3JlYXRlZCBhbmQgcmVmZXJlbmNlZCBpbiB0aGUgY29tcG9uZW50IFR5cGVTY3JpcHQgZmlsZS5cbiAgICAgKi9cbiAgICBpbmxpbmVTdHlsZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogSW5jbHVkZSB0ZW1wbGF0ZSBpbmxpbmUgaW4gdGhlIGNvbXBvbmVudCBUUyBmaWxlLiBCeSBkZWZhdWx0LCBhbiBleHRlcm5hbCB0ZW1wbGF0ZSBmaWxlXG4gICAgICogaXMgY3JlYXRlZCBhbmQgcmVmZXJlbmNlZCBpbiB0aGUgY29tcG9uZW50IFR5cGVTY3JpcHQgZmlsZS5cbiAgICAgKi9cbiAgICBpbmxpbmVUZW1wbGF0ZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogTGluayB0aGUgQ0xJIHRvIHRoZSBnbG9iYWwgdmVyc2lvbiAoaW50ZXJuYWwgZGV2ZWxvcG1lbnQgb25seSkuXG4gICAgICovXG4gICAgbGlua0NsaT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgd29ya3NwYWNlIHdpdGhvdXQgYW55IHRlc3RpbmcgZnJhbWV3b3Jrcy4gKFVzZSBmb3IgbGVhcm5pbmcgcHVycG9zZXMgb25seS4pXG4gICAgICovXG4gICAgbWluaW1hbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIG5ldyB3b3Jrc3BhY2UgYW5kIGluaXRpYWwgcHJvamVjdC5cbiAgICAgKi9cbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogVGhlIHBhdGggd2hlcmUgbmV3IHByb2plY3RzIHdpbGwgYmUgY3JlYXRlZCwgcmVsYXRpdmUgdG8gdGhlIG5ldyB3b3Jrc3BhY2Ugcm9vdC5cbiAgICAgKi9cbiAgICBuZXdQcm9qZWN0Um9vdD86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBUaGUgcGFja2FnZSBtYW5hZ2VyIHVzZWQgdG8gaW5zdGFsbCBkZXBlbmRlbmNpZXMuXG4gICAgICovXG4gICAgcGFja2FnZU1hbmFnZXI/OiBQYWNrYWdlTWFuYWdlcjtcbiAgICAvKipcbiAgICAgKiBUaGUgcHJlZml4IHRvIGFwcGx5IHRvIGdlbmVyYXRlZCBzZWxlY3RvcnMgZm9yIHRoZSBpbml0aWFsIHByb2plY3QuXG4gICAgICovXG4gICAgcHJlZml4Pzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEdlbmVyYXRlIGEgcm91dGluZyBtb2R1bGUgZm9yIHRoZSBpbml0aWFsIHByb2plY3QuXG4gICAgICovXG4gICAgcm91dGluZz86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogRG8gbm90IGluaXRpYWxpemUgYSBnaXQgcmVwb3NpdG9yeS5cbiAgICAgKi9cbiAgICBza2lwR2l0PzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBEbyBub3QgaW5zdGFsbCBkZXBlbmRlbmN5IHBhY2thZ2VzLlxuICAgICAqL1xuICAgIHNraXBJbnN0YWxsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBEbyBub3QgZ2VuZXJhdGUgXCJzcGVjLnRzXCIgdGVzdCBmaWxlcyBmb3IgdGhlIG5ldyBwcm9qZWN0LlxuICAgICAqL1xuICAgIHNraXBUZXN0cz86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhbiBhcHBsaWNhdGlvbiBiYXNlZCB1cG9uIHRoZSBzdGFuZGFsb25lIEFQSSwgd2l0aG91dCBOZ01vZHVsZXMuXG4gICAgICovXG4gICAgc3RhbmRhbG9uZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIHdvcmtzcGFjZSB3aXRoIHN0cmljdGVyIHR5cGUgY2hlY2tpbmcgYW5kIHN0cmljdGVyIGJ1bmRsZSBidWRnZXRzIHNldHRpbmdzLlxuICAgICAqIFRoaXMgc2V0dGluZyBoZWxwcyBpbXByb3ZlIG1haW50YWluYWJpbGl0eSBhbmQgY2F0Y2ggYnVncyBhaGVhZCBvZiB0aW1lLiBGb3IgbW9yZVxuICAgICAqIGluZm9ybWF0aW9uLCBzZWUgaHR0cHM6Ly9hbmd1bGFyLmlvL2d1aWRlL3N0cmljdC1tb2RlXG4gICAgICovXG4gICAgc3RyaWN0PzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBUaGUgZmlsZSBleHRlbnNpb24gb3IgcHJlcHJvY2Vzc29yIHRvIHVzZSBmb3Igc3R5bGUgZmlsZXMuXG4gICAgICovXG4gICAgc3R5bGU/OiBTdHlsZTtcbiAgICAvKipcbiAgICAgKiBUaGUgdmVyc2lvbiBvZiB0aGUgQW5ndWxhciBDTEkgdG8gdXNlLlxuICAgICAqL1xuICAgIHZlcnNpb246IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBUaGUgdmlldyBlbmNhcHN1bGF0aW9uIHN0cmF0ZWd5IHRvIHVzZSBpbiB0aGUgaW5pdGlhbCBwcm9qZWN0LlxuICAgICAqL1xuICAgIHZpZXdFbmNhcHN1bGF0aW9uPzogVmlld0VuY2Fwc3VsYXRpb247XG59XG5cbi8qKlxuICogSW5pdGlhbCBnaXQgcmVwb3NpdG9yeSBjb21taXQgaW5mb3JtYXRpb24uXG4gKi9cbmV4cG9ydCB0eXBlIENvbW1pdFVuaW9uID0gYm9vbGVhbiB8IENvbW1pdE9iamVjdDtcblxuZXhwb3J0IGludGVyZmFjZSBDb21taXRPYmplY3Qge1xuICAgIGVtYWlsOiAgICBzdHJpbmc7XG4gICAgbWVzc2FnZT86IHN0cmluZztcbiAgICBuYW1lOiAgICAgc3RyaW5nO1xuICAgIFtwcm9wZXJ0eTogc3RyaW5nXTogYW55O1xufVxuXG4vKipcbiAqIFRoZSBwYWNrYWdlIG1hbmFnZXIgdXNlZCB0byBpbnN0YWxsIGRlcGVuZGVuY2llcy5cbiAqL1xuZXhwb3J0IGVudW0gUGFja2FnZU1hbmFnZXIge1xuICAgIENucG0gPSBcImNucG1cIixcbiAgICBOcG0gPSBcIm5wbVwiLFxuICAgIFBucG0gPSBcInBucG1cIixcbiAgICBZYXJuID0gXCJ5YXJuXCIsXG59XG5cbi8qKlxuICogVGhlIGZpbGUgZXh0ZW5zaW9uIG9yIHByZXByb2Nlc3NvciB0byB1c2UgZm9yIHN0eWxlIGZpbGVzLlxuICovXG5leHBvcnQgZW51bSBTdHlsZSB7XG4gICAgQ3NzID0gXCJjc3NcIixcbiAgICBMZXNzID0gXCJsZXNzXCIsXG4gICAgU2FzcyA9IFwic2Fzc1wiLFxuICAgIFNjc3MgPSBcInNjc3NcIixcbn1cblxuLyoqXG4gKiBUaGUgdmlldyBlbmNhcHN1bGF0aW9uIHN0cmF0ZWd5IHRvIHVzZSBpbiB0aGUgaW5pdGlhbCBwcm9qZWN0LlxuICovXG5leHBvcnQgZW51bSBWaWV3RW5jYXBzdWxhdGlvbiB7XG4gICAgRW11bGF0ZWQgPSBcIkVtdWxhdGVkXCIsXG4gICAgTm9uZSA9IFwiTm9uZVwiLFxuICAgIFNoYWRvd0RvbSA9IFwiU2hhZG93RG9tXCIsXG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc2NoZW1hdGljcy9hbmd1bGFyL25nLW5ldy9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLG1GQUFtRjtBQUNuRixvRkFBb0Y7OztBQTBHcEY7O0dBRUc7QUFDSCxJQUFZLGNBS1g7QUFMRCxXQUFZLGNBQWM7SUFDdEIsK0JBQWEsQ0FBQTtJQUNiLDZCQUFXLENBQUE7SUFDWCwrQkFBYSxDQUFBO0lBQ2IsK0JBQWEsQ0FBQTtBQUNqQixDQUFDLEVBTFcsY0FBYyw4QkFBZCxjQUFjLFFBS3pCO0FBRUQ7O0dBRUc7QUFDSCxJQUFZLEtBS1g7QUFMRCxXQUFZLEtBQUs7SUFDYixvQkFBVyxDQUFBO0lBQ1gsc0JBQWEsQ0FBQTtJQUNiLHNCQUFhLENBQUE7SUFDYixzQkFBYSxDQUFBO0FBQ2pCLENBQUMsRUFMVyxLQUFLLHFCQUFMLEtBQUssUUFLaEI7QUFFRDs7R0FFRztBQUNILElBQVksaUJBSVg7QUFKRCxXQUFZLGlCQUFpQjtJQUN6QiwwQ0FBcUIsQ0FBQTtJQUNyQixrQ0FBYSxDQUFBO0lBQ2IsNENBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUpXLGlCQUFpQixpQ0FBakIsaUJBQWlCLFFBSTVCIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyBwcm9qZWN0IGJ5IGNvbWJpbmluZyB0aGUgd29ya3NwYWNlIGFuZCBhcHBsaWNhdGlvbiBzY2hlbWF0aWNzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYSB7XG4gICAgLyoqXG4gICAgICogSW5pdGlhbCBnaXQgcmVwb3NpdG9yeSBjb21taXQgaW5mb3JtYXRpb24uXG4gICAgICovXG4gICAgY29tbWl0PzogQ29tbWl0VW5pb247XG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGluaXRpYWwgYXBwbGljYXRpb24gcHJvamVjdCBpbiB0aGUgJ3NyYycgZm9sZGVyIG9mIHRoZSBuZXcgd29ya3NwYWNlLiBXaGVuXG4gICAgICogZmFsc2UsIGNyZWF0ZXMgYW4gZW1wdHkgd29ya3NwYWNlIHdpdGggbm8gaW5pdGlhbCBhcHBsaWNhdGlvbi4gWW91IGNhbiB0aGVuIHVzZSB0aGVcbiAgICAgKiBnZW5lcmF0ZSBhcHBsaWNhdGlvbiBjb21tYW5kIHNvIHRoYXQgYWxsIGFwcGxpY2F0aW9ucyBhcmUgY3JlYXRlZCBpbiB0aGUgcHJvamVjdHMgZm9sZGVyLlxuICAgICAqL1xuICAgIGNyZWF0ZUFwcGxpY2F0aW9uPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBUaGUgZGlyZWN0b3J5IG5hbWUgdG8gY3JlYXRlIHRoZSB3b3Jrc3BhY2UgaW4uXG4gICAgICovXG4gICAgZGlyZWN0b3J5Pzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEluY2x1ZGUgc3R5bGVzIGlubGluZSBpbiB0aGUgY29tcG9uZW50IFRTIGZpbGUuIEJ5IGRlZmF1bHQsIGFuIGV4dGVybmFsIHN0eWxlcyBmaWxlIGlzXG4gICAgICogY3JlYXRlZCBhbmQgcmVmZXJlbmNlZCBpbiB0aGUgY29tcG9uZW50IFR5cGVTY3JpcHQgZmlsZS5cbiAgICAgKi9cbiAgICBpbmxpbmVTdHlsZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogSW5jbHVkZSB0ZW1wbGF0ZSBpbmxpbmUgaW4gdGhlIGNvbXBvbmVudCBUUyBmaWxlLiBCeSBkZWZhdWx0LCBhbiBleHRlcm5hbCB0ZW1wbGF0ZSBmaWxlXG4gICAgICogaXMgY3JlYXRlZCBhbmQgcmVmZXJlbmNlZCBpbiB0aGUgY29tcG9uZW50IFR5cGVTY3JpcHQgZmlsZS5cbiAgICAgKi9cbiAgICBpbmxpbmVUZW1wbGF0ZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogTGluayB0aGUgQ0xJIHRvIHRoZSBnbG9iYWwgdmVyc2lvbiAoaW50ZXJuYWwgZGV2ZWxvcG1lbnQgb25seSkuXG4gICAgICovXG4gICAgbGlua0NsaT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgd29ya3NwYWNlIHdpdGhvdXQgYW55IHRlc3RpbmcgZnJhbWV3b3Jrcy4gKFVzZSBmb3IgbGVhcm5pbmcgcHVycG9zZXMgb25seS4pXG4gICAgICovXG4gICAgbWluaW1hbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIG5ldyB3b3Jrc3BhY2UgYW5kIGluaXRpYWwgcHJvamVjdC5cbiAgICAgKi9cbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogVGhlIHBhdGggd2hlcmUgbmV3IHByb2plY3RzIHdpbGwgYmUgY3JlYXRlZCwgcmVsYXRpdmUgdG8gdGhlIG5ldyB3b3Jrc3BhY2Ugcm9vdC5cbiAgICAgKi9cbiAgICBuZXdQcm9qZWN0Um9vdD86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBUaGUgcGFja2FnZSBtYW5hZ2VyIHVzZWQgdG8gaW5zdGFsbCBkZXBlbmRlbmNpZXMuXG4gICAgICovXG4gICAgcGFja2FnZU1hbmFnZXI/OiBQYWNrYWdlTWFuYWdlcjtcbiAgICAvKipcbiAgICAgKiBUaGUgcHJlZml4IHRvIGFwcGx5IHRvIGdlbmVyYXRlZCBzZWxlY3RvcnMgZm9yIHRoZSBpbml0aWFsIHByb2plY3QuXG4gICAgICovXG4gICAgcHJlZml4Pzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEVuYWJsZSByb3V0aW5nIGluIHRoZSBpbml0aWFsIHByb2plY3QuXG4gICAgICovXG4gICAgcm91dGluZz86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogRG8gbm90IGluaXRpYWxpemUgYSBnaXQgcmVwb3NpdG9yeS5cbiAgICAgKi9cbiAgICBza2lwR2l0PzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBEbyBub3QgaW5zdGFsbCBkZXBlbmRlbmN5IHBhY2thZ2VzLlxuICAgICAqL1xuICAgIHNraXBJbnN0YWxsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBEbyBub3QgZ2VuZXJhdGUgXCJzcGVjLnRzXCIgdGVzdCBmaWxlcyBmb3IgdGhlIG5ldyBwcm9qZWN0LlxuICAgICAqL1xuICAgIHNraXBUZXN0cz86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhbiBhcHBsaWNhdGlvbiBiYXNlZCB1cG9uIHRoZSBzdGFuZGFsb25lIEFQSSwgd2l0aG91dCBOZ01vZHVsZXMuXG4gICAgICovXG4gICAgc3RhbmRhbG9uZT86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIHdvcmtzcGFjZSB3aXRoIHN0cmljdGVyIHR5cGUgY2hlY2tpbmcgYW5kIHN0cmljdGVyIGJ1bmRsZSBidWRnZXRzIHNldHRpbmdzLlxuICAgICAqIFRoaXMgc2V0dGluZyBoZWxwcyBpbXByb3ZlIG1haW50YWluYWJpbGl0eSBhbmQgY2F0Y2ggYnVncyBhaGVhZCBvZiB0aW1lLiBGb3IgbW9yZVxuICAgICAqIGluZm9ybWF0aW9uLCBzZWUgaHR0cHM6Ly9hbmd1bGFyLmlvL2d1aWRlL3N0cmljdC1tb2RlXG4gICAgICovXG4gICAgc3RyaWN0PzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBUaGUgZmlsZSBleHRlbnNpb24gb3IgcHJlcHJvY2Vzc29yIHRvIHVzZSBmb3Igc3R5bGUgZmlsZXMuXG4gICAgICovXG4gICAgc3R5bGU/OiBTdHlsZTtcbiAgICAvKipcbiAgICAgKiBUaGUgdmVyc2lvbiBvZiB0aGUgQW5ndWxhciBDTEkgdG8gdXNlLlxuICAgICAqL1xuICAgIHZlcnNpb246IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBUaGUgdmlldyBlbmNhcHN1bGF0aW9uIHN0cmF0ZWd5IHRvIHVzZSBpbiB0aGUgaW5pdGlhbCBwcm9qZWN0LlxuICAgICAqL1xuICAgIHZpZXdFbmNhcHN1bGF0aW9uPzogVmlld0VuY2Fwc3VsYXRpb247XG59XG5cbi8qKlxuICogSW5pdGlhbCBnaXQgcmVwb3NpdG9yeSBjb21taXQgaW5mb3JtYXRpb24uXG4gKi9cbmV4cG9ydCB0eXBlIENvbW1pdFVuaW9uID0gYm9vbGVhbiB8IENvbW1pdE9iamVjdDtcblxuZXhwb3J0IGludGVyZmFjZSBDb21taXRPYmplY3Qge1xuICAgIGVtYWlsOiAgICBzdHJpbmc7XG4gICAgbWVzc2FnZT86IHN0cmluZztcbiAgICBuYW1lOiAgICAgc3RyaW5nO1xuICAgIFtwcm9wZXJ0eTogc3RyaW5nXTogYW55O1xufVxuXG4vKipcbiAqIFRoZSBwYWNrYWdlIG1hbmFnZXIgdXNlZCB0byBpbnN0YWxsIGRlcGVuZGVuY2llcy5cbiAqL1xuZXhwb3J0IGVudW0gUGFja2FnZU1hbmFnZXIge1xuICAgIENucG0gPSBcImNucG1cIixcbiAgICBOcG0gPSBcIm5wbVwiLFxuICAgIFBucG0gPSBcInBucG1cIixcbiAgICBZYXJuID0gXCJ5YXJuXCIsXG59XG5cbi8qKlxuICogVGhlIGZpbGUgZXh0ZW5zaW9uIG9yIHByZXByb2Nlc3NvciB0byB1c2UgZm9yIHN0eWxlIGZpbGVzLlxuICovXG5leHBvcnQgZW51bSBTdHlsZSB7XG4gICAgQ3NzID0gXCJjc3NcIixcbiAgICBMZXNzID0gXCJsZXNzXCIsXG4gICAgU2FzcyA9IFwic2Fzc1wiLFxuICAgIFNjc3MgPSBcInNjc3NcIixcbn1cblxuLyoqXG4gKiBUaGUgdmlldyBlbmNhcHN1bGF0aW9uIHN0cmF0ZWd5IHRvIHVzZSBpbiB0aGUgaW5pdGlhbCBwcm9qZWN0LlxuICovXG5leHBvcnQgZW51bSBWaWV3RW5jYXBzdWxhdGlvbiB7XG4gICAgRW11bGF0ZWQgPSBcIkVtdWxhdGVkXCIsXG4gICAgTm9uZSA9IFwiTm9uZVwiLFxuICAgIFNoYWRvd0RvbSA9IFwiU2hhZG93RG9tXCIsXG59XG4iXX0=
@@ -91,7 +91,7 @@
91
91
  },
92
92
  "routing": {
93
93
  "type": "boolean",
94
- "description": "Generate a routing module for the initial project.",
94
+ "description": "Enable routing in the initial project.",
95
95
  "x-user-analytics": "ep.ng_routing"
96
96
  },
97
97
  "prefix": {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@schematics/angular",
3
- "version": "17.0.0-next.3",
3
+ "version": "17.0.0-next.5",
4
4
  "description": "Schematics specific to Angular",
5
5
  "homepage": "https://github.com/angular/angular-cli",
6
6
  "keywords": [
@@ -23,8 +23,8 @@
23
23
  },
24
24
  "schematics": "./collection.json",
25
25
  "dependencies": {
26
- "@angular-devkit/core": "17.0.0-next.3",
27
- "@angular-devkit/schematics": "17.0.0-next.3",
26
+ "@angular-devkit/core": "17.0.0-next.5",
27
+ "@angular-devkit/schematics": "17.0.0-next.5",
28
28
  "jsonc-parser": "3.2.0"
29
29
  },
30
30
  "repository": {
package/pipe/index.js CHANGED
@@ -15,7 +15,7 @@ const validation_1 = require("../utility/validation");
15
15
  const workspace_1 = require("../utility/workspace");
16
16
  function default_1(options) {
17
17
  return async (host) => {
18
- options.path ?? (options.path = await (0, workspace_1.createDefaultPath)(host, options.project));
18
+ options.path ??= await (0, workspace_1.createDefaultPath)(host, options.project);
19
19
  options.module = (0, find_module_1.findModuleFromOptions)(host, options);
20
20
  const parsedPath = (0, parse_name_1.parseName)(options.path, options.name);
21
21
  options.name = parsedPath.name;
@@ -40,4 +40,4 @@ function default_1(options) {
40
40
  };
41
41
  }
42
42
  exports.default = default_1;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zY2hlbWF0aWNzL2FuZ3VsYXIvcGlwZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOztBQUVILDJEQVlvQztBQUNwQywwRkFBbUY7QUFDbkYsd0RBQStEO0FBQy9ELHNEQUFrRDtBQUNsRCxzREFBMEQ7QUFDMUQsb0RBQXlEO0FBR3pELG1CQUF5QixPQUFvQjtJQUMzQyxPQUFPLEtBQUssRUFBRSxJQUFVLEVBQUUsRUFBRTtRQUMxQixPQUFPLENBQUMsSUFBSSxLQUFaLE9BQU8sQ0FBQyxJQUFJLEdBQUssTUFBTSxJQUFBLDZCQUFpQixFQUFDLElBQUksRUFBRSxPQUFPLENBQUMsT0FBaUIsQ0FBQyxFQUFDO1FBQzFFLE9BQU8sQ0FBQyxNQUFNLEdBQUcsSUFBQSxtQ0FBcUIsRUFBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFdEQsTUFBTSxVQUFVLEdBQUcsSUFBQSxzQkFBUyxFQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pELE9BQU8sQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztRQUMvQixPQUFPLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUM7UUFDL0IsSUFBQSw4QkFBaUIsRUFBQyxvQkFBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUVsRCxNQUFNLGNBQWMsR0FBRyxJQUFBLGtCQUFLLEVBQUMsSUFBQSxnQkFBRyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzNDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUEsbUJBQU0sRUFBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBQSxpQkFBSSxHQUFFO1lBQ2xGLElBQUEsMkJBQWMsRUFBQztnQkFDYixHQUFHLG9CQUFPO2dCQUNWLFNBQVMsRUFBRSxDQUFDLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDakQsR0FBRyxPQUFPO2FBQ1gsQ0FBQztZQUNGLElBQUEsaUJBQUksRUFBQyxVQUFVLENBQUMsSUFBSSxDQUFDO1NBQ3RCLENBQUMsQ0FBQztRQUVILE9BQU8sSUFBQSxrQkFBSyxFQUFDO1lBQ1gsSUFBQSx1REFBd0IsRUFBQztnQkFDdkIsSUFBSSxFQUFFLE1BQU07Z0JBRVosR0FBRyxPQUFPO2FBQ1gsQ0FBQztZQUNGLElBQUEsc0JBQVMsRUFBQyxjQUFjLENBQUM7U0FDMUIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQTdCRCw0QkE2QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtcbiAgUnVsZSxcbiAgVHJlZSxcbiAgYXBwbHksXG4gIGFwcGx5VGVtcGxhdGVzLFxuICBjaGFpbixcbiAgZmlsdGVyLFxuICBtZXJnZVdpdGgsXG4gIG1vdmUsXG4gIG5vb3AsXG4gIHN0cmluZ3MsXG4gIHVybCxcbn0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L3NjaGVtYXRpY3MnO1xuaW1wb3J0IHsgYWRkRGVjbGFyYXRpb25Ub05nTW9kdWxlIH0gZnJvbSAnLi4vdXRpbGl0eS9hZGQtZGVjbGFyYXRpb24tdG8tbmctbW9kdWxlJztcbmltcG9ydCB7IGZpbmRNb2R1bGVGcm9tT3B0aW9ucyB9IGZyb20gJy4uL3V0aWxpdHkvZmluZC1tb2R1bGUnO1xuaW1wb3J0IHsgcGFyc2VOYW1lIH0gZnJvbSAnLi4vdXRpbGl0eS9wYXJzZS1uYW1lJztcbmltcG9ydCB7IHZhbGlkYXRlQ2xhc3NOYW1lIH0gZnJvbSAnLi4vdXRpbGl0eS92YWxpZGF0aW9uJztcbmltcG9ydCB7IGNyZWF0ZURlZmF1bHRQYXRoIH0gZnJvbSAnLi4vdXRpbGl0eS93b3Jrc3BhY2UnO1xuaW1wb3J0IHsgU2NoZW1hIGFzIFBpcGVPcHRpb25zIH0gZnJvbSAnLi9zY2hlbWEnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAob3B0aW9uczogUGlwZU9wdGlvbnMpOiBSdWxlIHtcbiAgcmV0dXJuIGFzeW5jIChob3N0OiBUcmVlKSA9PiB7XG4gICAgb3B0aW9ucy5wYXRoID8/PSBhd2FpdCBjcmVhdGVEZWZhdWx0UGF0aChob3N0LCBvcHRpb25zLnByb2plY3QgYXMgc3RyaW5nKTtcbiAgICBvcHRpb25zLm1vZHVsZSA9IGZpbmRNb2R1bGVGcm9tT3B0aW9ucyhob3N0LCBvcHRpb25zKTtcblxuICAgIGNvbnN0IHBhcnNlZFBhdGggPSBwYXJzZU5hbWUob3B0aW9ucy5wYXRoLCBvcHRpb25zLm5hbWUpO1xuICAgIG9wdGlvbnMubmFtZSA9IHBhcnNlZFBhdGgubmFtZTtcbiAgICBvcHRpb25zLnBhdGggPSBwYXJzZWRQYXRoLnBhdGg7XG4gICAgdmFsaWRhdGVDbGFzc05hbWUoc3RyaW5ncy5jbGFzc2lmeShvcHRpb25zLm5hbWUpKTtcblxuICAgIGNvbnN0IHRlbXBsYXRlU291cmNlID0gYXBwbHkodXJsKCcuL2ZpbGVzJyksIFtcbiAgICAgIG9wdGlvbnMuc2tpcFRlc3RzID8gZmlsdGVyKChwYXRoKSA9PiAhcGF0aC5lbmRzV2l0aCgnLnNwZWMudHMudGVtcGxhdGUnKSkgOiBub29wKCksXG4gICAgICBhcHBseVRlbXBsYXRlcyh7XG4gICAgICAgIC4uLnN0cmluZ3MsXG4gICAgICAgICdpZi1mbGF0JzogKHM6IHN0cmluZykgPT4gKG9wdGlvbnMuZmxhdCA/ICcnIDogcyksXG4gICAgICAgIC4uLm9wdGlvbnMsXG4gICAgICB9KSxcbiAgICAgIG1vdmUocGFyc2VkUGF0aC5wYXRoKSxcbiAgICBdKTtcblxuICAgIHJldHVybiBjaGFpbihbXG4gICAgICBhZGREZWNsYXJhdGlvblRvTmdNb2R1bGUoe1xuICAgICAgICB0eXBlOiAncGlwZScsXG5cbiAgICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIH0pLFxuICAgICAgbWVyZ2VXaXRoKHRlbXBsYXRlU291cmNlKSxcbiAgICBdKTtcbiAgfTtcbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zY2hlbWF0aWNzL2FuZ3VsYXIvcGlwZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOztBQUVILDJEQVlvQztBQUNwQywwRkFBbUY7QUFDbkYsd0RBQStEO0FBQy9ELHNEQUFrRDtBQUNsRCxzREFBMEQ7QUFDMUQsb0RBQXlEO0FBR3pELG1CQUF5QixPQUFvQjtJQUMzQyxPQUFPLEtBQUssRUFBRSxJQUFVLEVBQUUsRUFBRTtRQUMxQixPQUFPLENBQUMsSUFBSSxLQUFLLE1BQU0sSUFBQSw2QkFBaUIsRUFBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLE9BQWlCLENBQUMsQ0FBQztRQUMxRSxPQUFPLENBQUMsTUFBTSxHQUFHLElBQUEsbUNBQXFCLEVBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBRXRELE1BQU0sVUFBVSxHQUFHLElBQUEsc0JBQVMsRUFBQyxPQUFPLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxPQUFPLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUM7UUFDL0IsT0FBTyxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQy9CLElBQUEsOEJBQWlCLEVBQUMsb0JBQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFbEQsTUFBTSxjQUFjLEdBQUcsSUFBQSxrQkFBSyxFQUFDLElBQUEsZ0JBQUcsRUFBQyxTQUFTLENBQUMsRUFBRTtZQUMzQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFBLG1CQUFNLEVBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUEsaUJBQUksR0FBRTtZQUNsRixJQUFBLDJCQUFjLEVBQUM7Z0JBQ2IsR0FBRyxvQkFBTztnQkFDVixTQUFTLEVBQUUsQ0FBQyxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2pELEdBQUcsT0FBTzthQUNYLENBQUM7WUFDRixJQUFBLGlCQUFJLEVBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztTQUN0QixDQUFDLENBQUM7UUFFSCxPQUFPLElBQUEsa0JBQUssRUFBQztZQUNYLElBQUEsdURBQXdCLEVBQUM7Z0JBQ3ZCLElBQUksRUFBRSxNQUFNO2dCQUVaLEdBQUcsT0FBTzthQUNYLENBQUM7WUFDRixJQUFBLHNCQUFTLEVBQUMsY0FBYyxDQUFDO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQztBQUNKLENBQUM7QUE3QkQsNEJBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7XG4gIFJ1bGUsXG4gIFRyZWUsXG4gIGFwcGx5LFxuICBhcHBseVRlbXBsYXRlcyxcbiAgY2hhaW4sXG4gIGZpbHRlcixcbiAgbWVyZ2VXaXRoLFxuICBtb3ZlLFxuICBub29wLFxuICBzdHJpbmdzLFxuICB1cmwsXG59IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9zY2hlbWF0aWNzJztcbmltcG9ydCB7IGFkZERlY2xhcmF0aW9uVG9OZ01vZHVsZSB9IGZyb20gJy4uL3V0aWxpdHkvYWRkLWRlY2xhcmF0aW9uLXRvLW5nLW1vZHVsZSc7XG5pbXBvcnQgeyBmaW5kTW9kdWxlRnJvbU9wdGlvbnMgfSBmcm9tICcuLi91dGlsaXR5L2ZpbmQtbW9kdWxlJztcbmltcG9ydCB7IHBhcnNlTmFtZSB9IGZyb20gJy4uL3V0aWxpdHkvcGFyc2UtbmFtZSc7XG5pbXBvcnQgeyB2YWxpZGF0ZUNsYXNzTmFtZSB9IGZyb20gJy4uL3V0aWxpdHkvdmFsaWRhdGlvbic7XG5pbXBvcnQgeyBjcmVhdGVEZWZhdWx0UGF0aCB9IGZyb20gJy4uL3V0aWxpdHkvd29ya3NwYWNlJztcbmltcG9ydCB7IFNjaGVtYSBhcyBQaXBlT3B0aW9ucyB9IGZyb20gJy4vc2NoZW1hJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKG9wdGlvbnM6IFBpcGVPcHRpb25zKTogUnVsZSB7XG4gIHJldHVybiBhc3luYyAoaG9zdDogVHJlZSkgPT4ge1xuICAgIG9wdGlvbnMucGF0aCA/Pz0gYXdhaXQgY3JlYXRlRGVmYXVsdFBhdGgoaG9zdCwgb3B0aW9ucy5wcm9qZWN0IGFzIHN0cmluZyk7XG4gICAgb3B0aW9ucy5tb2R1bGUgPSBmaW5kTW9kdWxlRnJvbU9wdGlvbnMoaG9zdCwgb3B0aW9ucyk7XG5cbiAgICBjb25zdCBwYXJzZWRQYXRoID0gcGFyc2VOYW1lKG9wdGlvbnMucGF0aCwgb3B0aW9ucy5uYW1lKTtcbiAgICBvcHRpb25zLm5hbWUgPSBwYXJzZWRQYXRoLm5hbWU7XG4gICAgb3B0aW9ucy5wYXRoID0gcGFyc2VkUGF0aC5wYXRoO1xuICAgIHZhbGlkYXRlQ2xhc3NOYW1lKHN0cmluZ3MuY2xhc3NpZnkob3B0aW9ucy5uYW1lKSk7XG5cbiAgICBjb25zdCB0ZW1wbGF0ZVNvdXJjZSA9IGFwcGx5KHVybCgnLi9maWxlcycpLCBbXG4gICAgICBvcHRpb25zLnNraXBUZXN0cyA/IGZpbHRlcigocGF0aCkgPT4gIXBhdGguZW5kc1dpdGgoJy5zcGVjLnRzLnRlbXBsYXRlJykpIDogbm9vcCgpLFxuICAgICAgYXBwbHlUZW1wbGF0ZXMoe1xuICAgICAgICAuLi5zdHJpbmdzLFxuICAgICAgICAnaWYtZmxhdCc6IChzOiBzdHJpbmcpID0+IChvcHRpb25zLmZsYXQgPyAnJyA6IHMpLFxuICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgfSksXG4gICAgICBtb3ZlKHBhcnNlZFBhdGgucGF0aCksXG4gICAgXSk7XG5cbiAgICByZXR1cm4gY2hhaW4oW1xuICAgICAgYWRkRGVjbGFyYXRpb25Ub05nTW9kdWxlKHtcbiAgICAgICAgdHlwZTogJ3BpcGUnLFxuXG4gICAgICAgIC4uLm9wdGlvbnMsXG4gICAgICB9KSxcbiAgICAgIG1lcmdlV2l0aCh0ZW1wbGF0ZVNvdXJjZSksXG4gICAgXSk7XG4gIH07XG59XG4iXX0=
@@ -9,6 +9,6 @@
9
9
  ]
10
10
  },
11
11
  "files": [
12
- "src/<%= stripTsExtension(main) %>.ts"
12
+ "src/main.server.ts"
13
13
  ]
14
14
  }
@@ -11,4 +11,4 @@ import { AppComponent } from './app.component';
11
11
  ],
12
12
  bootstrap: [AppComponent],
13
13
  })
14
- export class <%= rootModuleClassName %> {}
14
+ export class AppServerModule {}
@@ -0,0 +1 @@
1
+ export { AppServerModule as default } from './app/app.module.server';
@@ -6,5 +6,5 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  import { Rule } from '@angular-devkit/schematics';
9
- import { Schema as UniversalOptions } from './schema';
10
- export default function (options: UniversalOptions): Rule;
9
+ import { Schema as ServerOptions } from './schema';
10
+ export default function (options: ServerOptions): Rule;
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ const core_1 = require("@angular-devkit/core");
11
+ const schematics_1 = require("@angular-devkit/schematics");
12
+ const tasks_1 = require("@angular-devkit/schematics/tasks");
13
+ const node_path_1 = require("node:path");
14
+ const dependencies_1 = require("../utility/dependencies");
15
+ const json_file_1 = require("../utility/json-file");
16
+ const latest_versions_1 = require("../utility/latest-versions");
17
+ const ng_ast_utils_1 = require("../utility/ng-ast-utils");
18
+ const paths_1 = require("../utility/paths");
19
+ const project_targets_1 = require("../utility/project-targets");
20
+ const util_1 = require("../utility/standalone/util");
21
+ const workspace_1 = require("../utility/workspace");
22
+ const workspace_models_1 = require("../utility/workspace-models");
23
+ const serverMainEntryName = 'main.server.ts';
24
+ function updateConfigFileBrowserBuilder(options, tsConfigDirectory) {
25
+ return (0, workspace_1.updateWorkspace)((workspace) => {
26
+ const clientProject = workspace.projects.get(options.project);
27
+ if (clientProject) {
28
+ // In case the browser builder hashes the assets
29
+ // we need to add this setting to the server builder
30
+ // as otherwise when assets it will be requested twice.
31
+ // One for the server which will be unhashed, and other on the client which will be hashed.
32
+ const getServerOptions = (options = {}) => {
33
+ return {
34
+ buildOptimizer: options?.buildOptimizer,
35
+ outputHashing: options?.outputHashing === 'all' ? 'media' : options?.outputHashing,
36
+ fileReplacements: options?.fileReplacements,
37
+ optimization: options?.optimization === undefined ? undefined : !!options?.optimization,
38
+ sourceMap: options?.sourceMap,
39
+ localization: options?.localization,
40
+ stylePreprocessorOptions: options?.stylePreprocessorOptions,
41
+ resourcesOutputPath: options?.resourcesOutputPath,
42
+ deployUrl: options?.deployUrl,
43
+ i18nMissingTranslation: options?.i18nMissingTranslation,
44
+ preserveSymlinks: options?.preserveSymlinks,
45
+ extractLicenses: options?.extractLicenses,
46
+ inlineStyleLanguage: options?.inlineStyleLanguage,
47
+ vendorChunk: options?.vendorChunk,
48
+ };
49
+ };
50
+ const buildTarget = clientProject.targets.get('build');
51
+ if (buildTarget?.options) {
52
+ buildTarget.options.outputPath = `dist/${options.project}/browser`;
53
+ }
54
+ const buildConfigurations = buildTarget?.configurations;
55
+ const configurations = {};
56
+ if (buildConfigurations) {
57
+ for (const [key, options] of Object.entries(buildConfigurations)) {
58
+ configurations[key] = getServerOptions(options);
59
+ }
60
+ }
61
+ const sourceRoot = clientProject.sourceRoot ?? (0, core_1.join)((0, core_1.normalize)(clientProject.root), 'src');
62
+ const serverTsConfig = (0, core_1.join)(tsConfigDirectory, 'tsconfig.server.json');
63
+ clientProject.targets.add({
64
+ name: 'server',
65
+ builder: workspace_models_1.Builders.Server,
66
+ defaultConfiguration: 'production',
67
+ options: {
68
+ outputPath: `dist/${options.project}/server`,
69
+ main: (0, core_1.join)((0, core_1.normalize)(sourceRoot), serverMainEntryName),
70
+ tsConfig: serverTsConfig,
71
+ ...(buildTarget?.options ? getServerOptions(buildTarget?.options) : {}),
72
+ },
73
+ configurations,
74
+ });
75
+ }
76
+ });
77
+ }
78
+ function updateConfigFileApplicationBuilder(options) {
79
+ return (0, workspace_1.updateWorkspace)((workspace) => {
80
+ const project = workspace.projects.get(options.project);
81
+ if (!project) {
82
+ return;
83
+ }
84
+ const buildTarget = project.targets.get('build');
85
+ if (buildTarget?.builder !== workspace_models_1.Builders.Application) {
86
+ throw new schematics_1.SchematicsException(`This schematic requires "${workspace_models_1.Builders.Application}" to be used as a build builder.`);
87
+ }
88
+ buildTarget.options ??= {};
89
+ buildTarget.options['server'] = node_path_1.posix.join(project.sourceRoot ?? node_path_1.posix.join(project.root, 'src'), serverMainEntryName);
90
+ });
91
+ }
92
+ function updateTsConfigFile(tsConfigPath) {
93
+ return (host) => {
94
+ const json = new json_file_1.JSONFile(host, tsConfigPath);
95
+ const filesPath = ['files'];
96
+ const files = new Set(json.get(filesPath) ?? []);
97
+ files.add('src/' + serverMainEntryName);
98
+ json.modify(filesPath, [...files]);
99
+ const typePath = ['compilerOptions', 'types'];
100
+ const types = new Set(json.get(typePath) ?? []);
101
+ types.add('node');
102
+ json.modify(typePath, [...types]);
103
+ };
104
+ }
105
+ function addDependencies() {
106
+ return (host) => {
107
+ const coreDep = (0, dependencies_1.getPackageJsonDependency)(host, '@angular/core');
108
+ if (coreDep === null) {
109
+ throw new schematics_1.SchematicsException('Could not find version.');
110
+ }
111
+ const platformServerDep = {
112
+ ...coreDep,
113
+ name: '@angular/platform-server',
114
+ };
115
+ (0, dependencies_1.addPackageJsonDependency)(host, platformServerDep);
116
+ (0, dependencies_1.addPackageJsonDependency)(host, {
117
+ type: dependencies_1.NodeDependencyType.Dev,
118
+ name: '@types/node',
119
+ version: latest_versions_1.latestVersions['@types/node'],
120
+ });
121
+ };
122
+ }
123
+ function default_1(options) {
124
+ return async (host, context) => {
125
+ const workspace = await (0, workspace_1.getWorkspace)(host);
126
+ const clientProject = workspace.projects.get(options.project);
127
+ if (clientProject?.extensions.projectType !== 'application') {
128
+ throw new schematics_1.SchematicsException(`Server schematic requires a project type of "application".`);
129
+ }
130
+ const clientBuildTarget = clientProject.targets.get('build');
131
+ if (!clientBuildTarget) {
132
+ throw (0, project_targets_1.targetBuildNotFoundError)();
133
+ }
134
+ const isUsingApplicationBuilder = clientBuildTarget.builder === workspace_models_1.Builders.Application;
135
+ if (clientProject.targets.has('server') ||
136
+ (isUsingApplicationBuilder && clientBuildTarget.options?.server !== undefined)) {
137
+ // Server has already been added.
138
+ return;
139
+ }
140
+ if (!options.skipInstall) {
141
+ context.addTask(new tasks_1.NodePackageInstallTask());
142
+ }
143
+ const clientBuildOptions = clientBuildTarget.options;
144
+ const browserEntryPoint = await (0, util_1.getMainFilePath)(host, options.project);
145
+ const isStandalone = (0, ng_ast_utils_1.isStandaloneApp)(host, browserEntryPoint);
146
+ const templateSource = (0, schematics_1.apply)((0, schematics_1.url)(isStandalone ? './files/standalone-src' : './files/src'), [
147
+ (0, schematics_1.applyTemplates)({
148
+ ...schematics_1.strings,
149
+ ...options,
150
+ }),
151
+ (0, schematics_1.move)((0, core_1.join)((0, core_1.normalize)(clientProject.root), 'src')),
152
+ ]);
153
+ const clientTsConfig = (0, core_1.normalize)(clientBuildOptions.tsConfig);
154
+ const tsConfigExtends = (0, core_1.basename)(clientTsConfig);
155
+ const tsConfigDirectory = (0, core_1.dirname)(clientTsConfig);
156
+ return (0, schematics_1.chain)([
157
+ (0, schematics_1.mergeWith)(templateSource),
158
+ ...(isUsingApplicationBuilder
159
+ ? [
160
+ updateConfigFileApplicationBuilder(options),
161
+ updateTsConfigFile(clientBuildOptions.tsConfig),
162
+ ]
163
+ : [
164
+ (0, schematics_1.mergeWith)((0, schematics_1.apply)((0, schematics_1.url)('./files/root'), [
165
+ (0, schematics_1.applyTemplates)({
166
+ ...schematics_1.strings,
167
+ ...options,
168
+ stripTsExtension: (s) => s.replace(/\.ts$/, ''),
169
+ tsConfigExtends,
170
+ hasLocalizePackage: !!(0, dependencies_1.getPackageJsonDependency)(host, '@angular/localize'),
171
+ relativePathToWorkspaceRoot: (0, paths_1.relativePathToWorkspaceRoot)(tsConfigDirectory),
172
+ }),
173
+ (0, schematics_1.move)(tsConfigDirectory),
174
+ ])),
175
+ updateConfigFileBrowserBuilder(options, tsConfigDirectory),
176
+ ]),
177
+ addDependencies(),
178
+ ]);
179
+ };
180
+ }
181
+ exports.default = default_1;
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/server/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { JsonValue, Path, basename, dirname, join, normalize } from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  SchematicsException,\n  Tree,\n  apply,\n  applyTemplates,\n  chain,\n  mergeWith,\n  move,\n  strings,\n  url,\n} from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport { posix } from 'node:path';\nimport {\n  NodeDependencyType,\n  addPackageJsonDependency,\n  getPackageJsonDependency,\n} from '../utility/dependencies';\nimport { JSONFile } from '../utility/json-file';\nimport { latestVersions } from '../utility/latest-versions';\nimport { isStandaloneApp } from '../utility/ng-ast-utils';\nimport { relativePathToWorkspaceRoot } from '../utility/paths';\nimport { targetBuildNotFoundError } from '../utility/project-targets';\nimport { getMainFilePath } from '../utility/standalone/util';\nimport { getWorkspace, updateWorkspace } from '../utility/workspace';\nimport { Builders } from '../utility/workspace-models';\nimport { Schema as ServerOptions } from './schema';\n\nconst serverMainEntryName = 'main.server.ts';\n\nfunction updateConfigFileBrowserBuilder(options: ServerOptions, tsConfigDirectory: Path): Rule {\n  return updateWorkspace((workspace) => {\n    const clientProject = workspace.projects.get(options.project);\n\n    if (clientProject) {\n      // In case the browser builder hashes the assets\n      // we need to add this setting to the server builder\n      // as otherwise when assets it will be requested twice.\n      // One for the server which will be unhashed, and other on the client which will be hashed.\n      const getServerOptions = (options: Record<string, JsonValue | undefined> = {}): {} => {\n        return {\n          buildOptimizer: options?.buildOptimizer,\n          outputHashing: options?.outputHashing === 'all' ? 'media' : options?.outputHashing,\n          fileReplacements: options?.fileReplacements,\n          optimization: options?.optimization === undefined ? undefined : !!options?.optimization,\n          sourceMap: options?.sourceMap,\n          localization: options?.localization,\n          stylePreprocessorOptions: options?.stylePreprocessorOptions,\n          resourcesOutputPath: options?.resourcesOutputPath,\n          deployUrl: options?.deployUrl,\n          i18nMissingTranslation: options?.i18nMissingTranslation,\n          preserveSymlinks: options?.preserveSymlinks,\n          extractLicenses: options?.extractLicenses,\n          inlineStyleLanguage: options?.inlineStyleLanguage,\n          vendorChunk: options?.vendorChunk,\n        };\n      };\n\n      const buildTarget = clientProject.targets.get('build');\n      if (buildTarget?.options) {\n        buildTarget.options.outputPath = `dist/${options.project}/browser`;\n      }\n\n      const buildConfigurations = buildTarget?.configurations;\n      const configurations: Record<string, {}> = {};\n      if (buildConfigurations) {\n        for (const [key, options] of Object.entries(buildConfigurations)) {\n          configurations[key] = getServerOptions(options);\n        }\n      }\n\n      const sourceRoot = clientProject.sourceRoot ?? join(normalize(clientProject.root), 'src');\n      const serverTsConfig = join(tsConfigDirectory, 'tsconfig.server.json');\n      clientProject.targets.add({\n        name: 'server',\n        builder: Builders.Server,\n        defaultConfiguration: 'production',\n        options: {\n          outputPath: `dist/${options.project}/server`,\n          main: join(normalize(sourceRoot), serverMainEntryName),\n          tsConfig: serverTsConfig,\n          ...(buildTarget?.options ? getServerOptions(buildTarget?.options) : {}),\n        },\n        configurations,\n      });\n    }\n  });\n}\n\nfunction updateConfigFileApplicationBuilder(options: ServerOptions): Rule {\n  return updateWorkspace((workspace) => {\n    const project = workspace.projects.get(options.project);\n    if (!project) {\n      return;\n    }\n\n    const buildTarget = project.targets.get('build');\n    if (buildTarget?.builder !== Builders.Application) {\n      throw new SchematicsException(\n        `This schematic requires \"${Builders.Application}\" to be used as a build builder.`,\n      );\n    }\n\n    buildTarget.options ??= {};\n    buildTarget.options['server'] = posix.join(\n      project.sourceRoot ?? posix.join(project.root, 'src'),\n      serverMainEntryName,\n    );\n  });\n}\n\nfunction updateTsConfigFile(tsConfigPath: string): Rule {\n  return (host: Tree) => {\n    const json = new JSONFile(host, tsConfigPath);\n    const filesPath = ['files'];\n    const files = new Set((json.get(filesPath) as string[] | undefined) ?? []);\n    files.add('src/' + serverMainEntryName);\n    json.modify(filesPath, [...files]);\n\n    const typePath = ['compilerOptions', 'types'];\n    const types = new Set((json.get(typePath) as string[] | undefined) ?? []);\n    types.add('node');\n    json.modify(typePath, [...types]);\n  };\n}\n\nfunction addDependencies(): Rule {\n  return (host: Tree) => {\n    const coreDep = getPackageJsonDependency(host, '@angular/core');\n    if (coreDep === null) {\n      throw new SchematicsException('Could not find version.');\n    }\n    const platformServerDep = {\n      ...coreDep,\n      name: '@angular/platform-server',\n    };\n    addPackageJsonDependency(host, platformServerDep);\n\n    addPackageJsonDependency(host, {\n      type: NodeDependencyType.Dev,\n      name: '@types/node',\n      version: latestVersions['@types/node'],\n    });\n  };\n}\n\nexport default function (options: ServerOptions): Rule {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const clientProject = workspace.projects.get(options.project);\n    if (clientProject?.extensions.projectType !== 'application') {\n      throw new SchematicsException(`Server schematic requires a project type of \"application\".`);\n    }\n\n    const clientBuildTarget = clientProject.targets.get('build');\n    if (!clientBuildTarget) {\n      throw targetBuildNotFoundError();\n    }\n\n    const isUsingApplicationBuilder = clientBuildTarget.builder === Builders.Application;\n    if (\n      clientProject.targets.has('server') ||\n      (isUsingApplicationBuilder && clientBuildTarget.options?.server !== undefined)\n    ) {\n      // Server has already been added.\n      return;\n    }\n\n    if (!options.skipInstall) {\n      context.addTask(new NodePackageInstallTask());\n    }\n    const clientBuildOptions = clientBuildTarget.options as Record<string, string>;\n    const browserEntryPoint = await getMainFilePath(host, options.project);\n    const isStandalone = isStandaloneApp(host, browserEntryPoint);\n\n    const templateSource = apply(url(isStandalone ? './files/standalone-src' : './files/src'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n      }),\n      move(join(normalize(clientProject.root), 'src')),\n    ]);\n\n    const clientTsConfig = normalize(clientBuildOptions.tsConfig);\n    const tsConfigExtends = basename(clientTsConfig);\n    const tsConfigDirectory = dirname(clientTsConfig);\n\n    return chain([\n      mergeWith(templateSource),\n      ...(isUsingApplicationBuilder\n        ? [\n            updateConfigFileApplicationBuilder(options),\n            updateTsConfigFile(clientBuildOptions.tsConfig),\n          ]\n        : [\n            mergeWith(\n              apply(url('./files/root'), [\n                applyTemplates({\n                  ...strings,\n                  ...options,\n                  stripTsExtension: (s: string) => s.replace(/\\.ts$/, ''),\n                  tsConfigExtends,\n                  hasLocalizePackage: !!getPackageJsonDependency(host, '@angular/localize'),\n                  relativePathToWorkspaceRoot: relativePathToWorkspaceRoot(tsConfigDirectory),\n                }),\n                move(tsConfigDirectory),\n              ]),\n            ),\n            updateConfigFileBrowserBuilder(options, tsConfigDirectory),\n          ]),\n      addDependencies(),\n    ]);\n  };\n}\n"]}
@@ -2,22 +2,10 @@
2
2
  * Pass this schematic to the "run" command to set up server-side rendering for an app.
3
3
  */
4
4
  export interface Schema {
5
- /**
6
- * The name of the main entry-point file.
7
- */
8
- main?: string;
9
5
  /**
10
6
  * The name of the project.
11
7
  */
12
8
  project: string;
13
- /**
14
- * The name of the root NgModule class.
15
- */
16
- rootModuleClassName?: string;
17
- /**
18
- * The name of the root NgModule file.
19
- */
20
- rootModuleFileName?: string;
21
9
  /**
22
10
  * Do not install packages for dependencies.
23
11
  */
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ // THIS FILE IS AUTOMATICALLY GENERATED. TO UPDATE THIS FILE YOU NEED TO CHANGE THE
3
+ // CORRESPONDING JSON SCHEMA FILE, THEN RUN devkit-admin build (or bazel build ...).
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc2NoZW1hdGljcy9hbmd1bGFyL3NlcnZlci9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLG1GQUFtRjtBQUNuRixvRkFBb0YiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8vIFRISVMgRklMRSBJUyBBVVRPTUFUSUNBTExZIEdFTkVSQVRFRC4gVE8gVVBEQVRFIFRISVMgRklMRSBZT1UgTkVFRCBUTyBDSEFOR0UgVEhFXG4vLyBDT1JSRVNQT05ESU5HIEpTT04gU0NIRU1BIEZJTEUsIFRIRU4gUlVOIGRldmtpdC1hZG1pbiBidWlsZCAob3IgYmF6ZWwgYnVpbGQgLi4uKS5cblxuLyoqXG4gKiBQYXNzIHRoaXMgc2NoZW1hdGljIHRvIHRoZSBcInJ1blwiIGNvbW1hbmQgdG8gc2V0IHVwIHNlcnZlci1zaWRlIHJlbmRlcmluZyBmb3IgYW4gYXBwLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYSB7XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIHByb2plY3QuXG4gICAgICovXG4gICAgcHJvamVjdDogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIERvIG5vdCBpbnN0YWxsIHBhY2thZ2VzIGZvciBkZXBlbmRlbmNpZXMuXG4gICAgICovXG4gICAgc2tpcEluc3RhbGw/OiBib29sZWFuO1xufVxuIl19
@@ -0,0 +1,23 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema",
3
+ "$id": "SchematicsAngularServerApp",
4
+ "title": "Angular Server App Options Schema",
5
+ "type": "object",
6
+ "additionalProperties": false,
7
+ "description": "Pass this schematic to the \"run\" command to set up server-side rendering for an app.",
8
+ "properties": {
9
+ "project": {
10
+ "type": "string",
11
+ "description": "The name of the project.",
12
+ "$default": {
13
+ "$source": "projectName"
14
+ }
15
+ },
16
+ "skipInstall": {
17
+ "description": "Do not install packages for dependencies.",
18
+ "type": "boolean",
19
+ "default": false
20
+ }
21
+ },
22
+ "required": ["project"]
23
+ }