@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
@@ -9,7 +9,6 @@
9
9
  * Use of this source code is governed by an MIT-style license that can be
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
- import { assertDefined } from './assert';
13
12
  import { attachPatchData } from './context_discovery';
14
13
  import { callHooks } from './hooks';
15
14
  import { NATIVE, RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1 } from './interfaces/container';
@@ -18,7 +17,7 @@ import { unusedValueExportToPlacateAjd as unused3 } from './interfaces/projectio
18
17
  import { isProceduralRenderer, unusedValueExportToPlacateAjd as unused4 } from './interfaces/renderer';
19
18
  import { CLEANUP, CONTAINER_INDEX, FLAGS, HEADER_OFFSET, HOST_NODE, NEXT, PARENT, QUERIES, RENDERER, TVIEW, unusedValueExportToPlacateAjd as unused5 } from './interfaces/view';
20
19
  import { assertNodeType } from './node_assert';
21
- import { getNativeByTNode, isLContainer, isRootView, readElementValue, stringify } from './util';
20
+ import { findComponentView, getNativeByTNode, isLContainer, isRootView, readElementValue, stringify } from './util';
22
21
  /** @type {?} */
23
22
  const unusedValueToPlacateAjd = unused1 + unused2 + unused3 + unused4 + unused5;
24
23
  /**
@@ -48,7 +47,7 @@ function getFirstParentNative(tNode) {
48
47
  while (parent && parent.type === 5 /* IcuContainer */) {
49
48
  parent = parent.parent;
50
49
  }
51
- return /** @type {?} */ ((parent));
50
+ return (/** @type {?} */ (parent));
52
51
  }
53
52
  /**
54
53
  * Gets the host element given a view. Will return null if the current view is an embedded view,
@@ -58,9 +57,9 @@ function getFirstParentNative(tNode) {
58
57
  */
59
58
  export function getHostNative(currentView) {
60
59
  /** @type {?} */
61
- const hostTNode = /** @type {?} */ (currentView[HOST_NODE]);
60
+ const hostTNode = (/** @type {?} */ (currentView[HOST_NODE]));
62
61
  return hostTNode && hostTNode.type !== 2 /* View */ ?
63
- (/** @type {?} */ (getNativeByTNode(hostTNode, /** @type {?} */ ((currentView[PARENT]))))) :
62
+ ((/** @type {?} */ (getNativeByTNode(hostTNode, (/** @type {?} */ (currentView[PARENT])))))) :
64
63
  null;
65
64
  }
66
65
  /**
@@ -70,13 +69,15 @@ export function getHostNative(currentView) {
70
69
  */
71
70
  export function getLContainer(tNode, embeddedView) {
72
71
  if (tNode.index === -1) {
72
+ // This is a dynamically created view inside a dynamic container.
73
+ // If the host index is -1, the view has not yet been inserted, so it has no parent.
73
74
  /** @type {?} */
74
75
  const containerHostIndex = embeddedView[CONTAINER_INDEX];
75
- return containerHostIndex > -1 ? /** @type {?} */ ((embeddedView[PARENT]))[containerHostIndex] : null;
76
+ return containerHostIndex > -1 ? (/** @type {?} */ (embeddedView[PARENT]))[containerHostIndex] : null;
76
77
  }
77
78
  else {
78
79
  // This is a inline view node (e.g. embeddedViewStart)
79
- return /** @type {?} */ (((embeddedView[PARENT]))[/** @type {?} */ ((tNode.parent)).index]);
80
+ return (/** @type {?} */ ((/** @type {?} */ (embeddedView[PARENT]))[(/** @type {?} */ (tNode.parent)).index]));
80
81
  }
81
82
  }
82
83
  /**
@@ -92,7 +93,7 @@ export function getContainerRenderParent(tViewNode, view) {
92
93
  return container ? container[RENDER_PARENT] : null;
93
94
  }
94
95
  /** @enum {number} */
95
- var WalkTNodeTreeAction = {
96
+ const WalkTNodeTreeAction = {
96
97
  /** node insert in the native environment */
97
98
  Insert: 0,
98
99
  /** node detach from the native environment */
@@ -100,13 +101,14 @@ var WalkTNodeTreeAction = {
100
101
  /** node destruction using the renderer's API */
101
102
  Destroy: 2,
102
103
  };
103
- /** *
104
+ /**
104
105
  * Stack used to keep track of projection nodes in walkTNodeTree.
105
106
  *
106
107
  * This is deliberately created outside of walkTNodeTree to avoid allocating
107
108
  * a new array each time the function is called. Instead the array will be
108
109
  * re-used by each invocation. This works because the function is not reentrant.
109
- @type {?} */
110
+ * @type {?}
111
+ */
110
112
  const projectionNodeStack = [];
111
113
  /**
112
114
  * Walks a tree of TNodes, applying a transformation on the element nodes, either only on the first
@@ -123,13 +125,13 @@ const projectionNodeStack = [];
123
125
  */
124
126
  function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
125
127
  /** @type {?} */
126
- const rootTNode = /** @type {?} */ (viewToWalk[TVIEW].node);
128
+ const rootTNode = (/** @type {?} */ (viewToWalk[TVIEW].node));
127
129
  /** @type {?} */
128
130
  let projectionNodeIndex = -1;
129
131
  /** @type {?} */
130
132
  let currentView = viewToWalk;
131
133
  /** @type {?} */
132
- let tNode = /** @type {?} */ (rootTNode.child);
134
+ let tNode = (/** @type {?} */ (rootTNode.child));
133
135
  while (tNode) {
134
136
  /** @type {?} */
135
137
  let nextTNode = null;
@@ -144,7 +146,7 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
144
146
  }
145
147
  else if (tNode.type === 0 /* Container */) {
146
148
  /** @type {?} */
147
- const lContainer = /** @type {?} */ (((currentView))[tNode.index]);
149
+ const lContainer = (/** @type {?} */ ((/** @type {?} */ (currentView))[tNode.index]));
148
150
  executeNodeAction(action, renderer, renderParent, lContainer[NATIVE], beforeNode);
149
151
  if (renderParent)
150
152
  lContainer[RENDER_PARENT] = renderParent;
@@ -158,18 +160,18 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
158
160
  }
159
161
  else if (tNode.type === 1 /* Projection */) {
160
162
  /** @type {?} */
161
- const componentView = findComponentView(/** @type {?} */ ((currentView)));
163
+ const componentView = findComponentView((/** @type {?} */ (currentView)));
162
164
  /** @type {?} */
163
- const componentHost = /** @type {?} */ (componentView[HOST_NODE]);
165
+ const componentHost = (/** @type {?} */ (componentView[HOST_NODE]));
164
166
  /** @type {?} */
165
- const head = (/** @type {?} */ (componentHost.projection))[/** @type {?} */ (tNode.projection)];
167
+ const head = ((/** @type {?} */ (componentHost.projection)))[(/** @type {?} */ (tNode.projection))];
166
168
  // Must store both the TNode and the view because this projection node could be nested
167
169
  // deeply inside embedded views, and we need to get back down to this particular nested view.
168
170
  projectionNodeStack[++projectionNodeIndex] = tNode;
169
- projectionNodeStack[++projectionNodeIndex] = /** @type {?} */ ((currentView));
171
+ projectionNodeStack[++projectionNodeIndex] = (/** @type {?} */ (currentView));
170
172
  if (head) {
171
- currentView = /** @type {?} */ ((componentView[PARENT]));
172
- nextTNode = /** @type {?} */ (currentView[TVIEW].data[head.index]);
173
+ currentView = (/** @type {?} */ (componentView[PARENT]));
174
+ nextTNode = (/** @type {?} */ (currentView[TVIEW].data[head.index]));
173
175
  }
174
176
  }
175
177
  else {
@@ -178,18 +180,18 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
178
180
  }
179
181
  if (nextTNode === null) {
180
182
  // this last node was projected, we need to get back down to its projection node
181
- if (tNode.next === null && (tNode.flags & 8192 /* isProjected */)) {
182
- currentView = /** @type {?} */ (projectionNodeStack[projectionNodeIndex--]);
183
- tNode = /** @type {?} */ (projectionNodeStack[projectionNodeIndex--]);
183
+ if (tNode.next === null && (tNode.flags & 2 /* isProjected */)) {
184
+ currentView = (/** @type {?} */ (projectionNodeStack[projectionNodeIndex--]));
185
+ tNode = (/** @type {?} */ (projectionNodeStack[projectionNodeIndex--]));
184
186
  }
185
187
  nextTNode = tNode.next;
186
188
  /**
187
- * Find the next node in the TNode tree, taking into account the place where a node is
188
- * projected (in the shadow DOM) rather than where it comes from (in the light DOM).
189
- *
190
- * If there is no sibling node, then it goes to the next sibling of the parent node...
191
- * until it reaches rootNode (at which point null is returned).
192
- */
189
+ * Find the next node in the TNode tree, taking into account the place where a node is
190
+ * projected (in the shadow DOM) rather than where it comes from (in the light DOM).
191
+ *
192
+ * If there is no sibling node, then it goes to the next sibling of the parent node...
193
+ * until it reaches rootNode (at which point null is returned).
194
+ */
193
195
  while (!nextTNode) {
194
196
  // If parent is null, we're crossing the view boundary, so we should get the host TNode.
195
197
  tNode = tNode.parent || currentView[TVIEW].node;
@@ -197,11 +199,11 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
197
199
  return null;
198
200
  // When exiting a container, the beforeNode must be restored to the previous value
199
201
  if (tNode.type === 0 /* Container */) {
200
- currentView = /** @type {?} */ ((currentView[PARENT]));
202
+ currentView = (/** @type {?} */ (currentView[PARENT]));
201
203
  beforeNode = currentView[tNode.index][NATIVE];
202
204
  }
203
205
  if (tNode.type === 2 /* View */ && currentView[NEXT]) {
204
- currentView = /** @type {?} */ (currentView[NEXT]);
206
+ currentView = (/** @type {?} */ (currentView[NEXT]));
205
207
  nextTNode = currentView[TVIEW].node;
206
208
  }
207
209
  else {
@@ -212,22 +214,6 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
212
214
  tNode = nextTNode;
213
215
  }
214
216
  }
215
- /**
216
- * Given a current view, finds the nearest component's host (LElement).
217
- *
218
- * @param {?} lViewData LViewData for which we want a host element node
219
- * @return {?} The host node
220
- */
221
- export function findComponentView(lViewData) {
222
- /** @type {?} */
223
- let rootTNode = lViewData[HOST_NODE];
224
- while (rootTNode && rootTNode.type === 2 /* View */) {
225
- ngDevMode && assertDefined(lViewData[PARENT], 'viewData.parent');
226
- lViewData = /** @type {?} */ ((lViewData[PARENT]));
227
- rootTNode = lViewData[HOST_NODE];
228
- }
229
- return lViewData;
230
- }
231
217
  /**
232
218
  * NOTE: for performance reasons, the possible actions are inlined within the function instead of
233
219
  * being passed as an argument.
@@ -240,16 +226,18 @@ export function findComponentView(lViewData) {
240
226
  */
241
227
  function executeNodeAction(action, renderer, parent, node, beforeNode) {
242
228
  if (action === 0 /* Insert */) {
243
- isProceduralRenderer(/** @type {?} */ ((renderer))) ?
244
- (/** @type {?} */ (renderer)).insertBefore(/** @type {?} */ ((parent)), node, /** @type {?} */ (beforeNode)) : /** @type {?} */ ((parent)).insertBefore(node, /** @type {?} */ (beforeNode), true);
229
+ isProceduralRenderer((/** @type {?} */ (renderer))) ?
230
+ ((/** @type {?} */ (renderer))).insertBefore((/** @type {?} */ (parent)), node, (/** @type {?} */ (beforeNode))) :
231
+ (/** @type {?} */ (parent)).insertBefore(node, (/** @type {?} */ (beforeNode)), true);
245
232
  }
246
233
  else if (action === 1 /* Detach */) {
247
- isProceduralRenderer(/** @type {?} */ ((renderer))) ?
248
- (/** @type {?} */ (renderer)).removeChild(/** @type {?} */ ((parent)), node) : /** @type {?} */ ((parent)).removeChild(node);
234
+ isProceduralRenderer((/** @type {?} */ (renderer))) ?
235
+ ((/** @type {?} */ (renderer))).removeChild((/** @type {?} */ (parent)), node) :
236
+ (/** @type {?} */ (parent)).removeChild(node);
249
237
  }
250
238
  else if (action === 2 /* Destroy */) {
251
- ngDevMode && ngDevMode.rendererDestroyNode++; /** @type {?} */
252
- (((/** @type {?} */ (renderer)).destroyNode))(node);
239
+ ngDevMode && ngDevMode.rendererDestroyNode++;
240
+ (/** @type {?} */ (((/** @type {?} */ (renderer))).destroyNode))(node);
253
241
  }
254
242
  }
255
243
  /**
@@ -269,8 +257,8 @@ export function createTextNode(value, renderer) {
269
257
  */
270
258
  export function addRemoveViewFromContainer(viewToWalk, insertMode, beforeNode) {
271
259
  /** @type {?} */
272
- const renderParent = getContainerRenderParent(/** @type {?} */ (viewToWalk[TVIEW].node), viewToWalk);
273
- ngDevMode && assertNodeType(/** @type {?} */ (viewToWalk[TVIEW].node), 2 /* View */);
260
+ const renderParent = getContainerRenderParent((/** @type {?} */ (viewToWalk[TVIEW].node)), viewToWalk);
261
+ ngDevMode && assertNodeType((/** @type {?} */ (viewToWalk[TVIEW].node)), 2 /* View */);
274
262
  if (renderParent) {
275
263
  /** @type {?} */
276
264
  const renderer = viewToWalk[RENDERER];
@@ -302,26 +290,28 @@ export function destroyViewTree(rootView) {
302
290
  /** @type {?} */
303
291
  let next = null;
304
292
  if (viewOrContainer.length >= HEADER_OFFSET) {
293
+ // If LView, traverse down to child.
305
294
  /** @type {?} */
306
- const view = /** @type {?} */ (viewOrContainer);
295
+ const view = (/** @type {?} */ (viewOrContainer));
307
296
  if (view[TVIEW].childIndex > -1)
308
297
  next = getLViewChild(view);
309
298
  }
310
299
  else {
300
+ // If container, traverse down to its first LView.
311
301
  /** @type {?} */
312
- const container = /** @type {?} */ (viewOrContainer);
302
+ const container = (/** @type {?} */ (viewOrContainer));
313
303
  if (container[VIEWS].length)
314
304
  next = container[VIEWS][0];
315
305
  }
316
306
  if (next == null) {
317
307
  // Only clean up view when moving to the side or up, as destroy hooks
318
308
  // should be called in order from the bottom up.
319
- while (viewOrContainer && !/** @type {?} */ ((viewOrContainer))[NEXT] && viewOrContainer !== rootView) {
309
+ while (viewOrContainer && !(/** @type {?} */ (viewOrContainer))[NEXT] && viewOrContainer !== rootView) {
320
310
  cleanUpView(viewOrContainer);
321
311
  viewOrContainer = getParentState(viewOrContainer, rootView);
322
312
  }
323
313
  cleanUpView(viewOrContainer || rootView);
324
- next = viewOrContainer && /** @type {?} */ ((viewOrContainer))[NEXT];
314
+ next = viewOrContainer && (/** @type {?} */ (viewOrContainer))[NEXT];
325
315
  }
326
316
  viewOrContainer = next;
327
317
  }
@@ -364,10 +354,10 @@ export function insertView(lView, lContainer, parentView, index, containerIndex)
364
354
  }
365
355
  // Notify query that a new view has been added
366
356
  if (lView[QUERIES]) {
367
- /** @type {?} */ ((lView[QUERIES])).insertView(index);
357
+ (/** @type {?} */ (lView[QUERIES])).insertView(index);
368
358
  }
369
359
  // Sets the attached flag
370
- lView[FLAGS] |= 8 /* Attached */;
360
+ lView[FLAGS] |= 16 /* Attached */;
371
361
  }
372
362
  /**
373
363
  * Detaches a view from a container.
@@ -378,7 +368,7 @@ export function insertView(lView, lContainer, parentView, index, containerIndex)
378
368
  * @param {?} lContainer The container from which to detach a view
379
369
  * @param {?} removeIndex The index of the view to detach
380
370
  * @param {?} detached Whether or not this view is already detached.
381
- * @return {?}
371
+ * @return {?} Detached LView instance.
382
372
  */
383
373
  export function detachView(lContainer, removeIndex, detached) {
384
374
  /** @type {?} */
@@ -386,19 +376,20 @@ export function detachView(lContainer, removeIndex, detached) {
386
376
  /** @type {?} */
387
377
  const viewToDetach = views[removeIndex];
388
378
  if (removeIndex > 0) {
389
- views[removeIndex - 1][NEXT] = /** @type {?} */ (viewToDetach[NEXT]);
379
+ views[removeIndex - 1][NEXT] = (/** @type {?} */ (viewToDetach[NEXT]));
390
380
  }
391
381
  views.splice(removeIndex, 1);
392
382
  if (!detached) {
393
383
  addRemoveViewFromContainer(viewToDetach, false);
394
384
  }
395
385
  if (viewToDetach[QUERIES]) {
396
- /** @type {?} */ ((viewToDetach[QUERIES])).removeView();
386
+ (/** @type {?} */ (viewToDetach[QUERIES])).removeView();
397
387
  }
398
388
  viewToDetach[CONTAINER_INDEX] = -1;
399
389
  viewToDetach[PARENT] = null;
400
390
  // Unsets the attached flag
401
- viewToDetach[FLAGS] &= ~8 /* Attached */;
391
+ viewToDetach[FLAGS] &= ~16 /* Attached */;
392
+ return viewToDetach;
402
393
  }
403
394
  /**
404
395
  * Removes a view from a container, i.e. detaches it and then destroys the underlying LView.
@@ -415,14 +406,14 @@ export function removeView(lContainer, containerHost, removeIndex) {
415
406
  destroyLView(view);
416
407
  }
417
408
  /**
418
- * Gets the child of the given LViewData
419
- * @param {?} viewData
409
+ * Gets the child of the given LView
410
+ * @param {?} lView
420
411
  * @return {?}
421
412
  */
422
- export function getLViewChild(viewData) {
413
+ export function getLViewChild(lView) {
423
414
  /** @type {?} */
424
- const childIndex = viewData[TVIEW].childIndex;
425
- return childIndex === -1 ? null : viewData[childIndex];
415
+ const childIndex = lView[TVIEW].childIndex;
416
+ return childIndex === -1 ? null : lView[childIndex];
426
417
  }
427
418
  /**
428
419
  * A standalone function which destroys an LView,
@@ -439,7 +430,7 @@ export function destroyLView(view) {
439
430
  }
440
431
  destroyViewTree(view);
441
432
  // Sets the destroyed flag
442
- view[FLAGS] |= 32 /* Destroyed */;
433
+ view[FLAGS] |= 64 /* Destroyed */;
443
434
  }
444
435
  /**
445
436
  * Determines which LViewOrLContainer to jump to when traversing back up the
@@ -456,11 +447,11 @@ export function destroyLView(view) {
456
447
  export function getParentState(state, rootView) {
457
448
  /** @type {?} */
458
449
  let tNode;
459
- if (state.length >= HEADER_OFFSET && (tNode = /** @type {?} */ (((/** @type {?} */ (state))))[HOST_NODE]) &&
450
+ if (state.length >= HEADER_OFFSET && (tNode = (/** @type {?} */ (((/** @type {?} */ (state)))))[HOST_NODE]) &&
460
451
  tNode.type === 2 /* View */) {
461
452
  // if it's an embedded view, the state needs to go up to the container, in case the
462
453
  // container has a next
463
- return /** @type {?} */ (getLContainer(/** @type {?} */ (tNode), /** @type {?} */ (state)));
454
+ return (/** @type {?} */ (getLContainer((/** @type {?} */ (tNode)), (/** @type {?} */ (state)))));
464
455
  }
465
456
  else {
466
457
  // otherwise, use parent view for containers or component views
@@ -468,55 +459,81 @@ export function getParentState(state, rootView) {
468
459
  }
469
460
  }
470
461
  /**
471
- * Removes all listeners and call all onDestroys in a given view.
462
+ * Calls onDestroys hooks for all directives and pipes in a given view and then removes all
463
+ * listeners. Listeners are removed as the last step so events delivered in the onDestroys hooks
464
+ * can be propagated to \@Output listeners.
472
465
  *
473
466
  * @param {?} viewOrContainer
474
467
  * @return {?}
475
468
  */
476
469
  function cleanUpView(viewOrContainer) {
477
- if ((/** @type {?} */ (viewOrContainer)).length >= HEADER_OFFSET) {
470
+ if (((/** @type {?} */ (viewOrContainer))).length >= HEADER_OFFSET) {
478
471
  /** @type {?} */
479
- const view = /** @type {?} */ (viewOrContainer);
480
- removeListeners(view);
472
+ const view = (/** @type {?} */ (viewOrContainer));
481
473
  executeOnDestroys(view);
482
474
  executePipeOnDestroys(view);
475
+ removeListeners(view);
476
+ /** @type {?} */
477
+ const hostTNode = view[HOST_NODE];
483
478
  // For component views only, the local renderer is destroyed as clean up time.
484
- if (view[TVIEW].id === -1 && isProceduralRenderer(view[RENDERER])) {
479
+ if (hostTNode && hostTNode.type === 3 /* Element */ && isProceduralRenderer(view[RENDERER])) {
485
480
  ngDevMode && ngDevMode.rendererDestroy++;
486
- (/** @type {?} */ (view[RENDERER])).destroy();
481
+ ((/** @type {?} */ (view[RENDERER]))).destroy();
487
482
  }
488
483
  }
489
484
  }
490
485
  /**
491
486
  * Removes listeners and unsubscribes from output subscriptions
492
- * @param {?} viewData
487
+ * @param {?} lView
493
488
  * @return {?}
494
489
  */
495
- function removeListeners(viewData) {
490
+ function removeListeners(lView) {
496
491
  /** @type {?} */
497
- const cleanup = /** @type {?} */ ((viewData[TVIEW].cleanup));
498
- if (cleanup != null) {
499
- for (let i = 0; i < cleanup.length - 1; i += 2) {
500
- if (typeof cleanup[i] === 'string') {
492
+ const tCleanup = (/** @type {?} */ (lView[TVIEW].cleanup));
493
+ if (tCleanup != null) {
494
+ /** @type {?} */
495
+ const lCleanup = (/** @type {?} */ (lView[CLEANUP]));
496
+ for (let i = 0; i < tCleanup.length - 1; i += 2) {
497
+ if (typeof tCleanup[i] === 'string') {
498
+ // This is a listener with the native renderer
499
+ /** @type {?} */
500
+ const idx = tCleanup[i + 1];
501
501
  /** @type {?} */
502
- const native = readElementValue(viewData[cleanup[i + 1]]);
502
+ const listener = lCleanup[tCleanup[i + 2]];
503
503
  /** @type {?} */
504
- const listener = /** @type {?} */ ((viewData[CLEANUP]))[cleanup[i + 2]];
505
- native.removeEventListener(cleanup[i], listener, cleanup[i + 3]);
504
+ const native = readElementValue(lView[idx]);
505
+ /** @type {?} */
506
+ const useCaptureOrSubIdx = tCleanup[i + 3];
507
+ if (typeof useCaptureOrSubIdx === 'boolean') {
508
+ // DOM listener
509
+ native.removeEventListener(tCleanup[i], listener, useCaptureOrSubIdx);
510
+ }
511
+ else {
512
+ if (useCaptureOrSubIdx >= 0) {
513
+ // unregister
514
+ lCleanup[useCaptureOrSubIdx]();
515
+ }
516
+ else {
517
+ // Subscription
518
+ lCleanup[-useCaptureOrSubIdx].unsubscribe();
519
+ }
520
+ }
506
521
  i += 2;
507
522
  }
508
- else if (typeof cleanup[i] === 'number') {
523
+ else if (typeof tCleanup[i] === 'number') {
524
+ // This is a listener with renderer2 (cleanup fn can be found by index)
509
525
  /** @type {?} */
510
- const cleanupFn = /** @type {?} */ ((viewData[CLEANUP]))[cleanup[i]];
526
+ const cleanupFn = lCleanup[tCleanup[i]];
511
527
  cleanupFn();
512
528
  }
513
529
  else {
530
+ // This is a cleanup function that is grouped with the index of its context
514
531
  /** @type {?} */
515
- const context = /** @type {?} */ ((viewData[CLEANUP]))[cleanup[i + 1]];
516
- cleanup[i].call(context);
532
+ const context = lCleanup[tCleanup[i + 1]];
533
+ tCleanup[i].call(context);
517
534
  }
518
535
  }
519
- viewData[CLEANUP] = null;
536
+ lView[CLEANUP] = null;
520
537
  }
521
538
  }
522
539
  /**
@@ -535,14 +552,14 @@ function executeOnDestroys(view) {
535
552
  }
536
553
  /**
537
554
  * Calls pipe destroy hooks for this view
538
- * @param {?} viewData
555
+ * @param {?} lView
539
556
  * @return {?}
540
557
  */
541
- function executePipeOnDestroys(viewData) {
558
+ function executePipeOnDestroys(lView) {
542
559
  /** @type {?} */
543
- const pipeDestroyHooks = viewData[TVIEW] && viewData[TVIEW].pipeDestroyHooks;
560
+ const pipeDestroyHooks = lView[TVIEW] && lView[TVIEW].pipeDestroyHooks;
544
561
  if (pipeDestroyHooks) {
545
- callHooks(/** @type {?} */ ((viewData)), pipeDestroyHooks);
562
+ callHooks((/** @type {?} */ (lView)), pipeDestroyHooks);
546
563
  }
547
564
  }
548
565
  /**
@@ -565,8 +582,9 @@ export function getRenderParent(tNode, currentView) {
565
582
  if (tNodeParent != null && tNodeParent.type === 4 /* ElementContainer */) {
566
583
  tNode = getHighestElementContainer(tNodeParent);
567
584
  }
568
- return tNode.parent == null && /** @type {?} */ ((hostTNode)).type === 2 /* View */ ?
569
- getContainerRenderParent(/** @type {?} */ (hostTNode), currentView) : /** @type {?} */ (getParentNative(tNode, currentView));
585
+ return tNode.parent == null && (/** @type {?} */ (hostTNode)).type === 2 /* View */ ?
586
+ getContainerRenderParent((/** @type {?} */ (hostTNode)), currentView) :
587
+ (/** @type {?} */ (getParentNative(tNode, currentView)));
570
588
  }
571
589
  return null;
572
590
  }
@@ -581,7 +599,7 @@ function canInsertNativeChildOfElement(tNode) {
581
599
  if (tNode.parent == null ||
582
600
  // We should also eagerly insert if the parent is a regular, non-component element
583
601
  // since we know that this relationship will never be broken.
584
- tNode.parent.type === 3 /* Element */ && !(tNode.parent.flags & 4096 /* isComponent */)) {
602
+ tNode.parent.type === 3 /* Element */ && !(tNode.parent.flags & 1 /* isComponent */)) {
585
603
  return true;
586
604
  }
587
605
  // Parent is a Component. Component's content nodes are not inserted immediately
@@ -604,8 +622,9 @@ function canInsertNativeChildOfElement(tNode) {
604
622
  * @return {?}
605
623
  */
606
624
  function canInsertNativeChildOfView(viewTNode, view) {
625
+ // Because we are inserting into a `View` the `View` may be disconnected.
607
626
  /** @type {?} */
608
- const container = /** @type {?} */ ((getLContainer(viewTNode, view)));
627
+ const container = (/** @type {?} */ (getLContainer(viewTNode, view)));
609
628
  if (container == null || container[RENDER_PARENT] == null) {
610
629
  // The `View` is not inserted into a `Container` or the parent `Container`
611
630
  // itself is disconnected. So we have to delay.
@@ -650,7 +669,7 @@ export function canInsertNativeNode(tNode, currentView) {
650
669
  if (parent === null)
651
670
  parent = currentView[HOST_NODE];
652
671
  if (parent && parent.type === 2 /* View */) {
653
- return canInsertNativeChildOfView(/** @type {?} */ (parent), currentView);
672
+ return canInsertNativeChildOfView((/** @type {?} */ (parent)), currentView);
654
673
  }
655
674
  else {
656
675
  // Parent is a regular element or a component
@@ -682,7 +701,7 @@ export function nativeInsertBefore(renderer, parent, child, beforeNode) {
682
701
  * @return {?}
683
702
  */
684
703
  export function nativeParentNode(renderer, node) {
685
- return /** @type {?} */ ((isProceduralRenderer(renderer) ? renderer.parentNode(node) : node.parentNode));
704
+ return (/** @type {?} */ ((isProceduralRenderer(renderer) ? renderer.parentNode(node) : node.parentNode)));
686
705
  }
687
706
  /**
688
707
  * Returns a native sibling of a given native node.
@@ -710,28 +729,29 @@ export function appendChild(childEl = null, childTNode, currentView) {
710
729
  /** @type {?} */
711
730
  const parentEl = getParentNative(childTNode, currentView);
712
731
  /** @type {?} */
713
- const parentTNode = childTNode.parent || /** @type {?} */ ((currentView[HOST_NODE]));
732
+ const parentTNode = childTNode.parent || (/** @type {?} */ (currentView[HOST_NODE]));
714
733
  if (parentTNode.type === 2 /* View */) {
715
734
  /** @type {?} */
716
- const lContainer = /** @type {?} */ (getLContainer(/** @type {?} */ (parentTNode), currentView));
735
+ const lContainer = (/** @type {?} */ (getLContainer((/** @type {?} */ (parentTNode)), currentView)));
717
736
  /** @type {?} */
718
737
  const views = lContainer[VIEWS];
719
738
  /** @type {?} */
720
739
  const index = views.indexOf(currentView);
721
- nativeInsertBefore(renderer, /** @type {?} */ ((lContainer[RENDER_PARENT])), childEl, getBeforeNodeForView(index, views, lContainer[NATIVE]));
740
+ nativeInsertBefore(renderer, (/** @type {?} */ (lContainer[RENDER_PARENT])), childEl, getBeforeNodeForView(index, views, lContainer[NATIVE]));
722
741
  }
723
742
  else if (parentTNode.type === 4 /* ElementContainer */) {
724
743
  /** @type {?} */
725
- const renderParent = /** @type {?} */ ((getRenderParent(childTNode, currentView)));
744
+ const renderParent = (/** @type {?} */ (getRenderParent(childTNode, currentView)));
726
745
  nativeInsertBefore(renderer, renderParent, childEl, parentEl);
727
746
  }
728
747
  else if (parentTNode.type === 5 /* IcuContainer */) {
729
748
  /** @type {?} */
730
- const icuAnchorNode = /** @type {?} */ (((getNativeByTNode(/** @type {?} */ ((childTNode.parent)), currentView))));
731
- nativeInsertBefore(renderer, /** @type {?} */ (parentEl), childEl, icuAnchorNode);
749
+ const icuAnchorNode = (/** @type {?} */ ((/** @type {?} */ (getNativeByTNode((/** @type {?} */ (childTNode.parent)), currentView)))));
750
+ nativeInsertBefore(renderer, (/** @type {?} */ (parentEl)), childEl, icuAnchorNode);
732
751
  }
733
752
  else {
734
- isProceduralRenderer(renderer) ? renderer.appendChild(/** @type {?} */ (((parentEl))), childEl) : /** @type {?} */ ((parentEl)).appendChild(childEl);
753
+ isProceduralRenderer(renderer) ? renderer.appendChild((/** @type {?} */ ((/** @type {?} */ (parentEl)))), childEl) :
754
+ (/** @type {?} */ (parentEl)).appendChild(childEl);
735
755
  }
736
756
  return true;
737
757
  }
@@ -758,9 +778,9 @@ function getHighestElementContainer(ngContainer) {
758
778
  export function getBeforeNodeForView(index, views, containerNative) {
759
779
  if (index + 1 < views.length) {
760
780
  /** @type {?} */
761
- const view = /** @type {?} */ (views[index + 1]);
781
+ const view = (/** @type {?} */ (views[index + 1]));
762
782
  /** @type {?} */
763
- const viewTNode = /** @type {?} */ (view[HOST_NODE]);
783
+ const viewTNode = (/** @type {?} */ (view[HOST_NODE]));
764
784
  return viewTNode.child ? getNativeByTNode(viewTNode.child, view) : containerNative;
765
785
  }
766
786
  else {
@@ -779,10 +799,11 @@ export function removeChild(childTNode, childEl, currentView) {
779
799
  // We only remove the element if not in View or not projected.
780
800
  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {
781
801
  /** @type {?} */
782
- const parentNative = /** @type {?} */ (((getParentNative(childTNode, currentView))));
802
+ const parentNative = (/** @type {?} */ ((/** @type {?} */ (getParentNative(childTNode, currentView)))));
783
803
  /** @type {?} */
784
804
  const renderer = currentView[RENDERER];
785
- isProceduralRenderer(renderer) ? renderer.removeChild(/** @type {?} */ (parentNative), childEl) : /** @type {?} */ ((parentNative)).removeChild(childEl);
805
+ isProceduralRenderer(renderer) ? renderer.removeChild((/** @type {?} */ (parentNative)), childEl) :
806
+ (/** @type {?} */ (parentNative)).removeChild(childEl);
786
807
  return true;
787
808
  }
788
809
  return false;
@@ -825,7 +846,7 @@ export function appendProjectedNode(projectedTNode, tProjectionNode, currentView
825
846
  else {
826
847
  if (projectedTNode.type === 4 /* ElementContainer */) {
827
848
  /** @type {?} */
828
- let ngContainerChildTNode = /** @type {?} */ (projectedTNode.child);
849
+ let ngContainerChildTNode = (/** @type {?} */ (projectedTNode.child));
829
850
  while (ngContainerChildTNode) {
830
851
  appendProjectedNode(ngContainerChildTNode, tProjectionNode, currentView, projectionView);
831
852
  ngContainerChildTNode = ngContainerChildTNode.next;
@@ -837,5 +858,4 @@ export function appendProjectedNode(projectedTNode, tProjectionNode, currentView
837
858
  }
838
859
  }
839
860
  }
840
-
841
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node_manipulation.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/node_manipulation.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {assertDefined} from './assert';\nimport {attachPatchData} from './context_discovery';\nimport {callHooks} from './hooks';\nimport {LContainer, NATIVE, RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1} from './interfaces/container';\nimport {TContainerNode, TElementContainerNode, TElementNode, TNode, TNodeFlags, TNodeType, TViewNode, unusedValueExportToPlacateAjd as unused2} from './interfaces/node';\nimport {unusedValueExportToPlacateAjd as unused3} from './interfaces/projection';\nimport {ProceduralRenderer3, RComment, RElement, RNode, RText, Renderer3, isProceduralRenderer, unusedValueExportToPlacateAjd as unused4} from './interfaces/renderer';\nimport {CLEANUP, CONTAINER_INDEX, FLAGS, HEADER_OFFSET, HOST_NODE, HookData, LViewData, LViewFlags, NEXT, PARENT, QUERIES, RENDERER, TVIEW, unusedValueExportToPlacateAjd as unused5} from './interfaces/view';\nimport {assertNodeType} from './node_assert';\nimport {getNativeByTNode, isLContainer, isRootView, readElementValue, stringify} from './util';\n\nconst unusedValueToPlacateAjd = unused1 + unused2 + unused3 + unused4 + unused5;\n\n/** Retrieves the parent element of a given node. */\nexport function getParentNative(tNode: TNode, currentView: LViewData): RElement|RComment|null {\n  if (tNode.parent == null) {\n    return getHostNative(currentView);\n  } else {\n    const parentTNode = getFirstParentNative(tNode);\n    return getNativeByTNode(parentTNode, currentView);\n  }\n}\n\n/**\n * Get the first parent of a node that isn't an IcuContainer TNode\n */\nfunction getFirstParentNative(tNode: TNode): TNode {\n  let parent = tNode.parent;\n  while (parent && parent.type === TNodeType.IcuContainer) {\n    parent = parent.parent;\n  }\n  return parent !;\n}\n\n/**\n * Gets the host element given a view. Will return null if the current view is an embedded view,\n * which does not have a host element.\n */\nexport function getHostNative(currentView: LViewData): RElement|null {\n  const hostTNode = currentView[HOST_NODE] as TElementNode;\n  return hostTNode && hostTNode.type !== TNodeType.View ?\n      (getNativeByTNode(hostTNode, currentView[PARENT] !) as RElement) :\n      null;\n}\n\nexport function getLContainer(tNode: TViewNode, embeddedView: LViewData): LContainer|null {\n  if (tNode.index === -1) {\n    // This is a dynamically created view inside a dynamic container.\n    // If the host index is -1, the view has not yet been inserted, so it has no parent.\n    const containerHostIndex = embeddedView[CONTAINER_INDEX];\n    return containerHostIndex > -1 ? embeddedView[PARENT] ![containerHostIndex] : null;\n  } else {\n    // This is a inline view node (e.g. embeddedViewStart)\n    return embeddedView[PARENT] ![tNode.parent !.index] as LContainer;\n  }\n}\n\n\n/**\n * Retrieves render parent for a given view.\n * Might be null if a view is not yet attached to any container.\n */\nexport function getContainerRenderParent(tViewNode: TViewNode, view: LViewData): RElement|null {\n  const container = getLContainer(tViewNode, view);\n  return container ? container[RENDER_PARENT] : null;\n}\n\nconst enum WalkTNodeTreeAction {\n  /** node insert in the native environment */\n  Insert = 0,\n\n  /** node detach from the native environment */\n  Detach = 1,\n\n  /** node destruction using the renderer's API */\n  Destroy = 2,\n}\n\n\n/**\n * Stack used to keep track of projection nodes in walkTNodeTree.\n *\n * This is deliberately created outside of walkTNodeTree to avoid allocating\n * a new array each time the function is called. Instead the array will be\n * re-used by each invocation. This works because the function is not reentrant.\n */\nconst projectionNodeStack: (LViewData | TNode)[] = [];\n\n/**\n * Walks a tree of TNodes, applying a transformation on the element nodes, either only on the first\n * one found, or on all of them.\n *\n * @param viewToWalk the view to walk\n * @param action identifies the action to be performed on the elements\n * @param renderer the current renderer.\n * @param renderParent Optional the render parent node to be set in all LContainers found,\n * required for action modes Insert and Destroy.\n * @param beforeNode Optional the node before which elements should be added, required for action\n * Insert.\n */\nfunction walkTNodeTree(\n    viewToWalk: LViewData, action: WalkTNodeTreeAction, renderer: Renderer3,\n    renderParent: RElement | null, beforeNode?: RNode | null) {\n  const rootTNode = viewToWalk[TVIEW].node as TViewNode;\n  let projectionNodeIndex = -1;\n  let currentView = viewToWalk;\n  let tNode: TNode|null = rootTNode.child as TNode;\n  while (tNode) {\n    let nextTNode: TNode|null = null;\n    if (tNode.type === TNodeType.Element) {\n      executeNodeAction(\n          action, renderer, renderParent, getNativeByTNode(tNode, currentView), beforeNode);\n      const nodeOrContainer = currentView[tNode.index];\n      if (isLContainer(nodeOrContainer)) {\n        // This element has an LContainer, and its comment needs to be handled\n        executeNodeAction(action, renderer, renderParent, nodeOrContainer[NATIVE], beforeNode);\n      }\n    } else if (tNode.type === TNodeType.Container) {\n      const lContainer = currentView ![tNode.index] as LContainer;\n      executeNodeAction(action, renderer, renderParent, lContainer[NATIVE], beforeNode);\n\n      if (renderParent) lContainer[RENDER_PARENT] = renderParent;\n\n      if (lContainer[VIEWS].length) {\n        currentView = lContainer[VIEWS][0];\n        nextTNode = currentView[TVIEW].node;\n\n        // When the walker enters a container, then the beforeNode has to become the local native\n        // comment node.\n        beforeNode = lContainer[NATIVE];\n      }\n    } else if (tNode.type === TNodeType.Projection) {\n      const componentView = findComponentView(currentView !);\n      const componentHost = componentView[HOST_NODE] as TElementNode;\n      const head: TNode|null =\n          (componentHost.projection as(TNode | null)[])[tNode.projection as number];\n\n      // Must store both the TNode and the view because this projection node could be nested\n      // deeply inside embedded views, and we need to get back down to this particular nested view.\n      projectionNodeStack[++projectionNodeIndex] = tNode;\n      projectionNodeStack[++projectionNodeIndex] = currentView !;\n      if (head) {\n        currentView = componentView[PARENT] !;\n        nextTNode = currentView[TVIEW].data[head.index] as TNode;\n      }\n    } else {\n      // Otherwise, this is a View or an ElementContainer\n      nextTNode = tNode.child;\n    }\n\n    if (nextTNode === null) {\n      // this last node was projected, we need to get back down to its projection node\n      if (tNode.next === null && (tNode.flags & TNodeFlags.isProjected)) {\n        currentView = projectionNodeStack[projectionNodeIndex--] as LViewData;\n        tNode = projectionNodeStack[projectionNodeIndex--] as TNode;\n      }\n      nextTNode = tNode.next;\n\n      /**\n       * Find the next node in the TNode tree, taking into account the place where a node is\n       * projected (in the shadow DOM) rather than where it comes from (in the light DOM).\n       *\n       * If there is no sibling node, then it goes to the next sibling of the parent node...\n       * until it reaches rootNode (at which point null is returned).\n       */\n      while (!nextTNode) {\n        // If parent is null, we're crossing the view boundary, so we should get the host TNode.\n        tNode = tNode.parent || currentView[TVIEW].node;\n\n        if (tNode === null || tNode === rootTNode) return null;\n\n        // When exiting a container, the beforeNode must be restored to the previous value\n        if (tNode.type === TNodeType.Container) {\n          currentView = currentView[PARENT] !;\n          beforeNode = currentView[tNode.index][NATIVE];\n        }\n\n        if (tNode.type === TNodeType.View && currentView[NEXT]) {\n          currentView = currentView[NEXT] as LViewData;\n          nextTNode = currentView[TVIEW].node;\n        } else {\n          nextTNode = tNode.next;\n        }\n      }\n    }\n    tNode = nextTNode;\n  }\n}\n\n/**\n * Given a current view, finds the nearest component's host (LElement).\n *\n * @param lViewData LViewData for which we want a host element node\n * @returns The host node\n */\nexport function findComponentView(lViewData: LViewData): LViewData {\n  let rootTNode = lViewData[HOST_NODE];\n\n  while (rootTNode && rootTNode.type === TNodeType.View) {\n    ngDevMode && assertDefined(lViewData[PARENT], 'viewData.parent');\n    lViewData = lViewData[PARENT] !;\n    rootTNode = lViewData[HOST_NODE];\n  }\n\n  return lViewData;\n}\n\n/**\n * NOTE: for performance reasons, the possible actions are inlined within the function instead of\n * being passed as an argument.\n */\nfunction executeNodeAction(\n    action: WalkTNodeTreeAction, renderer: Renderer3, parent: RElement | null,\n    node: RComment | RElement | RText, beforeNode?: RNode | null) {\n  if (action === WalkTNodeTreeAction.Insert) {\n    isProceduralRenderer(renderer !) ?\n        (renderer as ProceduralRenderer3).insertBefore(parent !, node, beforeNode as RNode | null) :\n        parent !.insertBefore(node, beforeNode as RNode | null, true);\n  } else if (action === WalkTNodeTreeAction.Detach) {\n    isProceduralRenderer(renderer !) ?\n        (renderer as ProceduralRenderer3).removeChild(parent !, node) :\n        parent !.removeChild(node);\n  } else if (action === WalkTNodeTreeAction.Destroy) {\n    ngDevMode && ngDevMode.rendererDestroyNode++;\n    (renderer as ProceduralRenderer3).destroyNode !(node);\n  }\n}\n\nexport function createTextNode(value: any, renderer: Renderer3): RText {\n  return isProceduralRenderer(renderer) ? renderer.createText(stringify(value)) :\n                                          renderer.createTextNode(stringify(value));\n}\n\n/**\n * Adds or removes all DOM elements associated with a view.\n *\n * Because some root nodes of the view may be containers, we sometimes need\n * to propagate deeply into the nested containers to remove all elements in the\n * views beneath it.\n *\n * @param viewToWalk The view from which elements should be added or removed\n * @param insertMode Whether or not elements should be added (if false, removing)\n * @param beforeNode The node before which elements should be added, if insert mode\n */\nexport function addRemoveViewFromContainer(\n    viewToWalk: LViewData, insertMode: true, beforeNode: RNode | null): void;\nexport function addRemoveViewFromContainer(viewToWalk: LViewData, insertMode: false): void;\nexport function addRemoveViewFromContainer(\n    viewToWalk: LViewData, insertMode: boolean, beforeNode?: RNode | null): void {\n  const renderParent = getContainerRenderParent(viewToWalk[TVIEW].node as TViewNode, viewToWalk);\n  ngDevMode && assertNodeType(viewToWalk[TVIEW].node as TNode, TNodeType.View);\n  if (renderParent) {\n    const renderer = viewToWalk[RENDERER];\n    walkTNodeTree(\n        viewToWalk, insertMode ? WalkTNodeTreeAction.Insert : WalkTNodeTreeAction.Detach, renderer,\n        renderParent, beforeNode);\n  }\n}\n\n/**\n * Traverses down and up the tree of views and containers to remove listeners and\n * call onDestroy callbacks.\n *\n * Notes:\n *  - Because it's used for onDestroy calls, it needs to be bottom-up.\n *  - Must process containers instead of their views to avoid splicing\n *  when views are destroyed and re-added.\n *  - Using a while loop because it's faster than recursion\n *  - Destroy only called on movement to sibling or movement to parent (laterally or up)\n *\n *  @param rootView The view to destroy\n */\nexport function destroyViewTree(rootView: LViewData): void {\n  // If the view has no children, we can clean it up and return early.\n  if (rootView[TVIEW].childIndex === -1) {\n    return cleanUpView(rootView);\n  }\n  let viewOrContainer: LViewData|LContainer|null = getLViewChild(rootView);\n\n  while (viewOrContainer) {\n    let next: LViewData|LContainer|null = null;\n\n    if (viewOrContainer.length >= HEADER_OFFSET) {\n      // If LViewData, traverse down to child.\n      const view = viewOrContainer as LViewData;\n      if (view[TVIEW].childIndex > -1) next = getLViewChild(view);\n    } else {\n      // If container, traverse down to its first LViewData.\n      const container = viewOrContainer as LContainer;\n      if (container[VIEWS].length) next = container[VIEWS][0];\n    }\n\n    if (next == null) {\n      // Only clean up view when moving to the side or up, as destroy hooks\n      // should be called in order from the bottom up.\n      while (viewOrContainer && !viewOrContainer ![NEXT] && viewOrContainer !== rootView) {\n        cleanUpView(viewOrContainer);\n        viewOrContainer = getParentState(viewOrContainer, rootView);\n      }\n      cleanUpView(viewOrContainer || rootView);\n      next = viewOrContainer && viewOrContainer ![NEXT];\n    }\n    viewOrContainer = next;\n  }\n}\n\n/**\n * Inserts a view into a container.\n *\n * This adds the view to the container's array of active views in the correct\n * position. It also adds the view's elements to the DOM if the container isn't a\n * root node of another view (in that case, the view's elements will be added when\n * the container's parent view is added later).\n *\n * @param lView The view to insert\n * @param lContainer The container into which the view should be inserted\n * @param parentView The new parent of the inserted view\n * @param index The index at which to insert the view\n * @param containerIndex The index of the container node, if dynamic\n */\nexport function insertView(\n    lView: LViewData, lContainer: LContainer, parentView: LViewData, index: number,\n    containerIndex: number) {\n  const views = lContainer[VIEWS];\n\n  if (index > 0) {\n    // This is a new view, we need to add it to the children.\n    views[index - 1][NEXT] = lView;\n  }\n\n  if (index < views.length) {\n    lView[NEXT] = views[index];\n    views.splice(index, 0, lView);\n  } else {\n    views.push(lView);\n    lView[NEXT] = null;\n  }\n\n  // Dynamically inserted views need a reference to their parent container's host so it's\n  // possible to jump from a view to its container's next when walking the node tree.\n  if (containerIndex > -1) {\n    lView[CONTAINER_INDEX] = containerIndex;\n    lView[PARENT] = parentView;\n  }\n\n  // Notify query that a new view has been added\n  if (lView[QUERIES]) {\n    lView[QUERIES] !.insertView(index);\n  }\n\n  // Sets the attached flag\n  lView[FLAGS] |= LViewFlags.Attached;\n}\n\n/**\n * Detaches a view from a container.\n *\n * This method splices the view from the container's array of active views. It also\n * removes the view's elements from the DOM.\n *\n * @param lContainer The container from which to detach a view\n * @param removeIndex The index of the view to detach\n * @param detached Whether or not this view is already detached.\n */\nexport function detachView(lContainer: LContainer, removeIndex: number, detached: boolean) {\n  const views = lContainer[VIEWS];\n  const viewToDetach = views[removeIndex];\n  if (removeIndex > 0) {\n    views[removeIndex - 1][NEXT] = viewToDetach[NEXT] as LViewData;\n  }\n  views.splice(removeIndex, 1);\n  if (!detached) {\n    addRemoveViewFromContainer(viewToDetach, false);\n  }\n\n  if (viewToDetach[QUERIES]) {\n    viewToDetach[QUERIES] !.removeView();\n  }\n  viewToDetach[CONTAINER_INDEX] = -1;\n  viewToDetach[PARENT] = null;\n  // Unsets the attached flag\n  viewToDetach[FLAGS] &= ~LViewFlags.Attached;\n}\n\n/**\n * Removes a view from a container, i.e. detaches it and then destroys the underlying LView.\n *\n * @param lContainer The container from which to remove a view\n * @param tContainer The TContainer node associated with the LContainer\n * @param removeIndex The index of the view to remove\n */\nexport function removeView(\n    lContainer: LContainer, containerHost: TElementNode | TContainerNode | TElementContainerNode,\n    removeIndex: number) {\n  const view = lContainer[VIEWS][removeIndex];\n  detachView(lContainer, removeIndex, !!containerHost.detached);\n  destroyLView(view);\n}\n\n/** Gets the child of the given LViewData */\nexport function getLViewChild(viewData: LViewData): LViewData|LContainer|null {\n  const childIndex = viewData[TVIEW].childIndex;\n  return childIndex === -1 ? null : viewData[childIndex];\n}\n\n/**\n * A standalone function which destroys an LView,\n * conducting cleanup (e.g. removing listeners, calling onDestroys).\n *\n * @param view The view to be destroyed.\n */\nexport function destroyLView(view: LViewData) {\n  const renderer = view[RENDERER];\n  if (isProceduralRenderer(renderer) && renderer.destroyNode) {\n    walkTNodeTree(view, WalkTNodeTreeAction.Destroy, renderer, null);\n  }\n  destroyViewTree(view);\n  // Sets the destroyed flag\n  view[FLAGS] |= LViewFlags.Destroyed;\n}\n\n/**\n * Determines which LViewOrLContainer to jump to when traversing back up the\n * tree in destroyViewTree.\n *\n * Normally, the view's parent LView should be checked, but in the case of\n * embedded views, the container (which is the view node's parent, but not the\n * LView's parent) needs to be checked for a possible next property.\n *\n * @param state The LViewOrLContainer for which we need a parent state\n * @param rootView The rootView, so we don't propagate too far up the view tree\n * @returns The correct parent LViewOrLContainer\n */\nexport function getParentState(state: LViewData | LContainer, rootView: LViewData): LViewData|\n    LContainer|null {\n  let tNode;\n  if (state.length >= HEADER_OFFSET && (tNode = (state as LViewData) ![HOST_NODE]) &&\n      tNode.type === TNodeType.View) {\n    // if it's an embedded view, the state needs to go up to the container, in case the\n    // container has a next\n    return getLContainer(tNode as TViewNode, state as LViewData) as LContainer;\n  } else {\n    // otherwise, use parent view for containers or component views\n    return state[PARENT] === rootView ? null : state[PARENT];\n  }\n}\n\n/**\n * Removes all listeners and call all onDestroys in a given view.\n *\n * @param view The LViewData to clean up\n */\nfunction cleanUpView(viewOrContainer: LViewData | LContainer): void {\n  if ((viewOrContainer as LViewData).length >= HEADER_OFFSET) {\n    const view = viewOrContainer as LViewData;\n    removeListeners(view);\n    executeOnDestroys(view);\n    executePipeOnDestroys(view);\n    // For component views only, the local renderer is destroyed as clean up time.\n    if (view[TVIEW].id === -1 && isProceduralRenderer(view[RENDERER])) {\n      ngDevMode && ngDevMode.rendererDestroy++;\n      (view[RENDERER] as ProceduralRenderer3).destroy();\n    }\n  }\n}\n\n/** Removes listeners and unsubscribes from output subscriptions */\nfunction removeListeners(viewData: LViewData): void {\n  const cleanup = viewData[TVIEW].cleanup !;\n  if (cleanup != null) {\n    for (let i = 0; i < cleanup.length - 1; i += 2) {\n      if (typeof cleanup[i] === 'string') {\n        // This is a listener with the native renderer\n        const native = readElementValue(viewData[cleanup[i + 1]]);\n        const listener = viewData[CLEANUP] ![cleanup[i + 2]];\n        native.removeEventListener(cleanup[i], listener, cleanup[i + 3]);\n        i += 2;\n      } else if (typeof cleanup[i] === 'number') {\n        // This is a listener with renderer2 (cleanup fn can be found by index)\n        const cleanupFn = viewData[CLEANUP] ![cleanup[i]];\n        cleanupFn();\n      } else {\n        // This is a cleanup function that is grouped with the index of its context\n        const context = viewData[CLEANUP] ![cleanup[i + 1]];\n        cleanup[i].call(context);\n      }\n    }\n    viewData[CLEANUP] = null;\n  }\n}\n\n/** Calls onDestroy hooks for this view */\nfunction executeOnDestroys(view: LViewData): void {\n  const tView = view[TVIEW];\n  let destroyHooks: HookData|null;\n  if (tView != null && (destroyHooks = tView.destroyHooks) != null) {\n    callHooks(view, destroyHooks);\n  }\n}\n\n/** Calls pipe destroy hooks for this view */\nfunction executePipeOnDestroys(viewData: LViewData): void {\n  const pipeDestroyHooks = viewData[TVIEW] && viewData[TVIEW].pipeDestroyHooks;\n  if (pipeDestroyHooks) {\n    callHooks(viewData !, pipeDestroyHooks);\n  }\n}\n\nexport function getRenderParent(tNode: TNode, currentView: LViewData): RElement|null {\n  if (canInsertNativeNode(tNode, currentView)) {\n    // If we are asked for a render parent of the root component we need to do low-level DOM\n    // operation as LTree doesn't exist above the topmost host node. We might need to find a render\n    // parent of the topmost host node if the root component injects ViewContainerRef.\n    if (isRootView(currentView)) {\n      return nativeParentNode(currentView[RENDERER], getNativeByTNode(tNode, currentView));\n    }\n\n    const hostTNode = currentView[HOST_NODE];\n\n    const tNodeParent = tNode.parent;\n    if (tNodeParent != null && tNodeParent.type === TNodeType.ElementContainer) {\n      tNode = getHighestElementContainer(tNodeParent);\n    }\n\n    return tNode.parent == null && hostTNode !.type === TNodeType.View ?\n        getContainerRenderParent(hostTNode as TViewNode, currentView) :\n        getParentNative(tNode, currentView) as RElement;\n  }\n  return null;\n}\n\nfunction canInsertNativeChildOfElement(tNode: TNode): boolean {\n  // If the parent is null, then we are inserting across views. This happens when we\n  // insert a root element of the component view into the component host element and it\n  // should always be eager.\n  if (tNode.parent == null ||\n      // We should also eagerly insert if the parent is a regular, non-component element\n      // since we know that this relationship will never be broken.\n      tNode.parent.type === TNodeType.Element && !(tNode.parent.flags & TNodeFlags.isComponent)) {\n    return true;\n  }\n\n  // Parent is a Component. Component's content nodes are not inserted immediately\n  // because they will be projected, and so doing insert at this point would be wasteful.\n  // Since the projection would than move it to its final destination.\n  return false;\n}\n\n/**\n * We might delay insertion of children for a given view if it is disconnected.\n * This might happen for 2 main reasons:\n * - view is not inserted into any container (view was created but not inserted yet)\n * - view is inserted into a container but the container itself is not inserted into the DOM\n * (container might be part of projection or child of a view that is not inserted yet).\n *\n * In other words we can insert children of a given view if this view was inserted into a container\n * and\n * the container itself has its render parent determined.\n */\nfunction canInsertNativeChildOfView(viewTNode: TViewNode, view: LViewData): boolean {\n  // Because we are inserting into a `View` the `View` may be disconnected.\n  const container = getLContainer(viewTNode, view) !;\n  if (container == null || container[RENDER_PARENT] == null) {\n    // The `View` is not inserted into a `Container` or the parent `Container`\n    // itself is disconnected. So we have to delay.\n    return false;\n  }\n\n  // The parent `Container` is in inserted state, so we can eagerly insert into\n  // this location.\n  return true;\n}\n\n/**\n * Returns whether a native element can be inserted into the given parent.\n *\n * There are two reasons why we may not be able to insert a element immediately.\n * - Projection: When creating a child content element of a component, we have to skip the\n *   insertion because the content of a component will be projected.\n *   `<component><content>delayed due to projection</content></component>`\n * - Parent container is disconnected: This can happen when we are inserting a view into\n *   parent container, which itself is disconnected. For example the parent container is part\n *   of a View which has not be inserted or is mare for projection but has not been inserted\n *   into destination.\n *\n\n *\n * @param tNode The tNode of the node that we want to insert.\n * @param currentView Current LView being processed.\n * @return boolean Whether the node should be inserted now (or delayed until later).\n */\nexport function canInsertNativeNode(tNode: TNode, currentView: LViewData): boolean {\n  let currentNode = tNode;\n  let parent: TNode|null = tNode.parent;\n\n  if (tNode.parent) {\n    if (tNode.parent.type === TNodeType.ElementContainer) {\n      currentNode = getHighestElementContainer(tNode);\n      parent = currentNode.parent;\n    } else if (tNode.parent.type === TNodeType.IcuContainer) {\n      currentNode = getFirstParentNative(currentNode);\n      parent = currentNode.parent;\n    }\n  }\n  if (parent === null) parent = currentView[HOST_NODE];\n\n  if (parent && parent.type === TNodeType.View) {\n    return canInsertNativeChildOfView(parent as TViewNode, currentView);\n  } else {\n    // Parent is a regular element or a component\n    return canInsertNativeChildOfElement(currentNode);\n  }\n}\n\n/**\n * Inserts a native node before another native node for a given parent using {@link Renderer3}.\n * This is a utility function that can be used when native nodes were determined - it abstracts an\n * actual renderer being used.\n */\nexport function nativeInsertBefore(\n    renderer: Renderer3, parent: RElement, child: RNode, beforeNode: RNode | null): void {\n  if (isProceduralRenderer(renderer)) {\n    renderer.insertBefore(parent, child, beforeNode);\n  } else {\n    parent.insertBefore(child, beforeNode, true);\n  }\n}\n\n/**\n * Returns a native parent of a given native node.\n */\nexport function nativeParentNode(renderer: Renderer3, node: RNode): RElement|null {\n  return (isProceduralRenderer(renderer) ? renderer.parentNode(node) : node.parentNode) as RElement;\n}\n\n/**\n * Returns a native sibling of a given native node.\n */\nexport function nativeNextSibling(renderer: Renderer3, node: RNode): RNode|null {\n  return isProceduralRenderer(renderer) ? renderer.nextSibling(node) : node.nextSibling;\n}\n\n/**\n * Appends the `child` element to the `parent`.\n *\n * The element insertion might be delayed {@link canInsertNativeNode}.\n *\n * @param childEl The child that should be appended\n * @param childTNode The TNode of the child element\n * @param currentView The current LView\n * @returns Whether or not the child was appended\n */\nexport function appendChild(\n    childEl: RNode | null = null, childTNode: TNode, currentView: LViewData): boolean {\n  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {\n    const renderer = currentView[RENDERER];\n    const parentEl = getParentNative(childTNode, currentView);\n    const parentTNode: TNode = childTNode.parent || currentView[HOST_NODE] !;\n\n    if (parentTNode.type === TNodeType.View) {\n      const lContainer = getLContainer(parentTNode as TViewNode, currentView) as LContainer;\n      const views = lContainer[VIEWS];\n      const index = views.indexOf(currentView);\n      nativeInsertBefore(\n          renderer, lContainer[RENDER_PARENT] !, childEl,\n          getBeforeNodeForView(index, views, lContainer[NATIVE]));\n    } else if (parentTNode.type === TNodeType.ElementContainer) {\n      const renderParent = getRenderParent(childTNode, currentView) !;\n      nativeInsertBefore(renderer, renderParent, childEl, parentEl);\n    } else if (parentTNode.type === TNodeType.IcuContainer) {\n      const icuAnchorNode = getNativeByTNode(childTNode.parent !, currentView) !as RElement;\n      nativeInsertBefore(renderer, parentEl as RElement, childEl, icuAnchorNode);\n    } else {\n      isProceduralRenderer(renderer) ? renderer.appendChild(parentEl !as RElement, childEl) :\n                                       parentEl !.appendChild(childEl);\n    }\n    return true;\n  }\n  return false;\n}\n\n/**\n * Gets the top-level ng-container if ng-containers are nested.\n *\n * @param ngContainer The TNode of the starting ng-container\n * @returns tNode The TNode of the highest level ng-container\n */\nfunction getHighestElementContainer(ngContainer: TNode): TNode {\n  while (ngContainer.parent != null && ngContainer.parent.type === TNodeType.ElementContainer) {\n    ngContainer = ngContainer.parent;\n  }\n  return ngContainer;\n}\n\nexport function getBeforeNodeForView(index: number, views: LViewData[], containerNative: RComment) {\n  if (index + 1 < views.length) {\n    const view = views[index + 1] as LViewData;\n    const viewTNode = view[HOST_NODE] as TViewNode;\n    return viewTNode.child ? getNativeByTNode(viewTNode.child, view) : containerNative;\n  } else {\n    return containerNative;\n  }\n}\n\n/**\n * Removes the `child` element from the DOM if not in view and not projected.\n *\n * @param childTNode The TNode of the child to remove\n * @param childEl The child that should be removed\n * @param currentView The current LView\n * @returns Whether or not the child was removed\n */\nexport function removeChild(\n    childTNode: TNode, childEl: RNode | null, currentView: LViewData): boolean {\n  // We only remove the element if not in View or not projected.\n  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {\n    const parentNative = getParentNative(childTNode, currentView) !as RElement;\n    const renderer = currentView[RENDERER];\n    isProceduralRenderer(renderer) ? renderer.removeChild(parentNative as RElement, childEl) :\n                                     parentNative !.removeChild(childEl);\n    return true;\n  }\n  return false;\n}\n\n/**\n * Appends a projected node to the DOM, or in the case of a projected container,\n * appends the nodes from all of the container's active views to the DOM.\n *\n * @param projectedTNode The TNode to be projected\n * @param tProjectionNode The projection (ng-content) TNode\n * @param currentView Current LView\n * @param projectionView Projection view (view above current)\n */\nexport function appendProjectedNode(\n    projectedTNode: TNode, tProjectionNode: TNode, currentView: LViewData,\n    projectionView: LViewData): void {\n  const native = getNativeByTNode(projectedTNode, projectionView);\n  appendChild(native, tProjectionNode, currentView);\n\n  // the projected contents are processed while in the shadow view (which is the currentView)\n  // therefore we need to extract the view where the host element lives since it's the\n  // logical container of the content projected views\n  attachPatchData(native, projectionView);\n\n  const renderParent = getRenderParent(tProjectionNode, currentView);\n\n  const nodeOrContainer = projectionView[projectedTNode.index];\n  if (projectedTNode.type === TNodeType.Container) {\n    // The node we are adding is a container and we are adding it to an element which\n    // is not a component (no more re-projection).\n    // Alternatively a container is projected at the root of a component's template\n    // and can't be re-projected (as not content of any component).\n    // Assign the final projection location in those cases.\n    nodeOrContainer[RENDER_PARENT] = renderParent;\n    const views = nodeOrContainer[VIEWS];\n    for (let i = 0; i < views.length; i++) {\n      addRemoveViewFromContainer(views[i], true, nodeOrContainer[NATIVE]);\n    }\n  } else {\n    if (projectedTNode.type === TNodeType.ElementContainer) {\n      let ngContainerChildTNode: TNode|null = projectedTNode.child as TNode;\n      while (ngContainerChildTNode) {\n        appendProjectedNode(ngContainerChildTNode, tProjectionNode, currentView, projectionView);\n        ngContainerChildTNode = ngContainerChildTNode.next;\n      }\n    }\n\n    if (isLContainer(nodeOrContainer)) {\n      nodeOrContainer[RENDER_PARENT] = renderParent;\n      appendChild(nodeOrContainer[NATIVE], tProjectionNode, currentView);\n    }\n  }\n}\n"]}
861
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node_manipulation.js","sourceRoot":"../../","sources":["packages/core/src/render3/node_manipulation.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {assertDefined} from './assert';\nimport {attachPatchData} from './context_discovery';\nimport {callHooks} from './hooks';\nimport {LContainer, NATIVE, RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1} from './interfaces/container';\nimport {TContainerNode, TElementContainerNode, TElementNode, TNode, TNodeFlags, TNodeType, TViewNode, unusedValueExportToPlacateAjd as unused2} from './interfaces/node';\nimport {unusedValueExportToPlacateAjd as unused3} from './interfaces/projection';\nimport {ProceduralRenderer3, RComment, RElement, RNode, RText, Renderer3, isProceduralRenderer, unusedValueExportToPlacateAjd as unused4} from './interfaces/renderer';\nimport {CLEANUP, CONTAINER_INDEX, FLAGS, HEADER_OFFSET, HOST_NODE, HookData, LView, LViewFlags, NEXT, PARENT, QUERIES, RENDERER, TVIEW, unusedValueExportToPlacateAjd as unused5} from './interfaces/view';\nimport {assertNodeType} from './node_assert';\nimport {findComponentView, getNativeByTNode, isLContainer, isRootView, readElementValue, stringify} from './util';\n\nconst unusedValueToPlacateAjd = unused1 + unused2 + unused3 + unused4 + unused5;\n\n/** Retrieves the parent element of a given node. */\nexport function getParentNative(tNode: TNode, currentView: LView): RElement|RComment|null {\n  if (tNode.parent == null) {\n    return getHostNative(currentView);\n  } else {\n    const parentTNode = getFirstParentNative(tNode);\n    return getNativeByTNode(parentTNode, currentView);\n  }\n}\n\n/**\n * Get the first parent of a node that isn't an IcuContainer TNode\n */\nfunction getFirstParentNative(tNode: TNode): TNode {\n  let parent = tNode.parent;\n  while (parent && parent.type === TNodeType.IcuContainer) {\n    parent = parent.parent;\n  }\n  return parent !;\n}\n\n/**\n * Gets the host element given a view. Will return null if the current view is an embedded view,\n * which does not have a host element.\n */\nexport function getHostNative(currentView: LView): RElement|null {\n  const hostTNode = currentView[HOST_NODE] as TElementNode;\n  return hostTNode && hostTNode.type !== TNodeType.View ?\n      (getNativeByTNode(hostTNode, currentView[PARENT] !) as RElement) :\n      null;\n}\n\nexport function getLContainer(tNode: TViewNode, embeddedView: LView): LContainer|null {\n  if (tNode.index === -1) {\n    // This is a dynamically created view inside a dynamic container.\n    // If the host index is -1, the view has not yet been inserted, so it has no parent.\n    const containerHostIndex = embeddedView[CONTAINER_INDEX];\n    return containerHostIndex > -1 ? embeddedView[PARENT] ![containerHostIndex] : null;\n  } else {\n    // This is a inline view node (e.g. embeddedViewStart)\n    return embeddedView[PARENT] ![tNode.parent !.index] as LContainer;\n  }\n}\n\n\n/**\n * Retrieves render parent for a given view.\n * Might be null if a view is not yet attached to any container.\n */\nexport function getContainerRenderParent(tViewNode: TViewNode, view: LView): RElement|null {\n  const container = getLContainer(tViewNode, view);\n  return container ? container[RENDER_PARENT] : null;\n}\n\nconst enum WalkTNodeTreeAction {\n  /** node insert in the native environment */\n  Insert = 0,\n\n  /** node detach from the native environment */\n  Detach = 1,\n\n  /** node destruction using the renderer's API */\n  Destroy = 2,\n}\n\n\n/**\n * Stack used to keep track of projection nodes in walkTNodeTree.\n *\n * This is deliberately created outside of walkTNodeTree to avoid allocating\n * a new array each time the function is called. Instead the array will be\n * re-used by each invocation. This works because the function is not reentrant.\n */\nconst projectionNodeStack: (LView | TNode)[] = [];\n\n/**\n * Walks a tree of TNodes, applying a transformation on the element nodes, either only on the first\n * one found, or on all of them.\n *\n * @param viewToWalk the view to walk\n * @param action identifies the action to be performed on the elements\n * @param renderer the current renderer.\n * @param renderParent Optional the render parent node to be set in all LContainers found,\n * required for action modes Insert and Destroy.\n * @param beforeNode Optional the node before which elements should be added, required for action\n * Insert.\n */\nfunction walkTNodeTree(\n    viewToWalk: LView, action: WalkTNodeTreeAction, renderer: Renderer3,\n    renderParent: RElement | null, beforeNode?: RNode | null) {\n  const rootTNode = viewToWalk[TVIEW].node as TViewNode;\n  let projectionNodeIndex = -1;\n  let currentView = viewToWalk;\n  let tNode: TNode|null = rootTNode.child as TNode;\n  while (tNode) {\n    let nextTNode: TNode|null = null;\n    if (tNode.type === TNodeType.Element) {\n      executeNodeAction(\n          action, renderer, renderParent, getNativeByTNode(tNode, currentView), beforeNode);\n      const nodeOrContainer = currentView[tNode.index];\n      if (isLContainer(nodeOrContainer)) {\n        // This element has an LContainer, and its comment needs to be handled\n        executeNodeAction(action, renderer, renderParent, nodeOrContainer[NATIVE], beforeNode);\n      }\n    } else if (tNode.type === TNodeType.Container) {\n      const lContainer = currentView ![tNode.index] as LContainer;\n      executeNodeAction(action, renderer, renderParent, lContainer[NATIVE], beforeNode);\n\n      if (renderParent) lContainer[RENDER_PARENT] = renderParent;\n\n      if (lContainer[VIEWS].length) {\n        currentView = lContainer[VIEWS][0];\n        nextTNode = currentView[TVIEW].node;\n\n        // When the walker enters a container, then the beforeNode has to become the local native\n        // comment node.\n        beforeNode = lContainer[NATIVE];\n      }\n    } else if (tNode.type === TNodeType.Projection) {\n      const componentView = findComponentView(currentView !);\n      const componentHost = componentView[HOST_NODE] as TElementNode;\n      const head: TNode|null =\n          (componentHost.projection as(TNode | null)[])[tNode.projection as number];\n\n      // Must store both the TNode and the view because this projection node could be nested\n      // deeply inside embedded views, and we need to get back down to this particular nested view.\n      projectionNodeStack[++projectionNodeIndex] = tNode;\n      projectionNodeStack[++projectionNodeIndex] = currentView !;\n      if (head) {\n        currentView = componentView[PARENT] !;\n        nextTNode = currentView[TVIEW].data[head.index] as TNode;\n      }\n    } else {\n      // Otherwise, this is a View or an ElementContainer\n      nextTNode = tNode.child;\n    }\n\n    if (nextTNode === null) {\n      // this last node was projected, we need to get back down to its projection node\n      if (tNode.next === null && (tNode.flags & TNodeFlags.isProjected)) {\n        currentView = projectionNodeStack[projectionNodeIndex--] as LView;\n        tNode = projectionNodeStack[projectionNodeIndex--] as TNode;\n      }\n      nextTNode = tNode.next;\n\n      /**\n       * Find the next node in the TNode tree, taking into account the place where a node is\n       * projected (in the shadow DOM) rather than where it comes from (in the light DOM).\n       *\n       * If there is no sibling node, then it goes to the next sibling of the parent node...\n       * until it reaches rootNode (at which point null is returned).\n       */\n      while (!nextTNode) {\n        // If parent is null, we're crossing the view boundary, so we should get the host TNode.\n        tNode = tNode.parent || currentView[TVIEW].node;\n\n        if (tNode === null || tNode === rootTNode) return null;\n\n        // When exiting a container, the beforeNode must be restored to the previous value\n        if (tNode.type === TNodeType.Container) {\n          currentView = currentView[PARENT] !;\n          beforeNode = currentView[tNode.index][NATIVE];\n        }\n\n        if (tNode.type === TNodeType.View && currentView[NEXT]) {\n          currentView = currentView[NEXT] as LView;\n          nextTNode = currentView[TVIEW].node;\n        } else {\n          nextTNode = tNode.next;\n        }\n      }\n    }\n    tNode = nextTNode;\n  }\n}\n\n/**\n * NOTE: for performance reasons, the possible actions are inlined within the function instead of\n * being passed as an argument.\n */\nfunction executeNodeAction(\n    action: WalkTNodeTreeAction, renderer: Renderer3, parent: RElement | null,\n    node: RComment | RElement | RText, beforeNode?: RNode | null) {\n  if (action === WalkTNodeTreeAction.Insert) {\n    isProceduralRenderer(renderer !) ?\n        (renderer as ProceduralRenderer3).insertBefore(parent !, node, beforeNode as RNode | null) :\n        parent !.insertBefore(node, beforeNode as RNode | null, true);\n  } else if (action === WalkTNodeTreeAction.Detach) {\n    isProceduralRenderer(renderer !) ?\n        (renderer as ProceduralRenderer3).removeChild(parent !, node) :\n        parent !.removeChild(node);\n  } else if (action === WalkTNodeTreeAction.Destroy) {\n    ngDevMode && ngDevMode.rendererDestroyNode++;\n    (renderer as ProceduralRenderer3).destroyNode !(node);\n  }\n}\n\nexport function createTextNode(value: any, renderer: Renderer3): RText {\n  return isProceduralRenderer(renderer) ? renderer.createText(stringify(value)) :\n                                          renderer.createTextNode(stringify(value));\n}\n\n/**\n * Adds or removes all DOM elements associated with a view.\n *\n * Because some root nodes of the view may be containers, we sometimes need\n * to propagate deeply into the nested containers to remove all elements in the\n * views beneath it.\n *\n * @param viewToWalk The view from which elements should be added or removed\n * @param insertMode Whether or not elements should be added (if false, removing)\n * @param beforeNode The node before which elements should be added, if insert mode\n */\nexport function addRemoveViewFromContainer(\n    viewToWalk: LView, insertMode: true, beforeNode: RNode | null): void;\nexport function addRemoveViewFromContainer(viewToWalk: LView, insertMode: false): void;\nexport function addRemoveViewFromContainer(\n    viewToWalk: LView, insertMode: boolean, beforeNode?: RNode | null): void {\n  const renderParent = getContainerRenderParent(viewToWalk[TVIEW].node as TViewNode, viewToWalk);\n  ngDevMode && assertNodeType(viewToWalk[TVIEW].node as TNode, TNodeType.View);\n  if (renderParent) {\n    const renderer = viewToWalk[RENDERER];\n    walkTNodeTree(\n        viewToWalk, insertMode ? WalkTNodeTreeAction.Insert : WalkTNodeTreeAction.Detach, renderer,\n        renderParent, beforeNode);\n  }\n}\n\n/**\n * Traverses down and up the tree of views and containers to remove listeners and\n * call onDestroy callbacks.\n *\n * Notes:\n *  - Because it's used for onDestroy calls, it needs to be bottom-up.\n *  - Must process containers instead of their views to avoid splicing\n *  when views are destroyed and re-added.\n *  - Using a while loop because it's faster than recursion\n *  - Destroy only called on movement to sibling or movement to parent (laterally or up)\n *\n *  @param rootView The view to destroy\n */\nexport function destroyViewTree(rootView: LView): void {\n  // If the view has no children, we can clean it up and return early.\n  if (rootView[TVIEW].childIndex === -1) {\n    return cleanUpView(rootView);\n  }\n  let viewOrContainer: LView|LContainer|null = getLViewChild(rootView);\n\n  while (viewOrContainer) {\n    let next: LView|LContainer|null = null;\n\n    if (viewOrContainer.length >= HEADER_OFFSET) {\n      // If LView, traverse down to child.\n      const view = viewOrContainer as LView;\n      if (view[TVIEW].childIndex > -1) next = getLViewChild(view);\n    } else {\n      // If container, traverse down to its first LView.\n      const container = viewOrContainer as LContainer;\n      if (container[VIEWS].length) next = container[VIEWS][0];\n    }\n\n    if (next == null) {\n      // Only clean up view when moving to the side or up, as destroy hooks\n      // should be called in order from the bottom up.\n      while (viewOrContainer && !viewOrContainer ![NEXT] && viewOrContainer !== rootView) {\n        cleanUpView(viewOrContainer);\n        viewOrContainer = getParentState(viewOrContainer, rootView);\n      }\n      cleanUpView(viewOrContainer || rootView);\n      next = viewOrContainer && viewOrContainer ![NEXT];\n    }\n    viewOrContainer = next;\n  }\n}\n\n/**\n * Inserts a view into a container.\n *\n * This adds the view to the container's array of active views in the correct\n * position. It also adds the view's elements to the DOM if the container isn't a\n * root node of another view (in that case, the view's elements will be added when\n * the container's parent view is added later).\n *\n * @param lView The view to insert\n * @param lContainer The container into which the view should be inserted\n * @param parentView The new parent of the inserted view\n * @param index The index at which to insert the view\n * @param containerIndex The index of the container node, if dynamic\n */\nexport function insertView(\n    lView: LView, lContainer: LContainer, parentView: LView, index: number,\n    containerIndex: number) {\n  const views = lContainer[VIEWS];\n\n  if (index > 0) {\n    // This is a new view, we need to add it to the children.\n    views[index - 1][NEXT] = lView;\n  }\n\n  if (index < views.length) {\n    lView[NEXT] = views[index];\n    views.splice(index, 0, lView);\n  } else {\n    views.push(lView);\n    lView[NEXT] = null;\n  }\n\n  // Dynamically inserted views need a reference to their parent container's host so it's\n  // possible to jump from a view to its container's next when walking the node tree.\n  if (containerIndex > -1) {\n    lView[CONTAINER_INDEX] = containerIndex;\n    lView[PARENT] = parentView;\n  }\n\n  // Notify query that a new view has been added\n  if (lView[QUERIES]) {\n    lView[QUERIES] !.insertView(index);\n  }\n\n  // Sets the attached flag\n  lView[FLAGS] |= LViewFlags.Attached;\n}\n\n/**\n * Detaches a view from a container.\n *\n * This method splices the view from the container's array of active views. It also\n * removes the view's elements from the DOM.\n *\n * @param lContainer The container from which to detach a view\n * @param removeIndex The index of the view to detach\n * @param detached Whether or not this view is already detached.\n * @returns Detached LView instance.\n */\nexport function detachView(lContainer: LContainer, removeIndex: number, detached: boolean): LView {\n  const views = lContainer[VIEWS];\n  const viewToDetach = views[removeIndex];\n  if (removeIndex > 0) {\n    views[removeIndex - 1][NEXT] = viewToDetach[NEXT] as LView;\n  }\n  views.splice(removeIndex, 1);\n  if (!detached) {\n    addRemoveViewFromContainer(viewToDetach, false);\n  }\n\n  if (viewToDetach[QUERIES]) {\n    viewToDetach[QUERIES] !.removeView();\n  }\n  viewToDetach[CONTAINER_INDEX] = -1;\n  viewToDetach[PARENT] = null;\n  // Unsets the attached flag\n  viewToDetach[FLAGS] &= ~LViewFlags.Attached;\n  return viewToDetach;\n}\n\n/**\n * Removes a view from a container, i.e. detaches it and then destroys the underlying LView.\n *\n * @param lContainer The container from which to remove a view\n * @param tContainer The TContainer node associated with the LContainer\n * @param removeIndex The index of the view to remove\n */\nexport function removeView(\n    lContainer: LContainer, containerHost: TElementNode | TContainerNode | TElementContainerNode,\n    removeIndex: number) {\n  const view = lContainer[VIEWS][removeIndex];\n  detachView(lContainer, removeIndex, !!containerHost.detached);\n  destroyLView(view);\n}\n\n/** Gets the child of the given LView */\nexport function getLViewChild(lView: LView): LView|LContainer|null {\n  const childIndex = lView[TVIEW].childIndex;\n  return childIndex === -1 ? null : lView[childIndex];\n}\n\n/**\n * A standalone function which destroys an LView,\n * conducting cleanup (e.g. removing listeners, calling onDestroys).\n *\n * @param view The view to be destroyed.\n */\nexport function destroyLView(view: LView) {\n  const renderer = view[RENDERER];\n  if (isProceduralRenderer(renderer) && renderer.destroyNode) {\n    walkTNodeTree(view, WalkTNodeTreeAction.Destroy, renderer, null);\n  }\n  destroyViewTree(view);\n  // Sets the destroyed flag\n  view[FLAGS] |= LViewFlags.Destroyed;\n}\n\n/**\n * Determines which LViewOrLContainer to jump to when traversing back up the\n * tree in destroyViewTree.\n *\n * Normally, the view's parent LView should be checked, but in the case of\n * embedded views, the container (which is the view node's parent, but not the\n * LView's parent) needs to be checked for a possible next property.\n *\n * @param state The LViewOrLContainer for which we need a parent state\n * @param rootView The rootView, so we don't propagate too far up the view tree\n * @returns The correct parent LViewOrLContainer\n */\nexport function getParentState(state: LView | LContainer, rootView: LView): LView|LContainer|null {\n  let tNode;\n  if (state.length >= HEADER_OFFSET && (tNode = (state as LView) ![HOST_NODE]) &&\n      tNode.type === TNodeType.View) {\n    // if it's an embedded view, the state needs to go up to the container, in case the\n    // container has a next\n    return getLContainer(tNode as TViewNode, state as LView) as LContainer;\n  } else {\n    // otherwise, use parent view for containers or component views\n    return state[PARENT] === rootView ? null : state[PARENT];\n  }\n}\n\n/**\n * Calls onDestroys hooks for all directives and pipes in a given view and then removes all\n * listeners. Listeners are removed as the last step so events delivered in the onDestroys hooks\n * can be propagated to @Output listeners.\n *\n * @param view The LView to clean up\n */\nfunction cleanUpView(viewOrContainer: LView | LContainer): void {\n  if ((viewOrContainer as LView).length >= HEADER_OFFSET) {\n    const view = viewOrContainer as LView;\n    executeOnDestroys(view);\n    executePipeOnDestroys(view);\n    removeListeners(view);\n    const hostTNode = view[HOST_NODE];\n    // For component views only, the local renderer is destroyed as clean up time.\n    if (hostTNode && hostTNode.type === TNodeType.Element && isProceduralRenderer(view[RENDERER])) {\n      ngDevMode && ngDevMode.rendererDestroy++;\n      (view[RENDERER] as ProceduralRenderer3).destroy();\n    }\n  }\n}\n\n/** Removes listeners and unsubscribes from output subscriptions */\nfunction removeListeners(lView: LView): void {\n  const tCleanup = lView[TVIEW].cleanup !;\n  if (tCleanup != null) {\n    const lCleanup = lView[CLEANUP] !;\n    for (let i = 0; i < tCleanup.length - 1; i += 2) {\n      if (typeof tCleanup[i] === 'string') {\n        // This is a listener with the native renderer\n        const idx = tCleanup[i + 1];\n        const listener = lCleanup[tCleanup[i + 2]];\n        const native = readElementValue(lView[idx]);\n        const useCaptureOrSubIdx = tCleanup[i + 3];\n        if (typeof useCaptureOrSubIdx === 'boolean') {\n          // DOM listener\n          native.removeEventListener(tCleanup[i], listener, useCaptureOrSubIdx);\n        } else {\n          if (useCaptureOrSubIdx >= 0) {\n            // unregister\n            lCleanup[useCaptureOrSubIdx]();\n          } else {\n            // Subscription\n            lCleanup[-useCaptureOrSubIdx].unsubscribe();\n          }\n        }\n        i += 2;\n      } else if (typeof tCleanup[i] === 'number') {\n        // This is a listener with renderer2 (cleanup fn can be found by index)\n        const cleanupFn = lCleanup[tCleanup[i]];\n        cleanupFn();\n      } else {\n        // This is a cleanup function that is grouped with the index of its context\n        const context = lCleanup[tCleanup[i + 1]];\n        tCleanup[i].call(context);\n      }\n    }\n    lView[CLEANUP] = null;\n  }\n}\n\n/** Calls onDestroy hooks for this view */\nfunction executeOnDestroys(view: LView): void {\n  const tView = view[TVIEW];\n  let destroyHooks: HookData|null;\n  if (tView != null && (destroyHooks = tView.destroyHooks) != null) {\n    callHooks(view, destroyHooks);\n  }\n}\n\n/** Calls pipe destroy hooks for this view */\nfunction executePipeOnDestroys(lView: LView): void {\n  const pipeDestroyHooks = lView[TVIEW] && lView[TVIEW].pipeDestroyHooks;\n  if (pipeDestroyHooks) {\n    callHooks(lView !, pipeDestroyHooks);\n  }\n}\n\nexport function getRenderParent(tNode: TNode, currentView: LView): RElement|null {\n  if (canInsertNativeNode(tNode, currentView)) {\n    // If we are asked for a render parent of the root component we need to do low-level DOM\n    // operation as LTree doesn't exist above the topmost host node. We might need to find a render\n    // parent of the topmost host node if the root component injects ViewContainerRef.\n    if (isRootView(currentView)) {\n      return nativeParentNode(currentView[RENDERER], getNativeByTNode(tNode, currentView));\n    }\n\n    const hostTNode = currentView[HOST_NODE];\n\n    const tNodeParent = tNode.parent;\n    if (tNodeParent != null && tNodeParent.type === TNodeType.ElementContainer) {\n      tNode = getHighestElementContainer(tNodeParent);\n    }\n\n    return tNode.parent == null && hostTNode !.type === TNodeType.View ?\n        getContainerRenderParent(hostTNode as TViewNode, currentView) :\n        getParentNative(tNode, currentView) as RElement;\n  }\n  return null;\n}\n\nfunction canInsertNativeChildOfElement(tNode: TNode): boolean {\n  // If the parent is null, then we are inserting across views. This happens when we\n  // insert a root element of the component view into the component host element and it\n  // should always be eager.\n  if (tNode.parent == null ||\n      // We should also eagerly insert if the parent is a regular, non-component element\n      // since we know that this relationship will never be broken.\n      tNode.parent.type === TNodeType.Element && !(tNode.parent.flags & TNodeFlags.isComponent)) {\n    return true;\n  }\n\n  // Parent is a Component. Component's content nodes are not inserted immediately\n  // because they will be projected, and so doing insert at this point would be wasteful.\n  // Since the projection would than move it to its final destination.\n  return false;\n}\n\n/**\n * We might delay insertion of children for a given view if it is disconnected.\n * This might happen for 2 main reasons:\n * - view is not inserted into any container (view was created but not inserted yet)\n * - view is inserted into a container but the container itself is not inserted into the DOM\n * (container might be part of projection or child of a view that is not inserted yet).\n *\n * In other words we can insert children of a given view if this view was inserted into a container\n * and\n * the container itself has its render parent determined.\n */\nfunction canInsertNativeChildOfView(viewTNode: TViewNode, view: LView): boolean {\n  // Because we are inserting into a `View` the `View` may be disconnected.\n  const container = getLContainer(viewTNode, view) !;\n  if (container == null || container[RENDER_PARENT] == null) {\n    // The `View` is not inserted into a `Container` or the parent `Container`\n    // itself is disconnected. So we have to delay.\n    return false;\n  }\n\n  // The parent `Container` is in inserted state, so we can eagerly insert into\n  // this location.\n  return true;\n}\n\n/**\n * Returns whether a native element can be inserted into the given parent.\n *\n * There are two reasons why we may not be able to insert a element immediately.\n * - Projection: When creating a child content element of a component, we have to skip the\n *   insertion because the content of a component will be projected.\n *   `<component><content>delayed due to projection</content></component>`\n * - Parent container is disconnected: This can happen when we are inserting a view into\n *   parent container, which itself is disconnected. For example the parent container is part\n *   of a View which has not be inserted or is mare for projection but has not been inserted\n *   into destination.\n *\n\n *\n * @param tNode The tNode of the node that we want to insert.\n * @param currentView Current LView being processed.\n * @return boolean Whether the node should be inserted now (or delayed until later).\n */\nexport function canInsertNativeNode(tNode: TNode, currentView: LView): boolean {\n  let currentNode = tNode;\n  let parent: TNode|null = tNode.parent;\n\n  if (tNode.parent) {\n    if (tNode.parent.type === TNodeType.ElementContainer) {\n      currentNode = getHighestElementContainer(tNode);\n      parent = currentNode.parent;\n    } else if (tNode.parent.type === TNodeType.IcuContainer) {\n      currentNode = getFirstParentNative(currentNode);\n      parent = currentNode.parent;\n    }\n  }\n  if (parent === null) parent = currentView[HOST_NODE];\n\n  if (parent && parent.type === TNodeType.View) {\n    return canInsertNativeChildOfView(parent as TViewNode, currentView);\n  } else {\n    // Parent is a regular element or a component\n    return canInsertNativeChildOfElement(currentNode);\n  }\n}\n\n/**\n * Inserts a native node before another native node for a given parent using {@link Renderer3}.\n * This is a utility function that can be used when native nodes were determined - it abstracts an\n * actual renderer being used.\n */\nexport function nativeInsertBefore(\n    renderer: Renderer3, parent: RElement, child: RNode, beforeNode: RNode | null): void {\n  if (isProceduralRenderer(renderer)) {\n    renderer.insertBefore(parent, child, beforeNode);\n  } else {\n    parent.insertBefore(child, beforeNode, true);\n  }\n}\n\n/**\n * Returns a native parent of a given native node.\n */\nexport function nativeParentNode(renderer: Renderer3, node: RNode): RElement|null {\n  return (isProceduralRenderer(renderer) ? renderer.parentNode(node) : node.parentNode) as RElement;\n}\n\n/**\n * Returns a native sibling of a given native node.\n */\nexport function nativeNextSibling(renderer: Renderer3, node: RNode): RNode|null {\n  return isProceduralRenderer(renderer) ? renderer.nextSibling(node) : node.nextSibling;\n}\n\n/**\n * Appends the `child` element to the `parent`.\n *\n * The element insertion might be delayed {@link canInsertNativeNode}.\n *\n * @param childEl The child that should be appended\n * @param childTNode The TNode of the child element\n * @param currentView The current LView\n * @returns Whether or not the child was appended\n */\nexport function appendChild(\n    childEl: RNode | null = null, childTNode: TNode, currentView: LView): boolean {\n  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {\n    const renderer = currentView[RENDERER];\n    const parentEl = getParentNative(childTNode, currentView);\n    const parentTNode: TNode = childTNode.parent || currentView[HOST_NODE] !;\n\n    if (parentTNode.type === TNodeType.View) {\n      const lContainer = getLContainer(parentTNode as TViewNode, currentView) as LContainer;\n      const views = lContainer[VIEWS];\n      const index = views.indexOf(currentView);\n      nativeInsertBefore(\n          renderer, lContainer[RENDER_PARENT] !, childEl,\n          getBeforeNodeForView(index, views, lContainer[NATIVE]));\n    } else if (parentTNode.type === TNodeType.ElementContainer) {\n      const renderParent = getRenderParent(childTNode, currentView) !;\n      nativeInsertBefore(renderer, renderParent, childEl, parentEl);\n    } else if (parentTNode.type === TNodeType.IcuContainer) {\n      const icuAnchorNode = getNativeByTNode(childTNode.parent !, currentView) !as RElement;\n      nativeInsertBefore(renderer, parentEl as RElement, childEl, icuAnchorNode);\n    } else {\n      isProceduralRenderer(renderer) ? renderer.appendChild(parentEl !as RElement, childEl) :\n                                       parentEl !.appendChild(childEl);\n    }\n    return true;\n  }\n  return false;\n}\n\n/**\n * Gets the top-level ng-container if ng-containers are nested.\n *\n * @param ngContainer The TNode of the starting ng-container\n * @returns tNode The TNode of the highest level ng-container\n */\nfunction getHighestElementContainer(ngContainer: TNode): TNode {\n  while (ngContainer.parent != null && ngContainer.parent.type === TNodeType.ElementContainer) {\n    ngContainer = ngContainer.parent;\n  }\n  return ngContainer;\n}\n\nexport function getBeforeNodeForView(index: number, views: LView[], containerNative: RComment) {\n  if (index + 1 < views.length) {\n    const view = views[index + 1] as LView;\n    const viewTNode = view[HOST_NODE] as TViewNode;\n    return viewTNode.child ? getNativeByTNode(viewTNode.child, view) : containerNative;\n  } else {\n    return containerNative;\n  }\n}\n\n/**\n * Removes the `child` element from the DOM if not in view and not projected.\n *\n * @param childTNode The TNode of the child to remove\n * @param childEl The child that should be removed\n * @param currentView The current LView\n * @returns Whether or not the child was removed\n */\nexport function removeChild(childTNode: TNode, childEl: RNode | null, currentView: LView): boolean {\n  // We only remove the element if not in View or not projected.\n  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {\n    const parentNative = getParentNative(childTNode, currentView) !as RElement;\n    const renderer = currentView[RENDERER];\n    isProceduralRenderer(renderer) ? renderer.removeChild(parentNative as RElement, childEl) :\n                                     parentNative !.removeChild(childEl);\n    return true;\n  }\n  return false;\n}\n\n/**\n * Appends a projected node to the DOM, or in the case of a projected container,\n * appends the nodes from all of the container's active views to the DOM.\n *\n * @param projectedTNode The TNode to be projected\n * @param tProjectionNode The projection (ng-content) TNode\n * @param currentView Current LView\n * @param projectionView Projection view (view above current)\n */\nexport function appendProjectedNode(\n    projectedTNode: TNode, tProjectionNode: TNode, currentView: LView,\n    projectionView: LView): void {\n  const native = getNativeByTNode(projectedTNode, projectionView);\n  appendChild(native, tProjectionNode, currentView);\n\n  // the projected contents are processed while in the shadow view (which is the currentView)\n  // therefore we need to extract the view where the host element lives since it's the\n  // logical container of the content projected views\n  attachPatchData(native, projectionView);\n\n  const renderParent = getRenderParent(tProjectionNode, currentView);\n\n  const nodeOrContainer = projectionView[projectedTNode.index];\n  if (projectedTNode.type === TNodeType.Container) {\n    // The node we are adding is a container and we are adding it to an element which\n    // is not a component (no more re-projection).\n    // Alternatively a container is projected at the root of a component's template\n    // and can't be re-projected (as not content of any component).\n    // Assign the final projection location in those cases.\n    nodeOrContainer[RENDER_PARENT] = renderParent;\n    const views = nodeOrContainer[VIEWS];\n    for (let i = 0; i < views.length; i++) {\n      addRemoveViewFromContainer(views[i], true, nodeOrContainer[NATIVE]);\n    }\n  } else {\n    if (projectedTNode.type === TNodeType.ElementContainer) {\n      let ngContainerChildTNode: TNode|null = projectedTNode.child as TNode;\n      while (ngContainerChildTNode) {\n        appendProjectedNode(ngContainerChildTNode, tProjectionNode, currentView, projectionView);\n        ngContainerChildTNode = ngContainerChildTNode.next;\n      }\n    }\n\n    if (isLContainer(nodeOrContainer)) {\n      nodeOrContainer[RENDER_PARENT] = renderParent;\n      appendChild(nodeOrContainer[NATIVE], tProjectionNode, currentView);\n    }\n  }\n}\n"]}