@angular/core 14.1.0-rc.0 → 14.2.0-next.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 +25 -20
- package/esm2020/src/core.mjs +2 -1
- package/esm2020/src/core_private_export.mjs +2 -2
- package/esm2020/src/di/injector_compatibility.mjs +2 -2
- package/esm2020/src/di/r3_injector.mjs +7 -1
- package/esm2020/src/errors.mjs +1 -1
- package/esm2020/src/linker/component_factory_resolver.mjs +1 -1
- package/esm2020/src/render3/component.mjs +120 -127
- package/esm2020/src/render3/component_ref.mjs +144 -9
- package/esm2020/src/render3/errors.mjs +9 -5
- package/esm2020/src/render3/index.mjs +2 -2
- package/esm2020/src/render3/instructions/element_validation.mjs +9 -5
- package/esm2020/src/render3/ng_module_ref.mjs +4 -14
- package/esm2020/src/version.mjs +1 -1
- package/esm2020/testing/src/logger.mjs +3 -3
- package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
- package/esm2020/testing/src/test_bed.mjs +442 -15
- package/esm2020/testing/src/test_bed_common.mjs +1 -1
- package/esm2020/testing/src/test_bed_compiler.mjs +823 -0
- package/esm2020/testing/src/test_hooks.mjs +5 -5
- package/esm2020/testing/src/testing.mjs +1 -1
- package/fesm2015/core.mjs +13088 -12945
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/testing.mjs +13215 -13220
- package/fesm2015/testing.mjs.map +1 -1
- package/fesm2020/core.mjs +13088 -12945
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/testing.mjs +13215 -13221
- package/fesm2020/testing.mjs.map +1 -1
- package/index.d.ts +155 -8
- package/package.json +1 -1
- package/testing/index.d.ts +19 -95
- package/esm2020/testing/src/r3_test_bed.mjs +0 -433
- package/esm2020/testing/src/r3_test_bed_compiler.mjs +0 -823
|
@@ -5,146 +5,139 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import { addToViewTree, CLEAN_PROMISE, createLView, getOrCreateTComponentView, getOrCreateTNode, initTNodeFlags, instantiateRootComponent, invokeHostBindingsInCreationMode, markAsComponentHost, registerHostBindingOpCodes } from './instructions/shared';
|
|
13
|
-
import { CONTEXT, HEADER_OFFSET, TVIEW } from './interfaces/view';
|
|
14
|
-
import { writeDirectClass, writeDirectStyle } from './node_manipulation';
|
|
15
|
-
import { getCurrentTNode, getLView, setSelectedIndex } from './state';
|
|
16
|
-
import { computeStaticStyling } from './styling/static_styling';
|
|
17
|
-
import { setUpAttributes } from './util/attrs_utils';
|
|
18
|
-
import { defaultScheduler } from './util/misc_utils';
|
|
19
|
-
import { getRootContext } from './util/view_traversal_utils';
|
|
20
|
-
// TODO: A hack to not pull in the NullInjector from @angular/core.
|
|
21
|
-
export const NULL_INJECTOR = {
|
|
22
|
-
get: (token, notFoundValue) => {
|
|
23
|
-
throwProviderNotFoundError(token, 'NullInjector');
|
|
24
|
-
}
|
|
25
|
-
};
|
|
8
|
+
import { getNullInjector } from '../di/r3_injector';
|
|
9
|
+
import { ComponentFactory } from './component_ref';
|
|
10
|
+
import { getComponentDef } from './definition';
|
|
11
|
+
import { assertComponentDef } from './errors';
|
|
26
12
|
/**
|
|
27
|
-
* Creates
|
|
13
|
+
* Creates a `ComponentRef` instance based on provided component type and a set of options.
|
|
28
14
|
*
|
|
29
|
-
* @
|
|
30
|
-
* @param def ComponentDef
|
|
31
|
-
* @param rootView The parent view where the host node is stored
|
|
32
|
-
* @param rendererFactory Factory to be used for creating child renderers.
|
|
33
|
-
* @param hostRenderer The current renderer
|
|
34
|
-
* @param sanitizer The sanitizer, if provided
|
|
15
|
+
* @usageNotes
|
|
35
16
|
*
|
|
36
|
-
*
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const tView = rootView[TVIEW];
|
|
40
|
-
const index = HEADER_OFFSET;
|
|
41
|
-
ngDevMode && assertIndexInRange(rootView, index);
|
|
42
|
-
rootView[index] = rNode;
|
|
43
|
-
// '#host' is added here as we don't know the real host DOM name (we don't want to read it) and at
|
|
44
|
-
// the same time we want to communicate the debug `TNode` that this is a special `TNode`
|
|
45
|
-
// representing a host element.
|
|
46
|
-
const tNode = getOrCreateTNode(tView, index, 2 /* TNodeType.Element */, '#host', null);
|
|
47
|
-
const mergedAttrs = tNode.mergedAttrs = def.hostAttrs;
|
|
48
|
-
if (mergedAttrs !== null) {
|
|
49
|
-
computeStaticStyling(tNode, mergedAttrs, true);
|
|
50
|
-
if (rNode !== null) {
|
|
51
|
-
setUpAttributes(hostRenderer, rNode, mergedAttrs);
|
|
52
|
-
if (tNode.classes !== null) {
|
|
53
|
-
writeDirectClass(hostRenderer, rNode, tNode.classes);
|
|
54
|
-
}
|
|
55
|
-
if (tNode.styles !== null) {
|
|
56
|
-
writeDirectStyle(hostRenderer, rNode, tNode.styles);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
const viewRenderer = rendererFactory.createRenderer(rNode, def);
|
|
61
|
-
const componentView = createLView(rootView, getOrCreateTComponentView(def), null, def.onPush ? 32 /* LViewFlags.Dirty */ : 16 /* LViewFlags.CheckAlways */, rootView[index], tNode, rendererFactory, viewRenderer, sanitizer || null, null, null);
|
|
62
|
-
if (tView.firstCreatePass) {
|
|
63
|
-
diPublicInInjector(getOrCreateNodeInjectorForNode(tNode, rootView), tView, def.type);
|
|
64
|
-
markAsComponentHost(tView, tNode);
|
|
65
|
-
initTNodeFlags(tNode, rootView.length, 1);
|
|
66
|
-
}
|
|
67
|
-
addToViewTree(rootView, componentView);
|
|
68
|
-
// Store component view at node index, with node as the HOST
|
|
69
|
-
return rootView[index] = componentView;
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* Creates a root component and sets it up with features and host bindings. Shared by
|
|
73
|
-
* renderComponent() and ViewContainerRef.createComponent().
|
|
74
|
-
*/
|
|
75
|
-
export function createRootComponent(componentView, componentDef, rootLView, rootContext, hostFeatures) {
|
|
76
|
-
const tView = rootLView[TVIEW];
|
|
77
|
-
// Create directive instance with factory() and store at next index in viewData
|
|
78
|
-
const component = instantiateRootComponent(tView, rootLView, componentDef);
|
|
79
|
-
rootContext.components.push(component);
|
|
80
|
-
componentView[CONTEXT] = component;
|
|
81
|
-
if (hostFeatures !== null) {
|
|
82
|
-
for (const feature of hostFeatures) {
|
|
83
|
-
feature(component, componentDef);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
// We want to generate an empty QueryList for root content queries for backwards
|
|
87
|
-
// compatibility with ViewEngine.
|
|
88
|
-
if (componentDef.contentQueries) {
|
|
89
|
-
const tNode = getCurrentTNode();
|
|
90
|
-
ngDevMode && assertDefined(tNode, 'TNode expected');
|
|
91
|
-
componentDef.contentQueries(1 /* RenderFlags.Create */, component, tNode.directiveStart);
|
|
92
|
-
}
|
|
93
|
-
const rootTNode = getCurrentTNode();
|
|
94
|
-
ngDevMode && assertDefined(rootTNode, 'tNode should have been already created');
|
|
95
|
-
if (tView.firstCreatePass &&
|
|
96
|
-
(componentDef.hostBindings !== null || componentDef.hostAttrs !== null)) {
|
|
97
|
-
setSelectedIndex(rootTNode.index);
|
|
98
|
-
const rootTView = rootLView[TVIEW];
|
|
99
|
-
registerHostBindingOpCodes(rootTView, rootTNode, rootLView, rootTNode.directiveStart, rootTNode.directiveEnd, componentDef);
|
|
100
|
-
invokeHostBindingsInCreationMode(componentDef, component);
|
|
101
|
-
}
|
|
102
|
-
return component;
|
|
103
|
-
}
|
|
104
|
-
export function createRootContext(scheduler, playerHandler) {
|
|
105
|
-
return {
|
|
106
|
-
components: [],
|
|
107
|
-
scheduler: scheduler || defaultScheduler,
|
|
108
|
-
clean: CLEAN_PROMISE,
|
|
109
|
-
playerHandler: playerHandler || null,
|
|
110
|
-
flags: 0 /* RootContextFlags.Empty */
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Used to enable lifecycle hooks on the root component.
|
|
17
|
+
* The example below demonstrates how the `createComponent` function can be used
|
|
18
|
+
* to create an instance of a ComponentRef dynamically and attach it to an ApplicationRef,
|
|
19
|
+
* so that it gets included into change detection cycles.
|
|
115
20
|
*
|
|
116
|
-
*
|
|
117
|
-
*
|
|
118
|
-
* be called properly.
|
|
21
|
+
* Note: the example uses standalone components, but the function can also be used for
|
|
22
|
+
* non-standalone components (declared in an NgModule) as well.
|
|
119
23
|
*
|
|
120
|
-
*
|
|
24
|
+
* ```typescript
|
|
25
|
+
* @Component({
|
|
26
|
+
* standalone: true,
|
|
27
|
+
* template: `Hello {{ name }}!`
|
|
28
|
+
* })
|
|
29
|
+
* class HelloComponent {
|
|
30
|
+
* name = 'Angular';
|
|
31
|
+
* }
|
|
121
32
|
*
|
|
33
|
+
* @Component({
|
|
34
|
+
* standalone: true,
|
|
35
|
+
* template: `<div id="hello-component-host"></div>`
|
|
36
|
+
* })
|
|
37
|
+
* class RootComponent {}
|
|
38
|
+
*
|
|
39
|
+
* // Bootstrap an application.
|
|
40
|
+
* const applicationRef = await bootstrapApplication(RootComponent);
|
|
41
|
+
*
|
|
42
|
+
* // Locate a DOM node that would be used as a host.
|
|
43
|
+
* const host = document.getElementById('hello-component-host');
|
|
44
|
+
*
|
|
45
|
+
* // Get an `EnvironmentInjector` instance from the `ApplicationRef`.
|
|
46
|
+
* const environmentInjector = applicationRef.injector;
|
|
47
|
+
*
|
|
48
|
+
* // We can now create a `ComponentRef` instance.
|
|
49
|
+
* const componentRef = createComponent(HelloComponent, {host, environmentInjector});
|
|
50
|
+
*
|
|
51
|
+
* // Last step is to register the newly created ref using the `ApplicationRef` instance
|
|
52
|
+
* // to include the component view into change detection cycles.
|
|
53
|
+
* applicationRef.attachView(componentRef.hostView);
|
|
122
54
|
* ```
|
|
123
|
-
*
|
|
124
|
-
*
|
|
55
|
+
*
|
|
56
|
+
* @param component Component class reference.
|
|
57
|
+
* @param options Set of options to use:
|
|
58
|
+
* * `environmentInjector`: An `EnvironmentInjector` instance to be used for the component, see
|
|
59
|
+
* additional info about it at https://angular.io/guide/standalone-components#environment-injectors.
|
|
60
|
+
* * `hostElement` (optional): A DOM node that should act as a host node for the component. If not
|
|
61
|
+
* provided, Angular creates one based on the tag name used in the component selector (and falls
|
|
62
|
+
* back to using `div` if selector doesn't have tag name info).
|
|
63
|
+
* * `elementInjector` (optional): An `ElementInjector` instance, see additional info about it at
|
|
64
|
+
* https://angular.io/guide/hierarchical-dependency-injection#elementinjector.
|
|
65
|
+
* * `projectableNodes` (optional): A list of DOM nodes that should be projected through
|
|
66
|
+
* [`<ng-content>`](api/core/ng-content) of the new component instance.
|
|
67
|
+
* @returns ComponentRef instance that represents a given Component.
|
|
68
|
+
*
|
|
69
|
+
* @publicApi
|
|
125
70
|
*/
|
|
126
|
-
export function
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
71
|
+
export function createComponent(component, options) {
|
|
72
|
+
ngDevMode && assertComponentDef(component);
|
|
73
|
+
const componentDef = getComponentDef(component);
|
|
74
|
+
const elementInjector = options.elementInjector || getNullInjector();
|
|
75
|
+
const factory = new ComponentFactory(componentDef);
|
|
76
|
+
return factory.create(elementInjector, options.projectableNodes, options.hostElement, options.environmentInjector);
|
|
130
77
|
}
|
|
131
78
|
/**
|
|
132
|
-
*
|
|
79
|
+
* Creates an object that allows to retrieve component metadata.
|
|
133
80
|
*
|
|
134
|
-
*
|
|
135
|
-
* change detection is executed. This is determined by finding the scheduler
|
|
136
|
-
* associated with the `component`'s render tree and waiting until the scheduler
|
|
137
|
-
* flushes. If nothing is scheduled, the function returns a resolved promise.
|
|
81
|
+
* @usageNotes
|
|
138
82
|
*
|
|
139
|
-
*
|
|
140
|
-
*
|
|
141
|
-
*
|
|
83
|
+
* The example below demonstrates how to use the function and how the fields
|
|
84
|
+
* of the returned object map to the component metadata.
|
|
85
|
+
*
|
|
86
|
+
* ```typescript
|
|
87
|
+
* @Component({
|
|
88
|
+
* standalone: true,
|
|
89
|
+
* selector: 'foo-component',
|
|
90
|
+
* template: `
|
|
91
|
+
* <ng-content></ng-content>
|
|
92
|
+
* <ng-content select="content-selector-a"></ng-content>
|
|
93
|
+
* `,
|
|
94
|
+
* })
|
|
95
|
+
* class FooComponent {
|
|
96
|
+
* @Input('inputName') inputPropName: string;
|
|
97
|
+
* @Output('outputName') outputPropName = new EventEmitter<void>();
|
|
98
|
+
* }
|
|
99
|
+
*
|
|
100
|
+
* const mirror = reflectComponentType(FooComponent);
|
|
101
|
+
* expect(mirror.type).toBe(FooComponent);
|
|
102
|
+
* expect(mirror.selector).toBe('foo-component');
|
|
103
|
+
* expect(mirror.isStandalone).toBe(true);
|
|
104
|
+
* expect(mirror.inputs).toEqual([{propName: 'inputName', templateName: 'inputPropName'}]);
|
|
105
|
+
* expect(mirror.outputs).toEqual([{propName: 'outputName', templateName: 'outputPropName'}]);
|
|
106
|
+
* expect(mirror.ngContentSelectors).toEqual([
|
|
107
|
+
* '*', // first `<ng-content>` in a template, the selector defaults to `*`
|
|
108
|
+
* 'content-selector-a' // second `<ng-content>` in a template
|
|
109
|
+
* ]);
|
|
142
110
|
* ```
|
|
143
111
|
*
|
|
144
|
-
* @param component Component
|
|
145
|
-
* @returns
|
|
112
|
+
* @param component Component class reference.
|
|
113
|
+
* @returns An object that allows to retrieve component metadata.
|
|
114
|
+
*
|
|
115
|
+
* @publicApi
|
|
146
116
|
*/
|
|
147
|
-
export function
|
|
148
|
-
|
|
117
|
+
export function reflectComponentType(component) {
|
|
118
|
+
const componentDef = getComponentDef(component);
|
|
119
|
+
if (!componentDef)
|
|
120
|
+
return null;
|
|
121
|
+
const factory = new ComponentFactory(componentDef);
|
|
122
|
+
return {
|
|
123
|
+
get selector() {
|
|
124
|
+
return factory.selector;
|
|
125
|
+
},
|
|
126
|
+
get type() {
|
|
127
|
+
return factory.componentType;
|
|
128
|
+
},
|
|
129
|
+
get inputs() {
|
|
130
|
+
return factory.inputs;
|
|
131
|
+
},
|
|
132
|
+
get outputs() {
|
|
133
|
+
return factory.outputs;
|
|
134
|
+
},
|
|
135
|
+
get ngContentSelectors() {
|
|
136
|
+
return factory.ngContentSelectors;
|
|
137
|
+
},
|
|
138
|
+
get isStandalone() {
|
|
139
|
+
return componentDef.standalone;
|
|
140
|
+
},
|
|
141
|
+
};
|
|
149
142
|
}
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/component.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\n// We are temporarily importing the existing viewEngine from core so we can be sure we are\n// correctly implementing its interfaces for backwards compatibility.\nimport {Injector} from '../di/injector';\nimport {Sanitizer} from '../sanitization/sanitizer';\nimport {assertDefined, assertIndexInRange} from '../util/assert';\n\nimport {diPublicInInjector, getOrCreateNodeInjectorForNode} from './di';\nimport {throwProviderNotFoundError} from './errors_di';\nimport {registerPostOrderHooks} from './hooks';\nimport {addToViewTree, CLEAN_PROMISE, createLView, getOrCreateTComponentView, getOrCreateTNode, initTNodeFlags, instantiateRootComponent, invokeHostBindingsInCreationMode, markAsComponentHost, registerHostBindingOpCodes} from './instructions/shared';\nimport {ComponentDef, RenderFlags} from './interfaces/definition';\nimport {TElementNode, TNodeType} from './interfaces/node';\nimport {PlayerHandler} from './interfaces/player';\nimport {Renderer, RendererFactory} from './interfaces/renderer';\nimport {RElement} from './interfaces/renderer_dom';\nimport {CONTEXT, HEADER_OFFSET, LView, LViewFlags, RootContext, RootContextFlags, TVIEW} from './interfaces/view';\nimport {writeDirectClass, writeDirectStyle} from './node_manipulation';\nimport {getCurrentTNode, getLView, setSelectedIndex} from './state';\nimport {computeStaticStyling} from './styling/static_styling';\nimport {setUpAttributes} from './util/attrs_utils';\nimport {defaultScheduler} from './util/misc_utils';\nimport {getRootContext} from './util/view_traversal_utils';\n\n\n\n/** Options that control how the component should be bootstrapped. */\nexport interface CreateComponentOptions {\n  /** Which renderer factory to use. */\n  rendererFactory?: RendererFactory;\n\n  /** A custom sanitizer instance */\n  sanitizer?: Sanitizer;\n\n  /** A custom animation player handler */\n  playerHandler?: PlayerHandler;\n\n  /**\n   * Host element on which the component will be bootstrapped. If not specified,\n   * the component definition's `tag` is used to query the existing DOM for the\n   * element to bootstrap.\n   */\n  host?: RElement|string;\n\n  /** Module injector for the component. If unspecified, the injector will be NULL_INJECTOR. */\n  injector?: Injector;\n\n  /**\n   * List of features to be applied to the created component. Features are simply\n   * functions that decorate a component with a certain behavior.\n   *\n   * Typically, the features in this list are features that cannot be added to the\n   * other features list in the component definition because they rely on other factors.\n   *\n   * Example: `LifecycleHooksFeature` is a function that adds lifecycle hook capabilities\n   * to root components in a tree-shakable way. It cannot be added to the component\n   * features list because there's no way of knowing when the component will be used as\n   * a root component.\n   */\n  hostFeatures?: HostFeature[];\n\n  /**\n   * A function which is used to schedule change detection work in the future.\n   *\n   * When marking components as dirty, it is necessary to schedule the work of\n   * change detection in the future. This is done to coalesce multiple\n   * {@link markDirty} calls into a single changed detection processing.\n   *\n   * The default value of the scheduler is the `requestAnimationFrame` function.\n   *\n   * It is also useful to override this function for testing purposes.\n   */\n  scheduler?: (work: () => void) => void;\n}\n\n/** See CreateComponentOptions.hostFeatures */\ntype HostFeature = (<T>(component: T, componentDef: ComponentDef<T>) => void);\n\n// TODO: A hack to not pull in the NullInjector from @angular/core.\nexport const NULL_INJECTOR: Injector = {\n  get: (token: any, notFoundValue?: any) => {\n    throwProviderNotFoundError(token, 'NullInjector');\n  }\n};\n\n/**\n * Creates the root component view and the root component node.\n *\n * @param rNode Render host element.\n * @param def ComponentDef\n * @param rootView The parent view where the host node is stored\n * @param rendererFactory Factory to be used for creating child renderers.\n * @param hostRenderer The current renderer\n * @param sanitizer The sanitizer, if provided\n *\n * @returns Component view created\n */\nexport function createRootComponentView(\n    rNode: RElement|null, def: ComponentDef<any>, rootView: LView, rendererFactory: RendererFactory,\n    hostRenderer: Renderer, sanitizer?: Sanitizer|null): LView {\n  const tView = rootView[TVIEW];\n  const index = HEADER_OFFSET;\n  ngDevMode && assertIndexInRange(rootView, index);\n  rootView[index] = rNode;\n  // '#host' is added here as we don't know the real host DOM name (we don't want to read it) and at\n  // the same time we want to communicate the debug `TNode` that this is a special `TNode`\n  // representing a host element.\n  const tNode: TElementNode = getOrCreateTNode(tView, index, TNodeType.Element, '#host', null);\n  const mergedAttrs = tNode.mergedAttrs = def.hostAttrs;\n  if (mergedAttrs !== null) {\n    computeStaticStyling(tNode, mergedAttrs, true);\n    if (rNode !== null) {\n      setUpAttributes(hostRenderer, rNode, mergedAttrs);\n      if (tNode.classes !== null) {\n        writeDirectClass(hostRenderer, rNode, tNode.classes);\n      }\n      if (tNode.styles !== null) {\n        writeDirectStyle(hostRenderer, rNode, tNode.styles);\n      }\n    }\n  }\n\n  const viewRenderer = rendererFactory.createRenderer(rNode, def);\n  const componentView = createLView(\n      rootView, getOrCreateTComponentView(def), null,\n      def.onPush ? LViewFlags.Dirty : LViewFlags.CheckAlways, rootView[index], tNode,\n      rendererFactory, viewRenderer, sanitizer || null, null, null);\n\n  if (tView.firstCreatePass) {\n    diPublicInInjector(getOrCreateNodeInjectorForNode(tNode, rootView), tView, def.type);\n    markAsComponentHost(tView, tNode);\n    initTNodeFlags(tNode, rootView.length, 1);\n  }\n\n  addToViewTree(rootView, componentView);\n\n  // Store component view at node index, with node as the HOST\n  return rootView[index] = componentView;\n}\n\n/**\n * Creates a root component and sets it up with features and host bindings. Shared by\n * renderComponent() and ViewContainerRef.createComponent().\n */\nexport function createRootComponent<T>(\n    componentView: LView, componentDef: ComponentDef<T>, rootLView: LView, rootContext: RootContext,\n    hostFeatures: HostFeature[]|null): any {\n  const tView = rootLView[TVIEW];\n  // Create directive instance with factory() and store at next index in viewData\n  const component = instantiateRootComponent(tView, rootLView, componentDef);\n\n  rootContext.components.push(component);\n  componentView[CONTEXT] = component;\n\n  if (hostFeatures !== null) {\n    for (const feature of hostFeatures) {\n      feature(component, componentDef);\n    }\n  }\n\n  // We want to generate an empty QueryList for root content queries for backwards\n  // compatibility with ViewEngine.\n  if (componentDef.contentQueries) {\n    const tNode = getCurrentTNode()!;\n    ngDevMode && assertDefined(tNode, 'TNode expected');\n    componentDef.contentQueries(RenderFlags.Create, component, tNode.directiveStart);\n  }\n\n  const rootTNode = getCurrentTNode()!;\n  ngDevMode && assertDefined(rootTNode, 'tNode should have been already created');\n  if (tView.firstCreatePass &&\n      (componentDef.hostBindings !== null || componentDef.hostAttrs !== null)) {\n    setSelectedIndex(rootTNode.index);\n\n    const rootTView = rootLView[TVIEW];\n    registerHostBindingOpCodes(\n        rootTView, rootTNode, rootLView, rootTNode.directiveStart, rootTNode.directiveEnd,\n        componentDef);\n\n    invokeHostBindingsInCreationMode(componentDef, component);\n  }\n  return component;\n}\n\n\nexport function createRootContext(\n    scheduler?: (workFn: () => void) => void, playerHandler?: PlayerHandler|null): RootContext {\n  return {\n    components: [],\n    scheduler: scheduler || defaultScheduler,\n    clean: CLEAN_PROMISE,\n    playerHandler: playerHandler || null,\n    flags: RootContextFlags.Empty\n  };\n}\n\n/**\n * Used to enable lifecycle hooks on the root component.\n *\n * Include this feature when calling `renderComponent` if the root component\n * you are rendering has lifecycle hooks defined. Otherwise, the hooks won't\n * be called properly.\n *\n * Example:\n *\n * ```\n * renderComponent(AppComponent, {hostFeatures: [LifecycleHooksFeature]});\n * ```\n */\nexport function LifecycleHooksFeature(): void {\n  const tNode = getCurrentTNode()!;\n  ngDevMode && assertDefined(tNode, 'TNode is required');\n  registerPostOrderHooks(getLView()[TVIEW], tNode);\n}\n\n/**\n * Wait on component until it is rendered.\n *\n * This function returns a `Promise` which is resolved when the component's\n * change detection is executed. This is determined by finding the scheduler\n * associated with the `component`'s render tree and waiting until the scheduler\n * flushes. If nothing is scheduled, the function returns a resolved promise.\n *\n * Example:\n * ```\n * await whenRendered(myComponent);\n * ```\n *\n * @param component Component to wait upon\n * @returns Promise which resolves when the component is rendered.\n */\nexport function whenRendered(component: any): Promise<null> {\n  return getRootContext(component).clean;\n}\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/component.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EAAsB,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAIvE,OAAO,EAAC,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAC,eAAe,EAAC,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAC,kBAAkB,EAAC,MAAM,UAAU,CAAC;AAE5C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0DG;AACH,MAAM,UAAU,eAAe,CAAI,SAAkB,EAAE,OAKtD;IACC,SAAS,IAAI,kBAAkB,CAAC,SAAS,CAAC,CAAC;IAC3C,MAAM,YAAY,GAAG,eAAe,CAAC,SAAS,CAAE,CAAC;IACjD,MAAM,eAAe,GAAG,OAAO,CAAC,eAAe,IAAI,eAAe,EAAE,CAAC;IACrE,MAAM,OAAO,GAAG,IAAI,gBAAgB,CAAI,YAAY,CAAC,CAAC;IACtD,OAAO,OAAO,CAAC,MAAM,CACjB,eAAe,EAAE,OAAO,CAAC,gBAAgB,EAAE,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC;AACnG,CAAC;AAoCD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AACH,MAAM,UAAU,oBAAoB,CAAI,SAAkB;IACxD,MAAM,YAAY,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;IAChD,IAAI,CAAC,YAAY;QAAE,OAAO,IAAI,CAAC;IAE/B,MAAM,OAAO,GAAG,IAAI,gBAAgB,CAAI,YAAY,CAAC,CAAC;IACtD,OAAO;QACL,IAAI,QAAQ;YACV,OAAO,OAAO,CAAC,QAAQ,CAAC;QAC1B,CAAC;QACD,IAAI,IAAI;YACN,OAAO,OAAO,CAAC,aAAa,CAAC;QAC/B,CAAC;QACD,IAAI,MAAM;YACR,OAAO,OAAO,CAAC,MAAM,CAAC;QACxB,CAAC;QACD,IAAI,OAAO;YACT,OAAO,OAAO,CAAC,OAAO,CAAC;QACzB,CAAC;QACD,IAAI,kBAAkB;YACpB,OAAO,OAAO,CAAC,kBAAkB,CAAC;QACpC,CAAC;QACD,IAAI,YAAY;YACd,OAAO,YAAY,CAAC,UAAU,CAAC;QACjC,CAAC;KACF,CAAC;AACJ,CAAC","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 {Injector} from '../di/injector';\nimport {EnvironmentInjector, getNullInjector} from '../di/r3_injector';\nimport {Type} from '../interface/type';\nimport {ComponentRef} from '../linker/component_factory';\n\nimport {ComponentFactory} from './component_ref';\nimport {getComponentDef} from './definition';\nimport {assertComponentDef} from './errors';\n\n/**\n * Creates a `ComponentRef` instance based on provided component type and a set of options.\n *\n * @usageNotes\n *\n * The example below demonstrates how the `createComponent` function can be used\n * to create an instance of a ComponentRef dynamically and attach it to an ApplicationRef,\n * so that it gets included into change detection cycles.\n *\n * Note: the example uses standalone components, but the function can also be used for\n * non-standalone components (declared in an NgModule) as well.\n *\n * ```typescript\n * @Component({\n *   standalone: true,\n *   template: `Hello {{ name }}!`\n * })\n * class HelloComponent {\n *   name = 'Angular';\n * }\n *\n * @Component({\n *   standalone: true,\n *   template: `<div id=\"hello-component-host\"></div>`\n * })\n * class RootComponent {}\n *\n * // Bootstrap an application.\n * const applicationRef = await bootstrapApplication(RootComponent);\n *\n * // Locate a DOM node that would be used as a host.\n * const host = document.getElementById('hello-component-host');\n *\n * // Get an `EnvironmentInjector` instance from the `ApplicationRef`.\n * const environmentInjector = applicationRef.injector;\n *\n * // We can now create a `ComponentRef` instance.\n * const componentRef = createComponent(HelloComponent, {host, environmentInjector});\n *\n * // Last step is to register the newly created ref using the `ApplicationRef` instance\n * // to include the component view into change detection cycles.\n * applicationRef.attachView(componentRef.hostView);\n * ```\n *\n * @param component Component class reference.\n * @param options Set of options to use:\n *  * `environmentInjector`: An `EnvironmentInjector` instance to be used for the component, see\n * additional info about it at https://angular.io/guide/standalone-components#environment-injectors.\n *  * `hostElement` (optional): A DOM node that should act as a host node for the component. If not\n * provided, Angular creates one based on the tag name used in the component selector (and falls\n * back to using `div` if selector doesn't have tag name info).\n *  * `elementInjector` (optional): An `ElementInjector` instance, see additional info about it at\n * https://angular.io/guide/hierarchical-dependency-injection#elementinjector.\n *  * `projectableNodes` (optional): A list of DOM nodes that should be projected through\n *                      [`<ng-content>`](api/core/ng-content) of the new component instance.\n * @returns ComponentRef instance that represents a given Component.\n *\n * @publicApi\n */\nexport function createComponent<C>(component: Type<C>, options: {\n  environmentInjector: EnvironmentInjector,\n  hostElement?: Element,\n  elementInjector?: Injector,\n  projectableNodes?: Node[][],\n}): ComponentRef<C> {\n  ngDevMode && assertComponentDef(component);\n  const componentDef = getComponentDef(component)!;\n  const elementInjector = options.elementInjector || getNullInjector();\n  const factory = new ComponentFactory<C>(componentDef);\n  return factory.create(\n      elementInjector, options.projectableNodes, options.hostElement, options.environmentInjector);\n}\n\n/**\n * An interface that describes the subset of component metadata\n * that can be retrieved using the `reflectComponentType` function.\n *\n * @publicApi\n */\nexport interface ComponentMirror<C> {\n  /**\n   * The component's HTML selector.\n   */\n  get selector(): string;\n  /**\n   * The type of component the factory will create.\n   */\n  get type(): Type<C>;\n  /**\n   * The inputs of the component.\n   */\n  get inputs(): ReadonlyArray<{readonly propName: string, readonly templateName: string}>;\n  /**\n   * The outputs of the component.\n   */\n  get outputs(): ReadonlyArray<{readonly propName: string, readonly templateName: string}>;\n  /**\n   * Selector for all <ng-content> elements in the component.\n   */\n  get ngContentSelectors(): ReadonlyArray<string>;\n  /**\n   * Whether this component is marked as standalone.\n   * Note: an extra flag, not present in `ComponentFactory`.\n   */\n  get isStandalone(): boolean;\n}\n\n/**\n * Creates an object that allows to retrieve component metadata.\n *\n * @usageNotes\n *\n * The example below demonstrates how to use the function and how the fields\n * of the returned object map to the component metadata.\n *\n * ```typescript\n * @Component({\n *   standalone: true,\n *   selector: 'foo-component',\n *   template: `\n *     <ng-content></ng-content>\n *     <ng-content select=\"content-selector-a\"></ng-content>\n *   `,\n * })\n * class FooComponent {\n *   @Input('inputName') inputPropName: string;\n *   @Output('outputName') outputPropName = new EventEmitter<void>();\n * }\n *\n * const mirror = reflectComponentType(FooComponent);\n * expect(mirror.type).toBe(FooComponent);\n * expect(mirror.selector).toBe('foo-component');\n * expect(mirror.isStandalone).toBe(true);\n * expect(mirror.inputs).toEqual([{propName: 'inputName', templateName: 'inputPropName'}]);\n * expect(mirror.outputs).toEqual([{propName: 'outputName', templateName: 'outputPropName'}]);\n * expect(mirror.ngContentSelectors).toEqual([\n *   '*',                 // first `<ng-content>` in a template, the selector defaults to `*`\n *   'content-selector-a' // second `<ng-content>` in a template\n * ]);\n * ```\n *\n * @param component Component class reference.\n * @returns An object that allows to retrieve component metadata.\n *\n * @publicApi\n */\nexport function reflectComponentType<C>(component: Type<C>): ComponentMirror<C>|null {\n  const componentDef = getComponentDef(component);\n  if (!componentDef) return null;\n\n  const factory = new ComponentFactory<C>(componentDef);\n  return {\n    get selector(): string {\n      return factory.selector;\n    },\n    get type(): Type<C> {\n      return factory.componentType;\n    },\n    get inputs(): ReadonlyArray<{propName: string, templateName: string}> {\n      return factory.inputs;\n    },\n    get outputs(): ReadonlyArray<{propName: string, templateName: string}> {\n      return factory.outputs;\n    },\n    get ngContentSelectors(): ReadonlyArray<string> {\n      return factory.ngContentSelectors;\n    },\n    get isStandalone(): boolean {\n      return componentDef.standalone;\n    },\n  };\n}\n"]}
|