@angular/core 9.0.0-rc.7 → 9.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (222) hide show
  1. package/bundles/core-testing.umd.js +18 -16
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +7 -7
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +6386 -6384
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +182 -175
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +726 -734
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +5 -5
  12. package/esm2015/core.js +17 -15
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/application_init.js +10 -2
  16. package/esm2015/src/application_module.js +6 -3
  17. package/esm2015/src/application_ref.js +7 -7
  18. package/esm2015/src/core.js +4 -4
  19. package/esm2015/src/core_private_export.js +7 -7
  20. package/esm2015/src/core_render3_private_export.js +2 -2
  21. package/esm2015/src/debug/debug_node.js +55 -16
  22. package/esm2015/src/di/injectable.js +1 -13
  23. package/esm2015/src/di/injector.js +12 -10
  24. package/esm2015/src/di/interface/provider.js +1 -1
  25. package/esm2015/src/di/r3_injector.js +5 -4
  26. package/esm2015/src/i18n/locale_data_api.js +22 -6
  27. package/esm2015/src/i18n/locale_en.js +16 -5
  28. package/esm2015/src/i18n/localization.js +7 -1
  29. package/esm2015/src/i18n/tokens.js +41 -1
  30. package/esm2015/src/interface/type.js +1 -1
  31. package/esm2015/src/metadata/ng_module.js +1 -1
  32. package/esm2015/src/render/api.js +4 -1
  33. package/esm2015/src/render3/assert.js +9 -1
  34. package/esm2015/src/render3/bindings.js +16 -5
  35. package/esm2015/src/render3/component.js +54 -25
  36. package/esm2015/src/render3/component_ref.js +28 -18
  37. package/esm2015/src/render3/definition.js +3 -1
  38. package/esm2015/src/render3/di.js +3 -4
  39. package/esm2015/src/render3/di_setup.js +5 -7
  40. package/esm2015/src/render3/errors.js +3 -1
  41. package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
  42. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  43. package/esm2015/src/render3/global_utils_api.js +3 -3
  44. package/esm2015/src/render3/i18n.js +60 -56
  45. package/esm2015/src/render3/index.js +2 -2
  46. package/esm2015/src/render3/instructions/advance.js +10 -11
  47. package/esm2015/src/render3/instructions/all.js +4 -5
  48. package/esm2015/src/render3/instructions/attribute.js +12 -5
  49. package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
  50. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  51. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  52. package/esm2015/src/render3/instructions/container.js +15 -12
  53. package/esm2015/src/render3/instructions/element.js +45 -132
  54. package/esm2015/src/render3/instructions/element_container.js +8 -10
  55. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  56. package/esm2015/src/render3/instructions/host_property.js +10 -7
  57. package/esm2015/src/render3/instructions/listener.js +18 -16
  58. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  59. package/esm2015/src/render3/instructions/projection.js +7 -5
  60. package/esm2015/src/render3/instructions/property.js +27 -6
  61. package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
  62. package/esm2015/src/render3/instructions/shared.js +279 -244
  63. package/esm2015/src/render3/instructions/storage.js +6 -8
  64. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  65. package/esm2015/src/render3/instructions/styling.js +731 -475
  66. package/esm2015/src/render3/instructions/text.js +5 -5
  67. package/esm2015/src/render3/interfaces/definition.js +41 -1
  68. package/esm2015/src/render3/interfaces/node.js +160 -115
  69. package/esm2015/src/render3/interfaces/styling.js +183 -375
  70. package/esm2015/src/render3/interfaces/view.js +10 -2
  71. package/esm2015/src/render3/jit/environment.js +1 -3
  72. package/esm2015/src/render3/namespaces.js +17 -0
  73. package/esm2015/src/render3/node_manipulation.js +177 -57
  74. package/esm2015/src/render3/node_selector_matcher.js +128 -24
  75. package/esm2015/src/render3/node_util.js +12 -7
  76. package/esm2015/src/render3/pipe.js +10 -14
  77. package/esm2015/src/render3/pure_function.js +107 -42
  78. package/esm2015/src/render3/query.js +32 -26
  79. package/esm2015/src/render3/state.js +57 -185
  80. package/esm2015/src/render3/styling/class_differ.js +47 -0
  81. package/esm2015/src/render3/styling/static_styling.js +54 -0
  82. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  83. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  84. package/esm2015/src/render3/tokens.js +2 -2
  85. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  86. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  87. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  88. package/esm2015/src/render3/util/global_utils.js +5 -5
  89. package/esm2015/src/render3/util/view_utils.js +6 -6
  90. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  91. package/esm2015/src/render3/view_ref.js +16 -13
  92. package/esm2015/src/sanitization/bypass.js +1 -1
  93. package/esm2015/src/sanitization/sanitization.js +20 -5
  94. package/esm2015/src/util/array_utils.js +240 -1
  95. package/esm2015/src/util/assert.js +37 -21
  96. package/esm2015/src/util/char_code.js +8 -0
  97. package/esm2015/src/util/iterable.js +4 -1
  98. package/esm2015/src/util/ng_dev_mode.js +1 -12
  99. package/esm2015/src/util/stringify.js +14 -1
  100. package/esm2015/src/version.js +1 -1
  101. package/esm2015/src/view/services.js +1 -1
  102. package/esm2015/testing/src/r3_test_bed.js +5 -1
  103. package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
  104. package/esm2015/testing/src/styling.js +103 -0
  105. package/esm5/core.js +17 -15
  106. package/esm5/src/application_init.js +10 -2
  107. package/esm5/src/application_module.js +6 -3
  108. package/esm5/src/application_ref.js +6 -6
  109. package/esm5/src/core.js +2 -2
  110. package/esm5/src/core_private_export.js +7 -7
  111. package/esm5/src/core_render3_private_export.js +2 -2
  112. package/esm5/src/debug/debug_node.js +39 -14
  113. package/esm5/src/di/injectable.js +1 -1
  114. package/esm5/src/di/injector.js +12 -12
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +5 -4
  117. package/esm5/src/i18n/locale_data_api.js +20 -6
  118. package/esm5/src/i18n/locale_en.js +16 -5
  119. package/esm5/src/i18n/localization.js +6 -1
  120. package/esm5/src/i18n/tokens.js +40 -1
  121. package/esm5/src/interface/type.js +1 -1
  122. package/esm5/src/metadata/ng_module.js +1 -1
  123. package/esm5/src/render/api.js +4 -1
  124. package/esm5/src/render3/assert.js +4 -1
  125. package/esm5/src/render3/bindings.js +19 -2
  126. package/esm5/src/render3/component.js +47 -22
  127. package/esm5/src/render3/component_ref.js +20 -17
  128. package/esm5/src/render3/definition.js +3 -1
  129. package/esm5/src/render3/di.js +3 -4
  130. package/esm5/src/render3/di_setup.js +4 -5
  131. package/esm5/src/render3/errors.js +3 -1
  132. package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
  133. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  134. package/esm5/src/render3/global_utils_api.js +3 -3
  135. package/esm5/src/render3/i18n.js +51 -51
  136. package/esm5/src/render3/index.js +2 -2
  137. package/esm5/src/render3/instructions/advance.js +9 -11
  138. package/esm5/src/render3/instructions/all.js +1 -2
  139. package/esm5/src/render3/instructions/attribute.js +9 -5
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
  141. package/esm5/src/render3/instructions/change_detection.js +8 -21
  142. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  143. package/esm5/src/render3/instructions/container.js +13 -12
  144. package/esm5/src/render3/instructions/element.js +41 -113
  145. package/esm5/src/render3/instructions/element_container.js +8 -9
  146. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  147. package/esm5/src/render3/instructions/host_property.js +8 -7
  148. package/esm5/src/render3/instructions/listener.js +13 -13
  149. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  150. package/esm5/src/render3/instructions/projection.js +6 -5
  151. package/esm5/src/render3/instructions/property.js +17 -6
  152. package/esm5/src/render3/instructions/property_interpolation.js +32 -24
  153. package/esm5/src/render3/instructions/shared.js +258 -210
  154. package/esm5/src/render3/instructions/storage.js +4 -6
  155. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  156. package/esm5/src/render3/instructions/styling.js +685 -367
  157. package/esm5/src/render3/instructions/text.js +5 -5
  158. package/esm5/src/render3/interfaces/definition.js +1 -1
  159. package/esm5/src/render3/interfaces/node.js +49 -1
  160. package/esm5/src/render3/interfaces/styling.js +57 -1
  161. package/esm5/src/render3/interfaces/view.js +1 -1
  162. package/esm5/src/render3/jit/environment.js +1 -3
  163. package/esm5/src/render3/namespaces.js +10 -0
  164. package/esm5/src/render3/node_manipulation.js +167 -54
  165. package/esm5/src/render3/node_selector_matcher.js +113 -20
  166. package/esm5/src/render3/node_util.js +12 -7
  167. package/esm5/src/render3/pipe.js +10 -14
  168. package/esm5/src/render3/pure_function.js +103 -33
  169. package/esm5/src/render3/query.js +25 -24
  170. package/esm5/src/render3/state.js +37 -133
  171. package/esm5/src/render3/styling/class_differ.js +39 -0
  172. package/esm5/src/render3/styling/static_styling.js +42 -0
  173. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  174. package/esm5/src/render3/styling/styling_parser.js +265 -0
  175. package/esm5/src/render3/tokens.js +2 -2
  176. package/esm5/src/render3/util/attrs_utils.js +117 -2
  177. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  178. package/esm5/src/render3/util/discovery_utils.js +115 -99
  179. package/esm5/src/render3/util/global_utils.js +5 -5
  180. package/esm5/src/render3/util/view_utils.js +5 -5
  181. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  182. package/esm5/src/render3/view_ref.js +14 -13
  183. package/esm5/src/sanitization/bypass.js +1 -1
  184. package/esm5/src/sanitization/sanitization.js +16 -5
  185. package/esm5/src/util/array_utils.js +240 -1
  186. package/esm5/src/util/assert.js +37 -21
  187. package/esm5/src/util/char_code.js +8 -0
  188. package/esm5/src/util/iterable.js +4 -1
  189. package/esm5/src/util/ng_dev_mode.js +1 -12
  190. package/esm5/src/util/stringify.js +14 -1
  191. package/esm5/src/version.js +1 -1
  192. package/esm5/src/view/services.js +1 -1
  193. package/esm5/testing/src/r3_test_bed.js +9 -1
  194. package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
  195. package/esm5/testing/src/styling.js +82 -0
  196. package/fesm2015/core.js +6431 -7075
  197. package/fesm2015/core.js.map +1 -1
  198. package/fesm2015/testing.js +10 -14
  199. package/fesm2015/testing.js.map +1 -1
  200. package/fesm5/core.js +6354 -6361
  201. package/fesm5/core.js.map +1 -1
  202. package/fesm5/testing.js +18 -16
  203. package/fesm5/testing.js.map +1 -1
  204. package/package.json +1 -1
  205. package/src/r3_symbols.d.ts +46 -23
  206. package/testing/testing.d.ts +3 -5
  207. package/testing/testing.metadata.json +1 -1
  208. package/testing.d.ts +2 -2
  209. package/esm2015/global.js +0 -7
  210. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  211. package/esm2015/src/render3/styling/bindings.js +0 -1248
  212. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  213. package/esm2015/src/render3/styling/state.js +0 -135
  214. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  215. package/esm2015/src/render3/util/styling_utils.js +0 -625
  216. package/esm5/global.js +0 -9
  217. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  218. package/esm5/src/render3/styling/bindings.js +0 -949
  219. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  220. package/esm5/src/render3/styling/state.js +0 -56
  221. package/esm5/src/render3/styling/styling_debug.js +0 -315
  222. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -11,19 +11,20 @@
11
11
  * found in the LICENSE file at https://angular.io/license
12
12
  */
13
13
  import { assertDataInRange, assertDefined, assertEqual } from '../../util/assert';
14
- import { assertHasParent } from '../assert';
14
+ import { assertFirstCreatePass, assertHasParent } from '../assert';
15
15
  import { attachPatchData } from '../context_discovery';
16
16
  import { registerPostOrderHooks } from '../hooks';
17
+ import { hasClassInput, hasStyleInput } from '../interfaces/node';
17
18
  import { isContentQueryHost, isDirectiveHost } from '../interfaces/type_checks';
18
- import { HEADER_OFFSET, RENDERER, TVIEW, T_HOST } from '../interfaces/view';
19
+ import { HEADER_OFFSET, RENDERER, T_HOST } from '../interfaces/view';
19
20
  import { assertNodeType } from '../node_assert';
20
- import { appendChild } from '../node_manipulation';
21
- import { decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getSelectedIndex, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode } from '../state';
21
+ import { appendChild, writeDirectClass, writeDirectStyle } from '../node_manipulation';
22
+ import { decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getTView, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode } from '../state';
23
+ import { computeStaticStyling } from '../styling/static_styling';
22
24
  import { setUpAttributes } from '../util/attrs_utils';
23
- import { getInitialStylingValue, hasClassInput, hasStyleInput, selectClassBasedInputName } from '../util/styling_utils';
24
- import { getConstant, getNativeByTNode, getTNode } from '../util/view_utils';
25
- import { createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, renderInitialStyling, resolveDirectives, saveResolvedLocalsInData, setInputsForProperty } from './shared';
26
- import { registerInitialStylingOnTNode } from './styling';
25
+ import { getConstant } from '../util/view_utils';
26
+ import { setDirectiveInputsWhichShadowsStyling } from './property';
27
+ import { createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, resolveDirectives, saveResolvedLocalsInData } from './shared';
27
28
  /**
28
29
  * @param {?} index
29
30
  * @param {?} tView
@@ -35,6 +36,7 @@ import { registerInitialStylingOnTNode } from './styling';
35
36
  * @return {?}
36
37
  */
37
38
  function elementStartFirstCreatePass(index, tView, lView, native, name, attrsIndex, localRefsIndex) {
39
+ ngDevMode && assertFirstCreatePass(tView);
38
40
  ngDevMode && ngDevMode.firstCreatePass++;
39
41
  /** @type {?} */
40
42
  const tViewConsts = tView.consts;
@@ -42,12 +44,12 @@ function elementStartFirstCreatePass(index, tView, lView, native, name, attrsInd
42
44
  const attrs = getConstant(tViewConsts, attrsIndex);
43
45
  /** @type {?} */
44
46
  const tNode = getOrCreateTNode(tView, lView[T_HOST], index, 3 /* Element */, name, attrs);
45
- if (attrs !== null) {
46
- registerInitialStylingOnTNode(tNode, attrs, 0);
47
- }
48
47
  /** @type {?} */
49
48
  const hasDirectives = resolveDirectives(tView, lView, tNode, getConstant(tViewConsts, localRefsIndex));
50
- ngDevMode && validateElement(lView, native, tNode, hasDirectives);
49
+ ngDevMode && warnAboutUnknownElement(tView, lView, native, tNode, hasDirectives);
50
+ if (tNode.mergedAttrs !== null) {
51
+ computeStaticStyling(tNode, tNode.mergedAttrs);
52
+ }
51
53
  if (tView.queries !== null) {
52
54
  tView.queries.elementStart(tView, tNode);
53
55
  }
@@ -72,7 +74,7 @@ export function ɵɵelementStart(index, name, attrsIndex, localRefsIndex) {
72
74
  /** @type {?} */
73
75
  const lView = getLView();
74
76
  /** @type {?} */
75
- const tView = lView[TVIEW];
77
+ const tView = getTView();
76
78
  /** @type {?} */
77
79
  const adjustedIndex = HEADER_OFFSET + index;
78
80
  ngDevMode && assertEqual(getBindingIndex(), tView.bindingStartIndex, 'elements should be created before any bindings');
@@ -88,14 +90,21 @@ export function ɵɵelementStart(index, name, attrsIndex, localRefsIndex) {
88
90
  (/** @type {?} */ (tView.data[adjustedIndex]));
89
91
  setPreviousOrParentTNode(tNode, true);
90
92
  /** @type {?} */
91
- const attrs = tNode.attrs;
92
- if (attrs != null) {
93
- setUpAttributes(renderer, native, attrs);
93
+ const mergedAttrs = tNode.mergedAttrs;
94
+ if (mergedAttrs !== null) {
95
+ setUpAttributes(renderer, native, mergedAttrs);
96
+ }
97
+ /** @type {?} */
98
+ const classes = tNode.classes;
99
+ if (classes !== null) {
100
+ writeDirectClass(renderer, native, classes);
94
101
  }
95
- if ((tNode.flags & 256 /* hasInitialStyling */) === 256 /* hasInitialStyling */) {
96
- renderInitialStyling(renderer, native, tNode, false);
102
+ /** @type {?} */
103
+ const styles = tNode.styles;
104
+ if (styles !== null) {
105
+ writeDirectStyle(renderer, native, styles);
97
106
  }
98
- appendChild(native, tNode, lView);
107
+ appendChild(tView, lView, native, tNode);
99
108
  // any immediate children of a component or template container must be pre-emptively
100
109
  // monkey-patched with the component view data so that the element can be inspected
101
110
  // later on using any element discovery utility methods (see `element_discovery.ts`)
@@ -107,7 +116,7 @@ export function ɵɵelementStart(index, name, attrsIndex, localRefsIndex) {
107
116
  createDirectivesInstances(tView, lView, tNode);
108
117
  executeContentQueries(tView, tNode, lView);
109
118
  }
110
- if (localRefsIndex != null) {
119
+ if (localRefsIndex !== null) {
111
120
  saveResolvedLocalsInData(lView, tNode);
112
121
  }
113
122
  }
@@ -132,24 +141,20 @@ export function ɵɵelementEnd() {
132
141
  /** @type {?} */
133
142
  const tNode = previousOrParentTNode;
134
143
  ngDevMode && assertNodeType(tNode, 3 /* Element */);
135
- /** @type {?} */
136
- const lView = getLView();
137
- /** @type {?} */
138
- const tView = lView[TVIEW];
139
144
  decreaseElementDepthCount();
145
+ /** @type {?} */
146
+ const tView = getTView();
140
147
  if (tView.firstCreatePass) {
141
148
  registerPostOrderHooks(tView, previousOrParentTNode);
142
149
  if (isContentQueryHost(previousOrParentTNode)) {
143
150
  (/** @type {?} */ (tView.queries)).elementEnd(previousOrParentTNode);
144
151
  }
145
152
  }
146
- if (hasClassInput(tNode)) {
147
- /** @type {?} */
148
- const inputName = selectClassBasedInputName((/** @type {?} */ (tNode.inputs)));
149
- setDirectiveStylingInput(tNode.classes, lView, (/** @type {?} */ (tNode.inputs))[inputName], inputName);
153
+ if (tNode.classes !== null && hasClassInput(tNode)) {
154
+ setDirectiveInputsWhichShadowsStyling(tView, tNode, getLView(), tNode.classes, true);
150
155
  }
151
- if (hasStyleInput(tNode)) {
152
- setDirectiveStylingInput(tNode.styles, lView, (/** @type {?} */ (tNode.inputs))['style'], 'style');
156
+ if (tNode.styles !== null && hasStyleInput(tNode)) {
157
+ setDirectiveInputsWhichShadowsStyling(tView, tNode, getLView(), tNode.styles, false);
153
158
  }
154
159
  }
155
160
  /**
@@ -168,108 +173,16 @@ export function ɵɵelement(index, name, attrsIndex, localRefsIndex) {
168
173
  ɵɵelementEnd();
169
174
  }
170
175
  /**
171
- * Assign static attribute values to a host element.
172
- *
173
- * This instruction will assign static attribute values as well as class and style
174
- * values to an element within the host bindings function. Since attribute values
175
- * can consist of different types of values, the `attrs` array must include the values in
176
- * the following format:
177
- *
178
- * attrs = [
179
- * // static attributes (like `title`, `name`, `id`...)
180
- * attr1, value1, attr2, value,
181
- *
182
- * // a single namespace value (like `x:id`)
183
- * NAMESPACE_MARKER, namespaceUri1, name1, value1,
184
- *
185
- * // another single namespace value (like `x:name`)
186
- * NAMESPACE_MARKER, namespaceUri2, name2, value2,
187
- *
188
- * // a series of CSS classes that will be applied to the element (no spaces)
189
- * CLASSES_MARKER, class1, class2, class3,
190
- *
191
- * // a series of CSS styles (property + value) that will be applied to the element
192
- * STYLES_MARKER, prop1, value1, prop2, value2
193
- * ]
194
- *
195
- * All non-class and non-style attributes must be defined at the start of the list
196
- * first before all class and style values are set. When there is a change in value
197
- * type (like when classes and styles are introduced) a marker must be used to separate
198
- * the entries. The marker values themselves are set via entries found in the
199
- * [AttributeMarker] enum.
200
- *
201
- * NOTE: This instruction is meant to used from `hostBindings` function only.
202
- *
203
- * \@codeGenApi
204
- * @param {?} attrs An array of static values (attributes, classes and styles) with the correct marker
205
- * values.
206
- *
207
- * @return {?}
208
- */
209
- export function ɵɵelementHostAttrs(attrs) {
210
- /** @type {?} */
211
- const hostElementIndex = getSelectedIndex();
212
- /** @type {?} */
213
- const lView = getLView();
214
- /** @type {?} */
215
- const tView = lView[TVIEW];
216
- /** @type {?} */
217
- const tNode = getTNode(hostElementIndex, lView);
218
- // non-element nodes (e.g. `<ng-container>`) are not rendered as actual
219
- // element nodes and adding styles/classes on to them will cause runtime
220
- // errors...
221
- if (tNode.type === 3 /* Element */) {
222
- /** @type {?} */
223
- const native = (/** @type {?} */ (getNativeByTNode(tNode, lView)));
224
- /** @type {?} */
225
- const lastAttrIndex = setUpAttributes(lView[RENDERER], native, attrs);
226
- if (tView.firstCreatePass) {
227
- /** @type {?} */
228
- const stylingNeedsToBeRendered = registerInitialStylingOnTNode(tNode, attrs, lastAttrIndex);
229
- // this is only called during the first template pass in the
230
- // event that this current directive assigned initial style/class
231
- // host attribute values to the element. Because initial styling
232
- // values are applied before directives are first rendered (within
233
- // `createElement`) this means that initial styling for any directives
234
- // still needs to be applied. Note that this will only happen during
235
- // the first template pass and not each time a directive applies its
236
- // attribute values to the element.
237
- if (stylingNeedsToBeRendered) {
238
- /** @type {?} */
239
- const renderer = lView[RENDERER];
240
- renderInitialStyling(renderer, native, tNode, true);
241
- }
242
- }
243
- }
244
- }
245
- /**
246
- * @param {?} context
176
+ * @param {?} tView
247
177
  * @param {?} lView
248
- * @param {?} stylingInputs
249
- * @param {?} propName
250
- * @return {?}
251
- */
252
- function setDirectiveStylingInput(context, lView, stylingInputs, propName) {
253
- // older versions of Angular treat the input as `null` in the
254
- // event that the value does not exist at all. For this reason
255
- // we can't have a styling value be an empty string.
256
- /** @type {?} */
257
- const value = (context && getInitialStylingValue(context)) || null;
258
- // Ivy does an extra `[class]` write with a falsy value since the value
259
- // is applied during creation mode. This is a deviation from VE and should
260
- // be (Jira Issue = FW-1467).
261
- setInputsForProperty(lView, stylingInputs, propName, value);
262
- }
263
- /**
264
- * @param {?} hostView
265
178
  * @param {?} element
266
179
  * @param {?} tNode
267
180
  * @param {?} hasDirectives
268
181
  * @return {?}
269
182
  */
270
- function validateElement(hostView, element, tNode, hasDirectives) {
183
+ function warnAboutUnknownElement(tView, lView, element, tNode, hasDirectives) {
271
184
  /** @type {?} */
272
- const schemas = hostView[TVIEW].schemas;
185
+ const schemas = tView.schemas;
273
186
  // If `schemas` is set to `null`, that's an indication that this Component was compiled in AOT
274
187
  // mode where this check happens at compile time. In JIT mode, `schemas` is always present and
275
188
  // defined as an array (as an empty array in case `schemas` field is not defined) and we should
@@ -291,21 +204,21 @@ function validateElement(hostView, element, tNode, hasDirectives) {
291
204
  element instanceof HTMLUnknownElement) ||
292
205
  (typeof customElements !== 'undefined' && tagName.indexOf('-') > -1 &&
293
206
  !customElements.get(tagName));
294
- if (isUnknown && !matchingSchemas(hostView, tagName)) {
207
+ if (isUnknown && !matchingSchemas(tView, lView, tagName)) {
295
208
  /** @type {?} */
296
- let errorMessage = `'${tagName}' is not a known element:\n`;
297
- errorMessage +=
209
+ let warning = `'${tagName}' is not a known element:\n`;
210
+ warning +=
298
211
  `1. If '${tagName}' is an Angular component, then verify that it is part of this module.\n`;
299
212
  if (tagName && tagName.indexOf('-') > -1) {
300
- errorMessage +=
213
+ warning +=
301
214
  `2. If '${tagName}' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.`;
302
215
  }
303
216
  else {
304
- errorMessage +=
217
+ warning +=
305
218
  `2. To allow any element add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component.`;
306
219
  }
307
- throw new Error(errorMessage);
220
+ console.warn(warning);
308
221
  }
309
222
  }
310
223
  }
311
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/element.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 {assertDataInRange, assertDefined, assertEqual} from '../../util/assert';\nimport {assertHasParent} from '../assert';\nimport {attachPatchData} from '../context_discovery';\nimport {registerPostOrderHooks} from '../hooks';\nimport {TAttributes, TElementNode, TNode, TNodeFlags, TNodeType} from '../interfaces/node';\nimport {RElement} from '../interfaces/renderer';\nimport {StylingMapArray, TStylingContext} from '../interfaces/styling';\nimport {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';\nimport {HEADER_OFFSET, LView, RENDERER, TVIEW, TView, T_HOST} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {appendChild} from '../node_manipulation';\nimport {decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getSelectedIndex, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode} from '../state';\nimport {setUpAttributes} from '../util/attrs_utils';\nimport {getInitialStylingValue, hasClassInput, hasStyleInput, selectClassBasedInputName} from '../util/styling_utils';\nimport {getConstant, getNativeByTNode, getTNode} from '../util/view_utils';\n\nimport {createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, renderInitialStyling, resolveDirectives, saveResolvedLocalsInData, setInputsForProperty} from './shared';\nimport {registerInitialStylingOnTNode} from './styling';\n\nfunction elementStartFirstCreatePass(\n    index: number, tView: TView, lView: LView, native: RElement, name: string,\n    attrsIndex?: number | null, localRefsIndex?: number): TElementNode {\n  ngDevMode && ngDevMode.firstCreatePass++;\n\n  const tViewConsts = tView.consts;\n  const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);\n  const tNode = getOrCreateTNode(tView, lView[T_HOST], index, TNodeType.Element, name, attrs);\n\n  if (attrs !== null) {\n    registerInitialStylingOnTNode(tNode, attrs, 0);\n  }\n\n  const hasDirectives =\n      resolveDirectives(tView, lView, tNode, getConstant<string[]>(tViewConsts, localRefsIndex));\n  ngDevMode && validateElement(lView, native, tNode, hasDirectives);\n\n  if (tView.queries !== null) {\n    tView.queries.elementStart(tView, tNode);\n  }\n\n  return tNode;\n}\n\n/**\n * Create DOM element. The instruction must later be followed by `elementEnd()` call.\n *\n * @param index Index of the element in the LView array\n * @param name Name of the DOM Node\n * @param attrsIndex Index of the element's attributes in the `consts` array.\n * @param localRefsIndex Index of the element's local references in the `consts` array.\n *\n * Attributes and localRefs are passed as an array of strings where elements with an even index\n * hold an attribute name and elements with an odd index hold an attribute value, ex.:\n * ['id', 'warning5', 'class', 'alert']\n *\n * @codeGenApi\n */\nexport function ɵɵelementStart(\n    index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {\n  const lView = getLView();\n  const tView = lView[TVIEW];\n  const adjustedIndex = HEADER_OFFSET + index;\n\n  ngDevMode && assertEqual(\n                   getBindingIndex(), tView.bindingStartIndex,\n                   'elements should be created before any bindings');\n  ngDevMode && ngDevMode.rendererCreateElement++;\n  ngDevMode && assertDataInRange(lView, adjustedIndex);\n\n  const renderer = lView[RENDERER];\n  const native = lView[adjustedIndex] = elementCreate(name, renderer, getNamespace());\n\n  const tNode = tView.firstCreatePass ?\n      elementStartFirstCreatePass(index, tView, lView, native, name, attrsIndex, localRefsIndex) :\n      tView.data[adjustedIndex] as TElementNode;\n  setPreviousOrParentTNode(tNode, true);\n\n  const attrs = tNode.attrs;\n  if (attrs != null) {\n    setUpAttributes(renderer, native, attrs);\n  }\n  if ((tNode.flags & TNodeFlags.hasInitialStyling) === TNodeFlags.hasInitialStyling) {\n    renderInitialStyling(renderer, native, tNode, false);\n  }\n\n  appendChild(native, tNode, lView);\n\n  // any immediate children of a component or template container must be pre-emptively\n  // monkey-patched with the component view data so that the element can be inspected\n  // later on using any element discovery utility methods (see `element_discovery.ts`)\n  if (getElementDepthCount() === 0) {\n    attachPatchData(native, lView);\n  }\n  increaseElementDepthCount();\n\n\n  if (isDirectiveHost(tNode)) {\n    createDirectivesInstances(tView, lView, tNode);\n    executeContentQueries(tView, tNode, lView);\n  }\n  if (localRefsIndex != null) {\n    saveResolvedLocalsInData(lView, tNode);\n  }\n}\n\n/**\n * Mark the end of the element.\n *\n * @codeGenApi\n */\nexport function ɵɵelementEnd(): void {\n  let previousOrParentTNode = getPreviousOrParentTNode();\n  ngDevMode && assertDefined(previousOrParentTNode, 'No parent node to close.');\n  if (getIsParent()) {\n    setIsNotParent();\n  } else {\n    ngDevMode && assertHasParent(getPreviousOrParentTNode());\n    previousOrParentTNode = previousOrParentTNode.parent !;\n    setPreviousOrParentTNode(previousOrParentTNode, false);\n  }\n\n  const tNode = previousOrParentTNode;\n  ngDevMode && assertNodeType(tNode, TNodeType.Element);\n\n  const lView = getLView();\n  const tView = lView[TVIEW];\n\n  decreaseElementDepthCount();\n\n  if (tView.firstCreatePass) {\n    registerPostOrderHooks(tView, previousOrParentTNode);\n    if (isContentQueryHost(previousOrParentTNode)) {\n      tView.queries !.elementEnd(previousOrParentTNode);\n    }\n  }\n\n  if (hasClassInput(tNode)) {\n    const inputName: string = selectClassBasedInputName(tNode.inputs !);\n    setDirectiveStylingInput(tNode.classes, lView, tNode.inputs ![inputName], inputName);\n  }\n\n  if (hasStyleInput(tNode)) {\n    setDirectiveStylingInput(tNode.styles, lView, tNode.inputs !['style'], 'style');\n  }\n}\n\n\n/**\n * Creates an empty element using {@link elementStart} and {@link elementEnd}\n *\n * @param index Index of the element in the data array\n * @param name Name of the DOM Node\n * @param attrsIndex Index of the element's attributes in the `consts` array.\n * @param localRefsIndex Index of the element's local references in the `consts` array.\n *\n * @codeGenApi\n */\nexport function ɵɵelement(\n    index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {\n  ɵɵelementStart(index, name, attrsIndex, localRefsIndex);\n  ɵɵelementEnd();\n}\n\n/**\n * Assign static attribute values to a host element.\n *\n * This instruction will assign static attribute values as well as class and style\n * values to an element within the host bindings function. Since attribute values\n * can consist of different types of values, the `attrs` array must include the values in\n * the following format:\n *\n * attrs = [\n *   // static attributes (like `title`, `name`, `id`...)\n *   attr1, value1, attr2, value,\n *\n *   // a single namespace value (like `x:id`)\n *   NAMESPACE_MARKER, namespaceUri1, name1, value1,\n *\n *   // another single namespace value (like `x:name`)\n *   NAMESPACE_MARKER, namespaceUri2, name2, value2,\n *\n *   // a series of CSS classes that will be applied to the element (no spaces)\n *   CLASSES_MARKER, class1, class2, class3,\n *\n *   // a series of CSS styles (property + value) that will be applied to the element\n *   STYLES_MARKER, prop1, value1, prop2, value2\n * ]\n *\n * All non-class and non-style attributes must be defined at the start of the list\n * first before all class and style values are set. When there is a change in value\n * type (like when classes and styles are introduced) a marker must be used to separate\n * the entries. The marker values themselves are set via entries found in the\n * [AttributeMarker] enum.\n *\n * NOTE: This instruction is meant to used from `hostBindings` function only.\n *\n * @param directive A directive instance the styling is associated with.\n * @param attrs An array of static values (attributes, classes and styles) with the correct marker\n * values.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostAttrs(attrs: TAttributes) {\n  const hostElementIndex = getSelectedIndex();\n  const lView = getLView();\n  const tView = lView[TVIEW];\n  const tNode = getTNode(hostElementIndex, lView);\n\n  // non-element nodes (e.g. `<ng-container>`) are not rendered as actual\n  // element nodes and adding styles/classes on to them will cause runtime\n  // errors...\n  if (tNode.type === TNodeType.Element) {\n    const native = getNativeByTNode(tNode, lView) as RElement;\n    const lastAttrIndex = setUpAttributes(lView[RENDERER], native, attrs);\n    if (tView.firstCreatePass) {\n      const stylingNeedsToBeRendered = registerInitialStylingOnTNode(tNode, attrs, lastAttrIndex);\n\n      // this is only called during the first template pass in the\n      // event that this current directive assigned initial style/class\n      // host attribute values to the element. Because initial styling\n      // values are applied before directives are first rendered (within\n      // `createElement`) this means that initial styling for any directives\n      // still needs to be applied. Note that this will only happen during\n      // the first template pass and not each time a directive applies its\n      // attribute values to the element.\n      if (stylingNeedsToBeRendered) {\n        const renderer = lView[RENDERER];\n        renderInitialStyling(renderer, native, tNode, true);\n      }\n    }\n  }\n}\n\nfunction setDirectiveStylingInput(\n    context: TStylingContext | StylingMapArray | null, lView: LView,\n    stylingInputs: (string | number)[], propName: string) {\n  // older versions of Angular treat the input as `null` in the\n  // event that the value does not exist at all. For this reason\n  // we can't have a styling value be an empty string.\n  const value = (context && getInitialStylingValue(context)) || null;\n\n  // Ivy does an extra `[class]` write with a falsy value since the value\n  // is applied during creation mode. This is a deviation from VE and should\n  // be (Jira Issue = FW-1467).\n  setInputsForProperty(lView, stylingInputs, propName, value);\n}\n\nfunction validateElement(\n    hostView: LView, element: RElement, tNode: TNode, hasDirectives: boolean): void {\n  const schemas = hostView[TVIEW].schemas;\n\n  // If `schemas` is set to `null`, that's an indication that this Component was compiled in AOT\n  // mode where this check happens at compile time. In JIT mode, `schemas` is always present and\n  // defined as an array (as an empty array in case `schemas` field is not defined) and we should\n  // execute the check below.\n  if (schemas === null) return;\n\n  const tagName = tNode.tagName;\n\n  // If the element matches any directive, it's considered as valid.\n  if (!hasDirectives && tagName !== null) {\n    // The element is unknown if it's an instance of HTMLUnknownElement or it isn't registered\n    // as a custom element. Note that unknown elements with a dash in their name won't be instances\n    // of HTMLUnknownElement in browsers that support web components.\n    const isUnknown =\n        // Note that we can't check for `typeof HTMLUnknownElement === 'function'`,\n        // because while most browsers return 'function', IE returns 'object'.\n        (typeof HTMLUnknownElement !== 'undefined' && HTMLUnknownElement &&\n         element instanceof HTMLUnknownElement) ||\n        (typeof customElements !== 'undefined' && tagName.indexOf('-') > -1 &&\n         !customElements.get(tagName));\n\n    if (isUnknown && !matchingSchemas(hostView, tagName)) {\n      let errorMessage = `'${tagName}' is not a known element:\\n`;\n      errorMessage +=\n          `1. If '${tagName}' is an Angular component, then verify that it is part of this module.\\n`;\n      if (tagName && tagName.indexOf('-') > -1) {\n        errorMessage +=\n            `2. If '${tagName}' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.`;\n      } else {\n        errorMessage +=\n            `2. To allow any element add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component.`;\n      }\n      throw new Error(errorMessage);\n    }\n  }\n}\n"]}
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/element.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 {assertDataInRange, assertDefined, assertEqual} from '../../util/assert';\nimport {assertFirstCreatePass, assertHasParent} from '../assert';\nimport {attachPatchData} from '../context_discovery';\nimport {registerPostOrderHooks} from '../hooks';\nimport {TAttributes, TElementNode, TNode, TNodeType, hasClassInput, hasStyleInput} from '../interfaces/node';\nimport {RElement} from '../interfaces/renderer';\nimport {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';\nimport {HEADER_OFFSET, LView, RENDERER, TVIEW, TView, T_HOST} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {appendChild, writeDirectClass, writeDirectStyle} from '../node_manipulation';\nimport {decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getTView, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode} from '../state';\nimport {computeStaticStyling} from '../styling/static_styling';\nimport {setUpAttributes} from '../util/attrs_utils';\nimport {getConstant} from '../util/view_utils';\nimport {setDirectiveInputsWhichShadowsStyling} from './property';\nimport {createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, resolveDirectives, saveResolvedLocalsInData} from './shared';\n\n\nfunction elementStartFirstCreatePass(\n    index: number, tView: TView, lView: LView, native: RElement, name: string,\n    attrsIndex?: number | null, localRefsIndex?: number): TElementNode {\n  ngDevMode && assertFirstCreatePass(tView);\n  ngDevMode && ngDevMode.firstCreatePass++;\n\n  const tViewConsts = tView.consts;\n  const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);\n  const tNode = getOrCreateTNode(tView, lView[T_HOST], index, TNodeType.Element, name, attrs);\n\n  const hasDirectives =\n      resolveDirectives(tView, lView, tNode, getConstant<string[]>(tViewConsts, localRefsIndex));\n  ngDevMode && warnAboutUnknownElement(tView, lView, native, tNode, hasDirectives);\n\n  if (tNode.mergedAttrs !== null) {\n    computeStaticStyling(tNode, tNode.mergedAttrs);\n  }\n\n  if (tView.queries !== null) {\n    tView.queries.elementStart(tView, tNode);\n  }\n\n  return tNode;\n}\n\n/**\n * Create DOM element. The instruction must later be followed by `elementEnd()` call.\n *\n * @param index Index of the element in the LView array\n * @param name Name of the DOM Node\n * @param attrsIndex Index of the element's attributes in the `consts` array.\n * @param localRefsIndex Index of the element's local references in the `consts` array.\n *\n * Attributes and localRefs are passed as an array of strings where elements with an even index\n * hold an attribute name and elements with an odd index hold an attribute value, ex.:\n * ['id', 'warning5', 'class', 'alert']\n *\n * @codeGenApi\n */\nexport function ɵɵelementStart(\n    index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {\n  const lView = getLView();\n  const tView = getTView();\n  const adjustedIndex = HEADER_OFFSET + index;\n\n  ngDevMode && assertEqual(\n                   getBindingIndex(), tView.bindingStartIndex,\n                   'elements should be created before any bindings');\n  ngDevMode && ngDevMode.rendererCreateElement++;\n  ngDevMode && assertDataInRange(lView, adjustedIndex);\n\n  const renderer = lView[RENDERER];\n  const native = lView[adjustedIndex] = elementCreate(name, renderer, getNamespace());\n\n  const tNode = tView.firstCreatePass ?\n      elementStartFirstCreatePass(index, tView, lView, native, name, attrsIndex, localRefsIndex) :\n      tView.data[adjustedIndex] as TElementNode;\n  setPreviousOrParentTNode(tNode, true);\n\n  const mergedAttrs = tNode.mergedAttrs;\n  if (mergedAttrs !== null) {\n    setUpAttributes(renderer, native, mergedAttrs);\n  }\n  const classes = tNode.classes;\n  if (classes !== null) {\n    writeDirectClass(renderer, native, classes);\n  }\n  const styles = tNode.styles;\n  if (styles !== null) {\n    writeDirectStyle(renderer, native, styles);\n  }\n\n  appendChild(tView, lView, native, tNode);\n\n  // any immediate children of a component or template container must be pre-emptively\n  // monkey-patched with the component view data so that the element can be inspected\n  // later on using any element discovery utility methods (see `element_discovery.ts`)\n  if (getElementDepthCount() === 0) {\n    attachPatchData(native, lView);\n  }\n  increaseElementDepthCount();\n\n\n  if (isDirectiveHost(tNode)) {\n    createDirectivesInstances(tView, lView, tNode);\n    executeContentQueries(tView, tNode, lView);\n  }\n  if (localRefsIndex !== null) {\n    saveResolvedLocalsInData(lView, tNode);\n  }\n}\n\n/**\n * Mark the end of the element.\n *\n * @codeGenApi\n */\nexport function ɵɵelementEnd(): void {\n  let previousOrParentTNode = getPreviousOrParentTNode();\n  ngDevMode && assertDefined(previousOrParentTNode, 'No parent node to close.');\n  if (getIsParent()) {\n    setIsNotParent();\n  } else {\n    ngDevMode && assertHasParent(getPreviousOrParentTNode());\n    previousOrParentTNode = previousOrParentTNode.parent !;\n    setPreviousOrParentTNode(previousOrParentTNode, false);\n  }\n\n  const tNode = previousOrParentTNode;\n  ngDevMode && assertNodeType(tNode, TNodeType.Element);\n\n\n  decreaseElementDepthCount();\n\n  const tView = getTView();\n  if (tView.firstCreatePass) {\n    registerPostOrderHooks(tView, previousOrParentTNode);\n    if (isContentQueryHost(previousOrParentTNode)) {\n      tView.queries !.elementEnd(previousOrParentTNode);\n    }\n  }\n\n  if (tNode.classes !== null && hasClassInput(tNode)) {\n    setDirectiveInputsWhichShadowsStyling(tView, tNode, getLView(), tNode.classes, true);\n  }\n\n  if (tNode.styles !== null && hasStyleInput(tNode)) {\n    setDirectiveInputsWhichShadowsStyling(tView, tNode, getLView(), tNode.styles, false);\n  }\n}\n\n/**\n * Creates an empty element using {@link elementStart} and {@link elementEnd}\n *\n * @param index Index of the element in the data array\n * @param name Name of the DOM Node\n * @param attrsIndex Index of the element's attributes in the `consts` array.\n * @param localRefsIndex Index of the element's local references in the `consts` array.\n *\n * @codeGenApi\n */\nexport function ɵɵelement(\n    index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {\n  ɵɵelementStart(index, name, attrsIndex, localRefsIndex);\n  ɵɵelementEnd();\n}\n\nfunction warnAboutUnknownElement(\n    tView: TView, lView: LView, element: RElement, tNode: TNode, hasDirectives: boolean): void {\n  const schemas = tView.schemas;\n\n  // If `schemas` is set to `null`, that's an indication that this Component was compiled in AOT\n  // mode where this check happens at compile time. In JIT mode, `schemas` is always present and\n  // defined as an array (as an empty array in case `schemas` field is not defined) and we should\n  // execute the check below.\n  if (schemas === null) return;\n\n  const tagName = tNode.tagName;\n\n  // If the element matches any directive, it's considered as valid.\n  if (!hasDirectives && tagName !== null) {\n    // The element is unknown if it's an instance of HTMLUnknownElement or it isn't registered\n    // as a custom element. Note that unknown elements with a dash in their name won't be instances\n    // of HTMLUnknownElement in browsers that support web components.\n    const isUnknown =\n        // Note that we can't check for `typeof HTMLUnknownElement === 'function'`,\n        // because while most browsers return 'function', IE returns 'object'.\n        (typeof HTMLUnknownElement !== 'undefined' && HTMLUnknownElement &&\n         element instanceof HTMLUnknownElement) ||\n        (typeof customElements !== 'undefined' && tagName.indexOf('-') > -1 &&\n         !customElements.get(tagName));\n\n    if (isUnknown && !matchingSchemas(tView, lView, tagName)) {\n      let warning = `'${tagName}' is not a known element:\\n`;\n      warning +=\n          `1. If '${tagName}' is an Angular component, then verify that it is part of this module.\\n`;\n      if (tagName && tagName.indexOf('-') > -1) {\n        warning +=\n            `2. If '${tagName}' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.`;\n      } else {\n        warning +=\n            `2. To allow any element add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component.`;\n      }\n      console.warn(warning);\n    }\n  }\n}\n"]}
@@ -15,13 +15,13 @@ import { assertHasParent } from '../assert';
15
15
  import { attachPatchData } from '../context_discovery';
16
16
  import { registerPostOrderHooks } from '../hooks';
17
17
  import { isContentQueryHost, isDirectiveHost } from '../interfaces/type_checks';
18
- import { HEADER_OFFSET, RENDERER, TVIEW, T_HOST } from '../interfaces/view';
18
+ import { HEADER_OFFSET, RENDERER, T_HOST } from '../interfaces/view';
19
19
  import { assertNodeType } from '../node_assert';
20
20
  import { appendChild } from '../node_manipulation';
21
- import { getBindingIndex, getIsParent, getLView, getPreviousOrParentTNode, setIsNotParent, setPreviousOrParentTNode } from '../state';
21
+ import { getBindingIndex, getIsParent, getLView, getPreviousOrParentTNode, getTView, setIsNotParent, setPreviousOrParentTNode } from '../state';
22
+ import { computeStaticStyling } from '../styling/static_styling';
22
23
  import { getConstant } from '../util/view_utils';
23
24
  import { createDirectivesInstances, executeContentQueries, getOrCreateTNode, resolveDirectives, saveResolvedLocalsInData } from './shared';
24
- import { registerInitialStylingOnTNode } from './styling';
25
25
  /**
26
26
  * @param {?} index
27
27
  * @param {?} tView
@@ -41,7 +41,7 @@ function elementContainerStartFirstCreatePass(index, tView, lView, attrsIndex, l
41
41
  // While ng-container doesn't necessarily support styling, we use the style context to identify
42
42
  // and execute directives on the ng-container.
43
43
  if (attrs !== null) {
44
- registerInitialStylingOnTNode(tNode, attrs, 0);
44
+ computeStaticStyling(tNode, attrs);
45
45
  }
46
46
  /** @type {?} */
47
47
  const localRefs = getConstant(tViewConsts, localRefsIndex);
@@ -70,7 +70,7 @@ export function ɵɵelementContainerStart(index, attrsIndex, localRefsIndex) {
70
70
  /** @type {?} */
71
71
  const lView = getLView();
72
72
  /** @type {?} */
73
- const tView = lView[TVIEW];
73
+ const tView = getTView();
74
74
  /** @type {?} */
75
75
  const adjustedIndex = index + HEADER_OFFSET;
76
76
  ngDevMode && assertDataInRange(lView, adjustedIndex);
@@ -84,7 +84,7 @@ export function ɵɵelementContainerStart(index, attrsIndex, localRefsIndex) {
84
84
  /** @type {?} */
85
85
  const native = lView[adjustedIndex] =
86
86
  lView[RENDERER].createComment(ngDevMode ? 'ng-container' : '');
87
- appendChild(native, tNode, lView);
87
+ appendChild(tView, lView, native, tNode);
88
88
  attachPatchData(native, lView);
89
89
  if (isDirectiveHost(tNode)) {
90
90
  createDirectivesInstances(tView, lView, tNode);
@@ -104,9 +104,7 @@ export function ɵɵelementContainerEnd() {
104
104
  /** @type {?} */
105
105
  let previousOrParentTNode = getPreviousOrParentTNode();
106
106
  /** @type {?} */
107
- const lView = getLView();
108
- /** @type {?} */
109
- const tView = lView[TVIEW];
107
+ const tView = getTView();
110
108
  if (getIsParent()) {
111
109
  setIsNotParent();
112
110
  }
@@ -138,4 +136,4 @@ export function ɵɵelementContainer(index, attrsIndex, localRefsIndex) {
138
136
  ɵɵelementContainerStart(index, attrsIndex, localRefsIndex);
139
137
  ɵɵelementContainerEnd();
140
138
  }
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element_container.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/element_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 {assertHasParent} from '../assert';\nimport {attachPatchData} from '../context_discovery';\nimport {registerPostOrderHooks} from '../hooks';\nimport {TAttributes, TElementContainerNode, TNodeType} from '../interfaces/node';\nimport {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';\nimport {HEADER_OFFSET, LView, RENDERER, TVIEW, TView, T_HOST} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {appendChild} from '../node_manipulation';\nimport {getBindingIndex, getIsParent, getLView, getPreviousOrParentTNode, setIsNotParent, setPreviousOrParentTNode} from '../state';\nimport {getConstant} from '../util/view_utils';\n\nimport {createDirectivesInstances, executeContentQueries, getOrCreateTNode, resolveDirectives, saveResolvedLocalsInData} from './shared';\nimport {registerInitialStylingOnTNode} from './styling';\n\nfunction elementContainerStartFirstCreatePass(\n    index: number, tView: TView, lView: LView, attrsIndex?: number | null,\n    localRefsIndex?: number): TElementContainerNode {\n  ngDevMode && ngDevMode.firstCreatePass++;\n\n  const tViewConsts = tView.consts;\n  const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);\n  const tNode = getOrCreateTNode(\n      tView, lView[T_HOST], index, TNodeType.ElementContainer, 'ng-container', attrs);\n\n  // While ng-container doesn't necessarily support styling, we use the style context to identify\n  // and execute directives on the ng-container.\n  if (attrs !== null) {\n    registerInitialStylingOnTNode(tNode, attrs, 0);\n  }\n\n  const localRefs = getConstant<string[]>(tViewConsts, localRefsIndex);\n  resolveDirectives(tView, lView, tNode, localRefs);\n\n  if (tView.queries !== null) {\n    tView.queries.elementStart(tView, tNode);\n  }\n\n  return tNode;\n}\n\n/**\n * Creates a logical container for other nodes (<ng-container>) backed by a comment node in the DOM.\n * The instruction must later be followed by `elementContainerEnd()` call.\n *\n * @param index Index of the element in the LView array\n * @param attrsIndex Index of the container attributes in the `consts` array.\n * @param localRefsIndex Index of the container's local references in the `consts` array.\n *\n * Even if this instruction accepts a set of attributes no actual attribute values are propagated to\n * the DOM (as a comment node can't have attributes). Attributes are here only for directive\n * matching purposes and setting initial inputs of directives.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainerStart(\n    index: number, attrsIndex?: number | null, localRefsIndex?: number): void {\n  const lView = getLView();\n  const tView = lView[TVIEW];\n  const adjustedIndex = index + HEADER_OFFSET;\n\n  ngDevMode && assertDataInRange(lView, adjustedIndex);\n  ngDevMode && assertEqual(\n                   getBindingIndex(), tView.bindingStartIndex,\n                   'element containers should be created before any bindings');\n\n  const tNode = tView.firstCreatePass ?\n      elementContainerStartFirstCreatePass(index, tView, lView, attrsIndex, localRefsIndex) :\n      tView.data[adjustedIndex] as TElementContainerNode;\n  setPreviousOrParentTNode(tNode, true);\n\n  ngDevMode && ngDevMode.rendererCreateComment++;\n  const native = lView[adjustedIndex] =\n      lView[RENDERER].createComment(ngDevMode ? 'ng-container' : '');\n  appendChild(native, tNode, lView);\n  attachPatchData(native, lView);\n\n  if (isDirectiveHost(tNode)) {\n    createDirectivesInstances(tView, lView, tNode);\n    executeContentQueries(tView, tNode, lView);\n  }\n\n  if (localRefsIndex != null) {\n    saveResolvedLocalsInData(lView, tNode);\n  }\n}\n\n/**\n * Mark the end of the <ng-container>.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainerEnd(): void {\n  let previousOrParentTNode = getPreviousOrParentTNode();\n  const lView = getLView();\n  const tView = lView[TVIEW];\n  if (getIsParent()) {\n    setIsNotParent();\n  } else {\n    ngDevMode && assertHasParent(previousOrParentTNode);\n    previousOrParentTNode = previousOrParentTNode.parent !;\n    setPreviousOrParentTNode(previousOrParentTNode, false);\n  }\n\n  ngDevMode && assertNodeType(previousOrParentTNode, TNodeType.ElementContainer);\n\n  if (tView.firstCreatePass) {\n    registerPostOrderHooks(tView, previousOrParentTNode);\n    if (isContentQueryHost(previousOrParentTNode)) {\n      tView.queries !.elementEnd(previousOrParentTNode);\n    }\n  }\n}\n\n/**\n * Creates an empty logical container using {@link elementContainerStart}\n * and {@link elementContainerEnd}\n *\n * @param index Index of the element in the LView array\n * @param attrsIndex Index of the container attributes in the `consts` array.\n * @param localRefsIndex Index of the container's local references in the `consts` array.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainer(\n    index: number, attrsIndex?: number | null, localRefsIndex?: number): void {\n  ɵɵelementContainerStart(index, attrsIndex, localRefsIndex);\n  ɵɵelementContainerEnd();\n}\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element_container.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/element_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 {assertHasParent} from '../assert';\nimport {attachPatchData} from '../context_discovery';\nimport {registerPostOrderHooks} from '../hooks';\nimport {TAttributes, TElementContainerNode, TNodeType} from '../interfaces/node';\nimport {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';\nimport {HEADER_OFFSET, LView, RENDERER, TView, T_HOST} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {appendChild} from '../node_manipulation';\nimport {getBindingIndex, getIsParent, getLView, getPreviousOrParentTNode, getTView, setIsNotParent, setPreviousOrParentTNode} from '../state';\nimport {computeStaticStyling} from '../styling/static_styling';\nimport {getConstant} from '../util/view_utils';\n\nimport {createDirectivesInstances, executeContentQueries, getOrCreateTNode, resolveDirectives, saveResolvedLocalsInData} from './shared';\n\nfunction elementContainerStartFirstCreatePass(\n    index: number, tView: TView, lView: LView, attrsIndex?: number | null,\n    localRefsIndex?: number): TElementContainerNode {\n  ngDevMode && ngDevMode.firstCreatePass++;\n\n  const tViewConsts = tView.consts;\n  const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);\n  const tNode = getOrCreateTNode(\n      tView, lView[T_HOST], index, TNodeType.ElementContainer, 'ng-container', attrs);\n\n  // While ng-container doesn't necessarily support styling, we use the style context to identify\n  // and execute directives on the ng-container.\n  if (attrs !== null) {\n    computeStaticStyling(tNode, attrs);\n  }\n\n  const localRefs = getConstant<string[]>(tViewConsts, localRefsIndex);\n  resolveDirectives(tView, lView, tNode, localRefs);\n\n  if (tView.queries !== null) {\n    tView.queries.elementStart(tView, tNode);\n  }\n\n  return tNode;\n}\n\n/**\n * Creates a logical container for other nodes (<ng-container>) backed by a comment node in the DOM.\n * The instruction must later be followed by `elementContainerEnd()` call.\n *\n * @param index Index of the element in the LView array\n * @param attrsIndex Index of the container attributes in the `consts` array.\n * @param localRefsIndex Index of the container's local references in the `consts` array.\n *\n * Even if this instruction accepts a set of attributes no actual attribute values are propagated to\n * the DOM (as a comment node can't have attributes). Attributes are here only for directive\n * matching purposes and setting initial inputs of directives.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainerStart(\n    index: number, attrsIndex?: number | null, localRefsIndex?: number): void {\n  const lView = getLView();\n  const tView = getTView();\n  const adjustedIndex = index + HEADER_OFFSET;\n\n  ngDevMode && assertDataInRange(lView, adjustedIndex);\n  ngDevMode && assertEqual(\n                   getBindingIndex(), tView.bindingStartIndex,\n                   'element containers should be created before any bindings');\n\n  const tNode = tView.firstCreatePass ?\n      elementContainerStartFirstCreatePass(index, tView, lView, attrsIndex, localRefsIndex) :\n      tView.data[adjustedIndex] as TElementContainerNode;\n  setPreviousOrParentTNode(tNode, true);\n\n  ngDevMode && ngDevMode.rendererCreateComment++;\n  const native = lView[adjustedIndex] =\n      lView[RENDERER].createComment(ngDevMode ? 'ng-container' : '');\n  appendChild(tView, lView, native, tNode);\n  attachPatchData(native, lView);\n\n  if (isDirectiveHost(tNode)) {\n    createDirectivesInstances(tView, lView, tNode);\n    executeContentQueries(tView, tNode, lView);\n  }\n\n  if (localRefsIndex != null) {\n    saveResolvedLocalsInData(lView, tNode);\n  }\n}\n\n/**\n * Mark the end of the <ng-container>.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainerEnd(): void {\n  let previousOrParentTNode = getPreviousOrParentTNode();\n  const tView = getTView();\n  if (getIsParent()) {\n    setIsNotParent();\n  } else {\n    ngDevMode && assertHasParent(previousOrParentTNode);\n    previousOrParentTNode = previousOrParentTNode.parent !;\n    setPreviousOrParentTNode(previousOrParentTNode, false);\n  }\n\n  ngDevMode && assertNodeType(previousOrParentTNode, TNodeType.ElementContainer);\n\n  if (tView.firstCreatePass) {\n    registerPostOrderHooks(tView, previousOrParentTNode);\n    if (isContentQueryHost(previousOrParentTNode)) {\n      tView.queries !.elementEnd(previousOrParentTNode);\n    }\n  }\n}\n\n/**\n * Creates an empty logical container using {@link elementContainerStart}\n * and {@link elementContainerEnd}\n *\n * @param index Index of the element in the LView array\n * @param attrsIndex Index of the container attributes in the `consts` array.\n * @param localRefsIndex Index of the container's local references in the `consts` array.\n *\n * @codeGenApi\n */\nexport function ɵɵelementContainer(\n    index: number, attrsIndex?: number | null, localRefsIndex?: number): void {\n  ɵɵelementContainerStart(index, attrsIndex, localRefsIndex);\n  ɵɵelementContainerEnd();\n}\n"]}
@@ -16,7 +16,7 @@ import { ACTIVE_INDEX, CONTAINER_HEADER_OFFSET } from '../interfaces/container';
16
16
  import { CONTEXT, PARENT, TVIEW, T_HOST } from '../interfaces/view';
17
17
  import { assertNodeType } from '../node_assert';
18
18
  import { insertView, removeView } from '../node_manipulation';
19
- import { enterView, getIsParent, getLView, getPreviousOrParentTNode, leaveViewProcessExit, setIsParent, setPreviousOrParentTNode } from '../state';
19
+ import { enterView, getIsParent, getLView, getPreviousOrParentTNode, getTView, leaveView, setIsParent, setPreviousOrParentTNode } from '../state';
20
20
  import { getLContainerActiveIndex, isCreationMode } from '../util/view_utils';
21
21
  import { assignTViewNodeToLView, createLView, createTView, refreshView, renderView } from './shared';
22
22
  /**
@@ -60,7 +60,7 @@ export function ɵɵembeddedViewStart(viewBlockId, decls, vars) {
60
60
  if (lContainer) {
61
61
  if (isCreationMode(viewToRender)) {
62
62
  // it is a new view, insert it into collection of views for a given container
63
- insertView(viewToRender, lContainer, getLContainerActiveIndex(lContainer));
63
+ insertView(viewToRender[TVIEW], viewToRender, lContainer, getLContainerActiveIndex(lContainer));
64
64
  }
65
65
  lContainer[ACTIVE_INDEX] += 2 /* INCREMENT */;
66
66
  }
@@ -132,20 +132,20 @@ export function ɵɵembeddedViewEnd() {
132
132
  /** @type {?} */
133
133
  const lView = getLView();
134
134
  /** @type {?} */
135
- const tView = lView[TVIEW];
135
+ const tView = getTView();
136
136
  /** @type {?} */
137
137
  const viewHost = lView[T_HOST];
138
138
  /** @type {?} */
139
139
  const context = lView[CONTEXT];
140
140
  if (isCreationMode(lView)) {
141
- renderView(lView, tView, context); // creation mode pass
141
+ renderView(tView, lView, context); // creation mode pass
142
142
  }
143
- refreshView(lView, tView, tView.template, context); // update mode pass
143
+ refreshView(tView, lView, tView.template, context); // update mode pass
144
144
  // update mode pass
145
145
  /** @type {?} */
146
146
  const lContainer = (/** @type {?} */ (lView[PARENT]));
147
147
  ngDevMode && assertLContainerOrUndefined(lContainer);
148
- leaveViewProcessExit();
148
+ leaveView();
149
149
  setPreviousOrParentTNode((/** @type {?} */ (viewHost)), false);
150
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, TVIEW, TView, TViewType, T_HOST} from '../interfaces/view';\nimport {assertNodeType} from '../node_assert';\nimport {insertView, removeView} from '../node_manipulation';\nimport {enterView, getIsParent, getLView, getPreviousOrParentTNode, leaveViewProcessExit, 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(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 = lView[TVIEW];\n  const viewHost = lView[T_HOST];\n  const context = lView[CONTEXT];\n\n  if (isCreationMode(lView)) {\n    renderView(lView, tView, context);  // creation mode pass\n  }\n  refreshView(lView, tView, tView.template, context);  // update mode pass\n\n  const lContainer = lView[PARENT] as LContainer;\n  ngDevMode && assertLContainerOrUndefined(lContainer);\n  leaveViewProcessExit();\n  setPreviousOrParentTNode(viewHost !, false);\n}\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"embedded_view.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/embedded_view.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EAAC,aAAa,EAAE,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAC,2BAA2B,EAAC,MAAM,WAAW,CAAC;AACtD,OAAO,EAAC,YAAY,EAAmB,uBAAuB,EAAa,MAAM,yBAAyB,CAAC;AAG3G,OAAO,EAAC,OAAO,EAAqB,MAAM,EAAE,KAAK,EAAoB,MAAM,EAAC,MAAM,oBAAoB,CAAC;AACvG,OAAO,EAAC,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAC,UAAU,EAAE,UAAU,EAAC,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAC,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,wBAAwB,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,wBAAwB,EAAC,MAAM,UAAU,CAAC;AAChJ,OAAO,EAAC,wBAAwB,EAAE,cAAc,EAAC,MAAM,oBAAoB,CAAC;AAE5E,OAAO,EAAC,sBAAsB,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAC,MAAM,UAAU,CAAC;;;;;;;;;;;AAYnG,MAAM,UAAU,mBAAmB,CAAC,WAAmB,EAAE,KAAa,EAAE,IAAY;;UAC5E,KAAK,GAAG,QAAQ,EAAE;;UAClB,qBAAqB,GAAG,wBAAwB,EAAE;;;UAElD,cAAc,GAAG,qBAAqB,CAAC,IAAI,iBAAmB,CAAC,CAAC;QAClE,mBAAA,qBAAqB,CAAC,MAAM,EAAE,CAAC,CAAC;QAChC,qBAAqB;;UACnB,UAAU,GAAG,mBAAA,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,EAAc;IAE5D,SAAS,IAAI,cAAc,CAAC,cAAc,oBAAsB,CAAC;;QAC7D,YAAY,GAAG,WAAW,CAAC,UAAU,EAAE,wBAAwB,CAAC,UAAU,CAAC,EAAE,WAAW,CAAC;IAE7F,IAAI,YAAY,EAAE;QAChB,WAAW,EAAE,CAAC;QACd,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC;KACnD;SAAM;QACL,6EAA6E;QAC7E,YAAY,GAAG,WAAW,CACtB,KAAK,EAAE,wBAAwB,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,mBAAA,cAAc,EAAkB,CAAC,EAC3F,IAAI,wBAA0B,IAAI,EAAE,IAAI,CAAC,CAAC;;cAExC,WAAW,GAAG,WAAW,EAAE,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC;YACvB,qBAAqB,IAAI,qBAAqB,CAAC,MAAM;QACzF,sBAAsB,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;QACpF,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC;KACnD;IACD,IAAI,UAAU,EAAE;QACd,IAAI,cAAc,CAAC,YAAY,CAAC,EAAE;YAChC,6EAA6E;YAC7E,UAAU,CACN,YAAY,CAAC,KAAK,CAAC,EAAE,YAAY,EAAE,UAAU,EAAE,wBAAwB,CAAC,UAAU,CAAC,CAAC,CAAC;SAC1F;QACD,UAAU,CAAC,YAAY,CAAC,qBAA6B,CAAC;KACvD;IACD,OAAO,cAAc,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,+BAAuC,CAAC,CAAC;sBACvB,CAAC;AAC3D,CAAC;;;;;;;;;;;;;;AAeD,SAAS,wBAAwB,CAC7B,SAAiB,EAAE,KAAa,EAAE,IAAY,EAAE,MAAsB;;UAClE,KAAK,GAAG,QAAQ,EAAE,CAAC,KAAK,CAAC;IAC/B,SAAS,IAAI,cAAc,CAAC,MAAM,oBAAsB,CAAC;;UACnD,eAAe,GAAG,mBAAA,MAAM,CAAC,MAAM,EAAW;IAChD,SAAS,IAAI,aAAa,CAAC,eAAe,EAAE,gBAAgB,CAAC,CAAC;IAC9D,SAAS,IAAI,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE,IAAI,EAAE,8BAA8B,CAAC,CAAC;IAC/F,IAAI,SAAS,IAAI,eAAe,CAAC,MAAM,IAAI,eAAe,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE;QAC7E,eAAe,CAAC,SAAS,CAAC,GAAG,WAAW,mBAChB,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,iBAAiB,EACzE,KAAK,CAAC,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;KACnD;IACD,OAAO,eAAe,CAAC,SAAS,CAAC,CAAC;AACpC,CAAC;;;;;;;;;;AAWD,SAAS,WAAW,CAAC,UAAsB,EAAE,QAAgB,EAAE,WAAmB;IAChF,KAAK,IAAI,CAAC,GAAG,QAAQ,GAAG,uBAAuB,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;cACrE,gBAAgB,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE;QAChD,IAAI,gBAAgB,KAAK,WAAW,EAAE;YACpC,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;SACtB;aAAM,IAAI,gBAAgB,GAAG,WAAW,EAAE;YACzC,4DAA4D;YAC5D,UAAU,CAAC,UAAU,EAAE,CAAC,GAAG,uBAAuB,CAAC,CAAC;SACrD;aAAM;YACL,iEAAiE;YACjE,qEAAqE;YACrE,oEAAoE;YACpE,MAAM;SACP;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC;;;;;;;AAOD,MAAM,UAAU,iBAAiB;;UACzB,KAAK,GAAG,QAAQ,EAAE;;UAClB,KAAK,GAAG,QAAQ,EAAE;;UAClB,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;;UACxB,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAE9B,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE;QACzB,UAAU,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAE,qBAAqB;KAC1D;IACD,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAE,mBAAmB;;;UAElE,UAAU,GAAG,mBAAA,KAAK,CAAC,MAAM,CAAC,EAAc;IAC9C,SAAS,IAAI,2BAA2B,CAAC,UAAU,CAAC,CAAC;IACrD,SAAS,EAAE,CAAC;IACZ,wBAAwB,CAAC,mBAAA,QAAQ,EAAE,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC","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, TVIEW, TView, TViewType, T_HOST} 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"]}