@angular/core 7.0.0-rc.1 → 7.0.3

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 (337) hide show
  1. package/bundles/core-testing.umd.js +36 -33
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +3 -3
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +1856 -1463
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +155 -94
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +7 -6
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +0 -3
  12. package/esm2015/core.js +6 -6
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/application_init.js +5 -1
  16. package/esm2015/src/application_module.js +2 -2
  17. package/esm2015/src/application_ref.js +11 -9
  18. package/esm2015/src/application_tokens.js +7 -7
  19. package/esm2015/src/change_detection/change_detection_util.js +3 -1
  20. package/esm2015/src/change_detection/change_detector_ref.js +2 -1
  21. package/esm2015/src/change_detection/constants.js +1 -1
  22. package/esm2015/src/change_detection/differs/default_iterable_differ.js +2 -1
  23. package/esm2015/src/change_detection/differs/iterable_differs.js +8 -6
  24. package/esm2015/src/change_detection/differs/keyvalue_differs.js +6 -5
  25. package/esm2015/src/change_detection/pipe_transform.js +2 -2
  26. package/esm2015/src/core.js +2 -2
  27. package/esm2015/src/core_render3_private_export.js +5 -4
  28. package/esm2015/src/debug/debug_node.js +6 -6
  29. package/esm2015/src/di/defs.js +5 -5
  30. package/esm2015/src/di/forward_ref.js +4 -4
  31. package/esm2015/src/di/injectable.js +5 -2
  32. package/esm2015/src/di/injection_token.js +3 -1
  33. package/esm2015/src/di/injector.js +3 -3
  34. package/esm2015/src/di/metadata.js +16 -1
  35. package/esm2015/src/di/provider.js +16 -6
  36. package/esm2015/src/di/r3_injector.js +2 -2
  37. package/esm2015/src/di/reflective_injector.js +2 -2
  38. package/esm2015/src/di/reflective_key.js +3 -1
  39. package/esm2015/src/di/reflective_provider.js +3 -3
  40. package/esm2015/src/error_handler.js +3 -1
  41. package/esm2015/src/event_emitter.js +2 -1
  42. package/esm2015/src/i18n/tokens.js +4 -4
  43. package/esm2015/src/is_dev_mode.js +4 -2
  44. package/esm2015/src/ivy_switch/runtime/index.js +2 -2
  45. package/esm2015/src/ivy_switch/runtime/ivy_switch_on.js +4 -2
  46. package/esm2015/src/ivy_switch/runtime/jit.js +2 -2
  47. package/esm2015/src/ivy_switch/runtime/legacy.js +7 -1
  48. package/esm2015/src/ivy_switch/runtime/local.js +2 -2
  49. package/esm2015/src/linker/compiler.js +5 -4
  50. package/esm2015/src/linker/component_factory.js +4 -2
  51. package/esm2015/src/linker/component_factory_resolver.js +2 -1
  52. package/esm2015/src/linker/element_ref.js +2 -2
  53. package/esm2015/src/linker/ng_module_factory.js +3 -3
  54. package/esm2015/src/linker/ng_module_factory_loader.js +4 -3
  55. package/esm2015/src/linker/query_list.js +3 -1
  56. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +3 -3
  57. package/esm2015/src/linker/template_ref.js +2 -1
  58. package/esm2015/src/linker/view_container_ref.js +2 -1
  59. package/esm2015/src/linker/view_ref.js +4 -2
  60. package/esm2015/src/metadata/di.js +13 -5
  61. package/esm2015/src/metadata/directives.js +20 -7
  62. package/esm2015/src/metadata/lifecycle_hooks.js +10 -5
  63. package/esm2015/src/metadata/ng_module.js +8 -6
  64. package/esm2015/src/metadata/view.js +1 -1
  65. package/esm2015/src/platform_core_providers.js +2 -2
  66. package/esm2015/src/profile/profile.js +5 -5
  67. package/esm2015/src/profile/wtf_impl.js +2 -2
  68. package/esm2015/src/r3_symbols.js +1 -1
  69. package/esm2015/src/reflection/reflection_capabilities.js +3 -3
  70. package/esm2015/src/render/api.js +20 -7
  71. package/esm2015/src/render3/component.js +52 -18
  72. package/esm2015/src/render3/component_ref.js +15 -15
  73. package/esm2015/src/render3/context_discovery.js +35 -126
  74. package/esm2015/src/render3/debug.js +33 -56
  75. package/esm2015/src/render3/definition.js +42 -37
  76. package/esm2015/src/render3/di.js +4 -28
  77. package/esm2015/src/render3/discovery_utils.js +10 -7
  78. package/esm2015/src/render3/i18n.js +60 -34
  79. package/esm2015/src/render3/index.js +3 -3
  80. package/esm2015/src/render3/instructions.js +162 -275
  81. package/esm2015/src/render3/interfaces/container.js +7 -5
  82. package/esm2015/src/render3/interfaces/context.js +60 -0
  83. package/esm2015/src/render3/interfaces/definition.js +7 -1
  84. package/esm2015/src/render3/interfaces/i18n.js +338 -0
  85. package/esm2015/src/render3/interfaces/node.js +12 -126
  86. package/esm2015/src/render3/interfaces/player.js +73 -1
  87. package/esm2015/src/render3/interfaces/styling.js +18 -22
  88. package/esm2015/src/render3/interfaces/view.js +19 -26
  89. package/esm2015/src/render3/jit/compiler_facade.js +22 -0
  90. package/esm2015/src/render3/jit/compiler_facade_interface.js +229 -0
  91. package/esm2015/src/render3/jit/directive.js +57 -93
  92. package/esm2015/src/render3/jit/environment.js +7 -3
  93. package/esm2015/src/render3/jit/injectable.js +21 -46
  94. package/esm2015/src/render3/jit/module.js +16 -43
  95. package/esm2015/src/render3/jit/pipe.js +6 -12
  96. package/esm2015/src/render3/jit/util.js +14 -17
  97. package/esm2015/src/render3/node_assert.js +1 -1
  98. package/esm2015/src/render3/node_manipulation.js +99 -109
  99. package/esm2015/src/render3/players.js +67 -0
  100. package/esm2015/src/render3/styling/class_and_style_bindings.js +347 -88
  101. package/esm2015/src/render3/styling/core_player_handler.js +2 -2
  102. package/esm2015/src/render3/styling/player_factory.js +48 -0
  103. package/esm2015/src/render3/styling/util.js +165 -17
  104. package/esm2015/src/render3/util.js +73 -20
  105. package/esm2015/src/render3/view_engine_compatibility.js +56 -40
  106. package/esm2015/src/sanitization/security.js +2 -2
  107. package/esm2015/src/testability/testability.js +5 -6
  108. package/esm2015/src/type.js +5 -2
  109. package/esm2015/src/util/decorators.js +2 -1
  110. package/esm2015/src/util.js +15 -1
  111. package/esm2015/src/version.js +6 -4
  112. package/esm2015/src/view/refs.js +3 -3
  113. package/esm2015/src/view/services.js +8 -6
  114. package/esm2015/src/zone/ng_zone.js +2 -2
  115. package/esm2015/testing/src/async.js +2 -2
  116. package/esm2015/testing/src/component_fixture.js +2 -2
  117. package/esm2015/testing/src/fake_async.js +7 -7
  118. package/esm2015/testing/src/fake_async_fallback.js +7 -7
  119. package/esm2015/testing/src/metadata_override.js +1 -1
  120. package/esm2015/testing/src/r3_test_bed.js +8 -6
  121. package/esm2015/testing/src/test_bed.js +10 -8
  122. package/esm2015/testing/src/test_bed_common.js +6 -6
  123. package/esm2015/testing/src/test_compiler.js +3 -3
  124. package/esm5/core.js +6 -6
  125. package/esm5/src/application_init.js +5 -1
  126. package/esm5/src/application_module.js +2 -2
  127. package/esm5/src/application_ref.js +11 -9
  128. package/esm5/src/application_tokens.js +7 -7
  129. package/esm5/src/change_detection/change_detection_util.js +3 -1
  130. package/esm5/src/change_detection/change_detector_ref.js +2 -1
  131. package/esm5/src/change_detection/constants.js +2 -1
  132. package/esm5/src/change_detection/differs/default_iterable_differ.js +2 -1
  133. package/esm5/src/change_detection/differs/iterable_differs.js +2 -1
  134. package/esm5/src/change_detection/differs/keyvalue_differs.js +2 -1
  135. package/esm5/src/change_detection/pipe_transform.js +1 -1
  136. package/esm5/src/core_render3_private_export.js +5 -4
  137. package/esm5/src/debug/debug_node.js +5 -5
  138. package/esm5/src/di/defs.js +3 -3
  139. package/esm5/src/di/forward_ref.js +3 -3
  140. package/esm5/src/di/injectable.js +6 -5
  141. package/esm5/src/di/injection_token.js +3 -1
  142. package/esm5/src/di/injector.js +3 -3
  143. package/esm5/src/di/metadata.js +6 -1
  144. package/esm5/src/di/provider.js +1 -1
  145. package/esm5/src/di/r3_injector.js +2 -2
  146. package/esm5/src/di/reflective_injector.js +2 -2
  147. package/esm5/src/di/reflective_key.js +3 -1
  148. package/esm5/src/di/reflective_provider.js +2 -2
  149. package/esm5/src/error_handler.js +3 -1
  150. package/esm5/src/event_emitter.js +2 -1
  151. package/esm5/src/i18n/tokens.js +5 -5
  152. package/esm5/src/is_dev_mode.js +4 -2
  153. package/esm5/src/ivy_switch/runtime/ivy_switch_on.js +3 -2
  154. package/esm5/src/ivy_switch/runtime/legacy.js +4 -1
  155. package/esm5/src/linker/compiler.js +5 -4
  156. package/esm5/src/linker/component_factory.js +5 -1
  157. package/esm5/src/linker/component_factory_resolver.js +4 -1
  158. package/esm5/src/linker/element_ref.js +2 -2
  159. package/esm5/src/linker/ng_module_factory.js +3 -3
  160. package/esm5/src/linker/ng_module_factory_loader.js +4 -3
  161. package/esm5/src/linker/query_list.js +3 -1
  162. package/esm5/src/linker/system_js_ng_module_factory_loader.js +3 -3
  163. package/esm5/src/linker/template_ref.js +2 -1
  164. package/esm5/src/linker/view_container_ref.js +2 -1
  165. package/esm5/src/linker/view_ref.js +4 -2
  166. package/esm5/src/metadata/di.js +10 -3
  167. package/esm5/src/metadata/directives.js +9 -6
  168. package/esm5/src/metadata/lifecycle_hooks.js +1 -1
  169. package/esm5/src/metadata/ng_module.js +4 -3
  170. package/esm5/src/metadata/view.js +4 -1
  171. package/esm5/src/platform_core_providers.js +2 -2
  172. package/esm5/src/profile/profile.js +5 -5
  173. package/esm5/src/profile/wtf_impl.js +1 -1
  174. package/esm5/src/r3_symbols.js +1 -1
  175. package/esm5/src/reflection/reflection_capabilities.js +3 -3
  176. package/esm5/src/render/api.js +11 -5
  177. package/esm5/src/render3/component.js +45 -16
  178. package/esm5/src/render3/component_ref.js +12 -13
  179. package/esm5/src/render3/context_discovery.js +33 -65
  180. package/esm5/src/render3/debug.js +31 -50
  181. package/esm5/src/render3/definition.js +35 -31
  182. package/esm5/src/render3/di.js +4 -20
  183. package/esm5/src/render3/discovery_utils.js +12 -7
  184. package/esm5/src/render3/i18n.js +40 -30
  185. package/esm5/src/render3/index.js +3 -3
  186. package/esm5/src/render3/instructions.js +143 -230
  187. package/esm5/src/render3/interfaces/container.js +6 -5
  188. package/esm5/src/render3/interfaces/context.js +13 -0
  189. package/esm5/src/render3/interfaces/definition.js +1 -1
  190. package/esm5/src/render3/interfaces/i18n.js +25 -0
  191. package/esm5/src/render3/interfaces/node.js +1 -1
  192. package/esm5/src/render3/interfaces/player.js +1 -1
  193. package/esm5/src/render3/interfaces/styling.js +1 -8
  194. package/esm5/src/render3/interfaces/view.js +18 -17
  195. package/esm5/src/render3/jit/compiler_facade.js +21 -0
  196. package/esm5/src/render3/jit/compiler_facade_interface.js +15 -0
  197. package/esm5/src/render3/jit/directive.js +44 -79
  198. package/esm5/src/render3/jit/environment.js +7 -3
  199. package/esm5/src/render3/jit/injectable.js +26 -46
  200. package/esm5/src/render3/jit/module.js +16 -31
  201. package/esm5/src/render3/jit/pipe.js +6 -9
  202. package/esm5/src/render3/jit/util.js +12 -17
  203. package/esm5/src/render3/node_assert.js +1 -1
  204. package/esm5/src/render3/node_manipulation.js +89 -101
  205. package/esm5/src/render3/players.js +59 -0
  206. package/esm5/src/render3/styling/class_and_style_bindings.js +248 -85
  207. package/esm5/src/render3/styling/core_player_handler.js +2 -2
  208. package/esm5/src/render3/styling/player_factory.js +29 -0
  209. package/esm5/src/render3/styling/util.js +132 -14
  210. package/esm5/src/render3/util.js +54 -21
  211. package/esm5/src/render3/view_engine_compatibility.js +46 -32
  212. package/esm5/src/sanitization/security.js +3 -3
  213. package/esm5/src/testability/testability.js +4 -4
  214. package/esm5/src/type.js +2 -2
  215. package/esm5/src/util/decorators.js +1 -1
  216. package/esm5/src/util.js +13 -1
  217. package/esm5/src/version.js +6 -3
  218. package/esm5/src/view/refs.js +1 -1
  219. package/esm5/src/view/services.js +7 -10
  220. package/esm5/src/zone/ng_zone.js +2 -2
  221. package/esm5/testing/src/async.js +2 -2
  222. package/esm5/testing/src/component_fixture.js +2 -2
  223. package/esm5/testing/src/fake_async.js +7 -7
  224. package/esm5/testing/src/fake_async_fallback.js +7 -7
  225. package/esm5/testing/src/metadata_override.js +1 -1
  226. package/esm5/testing/src/r3_test_bed.js +8 -7
  227. package/esm5/testing/src/test_bed.js +10 -8
  228. package/esm5/testing/src/test_bed_common.js +4 -4
  229. package/esm5/testing/src/test_compiler.js +3 -3
  230. package/fesm2015/core.js +2486 -1951
  231. package/fesm2015/core.js.map +1 -1
  232. package/fesm2015/testing.js +36 -32
  233. package/fesm2015/testing.js.map +1 -1
  234. package/fesm5/core.js +1830 -1439
  235. package/fesm5/core.js.map +1 -1
  236. package/fesm5/testing.js +36 -33
  237. package/fesm5/testing.js.map +1 -1
  238. package/package.json +1 -2
  239. package/src/application_init.d.ts +4 -0
  240. package/src/application_module.d.ts +1 -1
  241. package/src/application_ref.d.ts +10 -8
  242. package/src/application_tokens.d.ts +6 -6
  243. package/src/change_detection/change_detection_util.d.ts +2 -0
  244. package/src/change_detection/change_detector_ref.d.ts +1 -0
  245. package/src/change_detection/constants.d.ts +1 -0
  246. package/src/change_detection/differs/default_iterable_differ.d.ts +1 -0
  247. package/src/change_detection/differs/iterable_differs.d.ts +8 -6
  248. package/src/change_detection/differs/keyvalue_differs.d.ts +5 -4
  249. package/src/change_detection/pipe_transform.d.ts +1 -1
  250. package/src/core_render3_private_export.d.ts +7 -5
  251. package/src/debug/debug_node.d.ts +5 -5
  252. package/src/di/defs.d.ts +4 -4
  253. package/src/di/forward_ref.d.ts +3 -3
  254. package/src/di/injectable.d.ts +10 -7
  255. package/src/di/injection_token.d.ts +2 -0
  256. package/src/di/injector.d.ts +5 -3
  257. package/src/di/metadata.d.ts +24 -1
  258. package/src/di/provider.d.ts +19 -5
  259. package/src/di/r3_injector.d.ts +1 -1
  260. package/src/di/reflective_injector.d.ts +1 -1
  261. package/src/di/reflective_key.d.ts +2 -0
  262. package/src/di/reflective_provider.d.ts +2 -2
  263. package/src/error_handler.d.ts +2 -0
  264. package/src/event_emitter.d.ts +1 -0
  265. package/src/i18n/tokens.d.ts +4 -4
  266. package/src/is_dev_mode.d.ts +3 -1
  267. package/src/ivy_switch/runtime/ivy_switch_on.d.ts +2 -1
  268. package/src/ivy_switch/runtime/legacy.d.ts +3 -0
  269. package/src/linker/compiler.d.ts +5 -4
  270. package/src/linker/component_factory.d.ts +5 -1
  271. package/src/linker/component_factory_resolver.d.ts +3 -0
  272. package/src/linker/element_ref.d.ts +1 -1
  273. package/src/linker/ng_module_factory.d.ts +2 -2
  274. package/src/linker/ng_module_factory_loader.d.ts +3 -2
  275. package/src/linker/query_list.d.ts +2 -0
  276. package/src/linker/system_js_ng_module_factory_loader.d.ts +2 -2
  277. package/src/linker/template_ref.d.ts +1 -0
  278. package/src/linker/view_container_ref.d.ts +1 -0
  279. package/src/linker/view_ref.d.ts +3 -1
  280. package/src/metadata/di.d.ts +13 -5
  281. package/src/metadata/directives.d.ts +19 -6
  282. package/src/metadata/lifecycle_hooks.d.ts +9 -4
  283. package/src/metadata/ng_module.d.ts +7 -7
  284. package/src/metadata/view.d.ts +3 -0
  285. package/src/platform_core_providers.d.ts +1 -1
  286. package/src/profile/profile.d.ts +4 -4
  287. package/src/profile/wtf_impl.d.ts +1 -1
  288. package/src/r3_symbols.d.ts +1 -1
  289. package/src/render/api.d.ts +10 -7
  290. package/src/render3/component.d.ts +14 -3
  291. package/src/render3/context_discovery.d.ts +6 -58
  292. package/src/render3/definition.d.ts +0 -4
  293. package/src/render3/di.d.ts +1 -3
  294. package/src/render3/discovery_utils.d.ts +7 -1
  295. package/src/render3/i18n.d.ts +4 -0
  296. package/src/render3/index.d.ts +2 -2
  297. package/src/render3/instructions.d.ts +43 -50
  298. package/src/render3/interfaces/container.d.ts +36 -22
  299. package/src/render3/interfaces/context.d.ts +52 -0
  300. package/src/render3/interfaces/definition.d.ts +8 -3
  301. package/src/render3/interfaces/i18n.d.ts +326 -0
  302. package/src/render3/interfaces/node.d.ts +12 -89
  303. package/src/render3/interfaces/player.d.ts +58 -4
  304. package/src/render3/interfaces/styling.d.ts +17 -15
  305. package/src/render3/interfaces/view.d.ts +28 -28
  306. package/src/render3/jit/compiler_facade.d.ts +3 -0
  307. package/src/render3/jit/compiler_facade_interface.d.ts +131 -0
  308. package/src/render3/jit/directive.d.ts +3 -0
  309. package/src/render3/jit/util.d.ts +3 -3
  310. package/src/render3/node_manipulation.d.ts +21 -22
  311. package/src/render3/players.d.ts +32 -0
  312. package/src/render3/styling/class_and_style_bindings.d.ts +31 -24
  313. package/src/render3/styling/player_factory.d.ts +31 -0
  314. package/src/render3/styling/util.d.ts +31 -9
  315. package/src/render3/util.d.ts +32 -15
  316. package/src/render3/view_engine_compatibility.d.ts +3 -0
  317. package/src/sanitization/security.d.ts +2 -2
  318. package/src/testability/testability.d.ts +5 -6
  319. package/src/type.d.ts +6 -1
  320. package/src/util/decorators.d.ts +1 -0
  321. package/src/util.d.ts +10 -0
  322. package/src/version.d.ts +4 -1
  323. package/src/view/services.d.ts +2 -2
  324. package/src/zone/ng_zone.d.ts +1 -1
  325. package/testing/src/async.d.ts +1 -1
  326. package/testing/src/component_fixture.d.ts +1 -1
  327. package/testing/src/fake_async.d.ts +6 -6
  328. package/testing/src/fake_async_fallback.d.ts +6 -6
  329. package/testing/src/metadata_override.d.ts +1 -1
  330. package/testing/src/r3_test_bed.d.ts +4 -4
  331. package/testing/src/test_bed.d.ts +12 -10
  332. package/testing/src/test_bed_common.d.ts +6 -6
  333. package/testing/src/test_compiler.d.ts +2 -2
  334. package/testing/testing.metadata.json +1 -1
  335. package/esm2015/src/render3/player.js +0 -51
  336. package/esm5/src/render3/player.js +0 -39
  337. package/src/render3/player.d.ts +0 -3
@@ -10,38 +10,38 @@
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
12
  import { assertDefined } from './assert';
13
- import { attachPatchData, readElementValue } from './context_discovery';
13
+ import { attachPatchData } from './context_discovery';
14
14
  import { callHooks } from './hooks';
15
- import { RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1 } from './interfaces/container';
15
+ import { NATIVE, RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1 } from './interfaces/container';
16
16
  import { unusedValueExportToPlacateAjd as unused2 } from './interfaces/node';
17
17
  import { unusedValueExportToPlacateAjd as unused3 } from './interfaces/projection';
18
18
  import { isProceduralRenderer, unusedValueExportToPlacateAjd as unused4 } from './interfaces/renderer';
19
19
  import { CLEANUP, CONTAINER_INDEX, FLAGS, HEADER_OFFSET, HOST_NODE, NEXT, PARENT, QUERIES, RENDERER, TVIEW, unusedValueExportToPlacateAjd as unused5 } from './interfaces/view';
20
20
  import { assertNodeType } from './node_assert';
21
- import { getLNode, stringify } from './util';
21
+ import { getNativeByTNode, isLContainer, readElementValue, stringify } from './util';
22
22
  /** @type {?} */
23
23
  const unusedValueToPlacateAjd = unused1 + unused2 + unused3 + unused4 + unused5;
24
24
  /**
25
- * Retrieves the parent LNode of a given node.
25
+ * Retrieves the parent element of a given node.
26
26
  * @param {?} tNode
27
27
  * @param {?} currentView
28
28
  * @return {?}
29
29
  */
30
- export function getParentLNode(tNode, currentView) {
31
- return tNode.parent == null ? getHostElementNode(currentView) :
32
- getLNode(tNode.parent, currentView);
30
+ export function getParentNative(tNode, currentView) {
31
+ return tNode.parent == null ? getHostNative(currentView) :
32
+ getNativeByTNode(tNode.parent, currentView);
33
33
  }
34
34
  /**
35
- * Gets the host LElementNode given a view. Will return null if the host element is an
36
- * LViewNode, since they are being phased out.
35
+ * Gets the host element given a view. Will return null if the current view is an embedded view,
36
+ * which does not have a host element.
37
37
  * @param {?} currentView
38
38
  * @return {?}
39
39
  */
40
- export function getHostElementNode(currentView) {
40
+ export function getHostNative(currentView) {
41
41
  /** @type {?} */
42
42
  const hostTNode = /** @type {?} */ (currentView[HOST_NODE]);
43
43
  return hostTNode && hostTNode.type !== 2 /* View */ ?
44
- (/** @type {?} */ (getLNode(hostTNode, /** @type {?} */ ((currentView[PARENT]))))) :
44
+ (/** @type {?} */ (getNativeByTNode(hostTNode, /** @type {?} */ ((currentView[PARENT]))))) :
45
45
  null;
46
46
  }
47
47
  /**
@@ -49,20 +49,19 @@ export function getHostElementNode(currentView) {
49
49
  * @param {?} embeddedView
50
50
  * @return {?}
51
51
  */
52
- export function getContainerNode(tNode, embeddedView) {
52
+ export function getLContainer(tNode, embeddedView) {
53
53
  if (tNode.index === -1) {
54
54
  /** @type {?} */
55
55
  const containerHostIndex = embeddedView[CONTAINER_INDEX];
56
- return containerHostIndex > -1 ? /** @type {?} */ ((embeddedView[PARENT]))[containerHostIndex].dynamicLContainerNode :
57
- null;
56
+ return containerHostIndex > -1 ? /** @type {?} */ ((embeddedView[PARENT]))[containerHostIndex] : null;
58
57
  }
59
58
  else {
60
59
  // This is a inline view node (e.g. embeddedViewStart)
61
- return /** @type {?} */ (getParentLNode(tNode, /** @type {?} */ ((embeddedView[PARENT]))));
60
+ return /** @type {?} */ (((embeddedView[PARENT]))[/** @type {?} */ ((tNode.parent)).index]);
62
61
  }
63
62
  }
64
63
  /**
65
- * Retrieves render parent LElementNode for a given view.
64
+ * Retrieves render parent for a given view.
66
65
  * Might be null if a view is not yet attached to any container.
67
66
  * @param {?} tViewNode
68
67
  * @param {?} view
@@ -70,8 +69,8 @@ export function getContainerNode(tNode, embeddedView) {
70
69
  */
71
70
  export function getContainerRenderParent(tViewNode, view) {
72
71
  /** @type {?} */
73
- const container = getContainerNode(tViewNode, view);
74
- return container ? container.data[RENDER_PARENT] : null;
72
+ const container = getLContainer(tViewNode, view);
73
+ return container ? container[RENDER_PARENT] : null;
75
74
  }
76
75
  /** @enum {number} */
77
76
  var WalkTNodeTreeAction = {
@@ -95,15 +94,15 @@ const projectionNodeStack = [];
95
94
  * one found, or on all of them.
96
95
  *
97
96
  * @param {?} viewToWalk the view to walk
98
- * @param {?} action identifies the action to be performed on the LElement nodes.
97
+ * @param {?} action identifies the action to be performed on the elements
99
98
  * @param {?} renderer the current renderer.
100
- * @param {?=} renderParentNode Optional the render parent node to be set in all LContainerNodes found,
99
+ * @param {?} renderParent Optional the render parent node to be set in all LContainers found,
101
100
  * required for action modes Insert and Destroy.
102
101
  * @param {?=} beforeNode Optional the node before which elements should be added, required for action
103
102
  * Insert.
104
103
  * @return {?}
105
104
  */
106
- function walkTNodeTree(viewToWalk, action, renderer, renderParentNode, beforeNode) {
105
+ function walkTNodeTree(viewToWalk, action, renderer, renderParent, beforeNode) {
107
106
  /** @type {?} */
108
107
  const rootTNode = /** @type {?} */ (viewToWalk[TVIEW].node);
109
108
  /** @type {?} */
@@ -115,35 +114,27 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParentNode, beforeNod
115
114
  while (tNode) {
116
115
  /** @type {?} */
117
116
  let nextTNode = null;
118
- /** @type {?} */
119
- const parent = renderParentNode ? renderParentNode.native : null;
120
117
  if (tNode.type === 3 /* Element */) {
118
+ executeNodeAction(action, renderer, renderParent, getNativeByTNode(tNode, currentView), beforeNode);
121
119
  /** @type {?} */
122
- const elementNode = getLNode(tNode, currentView);
123
- executeNodeAction(action, renderer, parent, /** @type {?} */ ((elementNode.native)), beforeNode);
124
- if (elementNode.dynamicLContainerNode) {
125
- executeNodeAction(action, renderer, parent, /** @type {?} */ ((elementNode.dynamicLContainerNode.native)), beforeNode);
120
+ const nodeOrContainer = currentView[tNode.index];
121
+ if (isLContainer(nodeOrContainer)) {
122
+ // This element has an LContainer, and its comment needs to be handled
123
+ executeNodeAction(action, renderer, renderParent, nodeOrContainer[NATIVE], beforeNode);
126
124
  }
127
125
  }
128
126
  else if (tNode.type === 0 /* Container */) {
129
127
  /** @type {?} */
130
- const lContainerNode = /** @type {?} */ (((currentView))[tNode.index]);
131
- executeNodeAction(action, renderer, parent, /** @type {?} */ ((lContainerNode.native)), beforeNode);
132
- /** @type {?} */
133
- const childContainerData = lContainerNode.dynamicLContainerNode ?
134
- lContainerNode.dynamicLContainerNode.data :
135
- lContainerNode.data;
136
- if (renderParentNode) {
137
- childContainerData[RENDER_PARENT] = renderParentNode;
138
- }
139
- if (childContainerData[VIEWS].length) {
140
- currentView = childContainerData[VIEWS][0];
128
+ const lContainer = /** @type {?} */ (((currentView))[tNode.index]);
129
+ executeNodeAction(action, renderer, renderParent, lContainer[NATIVE], beforeNode);
130
+ if (renderParent)
131
+ lContainer[RENDER_PARENT] = renderParent;
132
+ if (lContainer[VIEWS].length) {
133
+ currentView = lContainer[VIEWS][0];
141
134
  nextTNode = currentView[TVIEW].node;
142
135
  // When the walker enters a container, then the beforeNode has to become the local native
143
136
  // comment node.
144
- beforeNode = lContainerNode.dynamicLContainerNode ?
145
- lContainerNode.dynamicLContainerNode.native :
146
- lContainerNode.native;
137
+ beforeNode = lContainer[NATIVE];
147
138
  }
148
139
  }
149
140
  else if (tNode.type === 1 /* Projection */) {
@@ -174,7 +165,7 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParentNode, beforeNod
174
165
  }
175
166
  nextTNode = tNode.next;
176
167
  /**
177
- * Find the next node in the LNode tree, taking into account the place where a node is
168
+ * Find the next node in the TNode tree, taking into account the place where a node is
178
169
  * projected (in the shadow DOM) rather than where it comes from (in the light DOM).
179
170
  *
180
171
  * If there is no sibling node, then it goes to the next sibling of the parent node...
@@ -188,7 +179,7 @@ function walkTNodeTree(viewToWalk, action, renderer, renderParentNode, beforeNod
188
179
  // When exiting a container, the beforeNode must be restored to the previous value
189
180
  if (tNode.type === 0 /* Container */) {
190
181
  currentView = /** @type {?} */ ((currentView[PARENT]));
191
- beforeNode = currentView[tNode.index].native;
182
+ beforeNode = currentView[tNode.index][NATIVE];
192
183
  }
193
184
  if (tNode.type === 2 /* View */ && currentView[NEXT]) {
194
185
  currentView = /** @type {?} */ (currentView[NEXT]);
@@ -259,14 +250,12 @@ export function createTextNode(value, renderer) {
259
250
  */
260
251
  export function addRemoveViewFromContainer(viewToWalk, insertMode, beforeNode) {
261
252
  /** @type {?} */
262
- const parentNode = getContainerRenderParent(/** @type {?} */ (viewToWalk[TVIEW].node), viewToWalk);
263
- /** @type {?} */
264
- const parent = parentNode ? parentNode.native : null;
253
+ const renderParent = getContainerRenderParent(/** @type {?} */ (viewToWalk[TVIEW].node), viewToWalk);
265
254
  ngDevMode && assertNodeType(/** @type {?} */ (viewToWalk[TVIEW].node), 2 /* View */);
266
- if (parent) {
255
+ if (renderParent) {
267
256
  /** @type {?} */
268
257
  const renderer = viewToWalk[RENDERER];
269
- walkTNodeTree(viewToWalk, insertMode ? 0 /* Insert */ : 1 /* Detach */, renderer, parentNode, beforeNode);
258
+ walkTNodeTree(viewToWalk, insertMode ? 0 /* Insert */ : 1 /* Detach */, renderer, renderParent, beforeNode);
270
259
  }
271
260
  }
272
261
  /**
@@ -396,15 +385,15 @@ export function detachView(lContainer, removeIndex, detached) {
396
385
  * Removes a view from a container, i.e. detaches it and then destroys the underlying LView.
397
386
  *
398
387
  * @param {?} lContainer The container from which to remove a view
399
- * @param {?} tContainer The TContainer node associated with the LContainer
388
+ * @param {?} containerHost
400
389
  * @param {?} removeIndex The index of the view to remove
401
390
  * @return {?}
402
391
  */
403
- export function removeView(lContainer, tContainer, removeIndex) {
392
+ export function removeView(lContainer, containerHost, removeIndex) {
404
393
  /** @type {?} */
405
394
  const view = lContainer[VIEWS][removeIndex];
395
+ detachView(lContainer, removeIndex, !!containerHost.detached);
406
396
  destroyLView(view);
407
- detachView(lContainer, removeIndex, !!tContainer.detached);
408
397
  }
409
398
  /**
410
399
  * Gets the child of the given LViewData
@@ -412,11 +401,9 @@ export function removeView(lContainer, tContainer, removeIndex) {
412
401
  * @return {?}
413
402
  */
414
403
  export function getLViewChild(viewData) {
415
- if (viewData[TVIEW].childIndex === -1)
416
- return null;
417
404
  /** @type {?} */
418
- const hostNode = viewData[viewData[TVIEW].childIndex];
419
- return hostNode.data ? hostNode.data : (/** @type {?} */ (hostNode.dynamicLContainerNode)).data;
405
+ const childIndex = viewData[TVIEW].childIndex;
406
+ return childIndex === -1 ? null : viewData[childIndex];
420
407
  }
421
408
  /**
422
409
  * A standalone function which destroys an LView,
@@ -429,7 +416,7 @@ export function destroyLView(view) {
429
416
  /** @type {?} */
430
417
  const renderer = view[RENDERER];
431
418
  if (isProceduralRenderer(renderer) && renderer.destroyNode) {
432
- walkTNodeTree(view, 2 /* Destroy */, renderer);
419
+ walkTNodeTree(view, 2 /* Destroy */, renderer, null);
433
420
  }
434
421
  destroyViewTree(view);
435
422
  // Sets the destroyed flag
@@ -454,7 +441,7 @@ export function getParentState(state, rootView) {
454
441
  tNode.type === 2 /* View */) {
455
442
  // if it's an embedded view, the state needs to go up to the container, in case the
456
443
  // container has a next
457
- return /** @type {?} */ (((getContainerNode(tNode, /** @type {?} */ (state)))).data);
444
+ return /** @type {?} */ (getLContainer(/** @type {?} */ (tNode), /** @type {?} */ (state)));
458
445
  }
459
446
  else {
460
447
  // otherwise, use parent view for containers or component views
@@ -468,7 +455,7 @@ export function getParentState(state, rootView) {
468
455
  * @return {?}
469
456
  */
470
457
  function cleanUpView(viewOrContainer) {
471
- if ((/** @type {?} */ (viewOrContainer))[TVIEW]) {
458
+ if ((/** @type {?} */ (viewOrContainer)).length >= HEADER_OFFSET) {
472
459
  /** @type {?} */
473
460
  const view = /** @type {?} */ (viewOrContainer);
474
461
  removeListeners(view);
@@ -493,7 +480,7 @@ function removeListeners(viewData) {
493
480
  for (let i = 0; i < cleanup.length - 1; i += 2) {
494
481
  if (typeof cleanup[i] === 'string') {
495
482
  /** @type {?} */
496
- const native = readElementValue(viewData[cleanup[i + 1]]).native;
483
+ const native = readElementValue(viewData[cleanup[i + 1]]);
497
484
  /** @type {?} */
498
485
  const listener = /** @type {?} */ ((viewData[CLEANUP]))[cleanup[i + 2]];
499
486
  native.removeEventListener(cleanup[i], listener, cleanup[i + 3]);
@@ -549,7 +536,7 @@ export function getRenderParent(tNode, currentView) {
549
536
  /** @type {?} */
550
537
  const hostTNode = currentView[HOST_NODE];
551
538
  return tNode.parent == null && /** @type {?} */ ((hostTNode)).type === 2 /* View */ ?
552
- getContainerRenderParent(/** @type {?} */ (hostTNode), currentView) : /** @type {?} */ (getParentLNode(tNode, currentView));
539
+ getContainerRenderParent(/** @type {?} */ (hostTNode), currentView) : /** @type {?} */ (getParentNative(tNode, currentView));
553
540
  }
554
541
  return null;
555
542
  }
@@ -588,8 +575,8 @@ function canInsertNativeChildOfElement(tNode) {
588
575
  */
589
576
  function canInsertNativeChildOfView(viewTNode, view) {
590
577
  /** @type {?} */
591
- const container = /** @type {?} */ ((getContainerNode(viewTNode, view)));
592
- if (container == null || container.data[RENDER_PARENT] == null) {
578
+ const container = /** @type {?} */ ((getLContainer(viewTNode, view)));
579
+ if (container == null || container[RENDER_PARENT] == null) {
593
580
  // The `View` is not inserted into a `Container` or the parent `Container`
594
581
  // itself is disconnected. So we have to delay.
595
582
  return false;
@@ -663,32 +650,28 @@ function nativeInsertBefore(renderer, parent, child, beforeNode) {
663
650
  * @return {?} Whether or not the child was appended
664
651
  */
665
652
  export function appendChild(childEl, childTNode, currentView) {
666
- /** @type {?} */
667
- const parentLNode = getParentLNode(childTNode, currentView);
668
- /** @type {?} */
669
- const parentEl = parentLNode ? parentLNode.native : null;
670
653
  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {
671
654
  /** @type {?} */
672
655
  const renderer = currentView[RENDERER];
673
656
  /** @type {?} */
657
+ const parentEl = getParentNative(childTNode, currentView);
658
+ /** @type {?} */
674
659
  const parentTNode = childTNode.parent || /** @type {?} */ ((currentView[HOST_NODE]));
675
660
  if (parentTNode.type === 2 /* View */) {
676
661
  /** @type {?} */
677
- const container = /** @type {?} */ (getContainerNode(parentTNode, currentView));
678
- /** @type {?} */
679
- const renderParent = container.data[RENDER_PARENT];
662
+ const lContainer = /** @type {?} */ (getLContainer(/** @type {?} */ (parentTNode), currentView));
680
663
  /** @type {?} */
681
- const views = container.data[VIEWS];
664
+ const views = lContainer[VIEWS];
682
665
  /** @type {?} */
683
666
  const index = views.indexOf(currentView);
684
- nativeInsertBefore(renderer, /** @type {?} */ ((renderParent)).native, childEl, getBeforeNodeForView(index, views, container));
667
+ nativeInsertBefore(renderer, /** @type {?} */ ((lContainer[RENDER_PARENT])), childEl, getBeforeNodeForView(index, views, lContainer[NATIVE]));
685
668
  }
686
669
  else if (parentTNode.type === 4 /* ElementContainer */) {
687
670
  /** @type {?} */
688
671
  let elementContainer = getHighestElementContainer(childTNode);
689
672
  /** @type {?} */
690
- let node = /** @type {?} */ ((getRenderParent(elementContainer, currentView)));
691
- nativeInsertBefore(renderer, node.native, childEl, parentEl);
673
+ let renderParent = /** @type {?} */ ((getRenderParent(elementContainer, currentView)));
674
+ nativeInsertBefore(renderer, renderParent, childEl, parentEl);
692
675
  }
693
676
  else {
694
677
  isProceduralRenderer(renderer) ? renderer.appendChild(/** @type {?} */ (((parentEl))), childEl) : /** @type {?} */ ((parentEl)).appendChild(childEl);
@@ -712,36 +695,37 @@ function getHighestElementContainer(ngContainer) {
712
695
  /**
713
696
  * @param {?} index
714
697
  * @param {?} views
715
- * @param {?} container
698
+ * @param {?} containerNative
716
699
  * @return {?}
717
700
  */
718
- export function getBeforeNodeForView(index, views, container) {
701
+ export function getBeforeNodeForView(index, views, containerNative) {
719
702
  if (index + 1 < views.length) {
720
703
  /** @type {?} */
721
704
  const view = /** @type {?} */ (views[index + 1]);
722
705
  /** @type {?} */
723
706
  const viewTNode = /** @type {?} */ (view[HOST_NODE]);
724
- return viewTNode.child ? getLNode(viewTNode.child, view).native : container.native;
707
+ return viewTNode.child ? getNativeByTNode(viewTNode.child, view) : containerNative;
725
708
  }
726
709
  else {
727
- return container.native;
710
+ return containerNative;
728
711
  }
729
712
  }
730
713
  /**
731
- * Removes the `child` element of the `parent` from the DOM.
714
+ * Removes the `child` element from the DOM if not in view and not projected.
732
715
  *
733
- * @param {?} tNode
734
- * @param {?} child The child that should be removed
716
+ * @param {?} childTNode The TNode of the child to remove
717
+ * @param {?} childEl The child that should be removed
735
718
  * @param {?} currentView The current LView
736
719
  * @return {?} Whether or not the child was removed
737
720
  */
738
- export function removeChild(tNode, child, currentView) {
739
- /** @type {?} */
740
- const parentNative = /** @type {?} */ (((getParentLNode(tNode, currentView))).native);
741
- if (child !== null && canInsertNativeNode(tNode, currentView)) {
721
+ export function removeChild(childTNode, childEl, currentView) {
722
+ // We only remove the element if not in View or not projected.
723
+ if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {
724
+ /** @type {?} */
725
+ const parentNative = /** @type {?} */ (((getParentNative(childTNode, currentView))));
742
726
  /** @type {?} */
743
727
  const renderer = currentView[RENDERER];
744
- isProceduralRenderer(renderer) ? renderer.removeChild(/** @type {?} */ (parentNative), child) : /** @type {?} */ ((parentNative)).removeChild(child);
728
+ isProceduralRenderer(renderer) ? renderer.removeChild(/** @type {?} */ (parentNative), childEl) : /** @type {?} */ ((parentNative)).removeChild(childEl);
745
729
  return true;
746
730
  }
747
731
  return false;
@@ -750,45 +734,51 @@ export function removeChild(tNode, child, currentView) {
750
734
  * Appends a projected node to the DOM, or in the case of a projected container,
751
735
  * appends the nodes from all of the container's active views to the DOM.
752
736
  *
753
- * @param {?} projectedLNode The node to process
754
- * @param {?} projectedTNode
755
- * @param {?} tProjectionNode
737
+ * @param {?} projectedTNode The TNode to be projected
738
+ * @param {?} tProjectionNode The projection (ng-content) TNode
756
739
  * @param {?} currentView Current LView
757
- * @param {?} projectionView Projection view
740
+ * @param {?} projectionView Projection view (view above current)
758
741
  * @return {?}
759
742
  */
760
- export function appendProjectedNode(projectedLNode, projectedTNode, tProjectionNode, currentView, projectionView) {
761
- appendChild(projectedLNode.native, tProjectionNode, currentView);
743
+ export function appendProjectedNode(projectedTNode, tProjectionNode, currentView, projectionView) {
744
+ /** @type {?} */
745
+ const native = getNativeByTNode(projectedTNode, projectionView);
746
+ appendChild(native, tProjectionNode, currentView);
762
747
  // the projected contents are processed while in the shadow view (which is the currentView)
763
748
  // therefore we need to extract the view where the host element lives since it's the
764
749
  // logical container of the content projected views
765
- attachPatchData(projectedLNode.native, projectionView);
750
+ attachPatchData(native, projectionView);
766
751
  /** @type {?} */
767
752
  const renderParent = getRenderParent(tProjectionNode, currentView);
753
+ /** @type {?} */
754
+ const nodeOrContainer = projectionView[projectedTNode.index];
768
755
  if (projectedTNode.type === 0 /* Container */) {
756
+ // The node we are adding is a container and we are adding it to an element which
757
+ // is not a component (no more re-projection).
758
+ // Alternatively a container is projected at the root of a component's template
759
+ // and can't be re-projected (as not content of any component).
760
+ // Assign the final projection location in those cases.
761
+ nodeOrContainer[RENDER_PARENT] = renderParent;
769
762
  /** @type {?} */
770
- const lContainer = (/** @type {?} */ (projectedLNode)).data;
771
- lContainer[RENDER_PARENT] = renderParent;
772
- /** @type {?} */
773
- const views = lContainer[VIEWS];
763
+ const views = nodeOrContainer[VIEWS];
774
764
  for (let i = 0; i < views.length; i++) {
775
- addRemoveViewFromContainer(views[i], true, projectedLNode.native);
765
+ addRemoveViewFromContainer(views[i], true, nodeOrContainer[NATIVE]);
776
766
  }
777
767
  }
778
- else if (projectedTNode.type === 4 /* ElementContainer */) {
779
- /** @type {?} */
780
- let ngContainerChildTNode = /** @type {?} */ (projectedTNode.child);
781
- while (ngContainerChildTNode) {
768
+ else {
769
+ if (projectedTNode.type === 4 /* ElementContainer */) {
782
770
  /** @type {?} */
783
- let ngContainerChild = getLNode(ngContainerChildTNode, projectionView);
784
- appendProjectedNode(/** @type {?} */ (ngContainerChild), ngContainerChildTNode, tProjectionNode, currentView, projectionView);
785
- ngContainerChildTNode = ngContainerChildTNode.next;
771
+ let ngContainerChildTNode = /** @type {?} */ (projectedTNode.child);
772
+ while (ngContainerChildTNode) {
773
+ appendProjectedNode(ngContainerChildTNode, tProjectionNode, currentView, projectionView);
774
+ ngContainerChildTNode = ngContainerChildTNode.next;
775
+ }
776
+ }
777
+ if (isLContainer(nodeOrContainer)) {
778
+ nodeOrContainer[RENDER_PARENT] = renderParent;
779
+ appendChild(nodeOrContainer[NATIVE], tProjectionNode, currentView);
786
780
  }
787
- }
788
- if (projectedLNode.dynamicLContainerNode) {
789
- projectedLNode.dynamicLContainerNode.data[RENDER_PARENT] = renderParent;
790
- appendChild(projectedLNode.dynamicLContainerNode.native, tProjectionNode, currentView);
791
781
  }
792
782
  }
793
783
 
794
- //# 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, readElementValue} from './context_discovery';\nimport {callHooks} from './hooks';\nimport {LContainer, RENDER_PARENT, VIEWS, unusedValueExportToPlacateAjd as unused1} from './interfaces/container';\nimport {LContainerNode, LElementContainerNode, LElementNode, LTextNode, TContainerNode, 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 {getLNode, stringify} from './util';\n\nconst unusedValueToPlacateAjd = unused1 + unused2 + unused3 + unused4 + unused5;\n\n/** Retrieves the parent LNode of a given node. */\nexport function getParentLNode(tNode: TNode, currentView: LViewData): LElementNode|\n    LElementContainerNode|LContainerNode|null {\n  return tNode.parent == null ? getHostElementNode(currentView) :\n                                getLNode(tNode.parent, currentView);\n}\n\n/**\n * Gets the host LElementNode given a view. Will return null if the host element is an\n * LViewNode, since they are being phased out.\n */\nexport function getHostElementNode(currentView: LViewData): LElementNode|null {\n  const hostTNode = currentView[HOST_NODE] as TElementNode;\n  return hostTNode && hostTNode.type !== TNodeType.View ?\n      (getLNode(hostTNode, currentView[PARENT] !) as LElementNode) :\n      null;\n}\n\nexport function getContainerNode(tNode: TNode, embeddedView: LViewData): LContainerNode|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 ?\n        embeddedView[PARENT] ![containerHostIndex].dynamicLContainerNode :\n        null;\n  } else {\n    // This is a inline view node (e.g. embeddedViewStart)\n    return getParentLNode(tNode, embeddedView[PARENT] !) as LContainerNode;\n  }\n}\n\n\n/**\n * Retrieves render parent LElementNode 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): LElementNode|null {\n  const container = getContainerNode(tViewNode, view);\n  return container ? container.data[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 LElement nodes.\n * @param renderer the current renderer.\n * @param renderParentNode Optional the render parent node to be set in all LContainerNodes 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    renderParentNode?: LElementNode | 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    const parent = renderParentNode ? renderParentNode.native : null;\n    if (tNode.type === TNodeType.Element) {\n      const elementNode = getLNode(tNode, currentView);\n      executeNodeAction(action, renderer, parent, elementNode.native !, beforeNode);\n      if (elementNode.dynamicLContainerNode) {\n        executeNodeAction(\n            action, renderer, parent, elementNode.dynamicLContainerNode.native !, beforeNode);\n      }\n    } else if (tNode.type === TNodeType.Container) {\n      const lContainerNode: LContainerNode = currentView ![tNode.index] as LContainerNode;\n      executeNodeAction(action, renderer, parent, lContainerNode.native !, beforeNode);\n      const childContainerData: LContainer = lContainerNode.dynamicLContainerNode ?\n          lContainerNode.dynamicLContainerNode.data :\n          lContainerNode.data;\n      if (renderParentNode) {\n        childContainerData[RENDER_PARENT] = renderParentNode;\n      }\n\n      if (childContainerData[VIEWS].length) {\n        currentView = childContainerData[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 = lContainerNode.dynamicLContainerNode ?\n            lContainerNode.dynamicLContainerNode.native :\n            lContainerNode.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 LNode 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 parentNode = getContainerRenderParent(viewToWalk[TVIEW].node as TViewNode, viewToWalk);\n  const parent = parentNode ? parentNode.native : null;\n  ngDevMode && assertNodeType(viewToWalk[TVIEW].node as TNode, TNodeType.View);\n  if (parent) {\n    const renderer = viewToWalk[RENDERER];\n    walkTNodeTree(\n        viewToWalk, insertMode ? WalkTNodeTreeAction.Insert : WalkTNodeTreeAction.Detach, renderer,\n        parentNode, 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, tContainer: TContainerNode, removeIndex: number) {\n  const view = lContainer[VIEWS][removeIndex];\n  destroyLView(view);\n  detachView(lContainer, removeIndex, !!tContainer.detached);\n}\n\n/** Gets the child of the given LViewData */\nexport function getLViewChild(viewData: LViewData): LViewData|LContainer|null {\n  if (viewData[TVIEW].childIndex === -1) return null;\n\n  const hostNode: LElementNode|LContainerNode = viewData[viewData[TVIEW].childIndex];\n\n  return hostNode.data ? hostNode.data : (hostNode.dynamicLContainerNode as LContainerNode).data;\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);\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 getContainerNode(tNode, state as LViewData) !.data as any;\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)[TVIEW]) {\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]]).native;\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): LElementNode|null {\n  if (canInsertNativeNode(tNode, currentView)) {\n    const hostTNode = currentView[HOST_NODE];\n    return tNode.parent == null && hostTNode !.type === TNodeType.View ?\n        getContainerRenderParent(hostTNode as TViewNode, currentView) :\n        getParentLNode(tNode, currentView) as LElementNode;\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 = getContainerNode(viewTNode, view) !;\n  if (container == null || container.data[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 parent The parent where the child will be inserted into.\n * @param currentView Current LView being processed.\n * @return boolean Whether the child 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 && tNode.parent.type === TNodeType.ElementContainer) {\n    currentNode = getHighestElementContainer(tNode);\n    parent = currentNode.parent;\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 */\nfunction 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 * 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, childTNode: TNode, currentView: LViewData): boolean {\n  const parentLNode = getParentLNode(childTNode, currentView);\n  const parentEl = parentLNode ? parentLNode.native : null;\n\n  if (childEl !== null && canInsertNativeNode(childTNode, currentView)) {\n    const renderer = currentView[RENDERER];\n    const parentTNode: TNode = childTNode.parent || currentView[HOST_NODE] !;\n\n    if (parentTNode.type === TNodeType.View) {\n      const container = getContainerNode(parentTNode, currentView) as LContainerNode;\n      const renderParent = container.data[RENDER_PARENT];\n      const views = container.data[VIEWS];\n      const index = views.indexOf(currentView);\n      nativeInsertBefore(\n          renderer, renderParent !.native, childEl, getBeforeNodeForView(index, views, container));\n    } else if (parentTNode.type === TNodeType.ElementContainer) {\n      let elementContainer = getHighestElementContainer(childTNode);\n      let node: LElementNode = getRenderParent(elementContainer, currentView) !;\n      nativeInsertBefore(renderer, node.native, childEl, parentEl);\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[], container: LContainerNode) {\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 ? getLNode(viewTNode.child, view).native : container.native;\n  } else {\n    return container.native;\n  }\n}\n\n/**\n * Removes the `child` element of the `parent` from the DOM.\n *\n * @param parentEl The parent element from which to remove the child\n * @param child 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(tNode: TNode, child: RNode | null, currentView: LViewData): boolean {\n  const parentNative = getParentLNode(tNode, currentView) !.native as RElement;\n  if (child !== null && canInsertNativeNode(tNode, currentView)) {\n    // We only remove the element if not in View or not projected.\n    const renderer = currentView[RENDERER];\n    isProceduralRenderer(renderer) ? renderer.removeChild(parentNative as RElement, child) :\n                                     parentNative !.removeChild(child);\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 projectedLNode The node to process\n * @param parentNode The last parent element to be processed\n * @param tProjectionNode\n * @param currentView Current LView\n * @param projectionView Projection view\n */\nexport function appendProjectedNode(\n    projectedLNode: LElementNode | LElementContainerNode | LTextNode | LContainerNode,\n    projectedTNode: TNode, tProjectionNode: TNode, currentView: LViewData,\n    projectionView: LViewData): void {\n  appendChild(projectedLNode.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(projectedLNode.native, projectionView);\n\n  const renderParent = getRenderParent(tProjectionNode, currentView);\n\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    const lContainer = (projectedLNode as LContainerNode).data;\n    lContainer[RENDER_PARENT] = renderParent;\n    const views = lContainer[VIEWS];\n    for (let i = 0; i < views.length; i++) {\n      addRemoveViewFromContainer(views[i], true, projectedLNode.native);\n    }\n  } else if (projectedTNode.type === TNodeType.ElementContainer) {\n    let ngContainerChildTNode: TNode|null = projectedTNode.child as TNode;\n    while (ngContainerChildTNode) {\n      let ngContainerChild = getLNode(ngContainerChildTNode, projectionView);\n      appendProjectedNode(\n          ngContainerChild as LElementNode | LElementContainerNode | LTextNode | LContainerNode,\n          ngContainerChildTNode, tProjectionNode, currentView, projectionView);\n      ngContainerChildTNode = ngContainerChildTNode.next;\n    }\n  }\n  if (projectedLNode.dynamicLContainerNode) {\n    projectedLNode.dynamicLContainerNode.data[RENDER_PARENT] = renderParent;\n    appendChild(projectedLNode.dynamicLContainerNode.native, tProjectionNode, currentView);\n  }\n}\n"]}
784
+ //# 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, 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  return tNode.parent == null ? getHostNative(currentView) :\n                                getNativeByTNode(tNode.parent, currentView);\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    const hostTNode = currentView[HOST_NODE];\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 parent The parent where the child will be inserted into.\n * @param currentView Current LView being processed.\n * @return boolean Whether the child 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 && tNode.parent.type === TNodeType.ElementContainer) {\n    currentNode = getHighestElementContainer(tNode);\n    parent = currentNode.parent;\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 */\nfunction 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 * 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, 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      let elementContainer = getHighestElementContainer(childTNode);\n      let renderParent: RElement = getRenderParent(elementContainer, currentView) !;\n      nativeInsertBefore(renderer, renderParent, childEl, parentEl);\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"]}