@angular/core 9.1.5 → 9.1.9
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/bundles/core-testing.umd.js +1 -1
- package/bundles/core-testing.umd.min.js +1 -1
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +99 -334
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +126 -133
- package/bundles/core.umd.min.js.map +1 -1
- package/core.d.ts +47 -102
- package/core.metadata.json +1 -1
- package/esm2015/index.js +2 -2
- package/esm2015/public_api.js +2 -2
- package/esm2015/src/core.js +2 -2
- package/esm2015/src/core_render3_private_export.js +2 -2
- package/esm2015/src/reflection/reflection_capabilities.js +2 -2
- package/esm2015/src/render3/assert.js +1 -8
- package/esm2015/src/render3/component.js +2 -2
- package/esm2015/src/render3/component_ref.js +5 -3
- package/esm2015/src/render3/index.js +2 -2
- package/esm2015/src/render3/instructions/all.js +2 -3
- package/esm2015/src/render3/instructions/element.js +9 -6
- package/esm2015/src/render3/instructions/element_container.js +2 -2
- package/esm2015/src/render3/instructions/lview_debug.js +14 -11
- package/esm2015/src/render3/instructions/shared.js +32 -63
- package/esm2015/src/render3/instructions/styling.js +2 -2
- package/esm2015/src/render3/instructions/template.js +100 -0
- package/esm2015/src/render3/interfaces/container.js +9 -32
- package/esm2015/src/render3/interfaces/node.js +34 -4
- package/esm2015/src/render3/interfaces/view.js +1 -1
- package/esm2015/src/render3/jit/environment.js +1 -6
- package/esm2015/src/render3/node_assert.js +1 -1
- package/esm2015/src/render3/node_manipulation.js +3 -3
- package/esm2015/src/render3/styling/static_styling.js +25 -20
- package/esm2015/src/render3/util/view_traversal_utils.js +28 -2
- package/esm2015/src/render3/util/view_utils.js +2 -17
- package/esm2015/src/render3/view_engine_compatibility.js +3 -7
- package/esm2015/src/render3/view_ref.js +1 -10
- package/esm2015/src/util/assert.js +1 -1
- package/esm2015/src/version.js +1 -1
- package/esm5/src/core_render3_private_export.js +2 -2
- package/esm5/src/reflection/reflection_capabilities.js +2 -2
- package/esm5/src/render3/assert.js +1 -4
- package/esm5/src/render3/component.js +2 -2
- package/esm5/src/render3/component_ref.js +5 -3
- package/esm5/src/render3/index.js +2 -2
- package/esm5/src/render3/instructions/all.js +2 -3
- package/esm5/src/render3/instructions/element.js +9 -6
- package/esm5/src/render3/instructions/element_container.js +2 -2
- package/esm5/src/render3/instructions/lview_debug.js +8 -12
- package/esm5/src/render3/instructions/shared.js +30 -55
- package/esm5/src/render3/instructions/styling.js +2 -2
- package/esm5/src/render3/instructions/template.js +73 -0
- package/esm5/src/render3/interfaces/container.js +10 -2
- package/esm5/src/render3/interfaces/node.js +1 -1
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/jit/environment.js +1 -6
- package/esm5/src/render3/node_assert.js +1 -1
- package/esm5/src/render3/node_manipulation.js +3 -3
- package/esm5/src/render3/styling/static_styling.js +23 -18
- package/esm5/src/render3/util/view_traversal_utils.js +20 -2
- package/esm5/src/render3/util/view_utils.js +2 -8
- package/esm5/src/render3/view_engine_compatibility.js +3 -6
- package/esm5/src/render3/view_ref.js +1 -5
- package/esm5/src/util/assert.js +1 -1
- package/esm5/src/version.js +1 -1
- package/fesm2015/core.js +151 -435
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +1 -1
- package/fesm5/core.js +100 -330
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +1 -1
- package/package.json +1 -1
- package/src/r3_symbols.d.ts +1 -1
- package/testing/testing.d.ts +1 -1
- package/testing.d.ts +1 -1
- package/esm2015/src/render3/instructions/container.js +0 -227
- package/esm2015/src/render3/instructions/embedded_view.js +0 -151
- package/esm5/src/render3/instructions/container.js +0 -173
- package/esm5/src/render3/instructions/embedded_view.js +0 -127
package/fesm5/testing.js
CHANGED
package/package.json
CHANGED
package/src/r3_symbols.d.ts
CHANGED
package/testing/testing.d.ts
CHANGED
package/testing.d.ts
CHANGED
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* Generated from: packages/core/src/render3/instructions/container.ts
|
|
4
|
-
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
|
-
*/
|
|
6
|
-
/**
|
|
7
|
-
* @license
|
|
8
|
-
* Copyright Google Inc. All Rights Reserved.
|
|
9
|
-
*
|
|
10
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
11
|
-
* found in the LICENSE file at https://angular.io/license
|
|
12
|
-
*/
|
|
13
|
-
import { assertDataInRange, assertEqual } from '../../util/assert';
|
|
14
|
-
import { assertFirstCreatePass, assertHasParent } from '../assert';
|
|
15
|
-
import { attachPatchData } from '../context_discovery';
|
|
16
|
-
import { executeCheckHooks, executeInitAndCheckHooks, incrementInitPhaseFlags, registerPostOrderHooks } from '../hooks';
|
|
17
|
-
import { ACTIVE_INDEX, CONTAINER_HEADER_OFFSET } from '../interfaces/container';
|
|
18
|
-
import { isDirectiveHost } from '../interfaces/type_checks';
|
|
19
|
-
import { FLAGS, HEADER_OFFSET, RENDERER, T_HOST } from '../interfaces/view';
|
|
20
|
-
import { assertNodeType } from '../node_assert';
|
|
21
|
-
import { appendChild, removeView } from '../node_manipulation';
|
|
22
|
-
import { getBindingIndex, getCheckNoChangesMode, getIsParent, getLView, getPreviousOrParentTNode, getTView, setIsNotParent, setPreviousOrParentTNode } from '../state';
|
|
23
|
-
import { getConstant, getLContainerActiveIndex, load } from '../util/view_utils';
|
|
24
|
-
import { addToViewTree, createDirectivesInstances, createLContainer, createTNode, createTView, getOrCreateTNode, resolveDirectives, saveResolvedLocalsInData } from './shared';
|
|
25
|
-
/**
|
|
26
|
-
* Creates an LContainer for inline views, e.g.
|
|
27
|
-
*
|
|
28
|
-
* % if (showing) {
|
|
29
|
-
* <div></div>
|
|
30
|
-
* % }
|
|
31
|
-
*
|
|
32
|
-
* \@codeGenApi
|
|
33
|
-
* @param {?} index The index of the container in the data array
|
|
34
|
-
*
|
|
35
|
-
* @return {?}
|
|
36
|
-
*/
|
|
37
|
-
export function ɵɵcontainer(index) {
|
|
38
|
-
/** @type {?} */
|
|
39
|
-
const lView = getLView();
|
|
40
|
-
/** @type {?} */
|
|
41
|
-
const tView = getTView();
|
|
42
|
-
/** @type {?} */
|
|
43
|
-
const tNode = containerInternal(tView, lView, index, null, null);
|
|
44
|
-
if (tView.firstCreatePass) {
|
|
45
|
-
tNode.tViews = [];
|
|
46
|
-
}
|
|
47
|
-
setIsNotParent();
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* @param {?} index
|
|
51
|
-
* @param {?} tView
|
|
52
|
-
* @param {?} lView
|
|
53
|
-
* @param {?} templateFn
|
|
54
|
-
* @param {?} decls
|
|
55
|
-
* @param {?} vars
|
|
56
|
-
* @param {?=} tagName
|
|
57
|
-
* @param {?=} attrsIndex
|
|
58
|
-
* @param {?=} localRefsIndex
|
|
59
|
-
* @return {?}
|
|
60
|
-
*/
|
|
61
|
-
function templateFirstCreatePass(index, tView, lView, templateFn, decls, vars, tagName, attrsIndex, localRefsIndex) {
|
|
62
|
-
ngDevMode && assertFirstCreatePass(tView);
|
|
63
|
-
ngDevMode && ngDevMode.firstCreatePass++;
|
|
64
|
-
/** @type {?} */
|
|
65
|
-
const tViewConsts = tView.consts;
|
|
66
|
-
// TODO(pk): refactor getOrCreateTNode to have the "create" only version
|
|
67
|
-
/** @type {?} */
|
|
68
|
-
const tNode = getOrCreateTNode(tView, lView[T_HOST], index, 0 /* Container */, tagName || null, getConstant(tViewConsts, attrsIndex));
|
|
69
|
-
resolveDirectives(tView, lView, tNode, getConstant(tViewConsts, localRefsIndex));
|
|
70
|
-
registerPostOrderHooks(tView, tNode);
|
|
71
|
-
/** @type {?} */
|
|
72
|
-
const embeddedTView = tNode.tViews = createTView(2 /* Embedded */, -1, templateFn, decls, vars, tView.directiveRegistry, tView.pipeRegistry, null, tView.schemas, tViewConsts);
|
|
73
|
-
/** @type {?} */
|
|
74
|
-
const embeddedTViewNode = (/** @type {?} */ (createTNode(tView, null, 2 /* View */, -1, null, null)));
|
|
75
|
-
embeddedTViewNode.injectorIndex = tNode.injectorIndex;
|
|
76
|
-
embeddedTView.node = embeddedTViewNode;
|
|
77
|
-
if (tView.queries !== null) {
|
|
78
|
-
tView.queries.template(tView, tNode);
|
|
79
|
-
embeddedTView.queries = tView.queries.embeddedTView(tNode);
|
|
80
|
-
}
|
|
81
|
-
return tNode;
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Creates an LContainer for an ng-template (dynamically-inserted view), e.g.
|
|
85
|
-
*
|
|
86
|
-
* <ng-template #foo>
|
|
87
|
-
* <div></div>
|
|
88
|
-
* </ng-template>
|
|
89
|
-
*
|
|
90
|
-
* \@codeGenApi
|
|
91
|
-
* @param {?} index The index of the container in the data array
|
|
92
|
-
* @param {?} templateFn Inline template
|
|
93
|
-
* @param {?} decls The number of nodes, local refs, and pipes for this template
|
|
94
|
-
* @param {?} vars The number of bindings for this template
|
|
95
|
-
* @param {?=} tagName The name of the container element, if applicable
|
|
96
|
-
* @param {?=} attrsIndex Index of template attributes in the `consts` array.
|
|
97
|
-
* @param {?=} localRefsIndex
|
|
98
|
-
* @param {?=} localRefExtractor A function which extracts local-refs values from the template.
|
|
99
|
-
* Defaults to the current element associated with the local-ref.
|
|
100
|
-
*
|
|
101
|
-
* @return {?}
|
|
102
|
-
*/
|
|
103
|
-
export function ɵɵtemplate(index, templateFn, decls, vars, tagName, attrsIndex, localRefsIndex, localRefExtractor) {
|
|
104
|
-
/** @type {?} */
|
|
105
|
-
const lView = getLView();
|
|
106
|
-
/** @type {?} */
|
|
107
|
-
const tView = getTView();
|
|
108
|
-
/** @type {?} */
|
|
109
|
-
const adjustedIndex = index + HEADER_OFFSET;
|
|
110
|
-
/** @type {?} */
|
|
111
|
-
const tNode = tView.firstCreatePass ?
|
|
112
|
-
templateFirstCreatePass(index, tView, lView, templateFn, decls, vars, tagName, attrsIndex, localRefsIndex) :
|
|
113
|
-
(/** @type {?} */ (tView.data[adjustedIndex]));
|
|
114
|
-
setPreviousOrParentTNode(tNode, false);
|
|
115
|
-
/** @type {?} */
|
|
116
|
-
const comment = lView[RENDERER].createComment(ngDevMode ? 'container' : '');
|
|
117
|
-
appendChild(tView, lView, comment, tNode);
|
|
118
|
-
attachPatchData(comment, lView);
|
|
119
|
-
addToViewTree(lView, lView[adjustedIndex] = createLContainer(comment, lView, comment, tNode));
|
|
120
|
-
if (isDirectiveHost(tNode)) {
|
|
121
|
-
createDirectivesInstances(tView, lView, tNode);
|
|
122
|
-
}
|
|
123
|
-
if (localRefsIndex != null) {
|
|
124
|
-
saveResolvedLocalsInData(lView, tNode, localRefExtractor);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* Sets a container up to receive views.
|
|
129
|
-
*
|
|
130
|
-
* \@codeGenApi
|
|
131
|
-
* @param {?} index The index of the container in the data array
|
|
132
|
-
*
|
|
133
|
-
* @return {?}
|
|
134
|
-
*/
|
|
135
|
-
export function ɵɵcontainerRefreshStart(index) {
|
|
136
|
-
/** @type {?} */
|
|
137
|
-
const lView = getLView();
|
|
138
|
-
/** @type {?} */
|
|
139
|
-
const tView = getTView();
|
|
140
|
-
/** @type {?} */
|
|
141
|
-
let previousOrParentTNode = (/** @type {?} */ (load(tView.data, index)));
|
|
142
|
-
ngDevMode && assertNodeType(previousOrParentTNode, 0 /* Container */);
|
|
143
|
-
setPreviousOrParentTNode(previousOrParentTNode, true);
|
|
144
|
-
lView[index + HEADER_OFFSET][ACTIVE_INDEX] = 0;
|
|
145
|
-
// We need to execute init hooks here so ngOnInit hooks are called in top level views
|
|
146
|
-
// before they are called in embedded views (for backwards compatibility).
|
|
147
|
-
if (!getCheckNoChangesMode()) {
|
|
148
|
-
/** @type {?} */
|
|
149
|
-
const hooksInitPhaseCompleted = (lView[FLAGS] & 3 /* InitPhaseStateMask */) === 3 /* InitPhaseCompleted */;
|
|
150
|
-
if (hooksInitPhaseCompleted) {
|
|
151
|
-
/** @type {?} */
|
|
152
|
-
const preOrderCheckHooks = tView.preOrderCheckHooks;
|
|
153
|
-
if (preOrderCheckHooks !== null) {
|
|
154
|
-
executeCheckHooks(lView, preOrderCheckHooks, null);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
else {
|
|
158
|
-
/** @type {?} */
|
|
159
|
-
const preOrderHooks = tView.preOrderHooks;
|
|
160
|
-
if (preOrderHooks !== null) {
|
|
161
|
-
executeInitAndCheckHooks(lView, preOrderHooks, 0 /* OnInitHooksToBeRun */, null);
|
|
162
|
-
}
|
|
163
|
-
incrementInitPhaseFlags(lView, 0 /* OnInitHooksToBeRun */);
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
/**
|
|
168
|
-
* Marks the end of the LContainer.
|
|
169
|
-
*
|
|
170
|
-
* Marking the end of LContainer is the time when to child views get inserted or removed.
|
|
171
|
-
*
|
|
172
|
-
* \@codeGenApi
|
|
173
|
-
* @return {?}
|
|
174
|
-
*/
|
|
175
|
-
export function ɵɵcontainerRefreshEnd() {
|
|
176
|
-
/** @type {?} */
|
|
177
|
-
let previousOrParentTNode = getPreviousOrParentTNode();
|
|
178
|
-
if (getIsParent()) {
|
|
179
|
-
setIsNotParent();
|
|
180
|
-
}
|
|
181
|
-
else {
|
|
182
|
-
ngDevMode && assertNodeType(previousOrParentTNode, 2 /* View */);
|
|
183
|
-
ngDevMode && assertHasParent(previousOrParentTNode);
|
|
184
|
-
previousOrParentTNode = (/** @type {?} */ (previousOrParentTNode.parent));
|
|
185
|
-
setPreviousOrParentTNode(previousOrParentTNode, false);
|
|
186
|
-
}
|
|
187
|
-
ngDevMode && assertNodeType(previousOrParentTNode, 0 /* Container */);
|
|
188
|
-
/** @type {?} */
|
|
189
|
-
const lContainer = getLView()[previousOrParentTNode.index];
|
|
190
|
-
/** @type {?} */
|
|
191
|
-
const nextIndex = getLContainerActiveIndex(lContainer);
|
|
192
|
-
// remove extra views at the end of the container
|
|
193
|
-
while (nextIndex < lContainer.length - CONTAINER_HEADER_OFFSET) {
|
|
194
|
-
removeView(lContainer, nextIndex);
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
/**
|
|
198
|
-
* @param {?} tView
|
|
199
|
-
* @param {?} lView
|
|
200
|
-
* @param {?} nodeIndex
|
|
201
|
-
* @param {?} tagName
|
|
202
|
-
* @param {?} attrs
|
|
203
|
-
* @return {?}
|
|
204
|
-
*/
|
|
205
|
-
function containerInternal(tView, lView, nodeIndex, tagName, attrs) {
|
|
206
|
-
ngDevMode &&
|
|
207
|
-
assertEqual(getBindingIndex(), tView.bindingStartIndex, 'container nodes should be created before any bindings');
|
|
208
|
-
/** @type {?} */
|
|
209
|
-
const adjustedIndex = nodeIndex + HEADER_OFFSET;
|
|
210
|
-
ngDevMode && assertDataInRange(lView, nodeIndex + HEADER_OFFSET);
|
|
211
|
-
ngDevMode && ngDevMode.rendererCreateComment++;
|
|
212
|
-
/** @type {?} */
|
|
213
|
-
const comment = lView[adjustedIndex] =
|
|
214
|
-
lView[RENDERER].createComment(ngDevMode ? 'container' : '');
|
|
215
|
-
/** @type {?} */
|
|
216
|
-
const tNode = getOrCreateTNode(tView, lView[T_HOST], nodeIndex, 0 /* Container */, tagName, attrs);
|
|
217
|
-
/** @type {?} */
|
|
218
|
-
const lContainer = lView[adjustedIndex] = createLContainer(comment, lView, comment, tNode);
|
|
219
|
-
appendChild(tView, lView, comment, tNode);
|
|
220
|
-
attachPatchData(comment, lView);
|
|
221
|
-
// Containers are added to the current view tree instead of their embedded views
|
|
222
|
-
// because views can be removed and re-inserted.
|
|
223
|
-
addToViewTree(lView, lContainer);
|
|
224
|
-
ngDevMode && assertNodeType(getPreviousOrParentTNode(), 0 /* Container */);
|
|
225
|
-
return tNode;
|
|
226
|
-
}
|
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/container.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 */\nimport {assertDataInRange, assertEqual} from '../../util/assert';\nimport {assertFirstCreatePass, assertHasParent} from '../assert';\nimport {attachPatchData} from '../context_discovery';\nimport {executeCheckHooks, executeInitAndCheckHooks, incrementInitPhaseFlags, registerPostOrderHooks} from '../hooks';\nimport {ACTIVE_INDEX, CONTAINER_HEADER_OFFSET, LContainer} from '../interfaces/container';\nimport {ComponentTemplate} from '../interfaces/definition';\nimport {LocalRefExtractor, TAttributes, TContainerNode, TNode, TNodeType, TViewNode} from '../interfaces/node';\nimport {isDirectiveHost} from '../interfaces/type_checks';\nimport {FLAGS, HEADER_OFFSET, InitPhaseState, LView, LViewFlags, RENDERER, T_HOST, TView, TViewType} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {appendChild, removeView} from '../node_manipulation';\nimport {getBindingIndex, getCheckNoChangesMode, getIsParent, getLView, getPreviousOrParentTNode, getTView, setIsNotParent, setPreviousOrParentTNode} from '../state';\nimport {getConstant, getLContainerActiveIndex, load} from '../util/view_utils';\n\nimport {addToViewTree, createDirectivesInstances, createLContainer, createTNode, createTView, getOrCreateTNode, resolveDirectives, saveResolvedLocalsInData} from './shared';\n\n\n\n/**\n * Creates an LContainer for inline views, e.g.\n *\n * % if (showing) {\n *   <div></div>\n * % }\n *\n * @param index The index of the container in the data array\n *\n * @codeGenApi\n */\nexport function ɵɵcontainer(index: number): void {\n  const lView = getLView();\n  const tView = getTView();\n  const tNode = containerInternal(tView, lView, index, null, null);\n\n  if (tView.firstCreatePass) {\n    tNode.tViews = [];\n  }\n  setIsNotParent();\n}\n\nfunction templateFirstCreatePass(\n    index: number, tView: TView, lView: LView, templateFn: ComponentTemplate<any>|null,\n    decls: number, vars: number, tagName?: string|null, attrsIndex?: number|null,\n    localRefsIndex?: number|null): TContainerNode {\n  ngDevMode && assertFirstCreatePass(tView);\n  ngDevMode && ngDevMode.firstCreatePass++;\n  const tViewConsts = tView.consts;\n  // TODO(pk): refactor getOrCreateTNode to have the \"create\" only version\n  const tNode = getOrCreateTNode(\n      tView, lView[T_HOST], index, TNodeType.Container, tagName || null,\n      getConstant<TAttributes>(tViewConsts, attrsIndex));\n\n  resolveDirectives(tView, lView, tNode, getConstant<string[]>(tViewConsts, localRefsIndex));\n  registerPostOrderHooks(tView, tNode);\n\n  const embeddedTView = tNode.tViews = createTView(\n      TViewType.Embedded, -1, templateFn, decls, vars, tView.directiveRegistry, tView.pipeRegistry,\n      null, tView.schemas, tViewConsts);\n  const embeddedTViewNode = createTNode(tView, null, TNodeType.View, -1, null, null) as TViewNode;\n  embeddedTViewNode.injectorIndex = tNode.injectorIndex;\n  embeddedTView.node = embeddedTViewNode;\n\n  if (tView.queries !== null) {\n    tView.queries.template(tView, tNode);\n    embeddedTView.queries = tView.queries.embeddedTView(tNode);\n  }\n\n  return tNode;\n}\n\n/**\n * Creates an LContainer for an ng-template (dynamically-inserted view), e.g.\n *\n * <ng-template #foo>\n *    <div></div>\n * </ng-template>\n *\n * @param index The index of the container in the data array\n * @param templateFn Inline template\n * @param decls The number of nodes, local refs, and pipes for this template\n * @param vars The number of bindings for this template\n * @param tagName The name of the container element, if applicable\n * @param attrsIndex Index of template attributes in the `consts` array.\n * @param localRefs Index of the local references in the `consts` array.\n * @param localRefExtractor A function which extracts local-refs values from the template.\n *        Defaults to the current element associated with the local-ref.\n *\n * @codeGenApi\n */\nexport function ɵɵtemplate(\n    index: number, templateFn: ComponentTemplate<any>|null, decls: number, vars: number,\n    tagName?: string|null, attrsIndex?: number|null, localRefsIndex?: number|null,\n    localRefExtractor?: LocalRefExtractor) {\n  const lView = getLView();\n  const tView = getTView();\n  const adjustedIndex = index + HEADER_OFFSET;\n\n  const tNode = tView.firstCreatePass ?\n      templateFirstCreatePass(\n          index, tView, lView, templateFn, decls, vars, tagName, attrsIndex, localRefsIndex) :\n      tView.data[adjustedIndex] as TContainerNode;\n  setPreviousOrParentTNode(tNode, false);\n\n  const comment = lView[RENDERER].createComment(ngDevMode ? 'container' : '');\n  appendChild(tView, lView, comment, tNode);\n  attachPatchData(comment, lView);\n\n  addToViewTree(lView, lView[adjustedIndex] = createLContainer(comment, lView, comment, tNode));\n\n  if (isDirectiveHost(tNode)) {\n    createDirectivesInstances(tView, lView, tNode);\n  }\n\n  if (localRefsIndex != null) {\n    saveResolvedLocalsInData(lView, tNode, localRefExtractor);\n  }\n}\n\n/**\n * Sets a container up to receive views.\n *\n * @param index The index of the container in the data array\n *\n * @codeGenApi\n */\nexport function ɵɵcontainerRefreshStart(index: number): void {\n  const lView = getLView();\n  const tView = getTView();\n  let previousOrParentTNode = load(tView.data, index) as TNode;\n  ngDevMode && assertNodeType(previousOrParentTNode, TNodeType.Container);\n  setPreviousOrParentTNode(previousOrParentTNode, true);\n\n  lView[index + HEADER_OFFSET][ACTIVE_INDEX] = 0;\n\n  // We need to execute init hooks here so ngOnInit hooks are called in top level views\n  // before they are called in embedded views (for backwards compatibility).\n  if (!getCheckNoChangesMode()) {\n    const hooksInitPhaseCompleted =\n        (lView[FLAGS] & LViewFlags.InitPhaseStateMask) === InitPhaseState.InitPhaseCompleted;\n    if (hooksInitPhaseCompleted) {\n      const preOrderCheckHooks = tView.preOrderCheckHooks;\n      if (preOrderCheckHooks !== null) {\n        executeCheckHooks(lView, preOrderCheckHooks, null);\n      }\n    } else {\n      const preOrderHooks = tView.preOrderHooks;\n      if (preOrderHooks !== null) {\n        executeInitAndCheckHooks(lView, preOrderHooks, InitPhaseState.OnInitHooksToBeRun, null);\n      }\n      incrementInitPhaseFlags(lView, InitPhaseState.OnInitHooksToBeRun);\n    }\n  }\n}\n\n/**\n * Marks the end of the LContainer.\n *\n * Marking the end of LContainer is the time when to child views get inserted or removed.\n *\n * @codeGenApi\n */\nexport function ɵɵcontainerRefreshEnd(): void {\n  let previousOrParentTNode = getPreviousOrParentTNode();\n  if (getIsParent()) {\n    setIsNotParent();\n  } else {\n    ngDevMode && assertNodeType(previousOrParentTNode, TNodeType.View);\n    ngDevMode && assertHasParent(previousOrParentTNode);\n    previousOrParentTNode = previousOrParentTNode.parent!;\n    setPreviousOrParentTNode(previousOrParentTNode, false);\n  }\n\n  ngDevMode && assertNodeType(previousOrParentTNode, TNodeType.Container);\n\n  const lContainer: LContainer = getLView()[previousOrParentTNode.index];\n  const nextIndex = getLContainerActiveIndex(lContainer);\n\n  // remove extra views at the end of the container\n  while (nextIndex < lContainer.length - CONTAINER_HEADER_OFFSET) {\n    removeView(lContainer, nextIndex);\n  }\n}\n\nfunction containerInternal(\n    tView: TView, lView: LView, nodeIndex: number, tagName: string|null,\n    attrs: TAttributes|null): TContainerNode {\n  ngDevMode &&\n      assertEqual(\n          getBindingIndex(), tView.bindingStartIndex,\n          'container nodes should be created before any bindings');\n\n  const adjustedIndex = nodeIndex + HEADER_OFFSET;\n  ngDevMode && assertDataInRange(lView, nodeIndex + HEADER_OFFSET);\n  ngDevMode && ngDevMode.rendererCreateComment++;\n  const comment = lView[adjustedIndex] =\n      lView[RENDERER].createComment(ngDevMode ? 'container' : '');\n  const tNode =\n      getOrCreateTNode(tView, lView[T_HOST], nodeIndex, TNodeType.Container, tagName, attrs);\n  const lContainer = lView[adjustedIndex] = createLContainer(comment, lView, comment, tNode);\n\n  appendChild(tView, lView, comment, tNode);\n  attachPatchData(comment, lView);\n\n  // Containers are added to the current view tree instead of their embedded views\n  // because views can be removed and re-inserted.\n  addToViewTree(lView, lContainer);\n\n  ngDevMode && assertNodeType(getPreviousOrParentTNode(), TNodeType.Container);\n  return tNode;\n}"]}
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* Generated from: packages/core/src/render3/instructions/embedded_view.ts
|
|
4
|
-
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
|
-
*/
|
|
6
|
-
/**
|
|
7
|
-
* @license
|
|
8
|
-
* Copyright Google Inc. All Rights Reserved.
|
|
9
|
-
*
|
|
10
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
11
|
-
* found in the LICENSE file at https://angular.io/license
|
|
12
|
-
*/
|
|
13
|
-
import { assertDefined, assertEqual } from '../../util/assert';
|
|
14
|
-
import { assertLContainerOrUndefined } from '../assert';
|
|
15
|
-
import { ACTIVE_INDEX, CONTAINER_HEADER_OFFSET } from '../interfaces/container';
|
|
16
|
-
import { CONTEXT, PARENT, T_HOST, TVIEW } from '../interfaces/view';
|
|
17
|
-
import { assertNodeType } from '../node_assert';
|
|
18
|
-
import { insertView, removeView } from '../node_manipulation';
|
|
19
|
-
import { enterView, getIsParent, getLView, getPreviousOrParentTNode, getTView, leaveView, setIsParent, setPreviousOrParentTNode } from '../state';
|
|
20
|
-
import { getLContainerActiveIndex, isCreationMode } from '../util/view_utils';
|
|
21
|
-
import { assignTViewNodeToLView, createLView, createTView, refreshView, renderView } from './shared';
|
|
22
|
-
/**
|
|
23
|
-
* Marks the start of an embedded view.
|
|
24
|
-
*
|
|
25
|
-
* \@codeGenApi
|
|
26
|
-
* @param {?} viewBlockId The ID of this view
|
|
27
|
-
* @param {?} decls
|
|
28
|
-
* @param {?} vars
|
|
29
|
-
* @return {?} boolean Whether or not this view is in creation mode
|
|
30
|
-
*
|
|
31
|
-
*/
|
|
32
|
-
export function ɵɵembeddedViewStart(viewBlockId, decls, vars) {
|
|
33
|
-
/** @type {?} */
|
|
34
|
-
const lView = getLView();
|
|
35
|
-
/** @type {?} */
|
|
36
|
-
const previousOrParentTNode = getPreviousOrParentTNode();
|
|
37
|
-
// The previous node can be a view node if we are processing an inline for loop
|
|
38
|
-
/** @type {?} */
|
|
39
|
-
const containerTNode = previousOrParentTNode.type === 2 /* View */ ?
|
|
40
|
-
(/** @type {?} */ (previousOrParentTNode.parent)) :
|
|
41
|
-
previousOrParentTNode;
|
|
42
|
-
/** @type {?} */
|
|
43
|
-
const lContainer = (/** @type {?} */ (lView[containerTNode.index]));
|
|
44
|
-
ngDevMode && assertNodeType(containerTNode, 0 /* Container */);
|
|
45
|
-
/** @type {?} */
|
|
46
|
-
let viewToRender = scanForView(lContainer, getLContainerActiveIndex(lContainer), viewBlockId);
|
|
47
|
-
if (viewToRender) {
|
|
48
|
-
setIsParent();
|
|
49
|
-
enterView(viewToRender, viewToRender[TVIEW].node);
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
// When we create a new LView, we always reset the state of the instructions.
|
|
53
|
-
viewToRender = createLView(lView, getOrCreateEmbeddedTView(viewBlockId, decls, vars, (/** @type {?} */ (containerTNode))), null, 16 /* CheckAlways */, null, null);
|
|
54
|
-
/** @type {?} */
|
|
55
|
-
const tParentNode = getIsParent() ? previousOrParentTNode :
|
|
56
|
-
previousOrParentTNode && previousOrParentTNode.parent;
|
|
57
|
-
assignTViewNodeToLView(viewToRender[TVIEW], tParentNode, viewBlockId, viewToRender);
|
|
58
|
-
enterView(viewToRender, viewToRender[TVIEW].node);
|
|
59
|
-
}
|
|
60
|
-
if (lContainer) {
|
|
61
|
-
if (isCreationMode(viewToRender)) {
|
|
62
|
-
// it is a new view, insert it into collection of views for a given container
|
|
63
|
-
insertView(viewToRender[TVIEW], viewToRender, lContainer, getLContainerActiveIndex(lContainer));
|
|
64
|
-
}
|
|
65
|
-
lContainer[ACTIVE_INDEX] += 2 /* INCREMENT */;
|
|
66
|
-
}
|
|
67
|
-
return isCreationMode(viewToRender) ? 1 /* Create */ | 2 /* Update */ :
|
|
68
|
-
2 /* Update */;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Initialize the TView (e.g. static data) for the active embedded view.
|
|
72
|
-
*
|
|
73
|
-
* Each embedded view block must create or retrieve its own TView. Otherwise, the embedded view's
|
|
74
|
-
* static data for a particular node would overwrite the static data for a node in the view above
|
|
75
|
-
* it with the same index (since it's in the same template).
|
|
76
|
-
*
|
|
77
|
-
* @param {?} viewIndex The index of the TView in TNode.tViews
|
|
78
|
-
* @param {?} decls The number of nodes, local refs, and pipes in this template
|
|
79
|
-
* @param {?} vars The number of bindings and pure function bindings in this template
|
|
80
|
-
* @param {?} parent
|
|
81
|
-
* @return {?} TView
|
|
82
|
-
*/
|
|
83
|
-
function getOrCreateEmbeddedTView(viewIndex, decls, vars, parent) {
|
|
84
|
-
/** @type {?} */
|
|
85
|
-
const tView = getLView()[TVIEW];
|
|
86
|
-
ngDevMode && assertNodeType(parent, 0 /* Container */);
|
|
87
|
-
/** @type {?} */
|
|
88
|
-
const containerTViews = (/** @type {?} */ (parent.tViews));
|
|
89
|
-
ngDevMode && assertDefined(containerTViews, 'TView expected');
|
|
90
|
-
ngDevMode && assertEqual(Array.isArray(containerTViews), true, 'TViews should be in an array');
|
|
91
|
-
if (viewIndex >= containerTViews.length || containerTViews[viewIndex] == null) {
|
|
92
|
-
containerTViews[viewIndex] = createTView(2 /* Embedded */, viewIndex, null, decls, vars, tView.directiveRegistry, tView.pipeRegistry, null, null, tView.consts);
|
|
93
|
-
}
|
|
94
|
-
return containerTViews[viewIndex];
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Looks for a view with a given view block id inside a provided LContainer.
|
|
98
|
-
* Removes views that need to be deleted in the process.
|
|
99
|
-
*
|
|
100
|
-
* @param {?} lContainer to search for views
|
|
101
|
-
* @param {?} startIdx starting index in the views array to search from
|
|
102
|
-
* @param {?} viewBlockId exact view block id to look for
|
|
103
|
-
* @return {?}
|
|
104
|
-
*/
|
|
105
|
-
function scanForView(lContainer, startIdx, viewBlockId) {
|
|
106
|
-
for (let i = startIdx + CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {
|
|
107
|
-
/** @type {?} */
|
|
108
|
-
const viewAtPositionId = lContainer[i][TVIEW].id;
|
|
109
|
-
if (viewAtPositionId === viewBlockId) {
|
|
110
|
-
return lContainer[i];
|
|
111
|
-
}
|
|
112
|
-
else if (viewAtPositionId < viewBlockId) {
|
|
113
|
-
// found a view that should not be at this position - remove
|
|
114
|
-
removeView(lContainer, i - CONTAINER_HEADER_OFFSET);
|
|
115
|
-
}
|
|
116
|
-
else {
|
|
117
|
-
// found a view with id greater than the one we are searching for
|
|
118
|
-
// which means that required view doesn't exist and can't be found at
|
|
119
|
-
// later positions in the views array - stop the searchdef.cont here
|
|
120
|
-
break;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
return null;
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* Marks the end of an embedded view.
|
|
127
|
-
*
|
|
128
|
-
* \@codeGenApi
|
|
129
|
-
* @return {?}
|
|
130
|
-
*/
|
|
131
|
-
export function ɵɵembeddedViewEnd() {
|
|
132
|
-
/** @type {?} */
|
|
133
|
-
const lView = getLView();
|
|
134
|
-
/** @type {?} */
|
|
135
|
-
const tView = getTView();
|
|
136
|
-
/** @type {?} */
|
|
137
|
-
const viewHost = lView[T_HOST];
|
|
138
|
-
/** @type {?} */
|
|
139
|
-
const context = lView[CONTEXT];
|
|
140
|
-
if (isCreationMode(lView)) {
|
|
141
|
-
renderView(tView, lView, context); // creation mode pass
|
|
142
|
-
}
|
|
143
|
-
refreshView(tView, lView, tView.template, context); // update mode pass
|
|
144
|
-
// update mode pass
|
|
145
|
-
/** @type {?} */
|
|
146
|
-
const lContainer = (/** @type {?} */ (lView[PARENT]));
|
|
147
|
-
ngDevMode && assertLContainerOrUndefined(lContainer);
|
|
148
|
-
leaveView();
|
|
149
|
-
setPreviousOrParentTNode((/** @type {?} */ (viewHost)), false);
|
|
150
|
-
}
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"embedded_view.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/embedded_view.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {assertDefined, assertEqual} from '../../util/assert';\nimport {assertLContainerOrUndefined} from '../assert';\nimport {ACTIVE_INDEX, ActiveIndexFlag, CONTAINER_HEADER_OFFSET, LContainer} from '../interfaces/container';\nimport {RenderFlags} from '../interfaces/definition';\nimport {TContainerNode, TNodeType} from '../interfaces/node';\nimport {CONTEXT, LView, LViewFlags, PARENT, T_HOST, TVIEW, TView, TViewType} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {insertView, removeView} from '../node_manipulation';\nimport {enterView, getIsParent, getLView, getPreviousOrParentTNode, getTView, leaveView, setIsParent, setPreviousOrParentTNode} from '../state';\nimport {getLContainerActiveIndex, isCreationMode} from '../util/view_utils';\n\nimport {assignTViewNodeToLView, createLView, createTView, refreshView, renderView} from './shared';\n\n\n\n/**\n * Marks the start of an embedded view.\n *\n * @param viewBlockId The ID of this view\n * @return boolean Whether or not this view is in creation mode\n *\n * @codeGenApi\n */\nexport function ɵɵembeddedViewStart(viewBlockId: number, decls: number, vars: number): RenderFlags {\n  const lView = getLView();\n  const previousOrParentTNode = getPreviousOrParentTNode();\n  // The previous node can be a view node if we are processing an inline for loop\n  const containerTNode = previousOrParentTNode.type === TNodeType.View ?\n      previousOrParentTNode.parent! :\n      previousOrParentTNode;\n  const lContainer = lView[containerTNode.index] as LContainer;\n\n  ngDevMode && assertNodeType(containerTNode, TNodeType.Container);\n  let viewToRender = scanForView(lContainer, getLContainerActiveIndex(lContainer), viewBlockId);\n\n  if (viewToRender) {\n    setIsParent();\n    enterView(viewToRender, viewToRender[TVIEW].node);\n  } else {\n    // When we create a new LView, we always reset the state of the instructions.\n    viewToRender = createLView(\n        lView, getOrCreateEmbeddedTView(viewBlockId, decls, vars, containerTNode as TContainerNode),\n        null, LViewFlags.CheckAlways, null, null);\n\n    const tParentNode = getIsParent() ? previousOrParentTNode :\n                                        previousOrParentTNode && previousOrParentTNode.parent;\n    assignTViewNodeToLView(viewToRender[TVIEW], tParentNode, viewBlockId, viewToRender);\n    enterView(viewToRender, viewToRender[TVIEW].node);\n  }\n  if (lContainer) {\n    if (isCreationMode(viewToRender)) {\n      // it is a new view, insert it into collection of views for a given container\n      insertView(\n          viewToRender[TVIEW], viewToRender, lContainer, getLContainerActiveIndex(lContainer));\n    }\n    lContainer[ACTIVE_INDEX] += ActiveIndexFlag.INCREMENT;\n  }\n  return isCreationMode(viewToRender) ? RenderFlags.Create | RenderFlags.Update :\n                                        RenderFlags.Update;\n}\n\n/**\n * Initialize the TView (e.g. static data) for the active embedded view.\n *\n * Each embedded view block must create or retrieve its own TView. Otherwise, the embedded view's\n * static data for a particular node would overwrite the static data for a node in the view above\n * it with the same index (since it's in the same template).\n *\n * @param viewIndex The index of the TView in TNode.tViews\n * @param decls The number of nodes, local refs, and pipes in this template\n * @param vars The number of bindings and pure function bindings in this template\n * @param container The parent container in which to look for the view's static data\n * @returns TView\n */\nfunction getOrCreateEmbeddedTView(\n    viewIndex: number, decls: number, vars: number, parent: TContainerNode): TView {\n  const tView = getLView()[TVIEW];\n  ngDevMode && assertNodeType(parent, TNodeType.Container);\n  const containerTViews = parent.tViews as TView[];\n  ngDevMode && assertDefined(containerTViews, 'TView expected');\n  ngDevMode && assertEqual(Array.isArray(containerTViews), true, 'TViews should be in an array');\n  if (viewIndex >= containerTViews.length || containerTViews[viewIndex] == null) {\n    containerTViews[viewIndex] = createTView(\n        TViewType.Embedded, viewIndex, null, decls, vars, tView.directiveRegistry,\n        tView.pipeRegistry, null, null, tView.consts);\n  }\n  return containerTViews[viewIndex];\n}\n\n\n/**\n * Looks for a view with a given view block id inside a provided LContainer.\n * Removes views that need to be deleted in the process.\n *\n * @param lContainer to search for views\n * @param startIdx starting index in the views array to search from\n * @param viewBlockId exact view block id to look for\n */\nfunction scanForView(lContainer: LContainer, startIdx: number, viewBlockId: number): LView|null {\n  for (let i = startIdx + CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {\n    const viewAtPositionId = lContainer[i][TVIEW].id;\n    if (viewAtPositionId === viewBlockId) {\n      return lContainer[i];\n    } else if (viewAtPositionId < viewBlockId) {\n      // found a view that should not be at this position - remove\n      removeView(lContainer, i - CONTAINER_HEADER_OFFSET);\n    } else {\n      // found a view with id greater than the one we are searching for\n      // which means that required view doesn't exist and can't be found at\n      // later positions in the views array - stop the searchdef.cont here\n      break;\n    }\n  }\n  return null;\n}\n\n/**\n * Marks the end of an embedded view.\n *\n * @codeGenApi\n */\nexport function ɵɵembeddedViewEnd(): void {\n  const lView = getLView();\n  const tView = getTView();\n  const viewHost = lView[T_HOST];\n  const context = lView[CONTEXT];\n\n  if (isCreationMode(lView)) {\n    renderView(tView, lView, context);  // creation mode pass\n  }\n  refreshView(tView, lView, tView.template, context);  // update mode pass\n\n  const lContainer = lView[PARENT] as LContainer;\n  ngDevMode && assertLContainerOrUndefined(lContainer);\n  leaveView();\n  setPreviousOrParentTNode(viewHost!, false);\n}\n"]}
|