@angular/core 14.1.0-next.2 → 14.1.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/src/application_ref.mjs +29 -15
- package/esm2020/src/change_detection/change_detector_ref.mjs +1 -1
- package/esm2020/src/core.mjs +2 -2
- package/esm2020/src/core_render3_private_export.mjs +2 -2
- package/esm2020/src/debug/debug_node.mjs +3 -4
- package/esm2020/src/di/index.mjs +1 -1
- package/esm2020/src/di/injector_compatibility.mjs +13 -8
- package/esm2020/src/di/injector_token.mjs +2 -2
- package/esm2020/src/di/interface/injector.mjs +2 -1
- package/esm2020/src/di/jit/util.mjs +3 -2
- package/esm2020/src/di/r3_injector.mjs +13 -1
- package/esm2020/src/di/reflective_key.mjs +3 -2
- package/esm2020/src/errors.mjs +1 -1
- package/esm2020/src/i18n/locale_data_api.mjs +3 -2
- package/esm2020/src/linker/component_factory.mjs +1 -1
- package/esm2020/src/linker/ng_module_factory.mjs +2 -2
- package/esm2020/src/linker/view_container_ref.mjs +2 -2
- package/esm2020/src/metadata/di.mjs +1 -1
- package/esm2020/src/render/api.mjs +2 -11
- package/esm2020/src/render3/component.mjs +3 -57
- package/esm2020/src/render3/component_ref.mjs +30 -5
- package/esm2020/src/render3/features/standalone_feature.mjs +2 -2
- package/esm2020/src/render3/index.mjs +4 -4
- package/esm2020/src/render3/instructions/change_detection.mjs +2 -20
- package/esm2020/src/render3/instructions/element_validation.mjs +4 -1
- package/esm2020/src/render3/instructions/listener.mjs +34 -44
- package/esm2020/src/render3/instructions/lview_debug.mjs +1 -1
- package/esm2020/src/render3/instructions/property_interpolation.mjs +2 -2
- package/esm2020/src/render3/instructions/shared.mjs +22 -59
- package/esm2020/src/render3/instructions/styling.mjs +2 -2
- package/esm2020/src/render3/interfaces/i18n.mjs +2 -2
- package/esm2020/src/render3/interfaces/renderer.mjs +1 -17
- package/esm2020/src/render3/interfaces/styling.mjs +1 -1
- package/esm2020/src/render3/interfaces/view.mjs +1 -1
- package/esm2020/src/render3/ng_module_ref.mjs +15 -2
- package/esm2020/src/render3/node_manipulation.mjs +24 -87
- package/esm2020/src/render3/node_manipulation_i18n.mjs +1 -1
- package/esm2020/src/render3/util/attrs_utils.mjs +4 -12
- package/esm2020/src/render3/util/view_utils.mjs +3 -6
- package/esm2020/src/version.mjs +1 -1
- package/esm2020/src/zone/ng_zone.mjs +9 -4
- package/esm2020/testing/src/logger.mjs +3 -3
- package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
- package/fesm2015/core.mjs +1697 -1830
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/testing.mjs +1037 -1279
- package/fesm2015/testing.mjs.map +1 -1
- package/fesm2020/core.mjs +1697 -1830
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/testing.mjs +1037 -1279
- package/fesm2020/testing.mjs.map +1 -1
- package/index.d.ts +169 -144
- package/package.json +1 -1
- package/schematics/migrations/typed-forms/util.js +2 -2
- package/schematics/utils/typescript/symbol.js +2 -2
- package/testing/index.d.ts +1 -1
- package/schematics/utils/schematics_prompt.d.ts +0 -17
- package/schematics/utils/schematics_prompt.js +0 -45
package/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v14.1.0-
|
|
2
|
+
* @license Angular v14.1.0-rc.0
|
|
3
3
|
* (c) 2010-2022 Google LLC. https://angular.io/
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -401,7 +401,6 @@ export declare class ApplicationRef {
|
|
|
401
401
|
private _zone;
|
|
402
402
|
private _injector;
|
|
403
403
|
private _exceptionHandler;
|
|
404
|
-
private _initStatus;
|
|
405
404
|
private _views;
|
|
406
405
|
private _runningTick;
|
|
407
406
|
private _stable;
|
|
@@ -427,6 +426,10 @@ export declare class ApplicationRef {
|
|
|
427
426
|
* @see [Usage notes](#is-stable-examples) for examples and caveats when using this API.
|
|
428
427
|
*/
|
|
429
428
|
readonly isStable: Observable<boolean>;
|
|
429
|
+
/**
|
|
430
|
+
* The `EnvironmentInjector` used to create this application.
|
|
431
|
+
*/
|
|
432
|
+
get injector(): EnvironmentInjector;
|
|
430
433
|
/**
|
|
431
434
|
* Bootstrap a component onto the element identified by its selector or, optionally, to a
|
|
432
435
|
* specified element.
|
|
@@ -530,7 +533,7 @@ export declare class ApplicationRef {
|
|
|
530
533
|
private _loadComponent;
|
|
531
534
|
/**
|
|
532
535
|
* Destroys an Angular application represented by this `ApplicationRef`. Calling this function
|
|
533
|
-
* will destroy the associated
|
|
536
|
+
* will destroy the associated environment injectors as well as all the bootstrapped components
|
|
534
537
|
* with their views.
|
|
535
538
|
*/
|
|
536
539
|
destroy(): void;
|
|
@@ -608,9 +611,11 @@ export declare interface AttributeDecorator {
|
|
|
608
611
|
}
|
|
609
612
|
|
|
610
613
|
/**
|
|
611
|
-
* Provides additional options to the
|
|
614
|
+
* Provides additional options to the bootstrapping process.
|
|
615
|
+
*
|
|
616
|
+
* @publicApi
|
|
612
617
|
*/
|
|
613
|
-
declare interface BootstrapOptions {
|
|
618
|
+
export declare interface BootstrapOptions {
|
|
614
619
|
/**
|
|
615
620
|
* Optionally specify which `NgZone` should be used.
|
|
616
621
|
*
|
|
@@ -629,7 +634,7 @@ declare interface BootstrapOptions {
|
|
|
629
634
|
*
|
|
630
635
|
* When button is clicked, because of the event bubbling, both
|
|
631
636
|
* event handlers will be called and 2 change detections will be
|
|
632
|
-
* triggered. We can
|
|
637
|
+
* triggered. We can coalesce such kind of events to only trigger
|
|
633
638
|
* change detection only once.
|
|
634
639
|
*
|
|
635
640
|
* By default, this option will be false. So the events will not be
|
|
@@ -738,7 +743,7 @@ export declare abstract class ChangeDetectorRef {
|
|
|
738
743
|
*
|
|
739
744
|
* Components are normally marked as dirty (in need of rerendering) when inputs
|
|
740
745
|
* have changed or events have fired in the view. Call this method to ensure that
|
|
741
|
-
* a component is checked even if these triggers have not
|
|
746
|
+
* a component is checked even if these triggers have not occurred.
|
|
742
747
|
*
|
|
743
748
|
* <!-- TODO: Add a link to a chapter on OnPush components -->
|
|
744
749
|
*
|
|
@@ -1321,6 +1326,15 @@ declare type ComponentInstance = {};
|
|
|
1321
1326
|
* @publicApi
|
|
1322
1327
|
*/
|
|
1323
1328
|
export declare abstract class ComponentRef<C> {
|
|
1329
|
+
/**
|
|
1330
|
+
* Updates a specified input name to a new value. Using this method will properly mark for check
|
|
1331
|
+
* component using the `OnPush` change detection strategy. It will also assure that the
|
|
1332
|
+
* `OnChanges` lifecycle hook runs when a dynamically created component is change-detected.
|
|
1333
|
+
*
|
|
1334
|
+
* @param name The name of an input.
|
|
1335
|
+
* @param value The new value of an input.
|
|
1336
|
+
*/
|
|
1337
|
+
abstract setInput(name: string, value: unknown): void;
|
|
1324
1338
|
/**
|
|
1325
1339
|
* The host or anchor [element](guide/glossary#element) for this component instance.
|
|
1326
1340
|
*/
|
|
@@ -1453,6 +1467,8 @@ export declare interface ContentChildDecorator {
|
|
|
1453
1467
|
* **Metadata Properties**:
|
|
1454
1468
|
*
|
|
1455
1469
|
* * **selector** - The directive type or the name used for querying.
|
|
1470
|
+
* * **descendants** - If `true` (default) include all descendants of the element. If `false` then
|
|
1471
|
+
* only query direct children of the element.
|
|
1456
1472
|
* * **read** - Used to read a different token from the queried element.
|
|
1457
1473
|
* * **static** - True to resolve query results before change detection runs,
|
|
1458
1474
|
* false to resolve after change detection. Defaults to false.
|
|
@@ -1486,10 +1502,12 @@ export declare interface ContentChildDecorator {
|
|
|
1486
1502
|
* @Annotation
|
|
1487
1503
|
*/
|
|
1488
1504
|
(selector: ProviderToken<unknown> | Function | string, opts?: {
|
|
1505
|
+
descendants?: boolean;
|
|
1489
1506
|
read?: any;
|
|
1490
1507
|
static?: boolean;
|
|
1491
1508
|
}): any;
|
|
1492
1509
|
new (selector: ProviderToken<unknown> | Function | string, opts?: {
|
|
1510
|
+
descendants?: boolean;
|
|
1493
1511
|
read?: any;
|
|
1494
1512
|
static?: boolean;
|
|
1495
1513
|
}): ContentChild;
|
|
@@ -1600,49 +1618,6 @@ declare type ContentQueriesFunction<T> = <U extends T>(rf: ɵRenderFlags, ctx: U
|
|
|
1600
1618
|
|
|
1601
1619
|
declare const CONTEXT = 8;
|
|
1602
1620
|
|
|
1603
|
-
/** Options that control how the component should be bootstrapped. */
|
|
1604
|
-
declare interface CreateComponentOptions {
|
|
1605
|
-
/** Which renderer factory to use. */
|
|
1606
|
-
rendererFactory?: RendererFactory3;
|
|
1607
|
-
/** A custom sanitizer instance */
|
|
1608
|
-
sanitizer?: Sanitizer;
|
|
1609
|
-
/** A custom animation player handler */
|
|
1610
|
-
playerHandler?: ɵPlayerHandler;
|
|
1611
|
-
/**
|
|
1612
|
-
* Host element on which the component will be bootstrapped. If not specified,
|
|
1613
|
-
* the component definition's `tag` is used to query the existing DOM for the
|
|
1614
|
-
* element to bootstrap.
|
|
1615
|
-
*/
|
|
1616
|
-
host?: RElement | string;
|
|
1617
|
-
/** Module injector for the component. If unspecified, the injector will be NULL_INJECTOR. */
|
|
1618
|
-
injector?: Injector;
|
|
1619
|
-
/**
|
|
1620
|
-
* List of features to be applied to the created component. Features are simply
|
|
1621
|
-
* functions that decorate a component with a certain behavior.
|
|
1622
|
-
*
|
|
1623
|
-
* Typically, the features in this list are features that cannot be added to the
|
|
1624
|
-
* other features list in the component definition because they rely on other factors.
|
|
1625
|
-
*
|
|
1626
|
-
* Example: `LifecycleHooksFeature` is a function that adds lifecycle hook capabilities
|
|
1627
|
-
* to root components in a tree-shakable way. It cannot be added to the component
|
|
1628
|
-
* features list because there's no way of knowing when the component will be used as
|
|
1629
|
-
* a root component.
|
|
1630
|
-
*/
|
|
1631
|
-
hostFeatures?: HostFeature[];
|
|
1632
|
-
/**
|
|
1633
|
-
* A function which is used to schedule change detection work in the future.
|
|
1634
|
-
*
|
|
1635
|
-
* When marking components as dirty, it is necessary to schedule the work of
|
|
1636
|
-
* change detection in the future. This is done to coalesce multiple
|
|
1637
|
-
* {@link markDirty} calls into a single changed detection processing.
|
|
1638
|
-
*
|
|
1639
|
-
* The default value of the scheduler is the `requestAnimationFrame` function.
|
|
1640
|
-
*
|
|
1641
|
-
* It is also useful to override this function for testing purposes.
|
|
1642
|
-
*/
|
|
1643
|
-
scheduler?: (work: () => void) => void;
|
|
1644
|
-
}
|
|
1645
|
-
|
|
1646
1621
|
/**
|
|
1647
1622
|
* Create a new environment injector.
|
|
1648
1623
|
*
|
|
@@ -1661,12 +1636,23 @@ export declare function createEnvironmentInjector(providers: Array<Provider | Im
|
|
|
1661
1636
|
|
|
1662
1637
|
/**
|
|
1663
1638
|
* Returns a new NgModuleRef instance based on the NgModule class and parent injector provided.
|
|
1639
|
+
*
|
|
1664
1640
|
* @param ngModule NgModule class.
|
|
1665
1641
|
* @param parentInjector Optional injector instance to use as a parent for the module injector. If
|
|
1666
1642
|
* not provided, `NullInjector` will be used instead.
|
|
1643
|
+
* @returns NgModuleRef that represents an NgModule instance.
|
|
1644
|
+
*
|
|
1667
1645
|
* @publicApi
|
|
1668
1646
|
*/
|
|
1669
|
-
export declare function
|
|
1647
|
+
export declare function createNgModule<T>(ngModule: Type<T>, parentInjector?: Injector): NgModuleRef<T>;
|
|
1648
|
+
|
|
1649
|
+
/**
|
|
1650
|
+
* The `createNgModule` function alias for backwards-compatibility.
|
|
1651
|
+
* Please avoid using it directly and use `createNgModule` instead.
|
|
1652
|
+
*
|
|
1653
|
+
* @deprecated Use `createNgModule` instead.
|
|
1654
|
+
*/
|
|
1655
|
+
export declare const createNgModuleRef: typeof createNgModule;
|
|
1670
1656
|
|
|
1671
1657
|
/**
|
|
1672
1658
|
* Creates a platform.
|
|
@@ -2640,6 +2626,17 @@ export declare abstract class EnvironmentInjector implements Injector {
|
|
|
2640
2626
|
* @suppress {duplicate}
|
|
2641
2627
|
*/
|
|
2642
2628
|
abstract get(token: any, notFoundValue?: any): any;
|
|
2629
|
+
/**
|
|
2630
|
+
* Runs the given function in the context of this `EnvironmentInjector`.
|
|
2631
|
+
*
|
|
2632
|
+
* Within the function's stack frame, `inject` can be used to inject dependencies from this
|
|
2633
|
+
* injector. Note that `inject` is only usable synchronously, and cannot be used in any
|
|
2634
|
+
* asynchronous callbacks or after any `await` points.
|
|
2635
|
+
*
|
|
2636
|
+
* @param fn the closure to be run in the context of this injector
|
|
2637
|
+
* @returns the return value of the function, if any
|
|
2638
|
+
*/
|
|
2639
|
+
abstract runInContext<ReturnT>(fn: () => ReturnT): ReturnT;
|
|
2643
2640
|
abstract destroy(): void;
|
|
2644
2641
|
}
|
|
2645
2642
|
|
|
@@ -2945,6 +2942,14 @@ export declare interface GetTestability {
|
|
|
2945
2942
|
findTestabilityInTree(registry: TestabilityRegistry, elem: any, findInAncestors: boolean): Testability | null;
|
|
2946
2943
|
}
|
|
2947
2944
|
|
|
2945
|
+
/**
|
|
2946
|
+
* The goal here is to make sure that the browser DOM API is the Renderer.
|
|
2947
|
+
* We do this by defining a subset of DOM API to be the renderer and then
|
|
2948
|
+
* use that at runtime for rendering.
|
|
2949
|
+
*
|
|
2950
|
+
* At runtime we can then use the DOM api directly, in server or web-worker
|
|
2951
|
+
* it will be easy to implement such API.
|
|
2952
|
+
*/
|
|
2948
2953
|
declare type GlobalTargetName = 'document' | 'window' | 'body';
|
|
2949
2954
|
|
|
2950
2955
|
declare type GlobalTargetResolver = (element: any) => EventTarget;
|
|
@@ -3149,9 +3154,6 @@ export declare interface HostDecorator {
|
|
|
3149
3154
|
new (): Host;
|
|
3150
3155
|
}
|
|
3151
3156
|
|
|
3152
|
-
/** See CreateComponentOptions.hostFeatures */
|
|
3153
|
-
declare type HostFeature = (<T>(component: T, componentDef: ɵComponentDef<T>) => void);
|
|
3154
|
-
|
|
3155
3157
|
/**
|
|
3156
3158
|
* Type of the HostListener metadata.
|
|
3157
3159
|
*
|
|
@@ -3615,9 +3617,38 @@ export declare function inject<T>(token: ProviderToken<T>): T;
|
|
|
3615
3617
|
* @throws if called outside of a supported context.
|
|
3616
3618
|
*
|
|
3617
3619
|
* @publicApi
|
|
3620
|
+
* @deprecated prefer an options object instead of `InjectFlags`
|
|
3618
3621
|
*/
|
|
3619
3622
|
export declare function inject<T>(token: ProviderToken<T>, flags?: InjectFlags): T | null;
|
|
3620
3623
|
|
|
3624
|
+
/**
|
|
3625
|
+
* @param token A token that represents a dependency that should be injected.
|
|
3626
|
+
* @param options Control how injection is executed. Options correspond to injection strategies
|
|
3627
|
+
* that can be specified with parameter decorators `@Host`, `@Self`, `@SkipSelf`, and
|
|
3628
|
+
* `@Optional`.
|
|
3629
|
+
* @returns the injected value if operation is successful.
|
|
3630
|
+
* @throws if called outside of a supported context, or if the token is not found.
|
|
3631
|
+
*
|
|
3632
|
+
* @publicApi
|
|
3633
|
+
*/
|
|
3634
|
+
export declare function inject<T>(token: ProviderToken<T>, options: InjectOptions & {
|
|
3635
|
+
optional?: false;
|
|
3636
|
+
}): T;
|
|
3637
|
+
|
|
3638
|
+
/**
|
|
3639
|
+
* @param token A token that represents a dependency that should be injected.
|
|
3640
|
+
* @param options Control how injection is executed. Options correspond to injection strategies
|
|
3641
|
+
* that can be specified with parameter decorators `@Host`, `@Self`, `@SkipSelf`, and
|
|
3642
|
+
* `@Optional`.
|
|
3643
|
+
* @returns the injected value if operation is successful, `null` if the token is not
|
|
3644
|
+
* found and optional injection has been requested.
|
|
3645
|
+
* @throws if called outside of a supported context, or if the token is not found and optional
|
|
3646
|
+
* injection was not requested.
|
|
3647
|
+
*
|
|
3648
|
+
* @publicApi
|
|
3649
|
+
*/
|
|
3650
|
+
export declare function inject<T>(token: ProviderToken<T>, options: InjectOptions): T | null;
|
|
3651
|
+
|
|
3621
3652
|
/**
|
|
3622
3653
|
* Type of the Injectable metadata.
|
|
3623
3654
|
*
|
|
@@ -3741,6 +3772,7 @@ export declare interface InjectDecorator {
|
|
|
3741
3772
|
* Injection flags for DI.
|
|
3742
3773
|
*
|
|
3743
3774
|
* @publicApi
|
|
3775
|
+
* @deprecated use an options object for `inject` instead.
|
|
3744
3776
|
*/
|
|
3745
3777
|
export declare enum InjectFlags {
|
|
3746
3778
|
/** Check self and check parent injector if needed */
|
|
@@ -3815,6 +3847,32 @@ export declare class InjectionToken<T> {
|
|
|
3815
3847
|
toString(): string;
|
|
3816
3848
|
}
|
|
3817
3849
|
|
|
3850
|
+
/**
|
|
3851
|
+
* Type of the options argument to `inject`.
|
|
3852
|
+
*
|
|
3853
|
+
* @publicApi
|
|
3854
|
+
*/
|
|
3855
|
+
export declare interface InjectOptions {
|
|
3856
|
+
/**
|
|
3857
|
+
* Use optional injection, and return `null` if the requested token is not found.
|
|
3858
|
+
*/
|
|
3859
|
+
optional?: boolean;
|
|
3860
|
+
/**
|
|
3861
|
+
* Start injection at the parent of the current injector.
|
|
3862
|
+
*/
|
|
3863
|
+
skipSelf?: boolean;
|
|
3864
|
+
/**
|
|
3865
|
+
* Only query the current injector for the token, and don't fall back to the parent injector if
|
|
3866
|
+
* it's not found.
|
|
3867
|
+
*/
|
|
3868
|
+
self?: boolean;
|
|
3869
|
+
/**
|
|
3870
|
+
* Stop injection at the host component's injector. Only relevant when injecting from an element
|
|
3871
|
+
* injector, and a no-op for environment injectors.
|
|
3872
|
+
*/
|
|
3873
|
+
host?: boolean;
|
|
3874
|
+
}
|
|
3875
|
+
|
|
3818
3876
|
/**
|
|
3819
3877
|
* An InjectionToken that gets the current `Injector` for `createInjector()`-style injectors.
|
|
3820
3878
|
*
|
|
@@ -4574,8 +4632,8 @@ declare interface LView<T = unknown> extends Array<any> {
|
|
|
4574
4632
|
* TView.cleanup saves an index to the necessary context in this array.
|
|
4575
4633
|
*
|
|
4576
4634
|
* After `LView` is created it is possible to attach additional instance specific functions at the
|
|
4577
|
-
* end of the `lView[
|
|
4578
|
-
*
|
|
4635
|
+
* end of the `lView[CLEANUP]` because we know that no more `T` level cleanup functions will be
|
|
4636
|
+
* added here.
|
|
4579
4637
|
*/
|
|
4580
4638
|
[CLEANUP]: any[] | null;
|
|
4581
4639
|
/**
|
|
@@ -4589,9 +4647,9 @@ declare interface LView<T = unknown> extends Array<any> {
|
|
|
4589
4647
|
/** An optional Module Injector to be used as fall back after Element Injectors are consulted. */
|
|
4590
4648
|
readonly [INJECTOR_2]: Injector | null;
|
|
4591
4649
|
/** Factory to be used for creating Renderer. */
|
|
4592
|
-
[RENDERER_FACTORY]:
|
|
4650
|
+
[RENDERER_FACTORY]: RendererFactory;
|
|
4593
4651
|
/** Renderer to be used for this view. */
|
|
4594
|
-
[RENDERER]:
|
|
4652
|
+
[RENDERER]: Renderer;
|
|
4595
4653
|
/** An optional custom sanitizer. */
|
|
4596
4654
|
[SANITIZER]: Sanitizer | null;
|
|
4597
4655
|
/**
|
|
@@ -5191,7 +5249,7 @@ export declare interface NgModuleDecorator {
|
|
|
5191
5249
|
* JIT mode. See [JIT API changes due to ViewEngine deprecation](guide/deprecations#jit-api-changes)
|
|
5192
5250
|
* for additional context. Angular provides APIs that accept NgModule classes directly (such as
|
|
5193
5251
|
* [PlatformRef.bootstrapModule](api/core/PlatformRef#bootstrapModule) and
|
|
5194
|
-
* [
|
|
5252
|
+
* [createNgModule](api/core/createNgModule)), consider switching to those APIs instead of
|
|
5195
5253
|
* using factory-based ones.
|
|
5196
5254
|
*/
|
|
5197
5255
|
export declare abstract class NgModuleFactory<T> {
|
|
@@ -5436,21 +5494,6 @@ declare interface NodeInjectorDebug {
|
|
|
5436
5494
|
parentInjectorIndex: number;
|
|
5437
5495
|
}
|
|
5438
5496
|
|
|
5439
|
-
/**
|
|
5440
|
-
* Object Oriented style of API needed to create elements and text nodes.
|
|
5441
|
-
*
|
|
5442
|
-
* This is the native browser API style, e.g. operations are methods on individual objects
|
|
5443
|
-
* like HTMLElement. With this style, no additional code is needed as a facade
|
|
5444
|
-
* (reducing payload size).
|
|
5445
|
-
* */
|
|
5446
|
-
declare interface ObjectOrientedRenderer3 {
|
|
5447
|
-
createComment(data: string): RComment;
|
|
5448
|
-
createElement(tagName: string): RElement;
|
|
5449
|
-
createElementNS(namespace: string, tagName: string): RElement;
|
|
5450
|
-
createTextNode(data: string): RText;
|
|
5451
|
-
querySelector(selectors: string): RElement | null;
|
|
5452
|
-
}
|
|
5453
|
-
|
|
5454
5497
|
/**
|
|
5455
5498
|
* @description
|
|
5456
5499
|
* A lifecycle hook that is called when any data-bound property of a directive changes.
|
|
@@ -5875,41 +5918,6 @@ declare const enum PreOrderHookFlags {
|
|
|
5875
5918
|
NumberOfInitHooksCalledMask = 4294901760
|
|
5876
5919
|
}
|
|
5877
5920
|
|
|
5878
|
-
/**
|
|
5879
|
-
* Procedural style of API needed to create elements and text nodes.
|
|
5880
|
-
*
|
|
5881
|
-
* In non-native browser environments (e.g. platforms such as web-workers), this is the
|
|
5882
|
-
* facade that enables element manipulation. This also facilitates backwards compatibility
|
|
5883
|
-
* with Renderer2.
|
|
5884
|
-
*/
|
|
5885
|
-
declare interface ProceduralRenderer3 {
|
|
5886
|
-
destroy(): void;
|
|
5887
|
-
createComment(value: string): RComment;
|
|
5888
|
-
createElement(name: string, namespace?: string | null): RElement;
|
|
5889
|
-
createText(value: string): RText;
|
|
5890
|
-
/**
|
|
5891
|
-
* This property is allowed to be null / undefined,
|
|
5892
|
-
* in which case the view engine won't call it.
|
|
5893
|
-
* This is used as a performance optimization for production mode.
|
|
5894
|
-
*/
|
|
5895
|
-
destroyNode?: ((node: RNode) => void) | null;
|
|
5896
|
-
appendChild(parent: RElement, newChild: RNode): void;
|
|
5897
|
-
insertBefore(parent: RNode, newChild: RNode, refChild: RNode | null, isMove?: boolean): void;
|
|
5898
|
-
removeChild(parent: RElement, oldChild: RNode, isHostElement?: boolean): void;
|
|
5899
|
-
selectRootElement(selectorOrNode: string | any, preserveContent?: boolean): RElement;
|
|
5900
|
-
parentNode(node: RNode): RElement | null;
|
|
5901
|
-
nextSibling(node: RNode): RNode | null;
|
|
5902
|
-
setAttribute(el: RElement, name: string, value: string | TrustedHTML | TrustedScript | TrustedScriptURL, namespace?: string | null): void;
|
|
5903
|
-
removeAttribute(el: RElement, name: string, namespace?: string | null): void;
|
|
5904
|
-
addClass(el: RElement, name: string): void;
|
|
5905
|
-
removeClass(el: RElement, name: string): void;
|
|
5906
|
-
setStyle(el: RElement, style: string, value: any, flags?: RendererStyleFlags2 | RendererStyleFlags3): void;
|
|
5907
|
-
removeStyle(el: RElement, style: string, flags?: RendererStyleFlags2 | RendererStyleFlags3): void;
|
|
5908
|
-
setProperty(el: RElement, name: string, value: any): void;
|
|
5909
|
-
setValue(node: RText | RComment, value: string): void;
|
|
5910
|
-
listen(target: GlobalTargetName | RNode, eventName: string, callback: (event: any) => boolean | void): () => void;
|
|
5911
|
-
}
|
|
5912
|
-
|
|
5913
5921
|
/**
|
|
5914
5922
|
* Describes a function that is used to process provider lists (such as provider
|
|
5915
5923
|
* overrides).
|
|
@@ -6308,6 +6316,7 @@ declare class R3Injector extends EnvironmentInjector {
|
|
|
6308
6316
|
*/
|
|
6309
6317
|
destroy(): void;
|
|
6310
6318
|
onDestroy(callback: () => void): void;
|
|
6319
|
+
runInContext<ReturnT>(fn: () => ReturnT): ReturnT;
|
|
6311
6320
|
get<T>(token: ProviderToken<T>, notFoundValue?: any, flags?: InjectFlags): T;
|
|
6312
6321
|
toString(): string;
|
|
6313
6322
|
private assertNotDestroyed;
|
|
@@ -6638,6 +6647,40 @@ declare interface RElement extends RNode {
|
|
|
6638
6647
|
|
|
6639
6648
|
declare const RENDERER = 11;
|
|
6640
6649
|
|
|
6650
|
+
/**
|
|
6651
|
+
* Procedural style of API needed to create elements and text nodes.
|
|
6652
|
+
*
|
|
6653
|
+
* In non-native browser environments (e.g. platforms such as web-workers), this is the
|
|
6654
|
+
* facade that enables element manipulation. In practice, this is implemented by `Renderer2`.
|
|
6655
|
+
*/
|
|
6656
|
+
declare interface Renderer {
|
|
6657
|
+
destroy(): void;
|
|
6658
|
+
createComment(value: string): RComment;
|
|
6659
|
+
createElement(name: string, namespace?: string | null): RElement;
|
|
6660
|
+
createText(value: string): RText;
|
|
6661
|
+
/**
|
|
6662
|
+
* This property is allowed to be null / undefined,
|
|
6663
|
+
* in which case the view engine won't call it.
|
|
6664
|
+
* This is used as a performance optimization for production mode.
|
|
6665
|
+
*/
|
|
6666
|
+
destroyNode?: ((node: RNode) => void) | null;
|
|
6667
|
+
appendChild(parent: RElement, newChild: RNode): void;
|
|
6668
|
+
insertBefore(parent: RNode, newChild: RNode, refChild: RNode | null, isMove?: boolean): void;
|
|
6669
|
+
removeChild(parent: RElement, oldChild: RNode, isHostElement?: boolean): void;
|
|
6670
|
+
selectRootElement(selectorOrNode: string | any, preserveContent?: boolean): RElement;
|
|
6671
|
+
parentNode(node: RNode): RElement | null;
|
|
6672
|
+
nextSibling(node: RNode): RNode | null;
|
|
6673
|
+
setAttribute(el: RElement, name: string, value: string | TrustedHTML | TrustedScript | TrustedScriptURL, namespace?: string | null): void;
|
|
6674
|
+
removeAttribute(el: RElement, name: string, namespace?: string | null): void;
|
|
6675
|
+
addClass(el: RElement, name: string): void;
|
|
6676
|
+
removeClass(el: RElement, name: string): void;
|
|
6677
|
+
setStyle(el: RElement, style: string, value: any, flags?: RendererStyleFlags2): void;
|
|
6678
|
+
removeStyle(el: RElement, style: string, flags?: RendererStyleFlags2): void;
|
|
6679
|
+
setProperty(el: RElement, name: string, value: any): void;
|
|
6680
|
+
setValue(node: RText | RComment, value: string): void;
|
|
6681
|
+
listen(target: GlobalTargetName | RNode, eventName: string, callback: (event: any) => boolean | void): () => void;
|
|
6682
|
+
}
|
|
6683
|
+
|
|
6641
6684
|
/**
|
|
6642
6685
|
* Extend this base class to implement custom rendering. By default, Angular
|
|
6643
6686
|
* renders a template into DOM. You can use custom rendering to intercept
|
|
@@ -6814,10 +6857,14 @@ export declare abstract class Renderer2 {
|
|
|
6814
6857
|
abstract listen(target: 'window' | 'document' | 'body' | any, eventName: string, callback: (event: any) => boolean | void): () => void;
|
|
6815
6858
|
}
|
|
6816
6859
|
|
|
6817
|
-
declare type Renderer3 = ObjectOrientedRenderer3 | ProceduralRenderer3;
|
|
6818
|
-
|
|
6819
6860
|
declare const RENDERER_FACTORY = 10;
|
|
6820
6861
|
|
|
6862
|
+
declare interface RendererFactory {
|
|
6863
|
+
createRenderer(hostElement: RElement | null, rendererType: RendererType2 | null): Renderer;
|
|
6864
|
+
begin?(): void;
|
|
6865
|
+
end?(): void;
|
|
6866
|
+
}
|
|
6867
|
+
|
|
6821
6868
|
/**
|
|
6822
6869
|
* Creates and initializes a custom renderer that implements the `Renderer2` base class.
|
|
6823
6870
|
*
|
|
@@ -6846,12 +6893,6 @@ export declare abstract class RendererFactory2 {
|
|
|
6846
6893
|
abstract whenRenderingDone?(): Promise<any>;
|
|
6847
6894
|
}
|
|
6848
6895
|
|
|
6849
|
-
declare interface RendererFactory3 {
|
|
6850
|
-
createRenderer(hostElement: RElement | null, rendererType: RendererType2 | null): Renderer3;
|
|
6851
|
-
begin?(): void;
|
|
6852
|
-
end?(): void;
|
|
6853
|
-
}
|
|
6854
|
-
|
|
6855
6896
|
/**
|
|
6856
6897
|
* Flags for renderer-specific style modifiers.
|
|
6857
6898
|
* @publicApi
|
|
@@ -6867,11 +6908,6 @@ export declare enum RendererStyleFlags2 {
|
|
|
6867
6908
|
DashCase = 2
|
|
6868
6909
|
}
|
|
6869
6910
|
|
|
6870
|
-
declare enum RendererStyleFlags3 {
|
|
6871
|
-
Important = 1,
|
|
6872
|
-
DashCase = 2
|
|
6873
|
-
}
|
|
6874
|
-
|
|
6875
6911
|
/**
|
|
6876
6912
|
* Used by `RendererFactory2` to associate custom rendering data and styles
|
|
6877
6913
|
* with a rendering implementation.
|
|
@@ -7046,6 +7082,7 @@ declare const enum RuntimeErrorCode {
|
|
|
7046
7082
|
INVALID_INJECTION_TOKEN = 204,
|
|
7047
7083
|
INJECTOR_ALREADY_DESTROYED = 205,
|
|
7048
7084
|
PROVIDER_IN_WRONG_CONTEXT = 207,
|
|
7085
|
+
MISSING_INJECTION_TOKEN = 208,
|
|
7049
7086
|
MULTIPLE_COMPONENTS_MATCH = -300,
|
|
7050
7087
|
EXPORT_NOT_FOUND = -301,
|
|
7051
7088
|
PIPE_NOT_FOUND = -302,
|
|
@@ -7060,7 +7097,9 @@ declare const enum RuntimeErrorCode {
|
|
|
7060
7097
|
PLATFORM_ALREADY_DESTROYED = 404,
|
|
7061
7098
|
ASYNC_INITIALIZERS_STILL_RUNNING = 405,
|
|
7062
7099
|
APPLICATION_REF_ALREADY_DESTROYED = 406,
|
|
7100
|
+
RENDERER_NOT_FOUND = 407,
|
|
7063
7101
|
INVALID_I18N_STRUCTURE = 700,
|
|
7102
|
+
MISSING_LOCALE_DATA = 701,
|
|
7064
7103
|
IMPORT_PROVIDERS_FROM_STANDALONE = 800,
|
|
7065
7104
|
INVALID_DIFFER_INPUT = 900,
|
|
7066
7105
|
NO_SUPPORTING_DIFFER_FACTORY = 901,
|
|
@@ -7069,7 +7108,9 @@ declare const enum RuntimeErrorCode {
|
|
|
7069
7108
|
UNSAFE_VALUE_IN_RESOURCE_URL = 904,
|
|
7070
7109
|
UNSAFE_VALUE_IN_SCRIPT = 905,
|
|
7071
7110
|
MISSING_GENERATED_DEF = 906,
|
|
7072
|
-
TYPE_IS_NOT_STANDALONE = 907
|
|
7111
|
+
TYPE_IS_NOT_STANDALONE = 907,
|
|
7112
|
+
MISSING_ZONEJS = 908,
|
|
7113
|
+
UNEXPECTED_ZONE_STATE = 909
|
|
7073
7114
|
}
|
|
7074
7115
|
|
|
7075
7116
|
declare const SANITIZER = 12;
|
|
@@ -8834,7 +8875,7 @@ declare const enum TViewType {
|
|
|
8834
8875
|
Component = 1,
|
|
8835
8876
|
/**
|
|
8836
8877
|
* `TView` associated with a template. Such as `*ngIf`, `<ng-template>` etc... A `Component`
|
|
8837
|
-
* can have zero or more `
|
|
8878
|
+
* can have zero or more `Embedded` `TView`s.
|
|
8838
8879
|
*/
|
|
8839
8880
|
Embedded = 2
|
|
8840
8881
|
}
|
|
@@ -10675,6 +10716,7 @@ export declare class ɵRender3ComponentRef<T> extends ComponentRef<T> {
|
|
|
10675
10716
|
changeDetectorRef: ChangeDetectorRef;
|
|
10676
10717
|
componentType: Type<T>;
|
|
10677
10718
|
constructor(componentType: Type<T>, instance: T, location: ElementRef, _rootLView: LView, _tNode: TElementNode | TContainerNode | TElementContainerNode);
|
|
10719
|
+
setInput(name: string, value: unknown): void;
|
|
10678
10720
|
get injector(): Injector;
|
|
10679
10721
|
destroy(): void;
|
|
10680
10722
|
onDestroy(callback: () => void): void;
|
|
@@ -10690,25 +10732,11 @@ export declare class ɵRender3NgModuleRef<T> extends NgModuleRef<T> implements I
|
|
|
10690
10732
|
readonly componentFactoryResolver: ComponentFactoryResolver_2;
|
|
10691
10733
|
constructor(ngModuleType: Type<T>, _parent: Injector | null);
|
|
10692
10734
|
get(token: any, notFoundValue?: any, injectFlags?: InjectFlags): any;
|
|
10735
|
+
runInContext<ReturnT>(fn: () => ReturnT): ReturnT;
|
|
10693
10736
|
destroy(): void;
|
|
10694
10737
|
onDestroy(callback: () => void): void;
|
|
10695
10738
|
}
|
|
10696
10739
|
|
|
10697
|
-
/**
|
|
10698
|
-
* Bootstraps a Component into an existing host element and returns an instance
|
|
10699
|
-
* of the component.
|
|
10700
|
-
*
|
|
10701
|
-
* Use this function to bootstrap a component into the DOM tree. Each invocation
|
|
10702
|
-
* of this function will create a separate tree of components, injectors and
|
|
10703
|
-
* change detection cycles and lifetimes. To dynamically insert a new component
|
|
10704
|
-
* into an existing tree such that it shares the same injection, change detection
|
|
10705
|
-
* and object lifetime, use {@link ViewContainer#createComponent}.
|
|
10706
|
-
*
|
|
10707
|
-
* @param componentType Component to bootstrap
|
|
10708
|
-
* @param options Optional parameters which control bootstrapping
|
|
10709
|
-
*/
|
|
10710
|
-
export declare function ɵrenderComponent<T>(componentType: ɵComponentType<T> | Type<T>, opts?: CreateComponentOptions): T;
|
|
10711
|
-
|
|
10712
10740
|
/**
|
|
10713
10741
|
* Flags passed into template functions to determine which blocks (i.e. creation, update)
|
|
10714
10742
|
* should be executed.
|
|
@@ -12758,9 +12786,6 @@ export declare function ɵɵinvalidFactory(): never;
|
|
|
12758
12786
|
* Throws an error indicating that a factory function could not be generated by the compiler for a
|
|
12759
12787
|
* particular class.
|
|
12760
12788
|
*
|
|
12761
|
-
* This instruction allows the actual error message to be optimized away when ngDevMode is turned
|
|
12762
|
-
* off, saving bytes of generated code while still providing a good experience in dev mode.
|
|
12763
|
-
*
|
|
12764
12789
|
* The name of the class is not mentioned here, but will be in the generated factory function name
|
|
12765
12790
|
* and thus in the stack trace.
|
|
12766
12791
|
*
|
|
@@ -13428,7 +13453,7 @@ export declare function ɵɵpropertyInterpolate8(propName: string, prefix: strin
|
|
|
13428
13453
|
* be conducted at runtime so child components that add new `@Inputs` don't have to be re-compiled.
|
|
13429
13454
|
*
|
|
13430
13455
|
* @param propName The name of the property to update.
|
|
13431
|
-
* @param values The collection of values and the strings
|
|
13456
|
+
* @param values The collection of values and the strings in between those values, beginning with a
|
|
13432
13457
|
* string prefix and ending with a string suffix.
|
|
13433
13458
|
* (e.g. `['prefix', value0, '-', value1, '-', value2, ..., value99, 'suffix']`)
|
|
13434
13459
|
* @param sanitizer An optional sanitizer function
|
|
@@ -13867,7 +13892,7 @@ export declare function ɵɵsetNgModuleScope(type: any, scope: {
|
|
|
13867
13892
|
/**
|
|
13868
13893
|
* A feature that acts as a setup code for the {@link StandaloneService}.
|
|
13869
13894
|
*
|
|
13870
|
-
* The most important
|
|
13895
|
+
* The most important responsibility of this feature is to expose the "getStandaloneInjector"
|
|
13871
13896
|
* function (an entry points to a standalone injector creation) on a component definition object. We
|
|
13872
13897
|
* go through the features infrastructure to make sure that the standalone injector creation logic
|
|
13873
13898
|
* is tree-shakable and not included in applications that don't use standalone components.
|
package/package.json
CHANGED
|
@@ -104,7 +104,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
104
104
|
var _a, _b;
|
|
105
105
|
const symbol = typeChecker.getSymbolAtLocation(node);
|
|
106
106
|
// We check symbol.declarations because we actually care about the name at the declaration site,
|
|
107
|
-
// not the usage site. These could be different in the case of
|
|
107
|
+
// not the usage site. These could be different in the case of overridden constructors.
|
|
108
108
|
if (!symbol || symbol.declarations === undefined || !symbol.declarations.length)
|
|
109
109
|
return false;
|
|
110
110
|
const decl = symbol.declarations[0];
|
|
@@ -131,4 +131,4 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
131
131
|
return false;
|
|
132
132
|
}
|
|
133
133
|
});
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/typed-forms/util.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 ts from 'typescript';\n\nimport {getImportSpecifier} from '../../utils/typescript/imports';\n\nexport const classes = new Set(['FormArray', 'FormBuilder', 'FormControl', 'FormGroup']);\nexport const formControl = 'FormControl';\nexport const untypedPrefix = 'Untyped';\nexport const forms = '@angular/forms';\n\nexport interface MigratableNode {\n  node: ts.Node;\n  importName: string;\n}\n\nexport type rewriteFn = (startPos: number, origLength: number, text: string) => void;\n\nexport function migrateFile(\n    sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: rewriteFn) {\n  const imports = getImports(sourceFile);\n\n  // If no relevant classes are imported, we can exit early.\n  if (imports.length === 0) return;\n\n  // For each control class, migrate all of its uses.\n  for (let i = imports.length; i >= 0; i--) {\n    const imp = imports[i];\n    const usages = getUsages(sourceFile, typeChecker, imp);\n    if (usages.length === 0) {\n      // Since there are no usages of this class we need to migrate it, we should completely\n      // skip it for the subsequent migration steps.\n      imports.splice(i, 1);\n    }\n    for (const usage of usages) {\n      const newName = getUntypedVersionOfImportOrName(usage.importName);\n      if (newName === null) {\n        // This should never happen.\n        console.error(\n            `Typed forms migration error: unknown replacement for usage ${usage.node.getText()}`);\n        continue;\n      }\n      rewrite(usage.node.getStart(), usage.node.getWidth(), newName);\n    }\n  }\n\n  // For each imported control class, migrate to the corresponding uptyped import.\n  for (const imp of imports) {\n    const untypedClass = getUntypedVersionOfImportOrName(imp.getText());\n    if (untypedClass === null) {\n      // This should never happen.\n      console.error(\n          `Typed forms migration error: unknown untyped version of import ${imp.getText()}`);\n      continue;\n    }\n    if (getImportSpecifier(sourceFile, forms, untypedClass)) {\n      // In order to make the migration idempotent, we must check whether the untyped version of the\n      // class is already present. If present, immediately continue.\n      continue;\n    }\n    rewrite(imp.getStart(), imp.getWidth(), untypedClass);\n  }\n}\n\nfunction getImports(sourceFile: ts.SourceFile): ts.ImportSpecifier[] {\n  let imports: ts.ImportSpecifier[] = [];\n  for (const cc of classes) {\n    const specifier = getImportSpecifier(sourceFile, forms, cc);\n    if (!specifier) continue;\n    imports.push(specifier);\n  }\n  return imports;\n}\n\nfunction getUntypedVersionOfImportOrName(name: string): string|null {\n  for (const cc of classes) {\n    if (name.includes(cc)) {\n      return `${untypedPrefix}${cc}`;\n    }\n  }\n  return null;\n}\n\nfunction getUsages(\n    sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker,\n    importSpecifier: ts.ImportSpecifier): MigratableNode[] {\n  const usages: MigratableNode[] = [];\n  const visitNode = (node: ts.Node) => {\n    if (ts.isImportSpecifier(node)) {\n      // Skip this node and all of its children; imports are a special case.\n      return;\n    }\n    if (ts.isIdentifier(node) && isUsageOfFormsImport(typeChecker, node, importSpecifier)) {\n      usages.push({node, importName: importSpecifier.getText()});\n    }\n    ts.forEachChild(node, visitNode);\n  };\n  ts.forEachChild(sourceFile, visitNode);\n  return usages;\n}\n\nfunction isUsageOfFormsImport(\n    typeChecker: ts.TypeChecker, node: ts.Identifier,\n    importSpecifier: ts.ImportSpecifier): boolean {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  // We check symbol.declarations because we actually care about the name at the declaration site,\n  // not the usage site. These could be different in the case of overriden constructors.\n  if (!symbol || symbol.declarations === undefined || !symbol.declarations.length) return false;\n\n  const decl = symbol.declarations[0];\n  if (!ts.isImportSpecifier(decl)) return false;\n\n  // As per `typescript/imports.ts`, we must walk up the tree to find the enclosing import\n  // declaration. For reasons specific to the TS AST, this is always 3 levels up from an import\n  // specifier node.\n  const importDecl = decl.parent.parent.parent;\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) return false;\n\n  const importName = typeChecker.getTypeAtLocation(importSpecifier)?.getSymbol()?.getName();\n  if (!importName) return false;\n\n  // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n  const declName = decl.propertyName ? decl.propertyName.text : decl.name.text;\n\n  if (importName === declName) return true;\n\n  // In the case of FormControl's overridden exported constructor, the value name and declaration\n  // name are not exactly the same. For our purposes, it's enough to check whether the latter is a\n  // substring of the former.\n  if (declName === formControl && importName.includes(declName)) return true;\n\n  return false;\n}\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/typed-forms/util.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 ts from 'typescript';\n\nimport {getImportSpecifier} from '../../utils/typescript/imports';\n\nexport const classes = new Set(['FormArray', 'FormBuilder', 'FormControl', 'FormGroup']);\nexport const formControl = 'FormControl';\nexport const untypedPrefix = 'Untyped';\nexport const forms = '@angular/forms';\n\nexport interface MigratableNode {\n  node: ts.Node;\n  importName: string;\n}\n\nexport type rewriteFn = (startPos: number, origLength: number, text: string) => void;\n\nexport function migrateFile(\n    sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: rewriteFn) {\n  const imports = getImports(sourceFile);\n\n  // If no relevant classes are imported, we can exit early.\n  if (imports.length === 0) return;\n\n  // For each control class, migrate all of its uses.\n  for (let i = imports.length; i >= 0; i--) {\n    const imp = imports[i];\n    const usages = getUsages(sourceFile, typeChecker, imp);\n    if (usages.length === 0) {\n      // Since there are no usages of this class we need to migrate it, we should completely\n      // skip it for the subsequent migration steps.\n      imports.splice(i, 1);\n    }\n    for (const usage of usages) {\n      const newName = getUntypedVersionOfImportOrName(usage.importName);\n      if (newName === null) {\n        // This should never happen.\n        console.error(\n            `Typed forms migration error: unknown replacement for usage ${usage.node.getText()}`);\n        continue;\n      }\n      rewrite(usage.node.getStart(), usage.node.getWidth(), newName);\n    }\n  }\n\n  // For each imported control class, migrate to the corresponding uptyped import.\n  for (const imp of imports) {\n    const untypedClass = getUntypedVersionOfImportOrName(imp.getText());\n    if (untypedClass === null) {\n      // This should never happen.\n      console.error(\n          `Typed forms migration error: unknown untyped version of import ${imp.getText()}`);\n      continue;\n    }\n    if (getImportSpecifier(sourceFile, forms, untypedClass)) {\n      // In order to make the migration idempotent, we must check whether the untyped version of the\n      // class is already present. If present, immediately continue.\n      continue;\n    }\n    rewrite(imp.getStart(), imp.getWidth(), untypedClass);\n  }\n}\n\nfunction getImports(sourceFile: ts.SourceFile): ts.ImportSpecifier[] {\n  let imports: ts.ImportSpecifier[] = [];\n  for (const cc of classes) {\n    const specifier = getImportSpecifier(sourceFile, forms, cc);\n    if (!specifier) continue;\n    imports.push(specifier);\n  }\n  return imports;\n}\n\nfunction getUntypedVersionOfImportOrName(name: string): string|null {\n  for (const cc of classes) {\n    if (name.includes(cc)) {\n      return `${untypedPrefix}${cc}`;\n    }\n  }\n  return null;\n}\n\nfunction getUsages(\n    sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker,\n    importSpecifier: ts.ImportSpecifier): MigratableNode[] {\n  const usages: MigratableNode[] = [];\n  const visitNode = (node: ts.Node) => {\n    if (ts.isImportSpecifier(node)) {\n      // Skip this node and all of its children; imports are a special case.\n      return;\n    }\n    if (ts.isIdentifier(node) && isUsageOfFormsImport(typeChecker, node, importSpecifier)) {\n      usages.push({node, importName: importSpecifier.getText()});\n    }\n    ts.forEachChild(node, visitNode);\n  };\n  ts.forEachChild(sourceFile, visitNode);\n  return usages;\n}\n\nfunction isUsageOfFormsImport(\n    typeChecker: ts.TypeChecker, node: ts.Identifier,\n    importSpecifier: ts.ImportSpecifier): boolean {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  // We check symbol.declarations because we actually care about the name at the declaration site,\n  // not the usage site. These could be different in the case of overridden constructors.\n  if (!symbol || symbol.declarations === undefined || !symbol.declarations.length) return false;\n\n  const decl = symbol.declarations[0];\n  if (!ts.isImportSpecifier(decl)) return false;\n\n  // As per `typescript/imports.ts`, we must walk up the tree to find the enclosing import\n  // declaration. For reasons specific to the TS AST, this is always 3 levels up from an import\n  // specifier node.\n  const importDecl = decl.parent.parent.parent;\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) return false;\n\n  const importName = typeChecker.getTypeAtLocation(importSpecifier)?.getSymbol()?.getName();\n  if (!importName) return false;\n\n  // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n  const declName = decl.propertyName ? decl.propertyName.text : decl.name.text;\n\n  if (importName === declName) return true;\n\n  // In the case of FormControl's overridden exported constructor, the value name and declaration\n  // name are not exactly the same. For our purposes, it's enough to check whether the latter is a\n  // substring of the former.\n  if (declName === formControl && importName.includes(declName)) return true;\n\n  return false;\n}\n"]}
|