@angular/core 15.1.0-next.0 → 15.1.0-next.2

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 (48) hide show
  1. package/esm2020/src/application_ref.mjs +13 -13
  2. package/esm2020/src/core.mjs +2 -1
  3. package/esm2020/src/core_render3_private_export.mjs +1 -2
  4. package/esm2020/src/di/create_injector.mjs +1 -1
  5. package/esm2020/src/di/r3_injector.mjs +7 -7
  6. package/esm2020/src/linker/query_list.mjs +7 -7
  7. package/esm2020/src/render/api.mjs +1 -3
  8. package/esm2020/src/render3/assert.mjs +1 -10
  9. package/esm2020/src/render3/component_ref.mjs +7 -18
  10. package/esm2020/src/render3/definition.mjs +9 -1
  11. package/esm2020/src/render3/index.mjs +2 -2
  12. package/esm2020/src/render3/instructions/shared.mjs +95 -169
  13. package/esm2020/src/render3/interfaces/context.mjs +5 -5
  14. package/esm2020/src/render3/interfaces/view.mjs +1 -10
  15. package/esm2020/src/render3/jit/module.mjs +2 -3
  16. package/esm2020/src/render3/namespaces.mjs +1 -8
  17. package/esm2020/src/render3/node_manipulation.mjs +3 -7
  18. package/esm2020/src/render3/node_selector_matcher.mjs +1 -4
  19. package/esm2020/src/render3/query.mjs +1 -6
  20. package/esm2020/src/render3/state.mjs +1 -4
  21. package/esm2020/src/render3/util/discovery_utils.mjs +3 -32
  22. package/esm2020/src/render3/util/view_utils.mjs +1 -15
  23. package/esm2020/src/render3/view_ref.mjs +6 -6
  24. package/esm2020/src/util/array_utils.mjs +3 -71
  25. package/esm2020/src/version.mjs +1 -1
  26. package/esm2020/testing/src/logger.mjs +3 -3
  27. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  28. package/fesm2015/core.mjs +282 -1253
  29. package/fesm2015/core.mjs.map +1 -1
  30. package/fesm2015/testing.mjs +287 -1258
  31. package/fesm2015/testing.mjs.map +1 -1
  32. package/fesm2020/core.mjs +282 -1253
  33. package/fesm2020/core.mjs.map +1 -1
  34. package/fesm2020/testing.mjs +287 -1258
  35. package/fesm2020/testing.mjs.map +1 -1
  36. package/index.d.ts +11 -224
  37. package/package.json +1 -1
  38. package/schematics/migrations/relative-link-resolution/util.d.ts +1 -1
  39. package/schematics/migrations/router-link-with-href/util.d.ts +1 -1
  40. package/schematics/migrations/typed-forms/util.d.ts +1 -1
  41. package/schematics/utils/import_manager.js +23 -3
  42. package/schematics/utils/ng_decorators.d.ts +1 -1
  43. package/schematics/utils/typescript/compiler_host.d.ts +1 -1
  44. package/schematics/utils/typescript/imports.d.ts +1 -1
  45. package/schematics/utils/typescript/property_name.d.ts +1 -1
  46. package/testing/index.d.ts +1 -1
  47. package/esm2020/src/render3/instructions/lview_debug.mjs +0 -684
  48. package/esm2020/src/util/named_array_type.mjs +0 -40
package/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v15.1.0-next.0
2
+ * @license Angular v15.1.0-next.2
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -2003,49 +2003,6 @@ export declare class DebugNode {
2003
2003
  get providerTokens(): any[];
2004
2004
  }
2005
2005
 
2006
- /**
2007
- * A logical node which comprise into `LView`s.
2008
- *
2009
- */
2010
- declare interface DebugNode_2 {
2011
- /**
2012
- * HTML representation of the node.
2013
- */
2014
- html: string | null;
2015
- /**
2016
- * Associated `TNode`
2017
- */
2018
- tNode: TNode;
2019
- /**
2020
- * Human readable node type.
2021
- */
2022
- type: string;
2023
- /**
2024
- * DOM native node.
2025
- */
2026
- native: Node;
2027
- /**
2028
- * Child nodes
2029
- */
2030
- children: DebugNode_2[];
2031
- /**
2032
- * A list of Component/Directive types which need to be instantiated an this location.
2033
- */
2034
- factories: Type<unknown>[];
2035
- /**
2036
- * A list of Component/Directive instances which were instantiated an this location.
2037
- */
2038
- instances: unknown[];
2039
- /**
2040
- * NodeInjector information.
2041
- */
2042
- injector: NodeInjectorDebug;
2043
- /**
2044
- * Injector resolution path.
2045
- */
2046
- injectorResolutionPath: any;
2047
- }
2048
-
2049
2006
  declare const DECLARATION_COMPONENT_VIEW = 16;
2050
2007
 
2051
2008
  declare const DECLARATION_LCONTAINER = 17;
@@ -4286,6 +4243,16 @@ declare interface InternalViewRef extends ViewRef {
4286
4243
  */
4287
4244
  export declare function isDevMode(): boolean;
4288
4245
 
4246
+ /**
4247
+ * Checks whether a given Component, Directive or Pipe is marked as standalone.
4248
+ * This will return false if passed anything other than a Component, Directive, or Pipe class
4249
+ * See this guide for additional information: https://angular.io/guide/standalone-components
4250
+ *
4251
+ * @param type A reference to a Component, Directive or Pipe.
4252
+ * @publicApi
4253
+ */
4254
+ export declare function isStandalone(type: Type<unknown>): boolean;
4255
+
4289
4256
  /**
4290
4257
  * Record representing the item change information.
4291
4258
  *
@@ -4643,28 +4610,6 @@ declare interface LContainer extends Array<any> {
4643
4610
  [VIEW_REFS]: unknown[] | null;
4644
4611
  }
4645
4612
 
4646
- /**
4647
- * Human readable version of the `LContainer`
4648
- *
4649
- * `LContainer` is a data structure used internally to keep track of child views. The `LContainer`
4650
- * is designed for efficiency and so at times it is difficult to read or write tests which assert on
4651
- * its values. For this reason when `ngDevMode` is true we patch a `LContainer.debug` property which
4652
- * points to `LContainerDebug` for easier debugging and test writing. It is the intent of
4653
- * `LContainerDebug` to be used in tests.
4654
- */
4655
- declare interface LContainerDebug {
4656
- readonly native: RComment;
4657
- /**
4658
- * Child `LView`s.
4659
- */
4660
- readonly views: LViewDebug[];
4661
- readonly parent: LViewDebug | null;
4662
- readonly movedViews: LView[] | null;
4663
- readonly host: RElement | RComment | LView;
4664
- readonly next: LViewDebug | LContainerDebug | null;
4665
- readonly hasTransplantedViews: boolean;
4666
- }
4667
-
4668
4613
  /**
4669
4614
  * Provide this token to set the locale of your application.
4670
4615
  * It is used for i18n extraction, by i18n pipes (DatePipe, I18nPluralPipe, CurrencyPipe,
@@ -4763,14 +4708,6 @@ declare interface LQuery<T> {
4763
4708
  * don't have to edit the data array based on which views are present.
4764
4709
  */
4765
4710
  declare interface LView<T = unknown> extends Array<any> {
4766
- /**
4767
- * Human readable representation of the `LView`.
4768
- *
4769
- * NOTE: This property only exists if `ngDevMode` is set to `true` and it is not present in
4770
- * production. Its presence is purely to help debug issue in development, and should not be relied
4771
- * on in production application.
4772
- */
4773
- debug?: LViewDebug;
4774
4711
  /**
4775
4712
  * The node into which this `LView` is inserted.
4776
4713
  */
@@ -5001,131 +4938,6 @@ declare interface LView<T = unknown> extends Array<any> {
5001
4938
  readonly [EMBEDDED_VIEW_INJECTOR]: Injector | null;
5002
4939
  }
5003
4940
 
5004
- /**
5005
- * Human readable version of the `LView`.
5006
- *
5007
- * `LView` is a data structure used internally to keep track of views. The `LView` is designed for
5008
- * efficiency and so at times it is difficult to read or write tests which assert on its values. For
5009
- * this reason when `ngDevMode` is true we patch a `LView.debug` property which points to
5010
- * `LViewDebug` for easier debugging and test writing. It is the intent of `LViewDebug` to be used
5011
- * in tests.
5012
- */
5013
- declare interface LViewDebug<T = unknown> {
5014
- /**
5015
- * Flags associated with the `LView` unpacked into a more readable state.
5016
- *
5017
- * See `LViewFlags` for the flag meanings.
5018
- */
5019
- readonly flags: {
5020
- initPhaseState: number;
5021
- creationMode: boolean;
5022
- firstViewPass: boolean;
5023
- checkAlways: boolean;
5024
- dirty: boolean;
5025
- attached: boolean;
5026
- destroyed: boolean;
5027
- isRoot: boolean;
5028
- indexWithinInitPhase: number;
5029
- };
5030
- /**
5031
- * Associated TView
5032
- */
5033
- readonly tView: TView;
5034
- /**
5035
- * Parent view (or container)
5036
- */
5037
- readonly parent: LViewDebug | LContainerDebug | null;
5038
- /**
5039
- * Next sibling to the `LView`.
5040
- */
5041
- readonly next: LViewDebug | LContainerDebug | null;
5042
- /**
5043
- * The context used for evaluation of the `LView`
5044
- *
5045
- * (Usually the component)
5046
- */
5047
- readonly context: T;
5048
- /**
5049
- * Hierarchical tree of nodes.
5050
- */
5051
- readonly nodes: DebugNode_2[];
5052
- /**
5053
- * Template structure (no instance data).
5054
- * (Shows how TNodes are connected)
5055
- */
5056
- readonly template: string;
5057
- /**
5058
- * HTML representation of the `LView`.
5059
- *
5060
- * This is only approximate to actual HTML as child `LView`s are removed.
5061
- */
5062
- readonly html: string;
5063
- /**
5064
- * The host element to which this `LView` is attached.
5065
- */
5066
- readonly hostHTML: string | null;
5067
- /**
5068
- * Child `LView`s
5069
- */
5070
- readonly childViews: Array<LViewDebug | LContainerDebug>;
5071
- /**
5072
- * Sub range of `LView` containing decls (DOM elements).
5073
- */
5074
- readonly decls: LViewDebugRange;
5075
- /**
5076
- * Sub range of `LView` containing vars (bindings).
5077
- */
5078
- readonly vars: LViewDebugRange;
5079
- /**
5080
- * Sub range of `LView` containing expando (used by DI).
5081
- */
5082
- readonly expando: LViewDebugRange;
5083
- }
5084
-
5085
- /**
5086
- * `LView` is subdivided to ranges where the actual data is stored. Some of these ranges such as
5087
- * `decls` and `vars` are known at compile time. Other such as `i18n` and `expando` are runtime only
5088
- * concepts.
5089
- */
5090
- declare interface LViewDebugRange {
5091
- /**
5092
- * The starting index in `LView` where the range begins. (Inclusive)
5093
- */
5094
- start: number;
5095
- /**
5096
- * The ending index in `LView` where the range ends. (Exclusive)
5097
- */
5098
- end: number;
5099
- /**
5100
- * The length of the range
5101
- */
5102
- length: number;
5103
- /**
5104
- * The merged content of the range. `t` contains data from `TView.data` and `l` contains `LView`
5105
- * data at an index.
5106
- */
5107
- content: LViewDebugRangeContent[];
5108
- }
5109
-
5110
- /**
5111
- * For convenience the static and instance portions of `TView` and `LView` are merged into a single
5112
- * object in `LViewRange`.
5113
- */
5114
- declare interface LViewDebugRangeContent {
5115
- /**
5116
- * Index into original `LView` or `TView.data`.
5117
- */
5118
- index: number;
5119
- /**
5120
- * Value from the `TView.data[index]` location.
5121
- */
5122
- t: any;
5123
- /**
5124
- * Value from the `LView[index]` location.
5125
- */
5126
- l: any;
5127
- }
5128
-
5129
4941
  /** Flags associated with an LView (saved in LView[FLAGS]) */
5130
4942
  declare const enum LViewFlags {
5131
4943
  /** The state of the init phase on the first 2 bits */
@@ -5689,29 +5501,6 @@ export declare class NgZone {
5689
5501
  */
5690
5502
  export declare const NO_ERRORS_SCHEMA: SchemaMetadata;
5691
5503
 
5692
- declare interface NodeInjectorDebug {
5693
- /**
5694
- * Instance bloom. Does the current injector have a provider with a given bloom mask.
5695
- */
5696
- bloom: string;
5697
- /**
5698
- * Cumulative bloom. Do any of the above injectors have a provider with a given bloom mask.
5699
- */
5700
- cumulativeBloom: string;
5701
- /**
5702
- * A list of providers associated with this injector.
5703
- */
5704
- providers: (Type<unknown> | ɵDirectiveDef<unknown> | ɵComponentDef<unknown>)[];
5705
- /**
5706
- * A list of providers associated with this injector visible to the view of the component only.
5707
- */
5708
- viewProviders: Type<unknown>[];
5709
- /**
5710
- * Location of the parent `TNode`.
5711
- */
5712
- parentInjectorIndex: number;
5713
- }
5714
-
5715
5504
  /**
5716
5505
  * @description
5717
5506
  * A lifecycle hook that is called when any data-bound property of a directive changes.
@@ -10517,8 +10306,6 @@ export declare const ɵisObservable: (obj: any | Observable<any>) => obj is Obse
10517
10306
  */
10518
10307
  export declare function ɵisPromise<T = any>(obj: any): obj is Promise<T>;
10519
10308
 
10520
- export declare function ɵisStandalone<T>(type: Type<T>): boolean;
10521
-
10522
10309
  /**
10523
10310
  * Determine if the argument is a Subscribable
10524
10311
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/core",
3
- "version": "15.1.0-next.0",
3
+ "version": "15.1.0-next.2",
4
4
  "description": "Angular - the core framework",
5
5
  "author": "angular",
6
6
  "license": "MIT",
@@ -16,5 +16,5 @@ export interface MigratableNode {
16
16
  objectLiteral: ts.ObjectLiteralExpression;
17
17
  property: ts.ObjectLiteralElementLike;
18
18
  }
19
- export declare type RewriteFn = (startPos: number, origLength: number, text: string) => void;
19
+ export type RewriteFn = (startPos: number, origLength: number, text: string) => void;
20
20
  export declare function migrateFile(sourceFile: ts.SourceFile, rewriteFn: RewriteFn): void;
@@ -15,5 +15,5 @@ export interface RewriteEntity {
15
15
  width: number;
16
16
  replacement: string;
17
17
  }
18
- export declare type RewriteFn = (startPos: number, width: number, text: string) => void;
18
+ export type RewriteFn = (startPos: number, width: number, text: string) => void;
19
19
  export declare function migrateFile(sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: RewriteFn): void;
@@ -15,5 +15,5 @@ export interface MigratableNode {
15
15
  node: ts.Node;
16
16
  importName: string;
17
17
  }
18
- export declare type rewriteFn = (startPos: number, origLength: number, text: string) => void;
18
+ export type rewriteFn = (startPos: number, origLength: number, text: string) => void;
19
19
  export declare function migrateFile(sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: rewriteFn): void;
@@ -22,6 +22,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
22
22
  exports.ImportManager = void 0;
23
23
  const path_1 = require("path");
24
24
  const typescript_1 = __importDefault(require("typescript"));
25
+ /** Whether the current TypeScript version is after 4.9. */
26
+ const IS_AFTER_TS_49 = isAfterVersion(4, 9);
25
27
  /**
26
28
  * Import manager that can be used to add TypeScript imports to given source
27
29
  * files. The manager ensures that multiple transformations are applied properly
@@ -124,11 +126,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
124
126
  const generatedUniqueIdentifier = this._getUniqueIdentifier(sourceFile, symbolName);
125
127
  const needsGeneratedUniqueName = generatedUniqueIdentifier.text !== symbolName;
126
128
  identifier = needsGeneratedUniqueName ? generatedUniqueIdentifier : propertyIdentifier;
127
- newImport = typescript_1.default.factory.createImportDeclaration(undefined, undefined, typescript_1.default.factory.createImportClause(false, undefined, typescript_1.default.factory.createNamedImports([typescript_1.default.factory.createImportSpecifier(false, needsGeneratedUniqueName ? propertyIdentifier : undefined, identifier)])), typescript_1.default.factory.createStringLiteral(moduleName));
129
+ newImport = createImportDeclaration(undefined, typescript_1.default.factory.createImportClause(false, undefined, typescript_1.default.factory.createNamedImports([typescript_1.default.factory.createImportSpecifier(false, needsGeneratedUniqueName ? propertyIdentifier : undefined, identifier)])), typescript_1.default.factory.createStringLiteral(moduleName));
128
130
  }
129
131
  else {
130
132
  identifier = this._getUniqueIdentifier(sourceFile, 'defaultExport');
131
- newImport = typescript_1.default.factory.createImportDeclaration(undefined, undefined, typescript_1.default.factory.createImportClause(false, identifier, undefined), typescript_1.default.factory.createStringLiteral(moduleName));
133
+ newImport = createImportDeclaration(undefined, typescript_1.default.factory.createImportClause(false, identifier, undefined), typescript_1.default.factory.createStringLiteral(moduleName));
132
134
  }
133
135
  const newImportText = this.printer.printNode(typescript_1.default.EmitHint.Unspecified, newImport, sourceFile);
134
136
  // If the import is generated at the start of the source file, we want to add
@@ -210,5 +212,23 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
210
212
  }
211
213
  }
212
214
  exports.ImportManager = ImportManager;
215
+ /**
216
+ * Creates a `ts.ImportDeclaration` declaration.
217
+ *
218
+ * TODO(crisbeto): this is a backwards-compatibility layer for versions of TypeScript less than 4.9.
219
+ * We should remove it once we have dropped support for the older versions.
220
+ */
221
+ function createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause) {
222
+ return IS_AFTER_TS_49 ? typescript_1.default.factory.createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause) :
223
+ typescript_1.default.factory.createImportDeclaration(undefined, modifiers, importClause, moduleSpecifier, assertClause);
224
+ }
225
+ /** Checks if the current version of TypeScript is after the specified major/minor versions. */
226
+ function isAfterVersion(targetMajor, targetMinor) {
227
+ const [major, minor] = typescript_1.default.versionMajorMinor.split('.').map(part => parseInt(part));
228
+ if (major < targetMajor) {
229
+ return false;
230
+ }
231
+ return major === targetMajor ? minor >= targetMinor : true;
232
+ }
213
233
  });
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import_manager.js","sourceRoot":"","sources":["../../../../../../../packages/core/schematics/utils/import_manager.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 {dirname, resolve} from 'path';\nimport ts from 'typescript';\n\n/** Update recorder for managing imports. */\nexport interface ImportManagerUpdateRecorder {\n  addNewImport(start: number, importText: string): void;\n  updateExistingImport(namedBindings: ts.NamedImports, newNamedBindings: string): void;\n}\n\n/**\n * Import manager that can be used to add TypeScript imports to given source\n * files. The manager ensures that multiple transformations are applied properly\n * without shifted offsets and that similar existing import declarations are re-used.\n */\nexport class ImportManager {\n  /** Map of import declarations that need to be updated to include the given symbols. */\n  private updatedImports =\n      new Map<ts.ImportDeclaration, {propertyName?: ts.Identifier, importName: ts.Identifier}[]>();\n  /** Map of source-files and their previously used identifier names. */\n  private usedIdentifierNames = new Map<ts.SourceFile, string[]>();\n  /**\n   * Array of previously resolved symbol imports. Cache can be re-used to return\n   * the same identifier without checking the source-file again.\n   */\n  private importCache: {\n    sourceFile: ts.SourceFile,\n    symbolName: string|null,\n    moduleName: string,\n    identifier: ts.Identifier\n  }[] = [];\n\n  constructor(\n      private getUpdateRecorder: (sf: ts.SourceFile) => ImportManagerUpdateRecorder,\n      private printer: ts.Printer) {}\n\n  /**\n   * Adds an import to the given source-file and returns the TypeScript\n   * identifier that can be used to access the newly imported symbol.\n   */\n  addImportToSourceFile(\n      sourceFile: ts.SourceFile, symbolName: string|null, moduleName: string,\n      typeImport = false): ts.Expression {\n    const sourceDir = dirname(sourceFile.fileName);\n    let importStartIndex = 0;\n    let existingImport: ts.ImportDeclaration|null = null;\n\n    // In case the given import has been already generated previously, we just return\n    // the previous generated identifier in order to avoid duplicate generated imports.\n    const cachedImport = this.importCache.find(\n        c => c.sourceFile === sourceFile && c.symbolName === symbolName &&\n            c.moduleName === moduleName);\n    if (cachedImport) {\n      return cachedImport.identifier;\n    }\n\n    // Walk through all source-file top-level statements and search for import declarations\n    // that already match the specified \"moduleName\" and can be updated to import the\n    // given symbol. If no matching import can be found, the last import in the source-file\n    // will be used as starting point for a new import that will be generated.\n    for (let i = sourceFile.statements.length - 1; i >= 0; i--) {\n      const statement = sourceFile.statements[i];\n\n      if (!ts.isImportDeclaration(statement) || !ts.isStringLiteral(statement.moduleSpecifier) ||\n          !statement.importClause) {\n        continue;\n      }\n\n      if (importStartIndex === 0) {\n        importStartIndex = this._getEndPositionOfNode(statement);\n      }\n\n      const moduleSpecifier = statement.moduleSpecifier.text;\n\n      if (moduleSpecifier.startsWith('.') &&\n              resolve(sourceDir, moduleSpecifier) !== resolve(sourceDir, moduleName) ||\n          moduleSpecifier !== moduleName) {\n        continue;\n      }\n\n      if (statement.importClause.namedBindings) {\n        const namedBindings = statement.importClause.namedBindings;\n\n        // In case a \"Type\" symbol is imported, we can't use namespace imports\n        // because these only export symbols available at runtime (no types)\n        if (ts.isNamespaceImport(namedBindings) && !typeImport) {\n          return ts.factory.createPropertyAccessExpression(\n              ts.factory.createIdentifier(namedBindings.name.text),\n              ts.factory.createIdentifier(symbolName || 'default'));\n        } else if (ts.isNamedImports(namedBindings) && symbolName) {\n          const existingElement = namedBindings.elements.find(\n              e =>\n                  e.propertyName ? e.propertyName.text === symbolName : e.name.text === symbolName);\n\n          if (existingElement) {\n            return ts.factory.createIdentifier(existingElement.name.text);\n          }\n\n          // In case the symbol could not be found in an existing import, we\n          // keep track of the import declaration as it can be updated to include\n          // the specified symbol name without having to create a new import.\n          existingImport = statement;\n        }\n      } else if (statement.importClause.name && !symbolName) {\n        return ts.factory.createIdentifier(statement.importClause.name.text);\n      }\n    }\n\n    if (existingImport) {\n      const propertyIdentifier = ts.factory.createIdentifier(symbolName!);\n      const generatedUniqueIdentifier = this._getUniqueIdentifier(sourceFile, symbolName!);\n      const needsGeneratedUniqueName = generatedUniqueIdentifier.text !== symbolName;\n      const importName = needsGeneratedUniqueName ? generatedUniqueIdentifier : propertyIdentifier;\n\n      // Since it can happen that multiple classes need to be imported within the\n      // specified source file and we want to add the identifiers to the existing\n      // import declaration, we need to keep track of the updated import declarations.\n      // We can't directly update the import declaration for each identifier as this\n      // would throw off the recorder offsets. We need to keep track of the new identifiers\n      // for the import and perform the import transformation as batches per source-file.\n      this.updatedImports.set(\n          existingImport, (this.updatedImports.get(existingImport) || []).concat({\n            propertyName: needsGeneratedUniqueName ? propertyIdentifier : undefined,\n            importName: importName,\n          }));\n\n      // Keep track of all updated imports so that we don't generate duplicate\n      // similar imports as these can't be statically analyzed in the source-file yet.\n      this.importCache.push({sourceFile, moduleName, symbolName, identifier: importName});\n\n      return importName;\n    }\n\n    let identifier: ts.Identifier|null = null;\n    let newImport: ts.ImportDeclaration|null = null;\n\n    if (symbolName) {\n      const propertyIdentifier = ts.factory.createIdentifier(symbolName);\n      const generatedUniqueIdentifier = this._getUniqueIdentifier(sourceFile, symbolName);\n      const needsGeneratedUniqueName = generatedUniqueIdentifier.text !== symbolName;\n      identifier = needsGeneratedUniqueName ? generatedUniqueIdentifier : propertyIdentifier;\n\n      newImport = ts.factory.createImportDeclaration(\n          undefined, undefined,\n          ts.factory.createImportClause(\n              false, undefined,\n              ts.factory.createNamedImports([ts.factory.createImportSpecifier(\n                  false, needsGeneratedUniqueName ? propertyIdentifier : undefined, identifier)])),\n          ts.factory.createStringLiteral(moduleName));\n    } else {\n      identifier = this._getUniqueIdentifier(sourceFile, 'defaultExport');\n      newImport = ts.factory.createImportDeclaration(\n          undefined, undefined, ts.factory.createImportClause(false, identifier, undefined),\n          ts.factory.createStringLiteral(moduleName));\n    }\n\n    const newImportText = this.printer.printNode(ts.EmitHint.Unspecified, newImport, sourceFile);\n    // If the import is generated at the start of the source file, we want to add\n    // a new-line after the import. Otherwise if the import is generated after an\n    // existing import, we need to prepend a new-line so that the import is not on\n    // the same line as the existing import anchor.\n    this.getUpdateRecorder(sourceFile)\n        .addNewImport(\n            importStartIndex, importStartIndex === 0 ? `${newImportText}\\n` : `\\n${newImportText}`);\n\n    // Keep track of all generated imports so that we don't generate duplicate\n    // similar imports as these can't be statically analyzed in the source-file yet.\n    this.importCache.push({sourceFile, symbolName, moduleName, identifier});\n\n    return identifier;\n  }\n\n  /**\n   * Stores the collected import changes within the appropriate update recorders. The\n   * updated imports can only be updated *once* per source-file because previous updates\n   * could otherwise shift the source-file offsets.\n   */\n  recordChanges() {\n    this.updatedImports.forEach((expressions, importDecl) => {\n      const sourceFile = importDecl.getSourceFile();\n      const recorder = this.getUpdateRecorder(sourceFile);\n      const namedBindings = importDecl.importClause!.namedBindings as ts.NamedImports;\n      const newNamedBindings = ts.factory.updateNamedImports(\n          namedBindings,\n          namedBindings.elements.concat(expressions.map(\n              ({propertyName, importName}) =>\n                  ts.factory.createImportSpecifier(false, propertyName, importName))));\n\n      const newNamedBindingsText =\n          this.printer.printNode(ts.EmitHint.Unspecified, newNamedBindings, sourceFile);\n      recorder.updateExistingImport(namedBindings, newNamedBindingsText);\n    });\n  }\n\n  /** Gets an unique identifier with a base name for the given source file. */\n  private _getUniqueIdentifier(sourceFile: ts.SourceFile, baseName: string): ts.Identifier {\n    if (this.isUniqueIdentifierName(sourceFile, baseName)) {\n      this._recordUsedIdentifier(sourceFile, baseName);\n      return ts.factory.createIdentifier(baseName);\n    }\n\n    let name = null;\n    let counter = 1;\n    do {\n      name = `${baseName}_${counter++}`;\n    } while (!this.isUniqueIdentifierName(sourceFile, name));\n\n    this._recordUsedIdentifier(sourceFile, name!);\n    return ts.factory.createIdentifier(name!);\n  }\n\n  /**\n   * Checks whether the specified identifier name is used within the given\n   * source file.\n   */\n  private isUniqueIdentifierName(sourceFile: ts.SourceFile, name: string) {\n    if (this.usedIdentifierNames.has(sourceFile) &&\n        this.usedIdentifierNames.get(sourceFile)!.indexOf(name) !== -1) {\n      return false;\n    }\n\n    // Walk through the source file and search for an identifier matching\n    // the given name. In that case, it's not guaranteed that this name\n    // is unique in the given declaration scope and we just return false.\n    const nodeQueue: ts.Node[] = [sourceFile];\n    while (nodeQueue.length) {\n      const node = nodeQueue.shift()!;\n      if (ts.isIdentifier(node) && node.text === name) {\n        return false;\n      }\n      nodeQueue.push(...node.getChildren());\n    }\n    return true;\n  }\n\n  private _recordUsedIdentifier(sourceFile: ts.SourceFile, identifierName: string) {\n    this.usedIdentifierNames.set(\n        sourceFile, (this.usedIdentifierNames.get(sourceFile) || []).concat(identifierName));\n  }\n\n  /**\n   * Determines the full end of a given node. By default the end position of a node is\n   * before all trailing comments. This could mean that generated imports shift comments.\n   */\n  private _getEndPositionOfNode(node: ts.Node) {\n    const nodeEndPos = node.getEnd();\n    const commentRanges = ts.getTrailingCommentRanges(node.getSourceFile().text, nodeEndPos);\n    if (!commentRanges || !commentRanges.length) {\n      return nodeEndPos;\n    }\n    return commentRanges[commentRanges.length - 1]!.end;\n  }\n}\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import_manager.js","sourceRoot":"","sources":["../../../../../../../packages/core/schematics/utils/import_manager.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 {dirname, resolve} from 'path';\nimport ts from 'typescript';\n\n/** Whether the current TypeScript version is after 4.9. */\nconst IS_AFTER_TS_49 = isAfterVersion(4, 9);\n\n/** Update recorder for managing imports. */\nexport interface ImportManagerUpdateRecorder {\n  addNewImport(start: number, importText: string): void;\n  updateExistingImport(namedBindings: ts.NamedImports, newNamedBindings: string): void;\n}\n\n/**\n * Import manager that can be used to add TypeScript imports to given source\n * files. The manager ensures that multiple transformations are applied properly\n * without shifted offsets and that similar existing import declarations are re-used.\n */\nexport class ImportManager {\n  /** Map of import declarations that need to be updated to include the given symbols. */\n  private updatedImports =\n      new Map<ts.ImportDeclaration, {propertyName?: ts.Identifier, importName: ts.Identifier}[]>();\n  /** Map of source-files and their previously used identifier names. */\n  private usedIdentifierNames = new Map<ts.SourceFile, string[]>();\n  /**\n   * Array of previously resolved symbol imports. Cache can be re-used to return\n   * the same identifier without checking the source-file again.\n   */\n  private importCache: {\n    sourceFile: ts.SourceFile,\n    symbolName: string|null,\n    moduleName: string,\n    identifier: ts.Identifier\n  }[] = [];\n\n  constructor(\n      private getUpdateRecorder: (sf: ts.SourceFile) => ImportManagerUpdateRecorder,\n      private printer: ts.Printer) {}\n\n  /**\n   * Adds an import to the given source-file and returns the TypeScript\n   * identifier that can be used to access the newly imported symbol.\n   */\n  addImportToSourceFile(\n      sourceFile: ts.SourceFile, symbolName: string|null, moduleName: string,\n      typeImport = false): ts.Expression {\n    const sourceDir = dirname(sourceFile.fileName);\n    let importStartIndex = 0;\n    let existingImport: ts.ImportDeclaration|null = null;\n\n    // In case the given import has been already generated previously, we just return\n    // the previous generated identifier in order to avoid duplicate generated imports.\n    const cachedImport = this.importCache.find(\n        c => c.sourceFile === sourceFile && c.symbolName === symbolName &&\n            c.moduleName === moduleName);\n    if (cachedImport) {\n      return cachedImport.identifier;\n    }\n\n    // Walk through all source-file top-level statements and search for import declarations\n    // that already match the specified \"moduleName\" and can be updated to import the\n    // given symbol. If no matching import can be found, the last import in the source-file\n    // will be used as starting point for a new import that will be generated.\n    for (let i = sourceFile.statements.length - 1; i >= 0; i--) {\n      const statement = sourceFile.statements[i];\n\n      if (!ts.isImportDeclaration(statement) || !ts.isStringLiteral(statement.moduleSpecifier) ||\n          !statement.importClause) {\n        continue;\n      }\n\n      if (importStartIndex === 0) {\n        importStartIndex = this._getEndPositionOfNode(statement);\n      }\n\n      const moduleSpecifier = statement.moduleSpecifier.text;\n\n      if (moduleSpecifier.startsWith('.') &&\n              resolve(sourceDir, moduleSpecifier) !== resolve(sourceDir, moduleName) ||\n          moduleSpecifier !== moduleName) {\n        continue;\n      }\n\n      if (statement.importClause.namedBindings) {\n        const namedBindings = statement.importClause.namedBindings;\n\n        // In case a \"Type\" symbol is imported, we can't use namespace imports\n        // because these only export symbols available at runtime (no types)\n        if (ts.isNamespaceImport(namedBindings) && !typeImport) {\n          return ts.factory.createPropertyAccessExpression(\n              ts.factory.createIdentifier(namedBindings.name.text),\n              ts.factory.createIdentifier(symbolName || 'default'));\n        } else if (ts.isNamedImports(namedBindings) && symbolName) {\n          const existingElement = namedBindings.elements.find(\n              e =>\n                  e.propertyName ? e.propertyName.text === symbolName : e.name.text === symbolName);\n\n          if (existingElement) {\n            return ts.factory.createIdentifier(existingElement.name.text);\n          }\n\n          // In case the symbol could not be found in an existing import, we\n          // keep track of the import declaration as it can be updated to include\n          // the specified symbol name without having to create a new import.\n          existingImport = statement;\n        }\n      } else if (statement.importClause.name && !symbolName) {\n        return ts.factory.createIdentifier(statement.importClause.name.text);\n      }\n    }\n\n    if (existingImport) {\n      const propertyIdentifier = ts.factory.createIdentifier(symbolName!);\n      const generatedUniqueIdentifier = this._getUniqueIdentifier(sourceFile, symbolName!);\n      const needsGeneratedUniqueName = generatedUniqueIdentifier.text !== symbolName;\n      const importName = needsGeneratedUniqueName ? generatedUniqueIdentifier : propertyIdentifier;\n\n      // Since it can happen that multiple classes need to be imported within the\n      // specified source file and we want to add the identifiers to the existing\n      // import declaration, we need to keep track of the updated import declarations.\n      // We can't directly update the import declaration for each identifier as this\n      // would throw off the recorder offsets. We need to keep track of the new identifiers\n      // for the import and perform the import transformation as batches per source-file.\n      this.updatedImports.set(\n          existingImport, (this.updatedImports.get(existingImport) || []).concat({\n            propertyName: needsGeneratedUniqueName ? propertyIdentifier : undefined,\n            importName: importName,\n          }));\n\n      // Keep track of all updated imports so that we don't generate duplicate\n      // similar imports as these can't be statically analyzed in the source-file yet.\n      this.importCache.push({sourceFile, moduleName, symbolName, identifier: importName});\n\n      return importName;\n    }\n\n    let identifier: ts.Identifier|null = null;\n    let newImport: ts.ImportDeclaration|null = null;\n\n    if (symbolName) {\n      const propertyIdentifier = ts.factory.createIdentifier(symbolName);\n      const generatedUniqueIdentifier = this._getUniqueIdentifier(sourceFile, symbolName);\n      const needsGeneratedUniqueName = generatedUniqueIdentifier.text !== symbolName;\n      identifier = needsGeneratedUniqueName ? generatedUniqueIdentifier : propertyIdentifier;\n\n      newImport = createImportDeclaration(\n          undefined,\n          ts.factory.createImportClause(\n              false, undefined,\n              ts.factory.createNamedImports([ts.factory.createImportSpecifier(\n                  false, needsGeneratedUniqueName ? propertyIdentifier : undefined, identifier)])),\n          ts.factory.createStringLiteral(moduleName));\n    } else {\n      identifier = this._getUniqueIdentifier(sourceFile, 'defaultExport');\n      newImport = createImportDeclaration(\n          undefined, ts.factory.createImportClause(false, identifier, undefined),\n          ts.factory.createStringLiteral(moduleName));\n    }\n\n    const newImportText = this.printer.printNode(ts.EmitHint.Unspecified, newImport, sourceFile);\n    // If the import is generated at the start of the source file, we want to add\n    // a new-line after the import. Otherwise if the import is generated after an\n    // existing import, we need to prepend a new-line so that the import is not on\n    // the same line as the existing import anchor.\n    this.getUpdateRecorder(sourceFile)\n        .addNewImport(\n            importStartIndex, importStartIndex === 0 ? `${newImportText}\\n` : `\\n${newImportText}`);\n\n    // Keep track of all generated imports so that we don't generate duplicate\n    // similar imports as these can't be statically analyzed in the source-file yet.\n    this.importCache.push({sourceFile, symbolName, moduleName, identifier});\n\n    return identifier;\n  }\n\n  /**\n   * Stores the collected import changes within the appropriate update recorders. The\n   * updated imports can only be updated *once* per source-file because previous updates\n   * could otherwise shift the source-file offsets.\n   */\n  recordChanges() {\n    this.updatedImports.forEach((expressions, importDecl) => {\n      const sourceFile = importDecl.getSourceFile();\n      const recorder = this.getUpdateRecorder(sourceFile);\n      const namedBindings = importDecl.importClause!.namedBindings as ts.NamedImports;\n      const newNamedBindings = ts.factory.updateNamedImports(\n          namedBindings,\n          namedBindings.elements.concat(expressions.map(\n              ({propertyName, importName}) =>\n                  ts.factory.createImportSpecifier(false, propertyName, importName))));\n\n      const newNamedBindingsText =\n          this.printer.printNode(ts.EmitHint.Unspecified, newNamedBindings, sourceFile);\n      recorder.updateExistingImport(namedBindings, newNamedBindingsText);\n    });\n  }\n\n  /** Gets an unique identifier with a base name for the given source file. */\n  private _getUniqueIdentifier(sourceFile: ts.SourceFile, baseName: string): ts.Identifier {\n    if (this.isUniqueIdentifierName(sourceFile, baseName)) {\n      this._recordUsedIdentifier(sourceFile, baseName);\n      return ts.factory.createIdentifier(baseName);\n    }\n\n    let name = null;\n    let counter = 1;\n    do {\n      name = `${baseName}_${counter++}`;\n    } while (!this.isUniqueIdentifierName(sourceFile, name));\n\n    this._recordUsedIdentifier(sourceFile, name!);\n    return ts.factory.createIdentifier(name!);\n  }\n\n  /**\n   * Checks whether the specified identifier name is used within the given\n   * source file.\n   */\n  private isUniqueIdentifierName(sourceFile: ts.SourceFile, name: string) {\n    if (this.usedIdentifierNames.has(sourceFile) &&\n        this.usedIdentifierNames.get(sourceFile)!.indexOf(name) !== -1) {\n      return false;\n    }\n\n    // Walk through the source file and search for an identifier matching\n    // the given name. In that case, it's not guaranteed that this name\n    // is unique in the given declaration scope and we just return false.\n    const nodeQueue: ts.Node[] = [sourceFile];\n    while (nodeQueue.length) {\n      const node = nodeQueue.shift()!;\n      if (ts.isIdentifier(node) && node.text === name) {\n        return false;\n      }\n      nodeQueue.push(...node.getChildren());\n    }\n    return true;\n  }\n\n  private _recordUsedIdentifier(sourceFile: ts.SourceFile, identifierName: string) {\n    this.usedIdentifierNames.set(\n        sourceFile, (this.usedIdentifierNames.get(sourceFile) || []).concat(identifierName));\n  }\n\n  /**\n   * Determines the full end of a given node. By default the end position of a node is\n   * before all trailing comments. This could mean that generated imports shift comments.\n   */\n  private _getEndPositionOfNode(node: ts.Node) {\n    const nodeEndPos = node.getEnd();\n    const commentRanges = ts.getTrailingCommentRanges(node.getSourceFile().text, nodeEndPos);\n    if (!commentRanges || !commentRanges.length) {\n      return nodeEndPos;\n    }\n    return commentRanges[commentRanges.length - 1]!.end;\n  }\n}\n\n/**\n * Creates a `ts.ImportDeclaration` declaration.\n *\n * TODO(crisbeto): this is a backwards-compatibility layer for versions of TypeScript less than 4.9.\n * We should remove it once we have dropped support for the older versions.\n */\nfunction createImportDeclaration(\n    modifiers: readonly ts.Modifier[]|undefined, importClause: ts.ImportClause|undefined,\n    moduleSpecifier: ts.Expression, assertClause?: ts.AssertClause): ts.ImportDeclaration {\n  return IS_AFTER_TS_49 ? (ts.factory.createImportDeclaration as any)(\n                              modifiers, importClause, moduleSpecifier, assertClause) :\n                          (ts.factory.createImportDeclaration as any)(\n                              undefined, modifiers, importClause, moduleSpecifier, assertClause);\n}\n\n/** Checks if the current version of TypeScript is after the specified major/minor versions. */\nfunction isAfterVersion(targetMajor: number, targetMinor: number): boolean {\n  const [major, minor] = ts.versionMajorMinor.split('.').map(part => parseInt(part));\n\n  if (major < targetMajor) {\n    return false;\n  }\n\n  return major === targetMajor ? minor >= targetMinor : true;\n}\n"]}
@@ -7,7 +7,7 @@
7
7
  */
8
8
  /// <amd-module name="@angular/core/schematics/utils/ng_decorators" />
9
9
  import ts from 'typescript';
10
- export declare type CallExpressionDecorator = ts.Decorator & {
10
+ export type CallExpressionDecorator = ts.Decorator & {
11
11
  expression: ts.CallExpression;
12
12
  };
13
13
  export interface NgDecorator {
@@ -8,7 +8,7 @@
8
8
  */
9
9
  import { Tree } from '@angular-devkit/schematics';
10
10
  import ts from 'typescript';
11
- export declare type FakeReadFileFn = (fileName: string) => string | undefined;
11
+ export type FakeReadFileFn = (fileName: string) => string | undefined;
12
12
  /**
13
13
  * Creates a TypeScript program instance for a TypeScript project within
14
14
  * the virtual file system tree.
@@ -7,7 +7,7 @@
7
7
  */
8
8
  /// <amd-module name="@angular/core/schematics/utils/typescript/imports" />
9
9
  import ts from 'typescript';
10
- export declare type Import = {
10
+ export type Import = {
11
11
  name: string;
12
12
  importModule: string;
13
13
  node: ts.ImportDeclaration;
@@ -8,7 +8,7 @@
8
8
  /// <amd-module name="@angular/core/schematics/utils/typescript/property_name" />
9
9
  import ts from 'typescript';
10
10
  /** Type that describes a property name with an obtainable text. */
11
- declare type PropertyNameWithText = Exclude<ts.PropertyName, ts.ComputedPropertyName>;
11
+ type PropertyNameWithText = Exclude<ts.PropertyName, ts.ComputedPropertyName>;
12
12
  /**
13
13
  * Gets the text of the given property name. Returns null if the property
14
14
  * name couldn't be determined statically.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v15.1.0-next.0
2
+ * @license Angular v15.1.0-next.2
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */