@angular/core 7.2.0-beta.0 → 7.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (454) hide show
  1. package/bundles/core-testing.umd.js +194 -128
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +5582 -4512
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +122 -129
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +12 -12
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +45 -35
  12. package/esm2015/core.js +12 -13
  13. package/esm2015/index.js +3 -4
  14. package/esm2015/public_api.js +3 -5
  15. package/esm2015/src/application_init.js +22 -10
  16. package/esm2015/src/application_module.js +6 -5
  17. package/esm2015/src/application_ref.js +94 -37
  18. package/esm2015/src/application_tokens.js +21 -16
  19. package/esm2015/src/change_detection/change_detection.js +8 -7
  20. package/esm2015/src/change_detection/change_detection_util.js +2 -4
  21. package/esm2015/src/change_detection/change_detector_ref.js +2 -3
  22. package/esm2015/src/change_detection/constants.js +30 -32
  23. package/esm2015/src/change_detection/differs/default_iterable_differ.js +108 -29
  24. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +53 -16
  25. package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
  26. package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
  27. package/esm2015/src/change_detection/pipe_transform.js +10 -5
  28. package/esm2015/src/change_detection.js +7 -3
  29. package/esm2015/src/codegen_private_exports.js +2 -3
  30. package/esm2015/src/console.js +3 -3
  31. package/esm2015/src/core.js +3 -4
  32. package/esm2015/src/core_private_export.js +2 -3
  33. package/esm2015/src/core_render3_private_export.js +13 -7
  34. package/esm2015/src/debug/debug_node.js +132 -90
  35. package/esm2015/src/di/defs.js +59 -50
  36. package/esm2015/src/di/forward_ref.js +5 -6
  37. package/esm2015/src/di/injectable.js +11 -11
  38. package/esm2015/src/di/injection_token.js +10 -6
  39. package/esm2015/src/di/injector.js +53 -43
  40. package/esm2015/src/di/injector_compatibility.js +13 -12
  41. package/esm2015/src/di/metadata.js +22 -13
  42. package/esm2015/src/di/provider.js +137 -120
  43. package/esm2015/src/di/r3_injector.js +127 -57
  44. package/esm2015/src/di/reflective_errors.js +19 -13
  45. package/esm2015/src/di/reflective_injector.js +20 -16
  46. package/esm2015/src/di/reflective_key.js +7 -5
  47. package/esm2015/src/di/reflective_provider.js +21 -20
  48. package/esm2015/src/di/scope.js +5 -5
  49. package/esm2015/src/di/util.js +13 -14
  50. package/esm2015/src/di.js +2 -3
  51. package/esm2015/src/error_handler.js +5 -4
  52. package/esm2015/src/errors.js +7 -8
  53. package/esm2015/src/event_emitter.js +3 -3
  54. package/esm2015/src/i18n/tokens.js +12 -10
  55. package/esm2015/src/is_dev_mode.js +2 -3
  56. package/esm2015/src/ivy_switch.js +2 -3
  57. package/esm2015/src/linker/compiler.js +9 -12
  58. package/esm2015/src/linker/component_factory.js +2 -3
  59. package/esm2015/src/linker/component_factory_resolver.js +24 -10
  60. package/esm2015/src/linker/element_ref.js +5 -3
  61. package/esm2015/src/linker/ng_module_factory.js +6 -5
  62. package/esm2015/src/linker/ng_module_factory_loader.js +63 -16
  63. package/esm2015/src/linker/query_list.js +16 -14
  64. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +12 -5
  65. package/esm2015/src/linker/template_ref.js +2 -3
  66. package/esm2015/src/linker/view_container_ref.js +2 -3
  67. package/esm2015/src/linker/view_ref.js +13 -7
  68. package/esm2015/src/linker.js +3 -3
  69. package/esm2015/src/metadata/di.js +22 -15
  70. package/esm2015/src/metadata/directives.js +33 -19
  71. package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
  72. package/esm2015/src/metadata/ng_module.js +82 -68
  73. package/esm2015/src/metadata/resource_loading.js +4 -3
  74. package/esm2015/src/metadata/view.js +25 -26
  75. package/esm2015/src/metadata.js +6 -3
  76. package/esm2015/src/platform_core_providers.js +5 -5
  77. package/esm2015/src/profile/profile.js +17 -13
  78. package/esm2015/src/profile/wtf_impl.js +36 -16
  79. package/esm2015/src/r3_symbols.js +18 -5
  80. package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
  81. package/esm2015/src/reflection/reflection.js +5 -5
  82. package/esm2015/src/reflection/reflection_capabilities.js +38 -27
  83. package/esm2015/src/reflection/reflector.js +2 -3
  84. package/esm2015/src/reflection/types.js +2 -12
  85. package/esm2015/src/render/api.js +67 -47
  86. package/esm2015/src/render.js +3 -3
  87. package/esm2015/src/render3/assert.js +38 -3
  88. package/esm2015/src/render3/bindings.js +111 -0
  89. package/esm2015/src/render3/component.js +88 -77
  90. package/esm2015/src/render3/component_ref.js +86 -56
  91. package/esm2015/src/render3/context_discovery.js +94 -92
  92. package/esm2015/src/render3/definition.js +58 -51
  93. package/esm2015/src/render3/di.js +206 -166
  94. package/esm2015/src/render3/di_setup.js +51 -31
  95. package/esm2015/src/render3/discovery_utils.js +225 -39
  96. package/esm2015/src/render3/empty.js +28 -0
  97. package/esm2015/src/render3/errors.js +11 -15
  98. package/esm2015/src/render3/features/inherit_definition_feature.js +13 -10
  99. package/esm2015/src/render3/features/ng_onchanges_feature.js +15 -12
  100. package/esm2015/src/render3/features/providers_feature.js +2 -3
  101. package/esm2015/src/render3/fields.js +5 -5
  102. package/esm2015/src/render3/global_utils.js +22 -7
  103. package/esm2015/src/render3/global_utils_api.js +13 -7
  104. package/esm2015/src/render3/hooks.js +21 -26
  105. package/esm2015/src/render3/i18n.js +134 -115
  106. package/esm2015/src/render3/index.js +15 -7
  107. package/esm2015/src/render3/instructions.js +938 -813
  108. package/esm2015/src/render3/interfaces/container.js +37 -6
  109. package/esm2015/src/render3/interfaces/context.js +39 -37
  110. package/esm2015/src/render3/interfaces/definition.js +225 -265
  111. package/esm2015/src/render3/interfaces/i18n.js +179 -151
  112. package/esm2015/src/render3/interfaces/injector.js +95 -13
  113. package/esm2015/src/render3/interfaces/node.js +413 -382
  114. package/esm2015/src/render3/interfaces/player.js +78 -37
  115. package/esm2015/src/render3/interfaces/projection.js +5 -10
  116. package/esm2015/src/render3/interfaces/query.js +66 -60
  117. package/esm2015/src/render3/interfaces/renderer.js +292 -117
  118. package/esm2015/src/render3/interfaces/sanitization.js +2 -6
  119. package/esm2015/src/render3/interfaces/styling.js +322 -111
  120. package/esm2015/src/render3/interfaces/view.js +356 -298
  121. package/esm2015/src/render3/jit/compiler_facade.js +10 -4
  122. package/esm2015/src/render3/jit/compiler_facade_interface.js +195 -152
  123. package/esm2015/src/render3/jit/directive.js +26 -16
  124. package/esm2015/src/render3/jit/environment.js +8 -5
  125. package/esm2015/src/render3/jit/injectable.js +7 -10
  126. package/esm2015/src/render3/jit/module.js +309 -25
  127. package/esm2015/src/render3/jit/pipe.js +2 -3
  128. package/esm2015/src/render3/jit/util.js +2 -3
  129. package/esm2015/src/render3/metadata.js +11 -10
  130. package/esm2015/src/render3/ng_dev_mode.js +5 -6
  131. package/esm2015/src/render3/ng_module_ref.js +48 -22
  132. package/esm2015/src/render3/node_assert.js +2 -3
  133. package/esm2015/src/render3/node_manipulation.js +137 -117
  134. package/esm2015/src/render3/node_selector_matcher.js +46 -19
  135. package/esm2015/src/render3/pipe.js +36 -21
  136. package/esm2015/src/render3/players.js +17 -12
  137. package/esm2015/src/render3/pure_function.js +86 -39
  138. package/esm2015/src/render3/query.js +93 -80
  139. package/esm2015/src/render3/state.js +88 -203
  140. package/esm2015/src/render3/styling/class_and_style_bindings.js +963 -249
  141. package/esm2015/src/render3/styling/core_player_handler.js +6 -4
  142. package/esm2015/src/render3/styling/player_factory.js +3 -4
  143. package/esm2015/src/render3/styling/util.js +69 -31
  144. package/esm2015/src/render3/tokens.js +7 -6
  145. package/esm2015/src/render3/util.js +65 -55
  146. package/esm2015/src/render3/view_engine_compatibility.js +36 -59
  147. package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
  148. package/esm2015/src/render3/view_ref.js +58 -44
  149. package/esm2015/src/sanitization/bypass.js +29 -6
  150. package/esm2015/src/sanitization/html_sanitizer.js +48 -16
  151. package/esm2015/src/sanitization/inert_body.js +33 -18
  152. package/esm2015/src/sanitization/sanitization.js +35 -25
  153. package/esm2015/src/sanitization/security.js +3 -4
  154. package/esm2015/src/sanitization/style_sanitizer.js +10 -7
  155. package/esm2015/src/sanitization/url_sanitizer.js +9 -7
  156. package/esm2015/src/testability/testability.js +72 -42
  157. package/esm2015/src/type.js +6 -8
  158. package/esm2015/src/util/decorators.js +19 -14
  159. package/esm2015/src/util/lang.js +2 -3
  160. package/esm2015/src/util/ng_reflect.js +2 -3
  161. package/esm2015/src/util/noop.js +2 -3
  162. package/esm2015/src/util/property.js +3 -4
  163. package/esm2015/src/util.js +12 -4
  164. package/esm2015/src/version.js +6 -6
  165. package/esm2015/src/view/element.js +17 -17
  166. package/esm2015/src/view/entrypoint.js +15 -5
  167. package/esm2015/src/view/errors.js +4 -5
  168. package/esm2015/src/view/index.js +2 -3
  169. package/esm2015/src/view/ng_content.js +3 -4
  170. package/esm2015/src/view/ng_module.js +2 -3
  171. package/esm2015/src/view/provider.js +89 -24
  172. package/esm2015/src/view/pure_expression.js +14 -15
  173. package/esm2015/src/view/query.js +14 -14
  174. package/esm2015/src/view/refs.js +96 -38
  175. package/esm2015/src/view/services.js +64 -37
  176. package/esm2015/src/view/text.js +5 -6
  177. package/esm2015/src/view/types.js +390 -325
  178. package/esm2015/src/view/util.js +29 -24
  179. package/esm2015/src/view/view.js +43 -36
  180. package/esm2015/src/view/view_attach.js +9 -10
  181. package/esm2015/src/zone/ng_zone.js +29 -28
  182. package/esm2015/src/zone.js +3 -3
  183. package/esm2015/testing/index.js +2 -3
  184. package/esm2015/testing/public_api.js +4 -4
  185. package/esm2015/testing/src/async.js +2 -3
  186. package/esm2015/testing/src/async_fallback.js +8 -7
  187. package/esm2015/testing/src/async_test_completer.js +14 -6
  188. package/esm2015/testing/src/before_each.js +10 -4
  189. package/esm2015/testing/src/component_fixture.js +48 -17
  190. package/esm2015/testing/src/fake_async.js +9 -3
  191. package/esm2015/testing/src/fake_async_fallback.js +5 -5
  192. package/esm2015/testing/src/lang_utils.js +3 -4
  193. package/esm2015/testing/src/logger.js +2 -3
  194. package/esm2015/testing/src/metadata_override.js +2 -6
  195. package/esm2015/testing/src/metadata_overrider.js +9 -8
  196. package/esm2015/testing/src/ng_zone_mock.js +2 -3
  197. package/esm2015/testing/src/private_export_testing.js +2 -3
  198. package/esm2015/testing/src/r3_test_bed.js +324 -174
  199. package/esm2015/testing/src/resolvers.js +28 -11
  200. package/esm2015/testing/src/test_bed.js +123 -54
  201. package/esm2015/testing/src/test_bed_common.js +142 -85
  202. package/esm2015/testing/src/test_compiler.js +2 -3
  203. package/esm2015/testing/src/testing.js +3 -3
  204. package/esm2015/testing/src/testing_internal.js +17 -12
  205. package/esm2015/testing/testing.js +1 -2
  206. package/esm5/core.js +12 -13
  207. package/esm5/index.js +1 -2
  208. package/esm5/public_api.js +1 -2
  209. package/esm5/src/application_init.js +1 -2
  210. package/esm5/src/application_module.js +1 -2
  211. package/esm5/src/application_ref.js +1 -2
  212. package/esm5/src/application_tokens.js +1 -2
  213. package/esm5/src/change_detection/change_detection.js +1 -2
  214. package/esm5/src/change_detection/change_detection_util.js +1 -2
  215. package/esm5/src/change_detection/change_detector_ref.js +1 -2
  216. package/esm5/src/change_detection/constants.js +3 -4
  217. package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -2
  218. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -2
  219. package/esm5/src/change_detection/differs/iterable_differs.js +1 -2
  220. package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -2
  221. package/esm5/src/change_detection/pipe_transform.js +1 -2
  222. package/esm5/src/change_detection.js +1 -2
  223. package/esm5/src/codegen_private_exports.js +1 -2
  224. package/esm5/src/console.js +1 -2
  225. package/esm5/src/core.js +1 -2
  226. package/esm5/src/core_private_export.js +1 -2
  227. package/esm5/src/core_render3_private_export.js +7 -5
  228. package/esm5/src/debug/debug_node.js +79 -58
  229. package/esm5/src/di/defs.js +3 -4
  230. package/esm5/src/di/forward_ref.js +1 -2
  231. package/esm5/src/di/injectable.js +1 -2
  232. package/esm5/src/di/injection_token.js +1 -2
  233. package/esm5/src/di/injector.js +1 -2
  234. package/esm5/src/di/injector_compatibility.js +1 -2
  235. package/esm5/src/di/metadata.js +1 -2
  236. package/esm5/src/di/provider.js +1 -2
  237. package/esm5/src/di/r3_injector.js +48 -28
  238. package/esm5/src/di/reflective_errors.js +1 -2
  239. package/esm5/src/di/reflective_injector.js +1 -2
  240. package/esm5/src/di/reflective_key.js +1 -2
  241. package/esm5/src/di/reflective_provider.js +1 -2
  242. package/esm5/src/di/scope.js +1 -2
  243. package/esm5/src/di/util.js +1 -2
  244. package/esm5/src/di.js +1 -2
  245. package/esm5/src/error_handler.js +1 -2
  246. package/esm5/src/errors.js +1 -2
  247. package/esm5/src/event_emitter.js +1 -2
  248. package/esm5/src/i18n/tokens.js +1 -2
  249. package/esm5/src/is_dev_mode.js +1 -2
  250. package/esm5/src/ivy_switch.js +1 -2
  251. package/esm5/src/linker/compiler.js +1 -2
  252. package/esm5/src/linker/component_factory.js +1 -2
  253. package/esm5/src/linker/component_factory_resolver.js +1 -2
  254. package/esm5/src/linker/element_ref.js +1 -2
  255. package/esm5/src/linker/ng_module_factory.js +1 -2
  256. package/esm5/src/linker/ng_module_factory_loader.js +37 -13
  257. package/esm5/src/linker/query_list.js +1 -2
  258. package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -2
  259. package/esm5/src/linker/template_ref.js +1 -2
  260. package/esm5/src/linker/view_container_ref.js +1 -2
  261. package/esm5/src/linker/view_ref.js +1 -2
  262. package/esm5/src/linker.js +1 -2
  263. package/esm5/src/metadata/di.js +1 -2
  264. package/esm5/src/metadata/directives.js +1 -2
  265. package/esm5/src/metadata/lifecycle_hooks.js +1 -2
  266. package/esm5/src/metadata/ng_module.js +1 -2
  267. package/esm5/src/metadata/resource_loading.js +1 -2
  268. package/esm5/src/metadata/view.js +1 -2
  269. package/esm5/src/metadata.js +1 -2
  270. package/esm5/src/platform_core_providers.js +1 -2
  271. package/esm5/src/profile/profile.js +1 -2
  272. package/esm5/src/profile/wtf_impl.js +1 -2
  273. package/esm5/src/r3_symbols.js +1 -2
  274. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -2
  275. package/esm5/src/reflection/reflection.js +1 -2
  276. package/esm5/src/reflection/reflection_capabilities.js +1 -2
  277. package/esm5/src/reflection/reflector.js +1 -2
  278. package/esm5/src/reflection/types.js +1 -2
  279. package/esm5/src/render/api.js +1 -2
  280. package/esm5/src/render.js +1 -2
  281. package/esm5/src/render3/assert.js +15 -2
  282. package/esm5/src/render3/bindings.js +63 -0
  283. package/esm5/src/render3/component.js +23 -16
  284. package/esm5/src/render3/component_ref.js +43 -36
  285. package/esm5/src/render3/context_discovery.js +68 -77
  286. package/esm5/src/render3/definition.js +30 -24
  287. package/esm5/src/render3/di.js +142 -135
  288. package/esm5/src/render3/di_setup.js +20 -21
  289. package/esm5/src/render3/discovery_utils.js +167 -36
  290. package/esm5/src/render3/empty.js +22 -0
  291. package/esm5/src/render3/errors.js +9 -12
  292. package/esm5/src/render3/features/inherit_definition_feature.js +3 -5
  293. package/esm5/src/render3/features/ng_onchanges_feature.js +11 -10
  294. package/esm5/src/render3/features/providers_feature.js +1 -2
  295. package/esm5/src/render3/fields.js +1 -2
  296. package/esm5/src/render3/global_utils.js +4 -3
  297. package/esm5/src/render3/global_utils_api.js +2 -3
  298. package/esm5/src/render3/hooks.js +14 -16
  299. package/esm5/src/render3/i18n.js +22 -27
  300. package/esm5/src/render3/index.js +5 -6
  301. package/esm5/src/render3/instructions.js +698 -593
  302. package/esm5/src/render3/interfaces/container.js +10 -3
  303. package/esm5/src/render3/interfaces/context.js +1 -2
  304. package/esm5/src/render3/interfaces/definition.js +1 -2
  305. package/esm5/src/render3/interfaces/i18n.js +1 -2
  306. package/esm5/src/render3/interfaces/injector.js +5 -6
  307. package/esm5/src/render3/interfaces/node.js +1 -2
  308. package/esm5/src/render3/interfaces/player.js +1 -2
  309. package/esm5/src/render3/interfaces/projection.js +1 -2
  310. package/esm5/src/render3/interfaces/query.js +1 -2
  311. package/esm5/src/render3/interfaces/renderer.js +1 -2
  312. package/esm5/src/render3/interfaces/sanitization.js +1 -2
  313. package/esm5/src/render3/interfaces/styling.js +1 -2
  314. package/esm5/src/render3/interfaces/view.js +3 -4
  315. package/esm5/src/render3/jit/compiler_facade.js +1 -2
  316. package/esm5/src/render3/jit/compiler_facade_interface.js +1 -2
  317. package/esm5/src/render3/jit/directive.js +19 -10
  318. package/esm5/src/render3/jit/environment.js +4 -2
  319. package/esm5/src/render3/jit/injectable.js +17 -18
  320. package/esm5/src/render3/jit/module.js +207 -13
  321. package/esm5/src/render3/jit/pipe.js +1 -2
  322. package/esm5/src/render3/jit/util.js +1 -2
  323. package/esm5/src/render3/metadata.js +1 -2
  324. package/esm5/src/render3/ng_dev_mode.js +1 -2
  325. package/esm5/src/render3/ng_module_ref.js +29 -11
  326. package/esm5/src/render3/node_assert.js +1 -2
  327. package/esm5/src/render3/node_manipulation.js +54 -50
  328. package/esm5/src/render3/node_selector_matcher.js +28 -9
  329. package/esm5/src/render3/pipe.js +33 -19
  330. package/esm5/src/render3/players.js +7 -9
  331. package/esm5/src/render3/pure_function.js +48 -38
  332. package/esm5/src/render3/query.js +8 -9
  333. package/esm5/src/render3/state.js +50 -135
  334. package/esm5/src/render3/styling/class_and_style_bindings.js +684 -214
  335. package/esm5/src/render3/styling/core_player_handler.js +1 -2
  336. package/esm5/src/render3/styling/player_factory.js +1 -2
  337. package/esm5/src/render3/styling/util.js +39 -22
  338. package/esm5/src/render3/tokens.js +1 -2
  339. package/esm5/src/render3/util.js +49 -37
  340. package/esm5/src/render3/view_engine_compatibility.js +20 -33
  341. package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -2
  342. package/esm5/src/render3/view_ref.js +33 -30
  343. package/esm5/src/sanitization/bypass.js +1 -2
  344. package/esm5/src/sanitization/html_sanitizer.js +1 -2
  345. package/esm5/src/sanitization/inert_body.js +4 -5
  346. package/esm5/src/sanitization/sanitization.js +25 -20
  347. package/esm5/src/sanitization/security.js +1 -2
  348. package/esm5/src/sanitization/style_sanitizer.js +1 -2
  349. package/esm5/src/sanitization/url_sanitizer.js +1 -2
  350. package/esm5/src/testability/testability.js +1 -2
  351. package/esm5/src/type.js +1 -2
  352. package/esm5/src/util/decorators.js +1 -2
  353. package/esm5/src/util/lang.js +1 -2
  354. package/esm5/src/util/ng_reflect.js +1 -2
  355. package/esm5/src/util/noop.js +1 -2
  356. package/esm5/src/util/property.js +1 -2
  357. package/esm5/src/util.js +1 -2
  358. package/esm5/src/version.js +2 -3
  359. package/esm5/src/view/element.js +1 -2
  360. package/esm5/src/view/entrypoint.js +1 -2
  361. package/esm5/src/view/errors.js +1 -2
  362. package/esm5/src/view/index.js +1 -2
  363. package/esm5/src/view/ng_content.js +1 -2
  364. package/esm5/src/view/ng_module.js +1 -2
  365. package/esm5/src/view/provider.js +1 -2
  366. package/esm5/src/view/pure_expression.js +1 -2
  367. package/esm5/src/view/query.js +1 -2
  368. package/esm5/src/view/refs.js +1 -2
  369. package/esm5/src/view/services.js +1 -2
  370. package/esm5/src/view/text.js +1 -2
  371. package/esm5/src/view/types.js +1 -2
  372. package/esm5/src/view/util.js +1 -2
  373. package/esm5/src/view/view.js +1 -2
  374. package/esm5/src/view/view_attach.js +1 -2
  375. package/esm5/src/zone/ng_zone.js +1 -2
  376. package/esm5/src/zone.js +1 -2
  377. package/esm5/testing/index.js +1 -2
  378. package/esm5/testing/public_api.js +1 -2
  379. package/esm5/testing/src/async.js +1 -2
  380. package/esm5/testing/src/async_fallback.js +1 -2
  381. package/esm5/testing/src/async_test_completer.js +1 -2
  382. package/esm5/testing/src/before_each.js +1 -2
  383. package/esm5/testing/src/component_fixture.js +1 -2
  384. package/esm5/testing/src/fake_async.js +1 -2
  385. package/esm5/testing/src/fake_async_fallback.js +1 -2
  386. package/esm5/testing/src/lang_utils.js +1 -2
  387. package/esm5/testing/src/logger.js +1 -2
  388. package/esm5/testing/src/metadata_override.js +1 -2
  389. package/esm5/testing/src/metadata_overrider.js +1 -2
  390. package/esm5/testing/src/ng_zone_mock.js +1 -2
  391. package/esm5/testing/src/private_export_testing.js +1 -2
  392. package/esm5/testing/src/r3_test_bed.js +182 -121
  393. package/esm5/testing/src/resolvers.js +11 -7
  394. package/esm5/testing/src/test_bed.js +1 -2
  395. package/esm5/testing/src/test_bed_common.js +1 -2
  396. package/esm5/testing/src/test_compiler.js +1 -2
  397. package/esm5/testing/src/testing.js +1 -2
  398. package/esm5/testing/src/testing_internal.js +2 -3
  399. package/esm5/testing/testing.js +1 -2
  400. package/fesm2015/core.js +8560 -6153
  401. package/fesm2015/core.js.map +1 -1
  402. package/fesm2015/testing.js +351 -229
  403. package/fesm2015/testing.js.map +1 -1
  404. package/fesm5/core.js +5541 -4482
  405. package/fesm5/core.js.map +1 -1
  406. package/fesm5/testing.js +185 -130
  407. package/fesm5/testing.js.map +1 -1
  408. package/package.json +1 -1
  409. package/src/change_detection/constants.d.ts +2 -2
  410. package/src/core_render3_private_export.d.ts +6 -3
  411. package/src/di/injectable.d.ts +3 -2
  412. package/src/di/r3_injector.d.ts +1 -1
  413. package/src/linker/ng_module_factory_loader.d.ts +5 -1
  414. package/src/render3/assert.d.ts +6 -0
  415. package/src/render3/bindings.d.ts +20 -0
  416. package/src/render3/component.d.ts +3 -3
  417. package/src/render3/component_ref.d.ts +14 -4
  418. package/src/render3/context_discovery.d.ts +9 -9
  419. package/src/render3/definition.d.ts +8 -23
  420. package/src/render3/di.d.ts +19 -17
  421. package/src/render3/discovery_utils.d.ts +66 -8
  422. package/src/render3/empty.d.ts +16 -0
  423. package/src/render3/errors.d.ts +1 -1
  424. package/src/render3/global_utils_api.d.ts +1 -1
  425. package/src/render3/hooks.d.ts +7 -6
  426. package/src/render3/index.d.ts +4 -4
  427. package/src/render3/instructions.d.ts +163 -118
  428. package/src/render3/interfaces/container.d.ts +9 -8
  429. package/src/render3/interfaces/context.d.ts +3 -3
  430. package/src/render3/interfaces/definition.d.ts +2 -12
  431. package/src/render3/interfaces/i18n.d.ts +25 -25
  432. package/src/render3/interfaces/injector.d.ts +8 -9
  433. package/src/render3/interfaces/node.d.ts +56 -23
  434. package/src/render3/interfaces/renderer.d.ts +2 -1
  435. package/src/render3/interfaces/styling.d.ts +392 -117
  436. package/src/render3/interfaces/view.d.ts +49 -35
  437. package/src/render3/jit/compiler_facade_interface.d.ts +10 -3
  438. package/src/render3/jit/module.d.ts +9 -1
  439. package/src/render3/metadata.d.ts +1 -1
  440. package/src/render3/ng_module_ref.d.ts +8 -6
  441. package/src/render3/node_manipulation.d.ts +21 -27
  442. package/src/render3/node_selector_matcher.d.ts +2 -2
  443. package/src/render3/state.d.ts +11 -38
  444. package/src/render3/styling/class_and_style_bindings.d.ts +130 -43
  445. package/src/render3/styling/util.d.ts +9 -4
  446. package/src/render3/util.d.ts +31 -25
  447. package/src/render3/view_engine_compatibility.d.ts +5 -12
  448. package/src/render3/view_engine_compatibility_prebound.d.ts +2 -2
  449. package/src/render3/view_ref.d.ts +2 -2
  450. package/src/sanitization/sanitization.d.ts +3 -2
  451. package/testing/src/r3_test_bed.d.ts +15 -0
  452. package/testing/src/resolvers.d.ts +2 -2
  453. package/testing/testing.metadata.json +1 -1
  454. package/testing.d.ts +5 -0
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
3
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
5
  /**
6
6
  * @license
@@ -10,7 +10,7 @@
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
12
  /** @enum {number} */
13
- var TNodeType = {
13
+ const TNodeType = {
14
14
  Container: 0,
15
15
  Projection: 1,
16
16
  View: 2,
@@ -21,51 +21,79 @@ var TNodeType = {
21
21
  };
22
22
  export { TNodeType };
23
23
  /** @enum {number} */
24
- var TNodeFlags = {
25
- /** The number of directives on this node is encoded on the least significant bits */
26
- DirectiveCountMask: 4095,
24
+ const TNodeFlags = {
27
25
  /** This bit is set if the node is a component */
28
- isComponent: 4096,
26
+ isComponent: 1,
29
27
  /** This bit is set if the node has been projected */
30
- isProjected: 8192,
28
+ isProjected: 2,
31
29
  /** This bit is set if the node has any content queries */
32
- hasContentQuery: 16384,
30
+ hasContentQuery: 4,
33
31
  /** This bit is set if the node has any directives that contain [class properties */
34
- hasClassInput: 32768,
35
- /** The index of the first directive on this node is encoded on the most significant bits */
36
- DirectiveStartingIndexShift: 16,
32
+ hasClassInput: 8,
37
33
  };
38
34
  export { TNodeFlags };
39
35
  /** @enum {number} */
40
- var TNodeProviderIndexes = {
36
+ const TNodeProviderIndexes = {
41
37
  /** The index of the first provider on this node is encoded on the least significant bits */
42
38
  ProvidersStartIndexMask: 65535,
43
39
  /** The count of view providers from the component on this node is encoded on the 16 most
44
- significant bits */
40
+ significant bits */
45
41
  CptViewProvidersCountShift: 16,
46
42
  CptViewProvidersCountShifter: 65536,
47
43
  };
48
44
  export { TNodeProviderIndexes };
49
45
  /** @enum {number} */
50
- var AttributeMarker = {
46
+ const AttributeMarker = {
51
47
  /**
52
- * Marker indicates that the following 3 values in the attributes array are:
53
- * namespaceUri, attributeName, attributeValue
54
- * in that order.
55
- */
48
+ * Marker indicates that the following 3 values in the attributes array are:
49
+ * namespaceUri, attributeName, attributeValue
50
+ * in that order.
51
+ */
56
52
  NamespaceURI: 0,
57
53
  /**
58
- * This marker indicates that the following attribute names were extracted from bindings (ex.:
59
- * [foo]="exp") and / or event handlers (ex. (bar)="doSth()").
60
- * Taking the above bindings and outputs as an example an attributes array could look as follows:
61
- * ['class', 'fade in', AttributeMarker.SelectOnly, 'foo', 'bar']
62
- */
63
- SelectOnly: 1,
54
+ * Signals class declaration.
55
+ *
56
+ * Each value following `Classes` designates a class name to include on the element.
57
+ * ## Example:
58
+ *
59
+ * Given:
60
+ * ```
61
+ * <div class="foo bar baz">...<d/vi>
62
+ * ```
63
+ *
64
+ * the generated code is:
65
+ * ```
66
+ * var _c1 = [AttributeMarker.Classes, 'foo', 'bar', 'baz'];
67
+ * ```
68
+ */
69
+ Classes: 1,
70
+ /**
71
+ * Signals style declaration.
72
+ *
73
+ * Each pair of values following `Styles` designates a style name and value to include on the
74
+ * element.
75
+ * ## Example:
76
+ *
77
+ * Given:
78
+ * ```
79
+ * <div style="width:100px; height:200px; color:red">...</div>
80
+ * ```
81
+ *
82
+ * the generated code is:
83
+ * ```
84
+ * var _c1 = [AttributeMarker.Styles, 'width', '100px', 'height'. '200px', 'color', 'red'];
85
+ * ```
86
+ */
87
+ Styles: 2,
88
+ /**
89
+ * This marker indicates that the following attribute names were extracted from bindings (ex.:
90
+ * [foo]="exp") and / or event handlers (ex. (bar)="doSth()").
91
+ * Taking the above bindings and outputs as an example an attributes array could look as follows:
92
+ * ['class', 'fade in', AttributeMarker.SelectOnly, 'foo', 'bar']
93
+ */
94
+ SelectOnly: 3,
64
95
  };
65
96
  export { AttributeMarker };
66
- /** @typedef {?} */
67
- var TAttributes;
68
- export { TAttributes };
69
97
  /**
70
98
  * Binding data (flyweight) for a particular node that is shared between all templates
71
99
  * of a specific type.
@@ -79,395 +107,398 @@ export { TAttributes };
79
107
  * @record
80
108
  */
81
109
  export function TNode() { }
82
- /**
83
- * The type of the TNode. See TNodeType.
84
- * @type {?}
85
- */
86
- TNode.prototype.type;
87
- /**
88
- * Index of the TNode in TView.data and corresponding native element in LViewData.
89
- *
90
- * This is necessary to get from any TNode to its corresponding native element when
91
- * traversing the node tree.
92
- *
93
- * If index is -1, this is a dynamically created container node or embedded view node.
94
- * @type {?}
95
- */
96
- TNode.prototype.index;
97
- /**
98
- * The index of the closest injector in this node's LViewData.
99
- *
100
- * If the index === -1, there is no injector on this node or any ancestor node in this view.
101
- *
102
- * If the index !== -1, it is the index of this node's injector OR the index of a parent injector
103
- * in the same view. We pass the parent injector index down the node tree of a view so it's
104
- * possible to find the parent injector without walking a potentially deep node tree. Injector
105
- * indices are not set across view boundaries because there could be multiple component hosts.
106
- *
107
- * If tNode.injectorIndex === tNode.parent.injectorIndex, then the index belongs to a parent
108
- * injector.
109
- * @type {?}
110
- */
111
- TNode.prototype.injectorIndex;
112
- /**
113
- * This number stores two values using its bits:
114
- *
115
- * - the number of directives on that node (first 12 bits)
116
- * - the starting index of the node's directives in the directives array (last 20 bits).
117
- *
118
- * These two values are necessary so DI can effectively search the directives associated
119
- * with a node without searching the whole directives array.
120
- * @type {?}
121
- */
122
- TNode.prototype.flags;
123
- /**
124
- * This number stores two values using its bits:
125
- *
126
- * - the index of the first provider on that node (first 16 bits)
127
- * - the count of view providers from the component on this node (last 16 bits)
128
- * @type {?}
129
- */
130
- TNode.prototype.providerIndexes;
131
- /**
132
- * The tag name associated with this node.
133
- * @type {?}
134
- */
135
- TNode.prototype.tagName;
136
- /**
137
- * Attributes associated with an element. We need to store attributes to support various use-cases
138
- * (attribute injection, content projection with selectors, directives matching).
139
- * Attributes are stored statically because reading them from the DOM would be way too slow for
140
- * content projection and queries.
141
- *
142
- * Since attrs will always be calculated first, they will never need to be marked undefined by
143
- * other instructions.
144
- *
145
- * For regular attributes a name of an attribute and its value alternate in the array.
146
- * e.g. ['role', 'checkbox']
147
- * This array can contain flags that will indicate "special attributes" (attributes with
148
- * namespaces, attributes extracted from bindings and outputs).
149
- * @type {?}
150
- */
151
- TNode.prototype.attrs;
152
- /**
153
- * A set of local names under which a given element is exported in a template and
154
- * visible to queries. An entry in this array can be created for different reasons:
155
- * - an element itself is referenced, ex.: `<div #foo>`
156
- * - a component is referenced, ex.: `<my-cmpt #foo>`
157
- * - a directive is referenced, ex.: `<my-cmpt #foo="directiveExportAs">`.
158
- *
159
- * A given element might have different local names and those names can be associated
160
- * with a directive. We store local names at even indexes while odd indexes are reserved
161
- * for directive index in a view (or `-1` if there is no associated directive).
162
- *
163
- * Some examples:
164
- * - `<div #foo>` => `["foo", -1]`
165
- * - `<my-cmpt #foo>` => `["foo", myCmptIdx]`
166
- * - `<my-cmpt #foo #bar="directiveExportAs">` => `["foo", myCmptIdx, "bar", directiveIdx]`
167
- * - `<div #foo #bar="directiveExportAs">` => `["foo", -1, "bar", directiveIdx]`
168
- * @type {?}
169
- */
170
- TNode.prototype.localNames;
171
- /**
172
- * Information about input properties that need to be set once from attribute data.
173
- * @type {?}
174
- */
175
- TNode.prototype.initialInputs;
176
- /**
177
- * Input data for all directives on this node.
178
- *
179
- * - `undefined` means that the prop has not been initialized yet,
180
- * - `null` means that the prop has been initialized but no inputs have been found.
181
- * @type {?}
182
- */
183
- TNode.prototype.inputs;
184
- /**
185
- * Output data for all directives on this node.
186
- *
187
- * - `undefined` means that the prop has not been initialized yet,
188
- * - `null` means that the prop has been initialized but no outputs have been found.
189
- * @type {?}
190
- */
191
- TNode.prototype.outputs;
192
- /**
193
- * The TView or TViews attached to this node.
194
- *
195
- * If this TNode corresponds to an LContainer with inline views, the container will
196
- * need to store separate static data for each of its view blocks (TView[]). Otherwise,
197
- * nodes in inline views with the same index as nodes in their parent views will overwrite
198
- * each other, as they are in the same template.
199
- *
200
- * Each index in this array corresponds to the static data for a certain
201
- * view. So if you had V(0) and V(1) in a container, you might have:
202
- *
203
- * [
204
- * [{tagName: 'div', attrs: ...}, null], // V(0) TView
205
- * [{tagName: 'button', attrs ...}, null] // V(1) TView
206
- *
207
- * If this TNode corresponds to an LContainer with a template (e.g. structural
208
- * directive), the template's TView will be stored here.
209
- *
210
- * If this TNode corresponds to an element, tViews will be null .
211
- * @type {?}
212
- */
213
- TNode.prototype.tViews;
214
- /**
215
- * The next sibling node. Necessary so we can propagate through the root nodes of a view
216
- * to insert them or remove them from the DOM.
217
- * @type {?}
218
- */
219
- TNode.prototype.next;
220
- /**
221
- * First child of the current node.
222
- *
223
- * For component nodes, the child will always be a ContentChild (in same view).
224
- * For embedded view nodes, the child will be in their child view.
225
- * @type {?}
226
- */
227
- TNode.prototype.child;
228
- /**
229
- * Parent node (in the same view only).
230
- *
231
- * We need a reference to a node's parent so we can append the node to its parent's native
232
- * element at the appropriate time.
233
- *
234
- * If the parent would be in a different view (e.g. component host), this property will be null.
235
- * It's important that we don't try to cross component boundaries when retrieving the parent
236
- * because the parent will change (e.g. index, attrs) depending on where the component was
237
- * used (and thus shouldn't be stored on TNode). In these cases, we retrieve the parent through
238
- * LView.node instead (which will be instance-specific).
239
- *
240
- * If this is an inline view node (V), the parent will be its container.
241
- * @type {?}
242
- */
243
- TNode.prototype.parent;
244
- /**
245
- * If this node is part of an i18n block, it indicates whether this node is part of the DOM.
246
- * If this node is not part of an i18n block, this field is null.
247
- * @type {?}
248
- */
249
- TNode.prototype.detached;
250
- /** @type {?} */
251
- TNode.prototype.stylingTemplate;
252
- /**
253
- * List of projected TNodes for a given component host element OR index into the said nodes.
254
- *
255
- * For easier discussion assume this example:
256
- * `<parent>`'s view definition:
257
- * ```
258
- * <child id="c1">content1</child>
259
- * <child id="c2"><span>content2</span></child>
260
- * ```
261
- * `<child>`'s view definition:
262
- * ```
263
- * <ng-content id="cont1"></ng-content>
264
- * ```
265
- *
266
- * If `Array.isArray(projection)` then `TNode` is a host element:
267
- * - `projection` stores the content nodes which are to be projected.
268
- * - The nodes represent categories defined by the selector: For example:
269
- * `<ng-content/><ng-content select="abc"/>` would represent the heads for `<ng-content/>`
270
- * and `<ng-content select="abc"/>` respectively.
271
- * - The nodes we store in `projection` are heads only, we used `.next` to get their
272
- * siblings.
273
- * - The nodes `.next` is sorted/rewritten as part of the projection setup.
274
- * - `projection` size is equal to the number of projections `<ng-content>`. The size of
275
- * `c1` will be `1` because `<child>` has only one `<ng-content>`.
276
- * - we store `projection` with the host (`c1`, `c2`) rather than the `<ng-content>` (`cont1`)
277
- * because the same component (`<child>`) can be used in multiple locations (`c1`, `c2`) and as
278
- * a result have different set of nodes to project.
279
- * - without `projection` it would be difficult to efficiently traverse nodes to be projected.
280
- *
281
- * If `typeof projection == 'number'` then `TNode` is a `<ng-content>` element:
282
- * - `projection` is an index of the host's `projection`Nodes.
283
- * - This would return the first head node to project:
284
- * `getHost(currentTNode).projection[currentTNode.projection]`.
285
- * - When projecting nodes the parent node retrieved may be a `<ng-content>` node, in which case
286
- * the process is recursive in nature (not implementation).
287
- * @type {?}
288
- */
289
- TNode.prototype.projection;
110
+ if (false) {
111
+ /**
112
+ * The type of the TNode. See TNodeType.
113
+ * @type {?}
114
+ */
115
+ TNode.prototype.type;
116
+ /**
117
+ * Index of the TNode in TView.data and corresponding native element in LView.
118
+ *
119
+ * This is necessary to get from any TNode to its corresponding native element when
120
+ * traversing the node tree.
121
+ *
122
+ * If index is -1, this is a dynamically created container node or embedded view node.
123
+ * @type {?}
124
+ */
125
+ TNode.prototype.index;
126
+ /**
127
+ * The index of the closest injector in this node's LView.
128
+ *
129
+ * If the index === -1, there is no injector on this node or any ancestor node in this view.
130
+ *
131
+ * If the index !== -1, it is the index of this node's injector OR the index of a parent injector
132
+ * in the same view. We pass the parent injector index down the node tree of a view so it's
133
+ * possible to find the parent injector without walking a potentially deep node tree. Injector
134
+ * indices are not set across view boundaries because there could be multiple component hosts.
135
+ *
136
+ * If tNode.injectorIndex === tNode.parent.injectorIndex, then the index belongs to a parent
137
+ * injector.
138
+ * @type {?}
139
+ */
140
+ TNode.prototype.injectorIndex;
141
+ /**
142
+ * Stores starting index of the directives.
143
+ * @type {?}
144
+ */
145
+ TNode.prototype.directiveStart;
146
+ /**
147
+ * Stores final exclusive index of the directives.
148
+ * @type {?}
149
+ */
150
+ TNode.prototype.directiveEnd;
151
+ /**
152
+ * Stores if Node isComponent, isProjected, hasContentQuery and hasClassInput
153
+ * @type {?}
154
+ */
155
+ TNode.prototype.flags;
156
+ /**
157
+ * This number stores two values using its bits:
158
+ *
159
+ * - the index of the first provider on that node (first 16 bits)
160
+ * - the count of view providers from the component on this node (last 16 bits)
161
+ * @type {?}
162
+ */
163
+ TNode.prototype.providerIndexes;
164
+ /**
165
+ * The tag name associated with this node.
166
+ * @type {?}
167
+ */
168
+ TNode.prototype.tagName;
169
+ /**
170
+ * Attributes associated with an element. We need to store attributes to support various use-cases
171
+ * (attribute injection, content projection with selectors, directives matching).
172
+ * Attributes are stored statically because reading them from the DOM would be way too slow for
173
+ * content projection and queries.
174
+ *
175
+ * Since attrs will always be calculated first, they will never need to be marked undefined by
176
+ * other instructions.
177
+ *
178
+ * For regular attributes a name of an attribute and its value alternate in the array.
179
+ * e.g. ['role', 'checkbox']
180
+ * This array can contain flags that will indicate "special attributes" (attributes with
181
+ * namespaces, attributes extracted from bindings and outputs).
182
+ * @type {?}
183
+ */
184
+ TNode.prototype.attrs;
185
+ /**
186
+ * A set of local names under which a given element is exported in a template and
187
+ * visible to queries. An entry in this array can be created for different reasons:
188
+ * - an element itself is referenced, ex.: `<div #foo>`
189
+ * - a component is referenced, ex.: `<my-cmpt #foo>`
190
+ * - a directive is referenced, ex.: `<my-cmpt #foo="directiveExportAs">`.
191
+ *
192
+ * A given element might have different local names and those names can be associated
193
+ * with a directive. We store local names at even indexes while odd indexes are reserved
194
+ * for directive index in a view (or `-1` if there is no associated directive).
195
+ *
196
+ * Some examples:
197
+ * - `<div #foo>` => `["foo", -1]`
198
+ * - `<my-cmpt #foo>` => `["foo", myCmptIdx]`
199
+ * - `<my-cmpt #foo #bar="directiveExportAs">` => `["foo", myCmptIdx, "bar", directiveIdx]`
200
+ * - `<div #foo #bar="directiveExportAs">` => `["foo", -1, "bar", directiveIdx]`
201
+ * @type {?}
202
+ */
203
+ TNode.prototype.localNames;
204
+ /**
205
+ * Information about input properties that need to be set once from attribute data.
206
+ * @type {?}
207
+ */
208
+ TNode.prototype.initialInputs;
209
+ /**
210
+ * Input data for all directives on this node.
211
+ *
212
+ * - `undefined` means that the prop has not been initialized yet,
213
+ * - `null` means that the prop has been initialized but no inputs have been found.
214
+ * @type {?}
215
+ */
216
+ TNode.prototype.inputs;
217
+ /**
218
+ * Output data for all directives on this node.
219
+ *
220
+ * - `undefined` means that the prop has not been initialized yet,
221
+ * - `null` means that the prop has been initialized but no outputs have been found.
222
+ * @type {?}
223
+ */
224
+ TNode.prototype.outputs;
225
+ /**
226
+ * The TView or TViews attached to this node.
227
+ *
228
+ * If this TNode corresponds to an LContainer with inline views, the container will
229
+ * need to store separate static data for each of its view blocks (TView[]). Otherwise,
230
+ * nodes in inline views with the same index as nodes in their parent views will overwrite
231
+ * each other, as they are in the same template.
232
+ *
233
+ * Each index in this array corresponds to the static data for a certain
234
+ * view. So if you had V(0) and V(1) in a container, you might have:
235
+ *
236
+ * [
237
+ * [{tagName: 'div', attrs: ...}, null], // V(0) TView
238
+ * [{tagName: 'button', attrs ...}, null] // V(1) TView
239
+ *
240
+ * If this TNode corresponds to an LContainer with a template (e.g. structural
241
+ * directive), the template's TView will be stored here.
242
+ *
243
+ * If this TNode corresponds to an element, tViews will be null .
244
+ * @type {?}
245
+ */
246
+ TNode.prototype.tViews;
247
+ /**
248
+ * The next sibling node. Necessary so we can propagate through the root nodes of a view
249
+ * to insert them or remove them from the DOM.
250
+ * @type {?}
251
+ */
252
+ TNode.prototype.next;
253
+ /**
254
+ * First child of the current node.
255
+ *
256
+ * For component nodes, the child will always be a ContentChild (in same view).
257
+ * For embedded view nodes, the child will be in their child view.
258
+ * @type {?}
259
+ */
260
+ TNode.prototype.child;
261
+ /**
262
+ * Parent node (in the same view only).
263
+ *
264
+ * We need a reference to a node's parent so we can append the node to its parent's native
265
+ * element at the appropriate time.
266
+ *
267
+ * If the parent would be in a different view (e.g. component host), this property will be null.
268
+ * It's important that we don't try to cross component boundaries when retrieving the parent
269
+ * because the parent will change (e.g. index, attrs) depending on where the component was
270
+ * used (and thus shouldn't be stored on TNode). In these cases, we retrieve the parent through
271
+ * LView.node instead (which will be instance-specific).
272
+ *
273
+ * If this is an inline view node (V), the parent will be its container.
274
+ * @type {?}
275
+ */
276
+ TNode.prototype.parent;
277
+ /**
278
+ * If this node is part of an i18n block, it indicates whether this node is part of the DOM.
279
+ * If this node is not part of an i18n block, this field is null.
280
+ * @type {?}
281
+ */
282
+ TNode.prototype.detached;
283
+ /** @type {?} */
284
+ TNode.prototype.stylingTemplate;
285
+ /**
286
+ * List of projected TNodes for a given component host element OR index into the said nodes.
287
+ *
288
+ * For easier discussion assume this example:
289
+ * `<parent>`'s view definition:
290
+ * ```
291
+ * <child id="c1">content1</child>
292
+ * <child id="c2"><span>content2</span></child>
293
+ * ```
294
+ * `<child>`'s view definition:
295
+ * ```
296
+ * <ng-content id="cont1"></ng-content>
297
+ * ```
298
+ *
299
+ * If `Array.isArray(projection)` then `TNode` is a host element:
300
+ * - `projection` stores the content nodes which are to be projected.
301
+ * - The nodes represent categories defined by the selector: For example:
302
+ * `<ng-content/><ng-content select="abc"/>` would represent the heads for `<ng-content/>`
303
+ * and `<ng-content select="abc"/>` respectively.
304
+ * - The nodes we store in `projection` are heads only, we used `.next` to get their
305
+ * siblings.
306
+ * - The nodes `.next` is sorted/rewritten as part of the projection setup.
307
+ * - `projection` size is equal to the number of projections `<ng-content>`. The size of
308
+ * `c1` will be `1` because `<child>` has only one `<ng-content>`.
309
+ * - we store `projection` with the host (`c1`, `c2`) rather than the `<ng-content>` (`cont1`)
310
+ * because the same component (`<child>`) can be used in multiple locations (`c1`, `c2`) and as
311
+ * a result have different set of nodes to project.
312
+ * - without `projection` it would be difficult to efficiently traverse nodes to be projected.
313
+ *
314
+ * If `typeof projection == 'number'` then `TNode` is a `<ng-content>` element:
315
+ * - `projection` is an index of the host's `projection`Nodes.
316
+ * - This would return the first head node to project:
317
+ * `getHost(currentTNode).projection[currentTNode.projection]`.
318
+ * - When projecting nodes the parent node retrieved may be a `<ng-content>` node, in which case
319
+ * the process is recursive in nature (not implementation).
320
+ * @type {?}
321
+ */
322
+ TNode.prototype.projection;
323
+ }
290
324
  /**
291
325
  * Static data for an element
292
326
  * @record
293
327
  */
294
328
  export function TElementNode() { }
295
- /**
296
- * Index in the data[] array
297
- * @type {?}
298
- */
299
- TElementNode.prototype.index;
300
- /** @type {?} */
301
- TElementNode.prototype.child;
302
- /**
303
- * Element nodes will have parents unless they are the first node of a component or
304
- * embedded view (which means their parent is in a different view and must be
305
- * retrieved using viewData[HOST_NODE]).
306
- * @type {?}
307
- */
308
- TElementNode.prototype.parent;
309
- /** @type {?} */
310
- TElementNode.prototype.tViews;
311
- /**
312
- * If this is a component TNode with projection, this will be an array of projected
313
- * TNodes (see TNode.projection for more info). If it's a regular element node or a
314
- * component without projection, it will be null.
315
- * @type {?}
316
- */
317
- TElementNode.prototype.projection;
329
+ if (false) {
330
+ /**
331
+ * Index in the data[] array
332
+ * @type {?}
333
+ */
334
+ TElementNode.prototype.index;
335
+ /** @type {?} */
336
+ TElementNode.prototype.child;
337
+ /**
338
+ * Element nodes will have parents unless they are the first node of a component or
339
+ * embedded view (which means their parent is in a different view and must be
340
+ * retrieved using viewData[HOST_NODE]).
341
+ * @type {?}
342
+ */
343
+ TElementNode.prototype.parent;
344
+ /** @type {?} */
345
+ TElementNode.prototype.tViews;
346
+ /**
347
+ * If this is a component TNode with projection, this will be an array of projected
348
+ * TNodes (see TNode.projection for more info). If it's a regular element node or a
349
+ * component without projection, it will be null.
350
+ * @type {?}
351
+ */
352
+ TElementNode.prototype.projection;
353
+ }
318
354
  /**
319
355
  * Static data for a text node
320
356
  * @record
321
357
  */
322
358
  export function TTextNode() { }
323
- /**
324
- * Index in the data[] array
325
- * @type {?}
326
- */
327
- TTextNode.prototype.index;
328
- /** @type {?} */
329
- TTextNode.prototype.child;
330
- /**
331
- * Text nodes will have parents unless they are the first node of a component or
332
- * embedded view (which means their parent is in a different view and must be
333
- * retrieved using LView.node).
334
- * @type {?}
335
- */
336
- TTextNode.prototype.parent;
337
- /** @type {?} */
338
- TTextNode.prototype.tViews;
339
- /** @type {?} */
340
- TTextNode.prototype.projection;
359
+ if (false) {
360
+ /**
361
+ * Index in the data[] array
362
+ * @type {?}
363
+ */
364
+ TTextNode.prototype.index;
365
+ /** @type {?} */
366
+ TTextNode.prototype.child;
367
+ /**
368
+ * Text nodes will have parents unless they are the first node of a component or
369
+ * embedded view (which means their parent is in a different view and must be
370
+ * retrieved using LView.node).
371
+ * @type {?}
372
+ */
373
+ TTextNode.prototype.parent;
374
+ /** @type {?} */
375
+ TTextNode.prototype.tViews;
376
+ /** @type {?} */
377
+ TTextNode.prototype.projection;
378
+ }
341
379
  /**
342
380
  * Static data for an LContainer
343
381
  * @record
344
382
  */
345
383
  export function TContainerNode() { }
346
- /**
347
- * Index in the data[] array.
348
- *
349
- * If it's -1, this is a dynamically created container node that isn't stored in
350
- * data[] (e.g. when you inject ViewContainerRef) .
351
- * @type {?}
352
- */
353
- TContainerNode.prototype.index;
354
- /** @type {?} */
355
- TContainerNode.prototype.child;
356
- /**
357
- * Container nodes will have parents unless:
358
- *
359
- * - They are the first node of a component or embedded view
360
- * - They are dynamically created
361
- * @type {?}
362
- */
363
- TContainerNode.prototype.parent;
364
- /** @type {?} */
365
- TContainerNode.prototype.tViews;
366
- /** @type {?} */
367
- TContainerNode.prototype.projection;
384
+ if (false) {
385
+ /**
386
+ * Index in the data[] array.
387
+ *
388
+ * If it's -1, this is a dynamically created container node that isn't stored in
389
+ * data[] (e.g. when you inject ViewContainerRef) .
390
+ * @type {?}
391
+ */
392
+ TContainerNode.prototype.index;
393
+ /** @type {?} */
394
+ TContainerNode.prototype.child;
395
+ /**
396
+ * Container nodes will have parents unless:
397
+ *
398
+ * - They are the first node of a component or embedded view
399
+ * - They are dynamically created
400
+ * @type {?}
401
+ */
402
+ TContainerNode.prototype.parent;
403
+ /** @type {?} */
404
+ TContainerNode.prototype.tViews;
405
+ /** @type {?} */
406
+ TContainerNode.prototype.projection;
407
+ }
368
408
  /**
369
409
  * Static data for an <ng-container>
370
410
  * @record
371
411
  */
372
412
  export function TElementContainerNode() { }
373
- /**
374
- * Index in the LViewData[] array.
375
- * @type {?}
376
- */
377
- TElementContainerNode.prototype.index;
378
- /** @type {?} */
379
- TElementContainerNode.prototype.child;
380
- /** @type {?} */
381
- TElementContainerNode.prototype.parent;
382
- /** @type {?} */
383
- TElementContainerNode.prototype.tViews;
384
- /** @type {?} */
385
- TElementContainerNode.prototype.projection;
413
+ if (false) {
414
+ /**
415
+ * Index in the LView[] array.
416
+ * @type {?}
417
+ */
418
+ TElementContainerNode.prototype.index;
419
+ /** @type {?} */
420
+ TElementContainerNode.prototype.child;
421
+ /** @type {?} */
422
+ TElementContainerNode.prototype.parent;
423
+ /** @type {?} */
424
+ TElementContainerNode.prototype.tViews;
425
+ /** @type {?} */
426
+ TElementContainerNode.prototype.projection;
427
+ }
386
428
  /**
387
429
  * Static data for an ICU expression
388
430
  * @record
389
431
  */
390
432
  export function TIcuContainerNode() { }
391
- /**
392
- * Index in the LViewData[] array.
393
- * @type {?}
394
- */
395
- TIcuContainerNode.prototype.index;
396
- /** @type {?} */
397
- TIcuContainerNode.prototype.child;
398
- /** @type {?} */
399
- TIcuContainerNode.prototype.parent;
400
- /** @type {?} */
401
- TIcuContainerNode.prototype.tViews;
402
- /** @type {?} */
403
- TIcuContainerNode.prototype.projection;
404
- /**
405
- * Indicates the current active case for an ICU expression.
406
- * It is null when there is no active case.
407
- * @type {?}
408
- */
409
- TIcuContainerNode.prototype.activeCaseIndex;
433
+ if (false) {
434
+ /**
435
+ * Index in the LView[] array.
436
+ * @type {?}
437
+ */
438
+ TIcuContainerNode.prototype.index;
439
+ /** @type {?} */
440
+ TIcuContainerNode.prototype.child;
441
+ /** @type {?} */
442
+ TIcuContainerNode.prototype.parent;
443
+ /** @type {?} */
444
+ TIcuContainerNode.prototype.tViews;
445
+ /** @type {?} */
446
+ TIcuContainerNode.prototype.projection;
447
+ /**
448
+ * Indicates the current active case for an ICU expression.
449
+ * It is null when there is no active case.
450
+ * @type {?}
451
+ */
452
+ TIcuContainerNode.prototype.activeCaseIndex;
453
+ }
410
454
  /**
411
455
  * Static data for a view
412
456
  * @record
413
457
  */
414
458
  export function TViewNode() { }
415
- /**
416
- * If -1, it's a dynamically created view. Otherwise, it is the view block ID.
417
- * @type {?}
418
- */
419
- TViewNode.prototype.index;
420
- /** @type {?} */
421
- TViewNode.prototype.child;
422
- /** @type {?} */
423
- TViewNode.prototype.parent;
424
- /** @type {?} */
425
- TViewNode.prototype.tViews;
426
- /** @type {?} */
427
- TViewNode.prototype.projection;
459
+ if (false) {
460
+ /**
461
+ * If -1, it's a dynamically created view. Otherwise, it is the view block ID.
462
+ * @type {?}
463
+ */
464
+ TViewNode.prototype.index;
465
+ /** @type {?} */
466
+ TViewNode.prototype.child;
467
+ /** @type {?} */
468
+ TViewNode.prototype.parent;
469
+ /** @type {?} */
470
+ TViewNode.prototype.tViews;
471
+ /** @type {?} */
472
+ TViewNode.prototype.projection;
473
+ }
428
474
  /**
429
475
  * Static data for an LProjectionNode
430
476
  * @record
431
477
  */
432
478
  export function TProjectionNode() { }
433
- /**
434
- * Index in the data[] array
435
- * @type {?}
436
- */
437
- TProjectionNode.prototype.child;
438
- /**
439
- * Projection nodes will have parents unless they are the first node of a component
440
- * or embedded view (which means their parent is in a different view and must be
441
- * retrieved using LView.node).
442
- * @type {?}
443
- */
444
- TProjectionNode.prototype.parent;
445
- /** @type {?} */
446
- TProjectionNode.prototype.tViews;
447
- /**
448
- * Index of the projection node. (See TNode.projection for more info.)
449
- * @type {?}
450
- */
451
- TProjectionNode.prototype.projection;
452
- /** @typedef {?} */
453
- var PropertyAliases;
454
- export { PropertyAliases };
455
- /** @typedef {?} */
456
- var PropertyAliasValue;
457
- export { PropertyAliasValue };
458
- /** @typedef {?} */
459
- var InitialInputData;
460
- export { InitialInputData };
461
- /** @typedef {?} */
462
- var InitialInputs;
463
- export { InitialInputs };
479
+ if (false) {
480
+ /**
481
+ * Index in the data[] array
482
+ * @type {?}
483
+ */
484
+ TProjectionNode.prototype.child;
485
+ /**
486
+ * Projection nodes will have parents unless they are the first node of a component
487
+ * or embedded view (which means their parent is in a different view and must be
488
+ * retrieved using LView.node).
489
+ * @type {?}
490
+ */
491
+ TProjectionNode.prototype.parent;
492
+ /** @type {?} */
493
+ TProjectionNode.prototype.tViews;
494
+ /**
495
+ * Index of the projection node. (See TNode.projection for more info.)
496
+ * @type {?}
497
+ */
498
+ TProjectionNode.prototype.projection;
499
+ }
500
+ // Note: This hack is necessary so we don't erroneously get a circular dependency
501
+ // failure based on types.
464
502
  /** @type {?} */
465
503
  export const unusedValueExportToPlacateAjd = 1;
466
- /** @typedef {?} */
467
- var TNodeWithLocalRefs;
468
- export { TNodeWithLocalRefs };
469
- /** @typedef {?} */
470
- var LocalRefExtractor;
471
- export { LocalRefExtractor };
472
-
473
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/interfaces/node.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAiBE,YAAiB;IACjB,aAAkB;IAClB,OAAY;IACZ,UAAe;IACf,gBAAqB;IACrB,mBAAwB;IACxB,eAAoB;;;;;;IAQpB,wBAAuD;;IAGvD,iBAAgD;;IAGhD,iBAAgD;;IAGhD,sBAAoD;;IAGpD,oBAAkD;;IAGlD,+BAAgC;;;;;;IAQhC,8BAA4D;;;IAI5D,8BAA+B;IAC/B,mCAAiE;;;;;;;;;;IAYjE,eAAgB;;;;;;;IAQhB,aAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuYhB,aAAa,6BAA6B,GAAG,CAAC,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 {StylingContext} from './styling';\nimport {LViewData, TView} from './view';\n\n\n/**\n * TNodeType corresponds to the TNode.type property. It contains information\n * on how to map a particular set of bits in TNode.flags to the node type.\n */\nexport const enum TNodeType {\n  Container = 0b000,\n  Projection = 0b001,\n  View = 0b010,\n  Element = 0b011,\n  ViewOrElement = 0b010,\n  ElementContainer = 0b100,\n  IcuContainer = 0b101,\n}\n\n/**\n * Corresponds to the TNode.flags property.\n */\nexport const enum TNodeFlags {\n  /** The number of directives on this node is encoded on the least significant bits */\n  DirectiveCountMask = 0b00000000000000000000111111111111,\n\n  /** This bit is set if the node is a component */\n  isComponent = 0b00000000000000000001000000000000,\n\n  /** This bit is set if the node has been projected */\n  isProjected = 0b00000000000000000010000000000000,\n\n  /** This bit is set if the node has any content queries */\n  hasContentQuery = 0b00000000000000000100000000000000,\n\n  /** This bit is set if the node has any directives that contain [class properties */\n  hasClassInput = 0b00000000000000001000000000000000,\n\n  /** The index of the first directive on this node is encoded on the most significant bits  */\n  DirectiveStartingIndexShift = 16,\n}\n\n/**\n * Corresponds to the TNode.providerIndexes property.\n */\nexport const enum TNodeProviderIndexes {\n  /** The index of the first provider on this node is encoded on the least significant bits */\n  ProvidersStartIndexMask = 0b00000000000000001111111111111111,\n\n  /** The count of view providers from the component on this node is encoded on the 16 most\n     significant bits */\n  CptViewProvidersCountShift = 16,\n  CptViewProvidersCountShifter = 0b00000000000000010000000000000000,\n}\n/**\n * A set of marker values to be used in the attributes arrays. Those markers indicate that some\n * items are not regular attributes and the processing should be adapted accordingly.\n */\nexport const enum AttributeMarker {\n  /**\n   * Marker indicates that the following 3 values in the attributes array are:\n   * namespaceUri, attributeName, attributeValue\n   * in that order.\n   */\n  NamespaceURI = 0,\n\n  /**\n   * This marker indicates that the following attribute names were extracted from bindings (ex.:\n   * [foo]=\"exp\") and / or event handlers (ex. (bar)=\"doSth()\").\n   * Taking the above bindings and outputs as an example an attributes array could look as follows:\n   * ['class', 'fade in', AttributeMarker.SelectOnly, 'foo', 'bar']\n   */\n  SelectOnly = 1\n}\n\n/**\n * A combination of:\n * - attribute names and values\n * - special markers acting as flags to alter attributes processing.\n */\nexport type TAttributes = (string | AttributeMarker)[];\n\n/**\n * Binding data (flyweight) for a particular node that is shared between all templates\n * of a specific type.\n *\n * If a property is:\n *    - PropertyAliases: that property's data was generated and this is it\n *    - Null: that property's data was already generated and nothing was found.\n *    - Undefined: that property's data has not yet been generated\n *\n * see: https://en.wikipedia.org/wiki/Flyweight_pattern for more on the Flyweight pattern\n */\nexport interface TNode {\n  /** The type of the TNode. See TNodeType. */\n  type: TNodeType;\n\n  /**\n   * Index of the TNode in TView.data and corresponding native element in LViewData.\n   *\n   * This is necessary to get from any TNode to its corresponding native element when\n   * traversing the node tree.\n   *\n   * If index is -1, this is a dynamically created container node or embedded view node.\n   */\n  index: number;\n\n  /**\n   * The index of the closest injector in this node's LViewData.\n   *\n   * If the index === -1, there is no injector on this node or any ancestor node in this view.\n   *\n   * If the index !== -1, it is the index of this node's injector OR the index of a parent injector\n   * in the same view. We pass the parent injector index down the node tree of a view so it's\n   * possible to find the parent injector without walking a potentially deep node tree. Injector\n   * indices are not set across view boundaries because there could be multiple component hosts.\n   *\n   * If tNode.injectorIndex === tNode.parent.injectorIndex, then the index belongs to a parent\n   * injector.\n   */\n  injectorIndex: number;\n\n  /**\n   * This number stores two values using its bits:\n   *\n   * - the number of directives on that node (first 12 bits)\n   * - the starting index of the node's directives in the directives array (last 20 bits).\n   *\n   * These two values are necessary so DI can effectively search the directives associated\n   * with a node without searching the whole directives array.\n   */\n  flags: TNodeFlags;\n\n  /**\n   * This number stores two values using its bits:\n   *\n   * - the index of the first provider on that node (first 16 bits)\n   * - the count of view providers from the component on this node (last 16 bits)\n   */\n  providerIndexes: TNodeProviderIndexes;\n\n  /** The tag name associated with this node. */\n  tagName: string|null;\n\n  /**\n   * Attributes associated with an element. We need to store attributes to support various use-cases\n   * (attribute injection, content projection with selectors, directives matching).\n   * Attributes are stored statically because reading them from the DOM would be way too slow for\n   * content projection and queries.\n   *\n   * Since attrs will always be calculated first, they will never need to be marked undefined by\n   * other instructions.\n   *\n   * For regular attributes a name of an attribute and its value alternate in the array.\n   * e.g. ['role', 'checkbox']\n   * This array can contain flags that will indicate \"special attributes\" (attributes with\n   * namespaces, attributes extracted from bindings and outputs).\n   */\n  attrs: TAttributes|null;\n\n  /**\n   * A set of local names under which a given element is exported in a template and\n   * visible to queries. An entry in this array can be created for different reasons:\n   * - an element itself is referenced, ex.: `<div #foo>`\n   * - a component is referenced, ex.: `<my-cmpt #foo>`\n   * - a directive is referenced, ex.: `<my-cmpt #foo=\"directiveExportAs\">`.\n   *\n   * A given element might have different local names and those names can be associated\n   * with a directive. We store local names at even indexes while odd indexes are reserved\n   * for directive index in a view (or `-1` if there is no associated directive).\n   *\n   * Some examples:\n   * - `<div #foo>` => `[\"foo\", -1]`\n   * - `<my-cmpt #foo>` => `[\"foo\", myCmptIdx]`\n   * - `<my-cmpt #foo #bar=\"directiveExportAs\">` => `[\"foo\", myCmptIdx, \"bar\", directiveIdx]`\n   * - `<div #foo #bar=\"directiveExportAs\">` => `[\"foo\", -1, \"bar\", directiveIdx]`\n   */\n  localNames: (string|number)[]|null;\n\n  /** Information about input properties that need to be set once from attribute data. */\n  initialInputs: InitialInputData|null|undefined;\n\n  /**\n   * Input data for all directives on this node.\n   *\n   * - `undefined` means that the prop has not been initialized yet,\n   * - `null` means that the prop has been initialized but no inputs have been found.\n   */\n  inputs: PropertyAliases|null|undefined;\n\n  /**\n   * Output data for all directives on this node.\n   *\n   * - `undefined` means that the prop has not been initialized yet,\n   * - `null` means that the prop has been initialized but no outputs have been found.\n   */\n  outputs: PropertyAliases|null|undefined;\n\n  /**\n   * The TView or TViews attached to this node.\n   *\n   * If this TNode corresponds to an LContainer with inline views, the container will\n   * need to store separate static data for each of its view blocks (TView[]). Otherwise,\n   * nodes in inline views with the same index as nodes in their parent views will overwrite\n   * each other, as they are in the same template.\n   *\n   * Each index in this array corresponds to the static data for a certain\n   * view. So if you had V(0) and V(1) in a container, you might have:\n   *\n   * [\n   *   [{tagName: 'div', attrs: ...}, null],     // V(0) TView\n   *   [{tagName: 'button', attrs ...}, null]    // V(1) TView\n   *\n   * If this TNode corresponds to an LContainer with a template (e.g. structural\n   * directive), the template's TView will be stored here.\n   *\n   * If this TNode corresponds to an element, tViews will be null .\n   */\n  tViews: TView|TView[]|null;\n\n  /**\n   * The next sibling node. Necessary so we can propagate through the root nodes of a view\n   * to insert them or remove them from the DOM.\n   */\n  next: TNode|null;\n\n  /**\n   * First child of the current node.\n   *\n   * For component nodes, the child will always be a ContentChild (in same view).\n   * For embedded view nodes, the child will be in their child view.\n   */\n  child: TNode|null;\n\n  /**\n   * Parent node (in the same view only).\n   *\n   * We need a reference to a node's parent so we can append the node to its parent's native\n   * element at the appropriate time.\n   *\n   * If the parent would be in a different view (e.g. component host), this property will be null.\n   * It's important that we don't try to cross component boundaries when retrieving the parent\n   * because the parent will change (e.g. index, attrs) depending on where the component was\n   * used (and thus shouldn't be stored on TNode). In these cases, we retrieve the parent through\n   * LView.node instead (which will be instance-specific).\n   *\n   * If this is an inline view node (V), the parent will be its container.\n   */\n  parent: TElementNode|TContainerNode|null;\n\n  /**\n   * If this node is part of an i18n block, it indicates whether this node is part of the DOM.\n   * If this node is not part of an i18n block, this field is null.\n   */\n  detached: boolean|null;\n\n  stylingTemplate: StylingContext|null;\n  /**\n   * List of projected TNodes for a given component host element OR index into the said nodes.\n   *\n   * For easier discussion assume this example:\n   * `<parent>`'s view definition:\n   * ```\n   * <child id=\"c1\">content1</child>\n   * <child id=\"c2\"><span>content2</span></child>\n   * ```\n   * `<child>`'s view definition:\n   * ```\n   * <ng-content id=\"cont1\"></ng-content>\n   * ```\n   *\n   * If `Array.isArray(projection)` then `TNode` is a host element:\n   * - `projection` stores the content nodes which are to be projected.\n   *    - The nodes represent categories defined by the selector: For example:\n   *      `<ng-content/><ng-content select=\"abc\"/>` would represent the heads for `<ng-content/>`\n   *      and `<ng-content select=\"abc\"/>` respectively.\n   *    - The nodes we store in `projection` are heads only, we used `.next` to get their\n   *      siblings.\n   *    - The nodes `.next` is sorted/rewritten as part of the projection setup.\n   *    - `projection` size is equal to the number of projections `<ng-content>`. The size of\n   *      `c1` will be `1` because `<child>` has only one `<ng-content>`.\n   * - we store `projection` with the host (`c1`, `c2`) rather than the `<ng-content>` (`cont1`)\n   *   because the same component (`<child>`) can be used in multiple locations (`c1`, `c2`) and as\n   *   a result have different set of nodes to project.\n   * - without `projection` it would be difficult to efficiently traverse nodes to be projected.\n   *\n   * If `typeof projection == 'number'` then `TNode` is a `<ng-content>` element:\n   * - `projection` is an index of the host's `projection`Nodes.\n   *   - This would return the first head node to project:\n   *     `getHost(currentTNode).projection[currentTNode.projection]`.\n   * - When projecting nodes the parent node retrieved may be a `<ng-content>` node, in which case\n   *   the process is recursive in nature (not implementation).\n   */\n  projection: (TNode|null)[]|number|null;\n}\n\n/** Static data for an element  */\nexport interface TElementNode extends TNode {\n  /** Index in the data[] array */\n  index: number;\n  child: TElementNode|TTextNode|TElementContainerNode|TContainerNode|TProjectionNode|null;\n  /**\n   * Element nodes will have parents unless they are the first node of a component or\n   * embedded view (which means their parent is in a different view and must be\n   * retrieved using viewData[HOST_NODE]).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n\n  /**\n   * If this is a component TNode with projection, this will be an array of projected\n   * TNodes (see TNode.projection for more info). If it's a regular element node or a\n   * component without projection, it will be null.\n   */\n  projection: (TNode|null)[]|null;\n}\n\n/** Static data for a text node */\nexport interface TTextNode extends TNode {\n  /** Index in the data[] array */\n  index: number;\n  child: null;\n  /**\n   * Text nodes will have parents unless they are the first node of a component or\n   * embedded view (which means their parent is in a different view and must be\n   * retrieved using LView.node).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an LContainer */\nexport interface TContainerNode extends TNode {\n  /**\n   * Index in the data[] array.\n   *\n   * If it's -1, this is a dynamically created container node that isn't stored in\n   * data[] (e.g. when you inject ViewContainerRef) .\n   */\n  index: number;\n  child: null;\n\n  /**\n   * Container nodes will have parents unless:\n   *\n   * - They are the first node of a component or embedded view\n   * - They are dynamically created\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: TView|TView[]|null;\n  projection: null;\n}\n\n/** Static data for an <ng-container> */\nexport interface TElementContainerNode extends TNode {\n  /** Index in the LViewData[] array. */\n  index: number;\n  child: TElementNode|TTextNode|TContainerNode|TElementContainerNode|TProjectionNode|null;\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an ICU expression */\nexport interface TIcuContainerNode extends TNode {\n  /** Index in the LViewData[] array. */\n  index: number;\n  child: TElementNode|TTextNode|null;\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n  /**\n   * Indicates the current active case for an ICU expression.\n   * It is null when there is no active case.\n   */\n  activeCaseIndex: number|null;\n}\n\n/** Static data for a view  */\nexport interface TViewNode extends TNode {\n  /** If -1, it's a dynamically created view. Otherwise, it is the view block ID. */\n  index: number;\n  child: TElementNode|TTextNode|TElementContainerNode|TContainerNode|TProjectionNode|null;\n  parent: TContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an LProjectionNode  */\nexport interface TProjectionNode extends TNode {\n  /** Index in the data[] array */\n  child: null;\n  /**\n   * Projection nodes will have parents unless they are the first node of a component\n   * or embedded view (which means their parent is in a different view and must be\n   * retrieved using LView.node).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n\n  /** Index of the projection node. (See TNode.projection for more info.) */\n  projection: number;\n}\n\n/**\n * This mapping is necessary so we can set input properties and output listeners\n * properly at runtime when property names are minified or aliased.\n *\n * Key: unminified / public input or output name\n * Value: array containing minified / internal name and related directive index\n *\n * The value must be an array to support inputs and outputs with the same name\n * on the same node.\n */\nexport type PropertyAliases = {\n  // This uses an object map because using the Map type would be too slow\n  [key: string]: PropertyAliasValue\n};\n\n/**\n * Store the runtime input or output names for all the directives.\n *\n * - Even indices: directive index\n * - Odd indices: minified / internal name\n *\n * e.g. [0, 'change-minified']\n */\nexport type PropertyAliasValue = (number | string)[];\n\n\n/**\n * This array contains information about input properties that\n * need to be set once from attribute data. It's ordered by\n * directive index (relative to element) so it's simple to\n * look up a specific directive's initial input data.\n *\n * Within each sub-array:\n *\n * Even indices: minified/internal input name\n * Odd indices: initial value\n *\n * If a directive on a node does not have any input properties\n * that should be set from attributes, its index is set to null\n * to avoid a sparse array.\n *\n * e.g. [null, ['role-min', 'button']]\n */\nexport type InitialInputData = (InitialInputs | null)[];\n\n/**\n * Used by InitialInputData to store input properties\n * that should be set once from attributes.\n *\n * Even indices: minified/internal input name\n * Odd indices: initial value\n *\n * e.g. ['role-min', 'button']\n */\nexport type InitialInputs = string[];\n\n// Note: This hack is necessary so we don't erroneously get a circular dependency\n// failure based on types.\nexport const unusedValueExportToPlacateAjd = 1;\n\n/**\n * Type representing a set of TNodes that can have local refs (`#foo`) placed on them.\n */\nexport type TNodeWithLocalRefs = TContainerNode | TElementNode | TElementContainerNode;\n\n/**\n * Type for a function that extracts a value for a local refs.\n * Example:\n * - `<div #nativeDivEl>` - `nativeDivEl` should point to the native `<div>` element;\n * - `<ng-template #tplRef>` - `tplRef` should point to the `TemplateRef` instance;\n */\nexport type LocalRefExtractor = (tNode: TNodeWithLocalRefs, currentView: LViewData) => any;\n"]}
504
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/node.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAiBE,YAAiB;IACjB,aAAkB;IAClB,OAAY;IACZ,UAAe;IACf,gBAAqB;IACrB,mBAAwB;IACxB,eAAoB;;;;;IAOpB,iDAAiD;IACjD,cAAoB;IAEpB,qDAAqD;IACrD,cAAoB;IAEpB,0DAA0D;IAC1D,kBAAwB;IAExB,oFAAoF;IACpF,gBAAsB;;;;;IAOtB,4FAA4F;IAC5F,8BAA4D;IAE5D;0BACsB;IACtB,8BAA+B;IAC/B,mCAAiE;;;;;IAOjE;;;;OAIG;IACH,eAAgB;IAEhB;;;;;;;;;;;;;;;QAeI;IACJ,UAAW;IAEX;;;;;;;;;;;;;;;;OAgBG;IACH,SAAU;IAEV;;;;;OAKG;IACH,aAAc;;;;;;;;;;;;;;;AAqBhB,2BA8MC;;;;;;IA5MC,qBAAgB;;;;;;;;;;IAUhB,sBAAc;;;;;;;;;;;;;;;IAed,8BAAsB;;;;;IAKtB,+BAAuB;;;;;IAKvB,6BAAqB;;;;;IAKrB,sBAAkB;;;;;;;;IASlB,gCAAsC;;;;;IAGtC,wBAAqB;;;;;;;;;;;;;;;;IAgBrB,sBAAwB;;;;;;;;;;;;;;;;;;;IAmBxB,2BAAmC;;;;;IAGnC,8BAA+C;;;;;;;;IAQ/C,uBAAuC;;;;;;;;IAQvC,wBAAwC;;;;;;;;;;;;;;;;;;;;;;IAsBxC,uBAA2B;;;;;;IAM3B,qBAAiB;;;;;;;;IAQjB,sBAAkB;;;;;;;;;;;;;;;;IAgBlB,uBAAyC;;;;;;IAMzC,yBAAuB;;IAEvB,gCAAqC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAqCrC,2BAAuC;;;;;;AAIzC,kCAkBC;;;;;;IAhBC,6BAAc;;IACd,6BAAwF;;;;;;;IAMxF,8BAAgD;;IAChD,8BAAa;;;;;;;IAOb,kCAAgC;;;;;;AAIlC,+BAYC;;;;;;IAVC,0BAAc;;IACd,0BAAY;;;;;;;IAMZ,2BAAgD;;IAChD,2BAAa;;IACb,+BAAiB;;;;;;AAInB,oCAmBC;;;;;;;;;IAZC,+BAAc;;IACd,+BAAY;;;;;;;;IAQZ,gCAAgD;;IAChD,gCAA2B;;IAC3B,oCAAiB;;;;;;AAInB,2CAOC;;;;;;IALC,sCAAc;;IACd,sCAAwF;;IACxF,uCAAgD;;IAChD,uCAAa;;IACb,2CAAiB;;;;;;AAInB,uCAYC;;;;;;IAVC,kCAAc;;IACd,kCAAmC;;IACnC,mCAAgD;;IAChD,mCAAa;;IACb,uCAAiB;;;;;;IAKjB,4CAA6B;;;;;;AAI/B,+BAOC;;;;;;IALC,0BAAc;;IACd,0BAAwF;;IACxF,2BAA4B;;IAC5B,2BAAa;;IACb,+BAAiB;;;;;;AAInB,qCAaC;;;;;;IAXC,gCAAY;;;;;;;IAMZ,iCAAgD;;IAChD,iCAAa;;;;;IAGb,qCAAmB;;;;;AA6DrB,MAAM,OAAO,6BAA6B,GAAG,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 {StylingContext} from './styling';\nimport {LView, TView} from './view';\n\n\n/**\n * TNodeType corresponds to the TNode.type property. It contains information\n * on how to map a particular set of bits in TNode.flags to the node type.\n */\nexport const enum TNodeType {\n  Container = 0b000,\n  Projection = 0b001,\n  View = 0b010,\n  Element = 0b011,\n  ViewOrElement = 0b010,\n  ElementContainer = 0b100,\n  IcuContainer = 0b101,\n}\n\n/**\n * Corresponds to the TNode.flags property.\n */\nexport const enum TNodeFlags {\n  /** This bit is set if the node is a component */\n  isComponent = 0b0001,\n\n  /** This bit is set if the node has been projected */\n  isProjected = 0b0010,\n\n  /** This bit is set if the node has any content queries */\n  hasContentQuery = 0b0100,\n\n  /** This bit is set if the node has any directives that contain [class properties */\n  hasClassInput = 0b1000,\n}\n\n/**\n * Corresponds to the TNode.providerIndexes property.\n */\nexport const enum TNodeProviderIndexes {\n  /** The index of the first provider on this node is encoded on the least significant bits */\n  ProvidersStartIndexMask = 0b00000000000000001111111111111111,\n\n  /** The count of view providers from the component on this node is encoded on the 16 most\n     significant bits */\n  CptViewProvidersCountShift = 16,\n  CptViewProvidersCountShifter = 0b00000000000000010000000000000000,\n}\n/**\n * A set of marker values to be used in the attributes arrays. These markers indicate that some\n * items are not regular attributes and the processing should be adapted accordingly.\n */\nexport const enum AttributeMarker {\n  /**\n   * Marker indicates that the following 3 values in the attributes array are:\n   * namespaceUri, attributeName, attributeValue\n   * in that order.\n   */\n  NamespaceURI = 0,\n\n  /**\n    * Signals class declaration.\n    *\n    * Each value following `Classes` designates a class name to include on the element.\n    * ## Example:\n    *\n    * Given:\n    * ```\n    * <div class=\"foo bar baz\">...<d/vi>\n    * ```\n    *\n    * the generated code is:\n    * ```\n    * var _c1 = [AttributeMarker.Classes, 'foo', 'bar', 'baz'];\n    * ```\n    */\n  Classes = 1,\n\n  /**\n   * Signals style declaration.\n   *\n   * Each pair of values following `Styles` designates a style name and value to include on the\n   * element.\n   * ## Example:\n   *\n   * Given:\n   * ```\n   * <div style=\"width:100px; height:200px; color:red\">...</div>\n   * ```\n   *\n   * the generated code is:\n   * ```\n   * var _c1 = [AttributeMarker.Styles, 'width', '100px', 'height'. '200px', 'color', 'red'];\n   * ```\n   */\n  Styles = 2,\n\n  /**\n   * This marker indicates that the following attribute names were extracted from bindings (ex.:\n   * [foo]=\"exp\") and / or event handlers (ex. (bar)=\"doSth()\").\n   * Taking the above bindings and outputs as an example an attributes array could look as follows:\n   * ['class', 'fade in', AttributeMarker.SelectOnly, 'foo', 'bar']\n   */\n  SelectOnly = 3,\n}\n\n/**\n * A combination of:\n * - attribute names and values\n * - special markers acting as flags to alter attributes processing.\n */\nexport type TAttributes = (string | AttributeMarker)[];\n\n/**\n * Binding data (flyweight) for a particular node that is shared between all templates\n * of a specific type.\n *\n * If a property is:\n *    - PropertyAliases: that property's data was generated and this is it\n *    - Null: that property's data was already generated and nothing was found.\n *    - Undefined: that property's data has not yet been generated\n *\n * see: https://en.wikipedia.org/wiki/Flyweight_pattern for more on the Flyweight pattern\n */\nexport interface TNode {\n  /** The type of the TNode. See TNodeType. */\n  type: TNodeType;\n\n  /**\n   * Index of the TNode in TView.data and corresponding native element in LView.\n   *\n   * This is necessary to get from any TNode to its corresponding native element when\n   * traversing the node tree.\n   *\n   * If index is -1, this is a dynamically created container node or embedded view node.\n   */\n  index: number;\n\n  /**\n   * The index of the closest injector in this node's LView.\n   *\n   * If the index === -1, there is no injector on this node or any ancestor node in this view.\n   *\n   * If the index !== -1, it is the index of this node's injector OR the index of a parent injector\n   * in the same view. We pass the parent injector index down the node tree of a view so it's\n   * possible to find the parent injector without walking a potentially deep node tree. Injector\n   * indices are not set across view boundaries because there could be multiple component hosts.\n   *\n   * If tNode.injectorIndex === tNode.parent.injectorIndex, then the index belongs to a parent\n   * injector.\n   */\n  injectorIndex: number;\n\n  /**\n   * Stores starting index of the directives.\n   */\n  directiveStart: number;\n\n  /**\n   * Stores final exclusive index of the directives.\n   */\n  directiveEnd: number;\n\n  /**\n   * Stores if Node isComponent, isProjected, hasContentQuery and hasClassInput\n   */\n  flags: TNodeFlags;\n\n  /**\n   * This number stores two values using its bits:\n   *\n   * - the index of the first provider on that node (first 16 bits)\n   * - the count of view providers from the component on this node (last 16 bits)\n   */\n  // TODO(misko): break this into actual vars.\n  providerIndexes: TNodeProviderIndexes;\n\n  /** The tag name associated with this node. */\n  tagName: string|null;\n\n  /**\n   * Attributes associated with an element. We need to store attributes to support various use-cases\n   * (attribute injection, content projection with selectors, directives matching).\n   * Attributes are stored statically because reading them from the DOM would be way too slow for\n   * content projection and queries.\n   *\n   * Since attrs will always be calculated first, they will never need to be marked undefined by\n   * other instructions.\n   *\n   * For regular attributes a name of an attribute and its value alternate in the array.\n   * e.g. ['role', 'checkbox']\n   * This array can contain flags that will indicate \"special attributes\" (attributes with\n   * namespaces, attributes extracted from bindings and outputs).\n   */\n  attrs: TAttributes|null;\n\n  /**\n   * A set of local names under which a given element is exported in a template and\n   * visible to queries. An entry in this array can be created for different reasons:\n   * - an element itself is referenced, ex.: `<div #foo>`\n   * - a component is referenced, ex.: `<my-cmpt #foo>`\n   * - a directive is referenced, ex.: `<my-cmpt #foo=\"directiveExportAs\">`.\n   *\n   * A given element might have different local names and those names can be associated\n   * with a directive. We store local names at even indexes while odd indexes are reserved\n   * for directive index in a view (or `-1` if there is no associated directive).\n   *\n   * Some examples:\n   * - `<div #foo>` => `[\"foo\", -1]`\n   * - `<my-cmpt #foo>` => `[\"foo\", myCmptIdx]`\n   * - `<my-cmpt #foo #bar=\"directiveExportAs\">` => `[\"foo\", myCmptIdx, \"bar\", directiveIdx]`\n   * - `<div #foo #bar=\"directiveExportAs\">` => `[\"foo\", -1, \"bar\", directiveIdx]`\n   */\n  localNames: (string|number)[]|null;\n\n  /** Information about input properties that need to be set once from attribute data. */\n  initialInputs: InitialInputData|null|undefined;\n\n  /**\n   * Input data for all directives on this node.\n   *\n   * - `undefined` means that the prop has not been initialized yet,\n   * - `null` means that the prop has been initialized but no inputs have been found.\n   */\n  inputs: PropertyAliases|null|undefined;\n\n  /**\n   * Output data for all directives on this node.\n   *\n   * - `undefined` means that the prop has not been initialized yet,\n   * - `null` means that the prop has been initialized but no outputs have been found.\n   */\n  outputs: PropertyAliases|null|undefined;\n\n  /**\n   * The TView or TViews attached to this node.\n   *\n   * If this TNode corresponds to an LContainer with inline views, the container will\n   * need to store separate static data for each of its view blocks (TView[]). Otherwise,\n   * nodes in inline views with the same index as nodes in their parent views will overwrite\n   * each other, as they are in the same template.\n   *\n   * Each index in this array corresponds to the static data for a certain\n   * view. So if you had V(0) and V(1) in a container, you might have:\n   *\n   * [\n   *   [{tagName: 'div', attrs: ...}, null],     // V(0) TView\n   *   [{tagName: 'button', attrs ...}, null]    // V(1) TView\n   *\n   * If this TNode corresponds to an LContainer with a template (e.g. structural\n   * directive), the template's TView will be stored here.\n   *\n   * If this TNode corresponds to an element, tViews will be null .\n   */\n  tViews: TView|TView[]|null;\n\n  /**\n   * The next sibling node. Necessary so we can propagate through the root nodes of a view\n   * to insert them or remove them from the DOM.\n   */\n  next: TNode|null;\n\n  /**\n   * First child of the current node.\n   *\n   * For component nodes, the child will always be a ContentChild (in same view).\n   * For embedded view nodes, the child will be in their child view.\n   */\n  child: TNode|null;\n\n  /**\n   * Parent node (in the same view only).\n   *\n   * We need a reference to a node's parent so we can append the node to its parent's native\n   * element at the appropriate time.\n   *\n   * If the parent would be in a different view (e.g. component host), this property will be null.\n   * It's important that we don't try to cross component boundaries when retrieving the parent\n   * because the parent will change (e.g. index, attrs) depending on where the component was\n   * used (and thus shouldn't be stored on TNode). In these cases, we retrieve the parent through\n   * LView.node instead (which will be instance-specific).\n   *\n   * If this is an inline view node (V), the parent will be its container.\n   */\n  parent: TElementNode|TContainerNode|null;\n\n  /**\n   * If this node is part of an i18n block, it indicates whether this node is part of the DOM.\n   * If this node is not part of an i18n block, this field is null.\n   */\n  detached: boolean|null;\n\n  stylingTemplate: StylingContext|null;\n  /**\n   * List of projected TNodes for a given component host element OR index into the said nodes.\n   *\n   * For easier discussion assume this example:\n   * `<parent>`'s view definition:\n   * ```\n   * <child id=\"c1\">content1</child>\n   * <child id=\"c2\"><span>content2</span></child>\n   * ```\n   * `<child>`'s view definition:\n   * ```\n   * <ng-content id=\"cont1\"></ng-content>\n   * ```\n   *\n   * If `Array.isArray(projection)` then `TNode` is a host element:\n   * - `projection` stores the content nodes which are to be projected.\n   *    - The nodes represent categories defined by the selector: For example:\n   *      `<ng-content/><ng-content select=\"abc\"/>` would represent the heads for `<ng-content/>`\n   *      and `<ng-content select=\"abc\"/>` respectively.\n   *    - The nodes we store in `projection` are heads only, we used `.next` to get their\n   *      siblings.\n   *    - The nodes `.next` is sorted/rewritten as part of the projection setup.\n   *    - `projection` size is equal to the number of projections `<ng-content>`. The size of\n   *      `c1` will be `1` because `<child>` has only one `<ng-content>`.\n   * - we store `projection` with the host (`c1`, `c2`) rather than the `<ng-content>` (`cont1`)\n   *   because the same component (`<child>`) can be used in multiple locations (`c1`, `c2`) and as\n   *   a result have different set of nodes to project.\n   * - without `projection` it would be difficult to efficiently traverse nodes to be projected.\n   *\n   * If `typeof projection == 'number'` then `TNode` is a `<ng-content>` element:\n   * - `projection` is an index of the host's `projection`Nodes.\n   *   - This would return the first head node to project:\n   *     `getHost(currentTNode).projection[currentTNode.projection]`.\n   * - When projecting nodes the parent node retrieved may be a `<ng-content>` node, in which case\n   *   the process is recursive in nature (not implementation).\n   */\n  projection: (TNode|null)[]|number|null;\n}\n\n/** Static data for an element  */\nexport interface TElementNode extends TNode {\n  /** Index in the data[] array */\n  index: number;\n  child: TElementNode|TTextNode|TElementContainerNode|TContainerNode|TProjectionNode|null;\n  /**\n   * Element nodes will have parents unless they are the first node of a component or\n   * embedded view (which means their parent is in a different view and must be\n   * retrieved using viewData[HOST_NODE]).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n\n  /**\n   * If this is a component TNode with projection, this will be an array of projected\n   * TNodes (see TNode.projection for more info). If it's a regular element node or a\n   * component without projection, it will be null.\n   */\n  projection: (TNode|null)[]|null;\n}\n\n/** Static data for a text node */\nexport interface TTextNode extends TNode {\n  /** Index in the data[] array */\n  index: number;\n  child: null;\n  /**\n   * Text nodes will have parents unless they are the first node of a component or\n   * embedded view (which means their parent is in a different view and must be\n   * retrieved using LView.node).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an LContainer */\nexport interface TContainerNode extends TNode {\n  /**\n   * Index in the data[] array.\n   *\n   * If it's -1, this is a dynamically created container node that isn't stored in\n   * data[] (e.g. when you inject ViewContainerRef) .\n   */\n  index: number;\n  child: null;\n\n  /**\n   * Container nodes will have parents unless:\n   *\n   * - They are the first node of a component or embedded view\n   * - They are dynamically created\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: TView|TView[]|null;\n  projection: null;\n}\n\n/** Static data for an <ng-container> */\nexport interface TElementContainerNode extends TNode {\n  /** Index in the LView[] array. */\n  index: number;\n  child: TElementNode|TTextNode|TContainerNode|TElementContainerNode|TProjectionNode|null;\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an ICU expression */\nexport interface TIcuContainerNode extends TNode {\n  /** Index in the LView[] array. */\n  index: number;\n  child: TElementNode|TTextNode|null;\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n  projection: null;\n  /**\n   * Indicates the current active case for an ICU expression.\n   * It is null when there is no active case.\n   */\n  activeCaseIndex: number|null;\n}\n\n/** Static data for a view  */\nexport interface TViewNode extends TNode {\n  /** If -1, it's a dynamically created view. Otherwise, it is the view block ID. */\n  index: number;\n  child: TElementNode|TTextNode|TElementContainerNode|TContainerNode|TProjectionNode|null;\n  parent: TContainerNode|null;\n  tViews: null;\n  projection: null;\n}\n\n/** Static data for an LProjectionNode  */\nexport interface TProjectionNode extends TNode {\n  /** Index in the data[] array */\n  child: null;\n  /**\n   * Projection nodes will have parents unless they are the first node of a component\n   * or embedded view (which means their parent is in a different view and must be\n   * retrieved using LView.node).\n   */\n  parent: TElementNode|TElementContainerNode|null;\n  tViews: null;\n\n  /** Index of the projection node. (See TNode.projection for more info.) */\n  projection: number;\n}\n\n/**\n * This mapping is necessary so we can set input properties and output listeners\n * properly at runtime when property names are minified or aliased.\n *\n * Key: unminified / public input or output name\n * Value: array containing minified / internal name and related directive index\n *\n * The value must be an array to support inputs and outputs with the same name\n * on the same node.\n */\nexport type PropertyAliases = {\n  // This uses an object map because using the Map type would be too slow\n  [key: string]: PropertyAliasValue\n};\n\n/**\n * Store the runtime input or output names for all the directives.\n *\n * - Even indices: directive index\n * - Odd indices: minified / internal name\n *\n * e.g. [0, 'change-minified']\n */\nexport type PropertyAliasValue = (number | string)[];\n\n\n/**\n * This array contains information about input properties that\n * need to be set once from attribute data. It's ordered by\n * directive index (relative to element) so it's simple to\n * look up a specific directive's initial input data.\n *\n * Within each sub-array:\n *\n * Even indices: minified/internal input name\n * Odd indices: initial value\n *\n * If a directive on a node does not have any input properties\n * that should be set from attributes, its index is set to null\n * to avoid a sparse array.\n *\n * e.g. [null, ['role-min', 'button']]\n */\nexport type InitialInputData = (InitialInputs | null)[];\n\n/**\n * Used by InitialInputData to store input properties\n * that should be set once from attributes.\n *\n * Even indices: minified/internal input name\n * Odd indices: initial value\n *\n * e.g. ['role-min', 'button']\n */\nexport type InitialInputs = string[];\n\n// Note: This hack is necessary so we don't erroneously get a circular dependency\n// failure based on types.\nexport const unusedValueExportToPlacateAjd = 1;\n\n/**\n * Type representing a set of TNodes that can have local refs (`#foo`) placed on them.\n */\nexport type TNodeWithLocalRefs = TContainerNode | TElementNode | TElementContainerNode;\n\n/**\n * Type for a function that extracts a value for a local refs.\n * Example:\n * - `<div #nativeDivEl>` - `nativeDivEl` should point to the native `<div>` element;\n * - `<ng-template #tplRef>` - `tplRef` should point to the `TemplateRef` instance;\n */\nexport type LocalRefExtractor = (tNode: TNodeWithLocalRefs, currentView: LView) => any;\n"]}