@angular/core 7.2.0-beta.0 → 7.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (454) hide show
  1. package/bundles/core-testing.umd.js +194 -128
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +5582 -4512
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +122 -129
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +12 -12
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +45 -35
  12. package/esm2015/core.js +12 -13
  13. package/esm2015/index.js +3 -4
  14. package/esm2015/public_api.js +3 -5
  15. package/esm2015/src/application_init.js +22 -10
  16. package/esm2015/src/application_module.js +6 -5
  17. package/esm2015/src/application_ref.js +94 -37
  18. package/esm2015/src/application_tokens.js +21 -16
  19. package/esm2015/src/change_detection/change_detection.js +8 -7
  20. package/esm2015/src/change_detection/change_detection_util.js +2 -4
  21. package/esm2015/src/change_detection/change_detector_ref.js +2 -3
  22. package/esm2015/src/change_detection/constants.js +30 -32
  23. package/esm2015/src/change_detection/differs/default_iterable_differ.js +108 -29
  24. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +53 -16
  25. package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
  26. package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
  27. package/esm2015/src/change_detection/pipe_transform.js +10 -5
  28. package/esm2015/src/change_detection.js +7 -3
  29. package/esm2015/src/codegen_private_exports.js +2 -3
  30. package/esm2015/src/console.js +3 -3
  31. package/esm2015/src/core.js +3 -4
  32. package/esm2015/src/core_private_export.js +2 -3
  33. package/esm2015/src/core_render3_private_export.js +13 -7
  34. package/esm2015/src/debug/debug_node.js +132 -90
  35. package/esm2015/src/di/defs.js +59 -50
  36. package/esm2015/src/di/forward_ref.js +5 -6
  37. package/esm2015/src/di/injectable.js +11 -11
  38. package/esm2015/src/di/injection_token.js +10 -6
  39. package/esm2015/src/di/injector.js +53 -43
  40. package/esm2015/src/di/injector_compatibility.js +13 -12
  41. package/esm2015/src/di/metadata.js +22 -13
  42. package/esm2015/src/di/provider.js +137 -120
  43. package/esm2015/src/di/r3_injector.js +127 -57
  44. package/esm2015/src/di/reflective_errors.js +19 -13
  45. package/esm2015/src/di/reflective_injector.js +20 -16
  46. package/esm2015/src/di/reflective_key.js +7 -5
  47. package/esm2015/src/di/reflective_provider.js +21 -20
  48. package/esm2015/src/di/scope.js +5 -5
  49. package/esm2015/src/di/util.js +13 -14
  50. package/esm2015/src/di.js +2 -3
  51. package/esm2015/src/error_handler.js +5 -4
  52. package/esm2015/src/errors.js +7 -8
  53. package/esm2015/src/event_emitter.js +3 -3
  54. package/esm2015/src/i18n/tokens.js +12 -10
  55. package/esm2015/src/is_dev_mode.js +2 -3
  56. package/esm2015/src/ivy_switch.js +2 -3
  57. package/esm2015/src/linker/compiler.js +9 -12
  58. package/esm2015/src/linker/component_factory.js +2 -3
  59. package/esm2015/src/linker/component_factory_resolver.js +24 -10
  60. package/esm2015/src/linker/element_ref.js +5 -3
  61. package/esm2015/src/linker/ng_module_factory.js +6 -5
  62. package/esm2015/src/linker/ng_module_factory_loader.js +63 -16
  63. package/esm2015/src/linker/query_list.js +16 -14
  64. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +12 -5
  65. package/esm2015/src/linker/template_ref.js +2 -3
  66. package/esm2015/src/linker/view_container_ref.js +2 -3
  67. package/esm2015/src/linker/view_ref.js +13 -7
  68. package/esm2015/src/linker.js +3 -3
  69. package/esm2015/src/metadata/di.js +22 -15
  70. package/esm2015/src/metadata/directives.js +33 -19
  71. package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
  72. package/esm2015/src/metadata/ng_module.js +82 -68
  73. package/esm2015/src/metadata/resource_loading.js +4 -3
  74. package/esm2015/src/metadata/view.js +25 -26
  75. package/esm2015/src/metadata.js +6 -3
  76. package/esm2015/src/platform_core_providers.js +5 -5
  77. package/esm2015/src/profile/profile.js +17 -13
  78. package/esm2015/src/profile/wtf_impl.js +36 -16
  79. package/esm2015/src/r3_symbols.js +18 -5
  80. package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
  81. package/esm2015/src/reflection/reflection.js +5 -5
  82. package/esm2015/src/reflection/reflection_capabilities.js +38 -27
  83. package/esm2015/src/reflection/reflector.js +2 -3
  84. package/esm2015/src/reflection/types.js +2 -12
  85. package/esm2015/src/render/api.js +67 -47
  86. package/esm2015/src/render.js +3 -3
  87. package/esm2015/src/render3/assert.js +38 -3
  88. package/esm2015/src/render3/bindings.js +111 -0
  89. package/esm2015/src/render3/component.js +88 -77
  90. package/esm2015/src/render3/component_ref.js +86 -56
  91. package/esm2015/src/render3/context_discovery.js +94 -92
  92. package/esm2015/src/render3/definition.js +58 -51
  93. package/esm2015/src/render3/di.js +206 -166
  94. package/esm2015/src/render3/di_setup.js +51 -31
  95. package/esm2015/src/render3/discovery_utils.js +225 -39
  96. package/esm2015/src/render3/empty.js +28 -0
  97. package/esm2015/src/render3/errors.js +11 -15
  98. package/esm2015/src/render3/features/inherit_definition_feature.js +13 -10
  99. package/esm2015/src/render3/features/ng_onchanges_feature.js +15 -12
  100. package/esm2015/src/render3/features/providers_feature.js +2 -3
  101. package/esm2015/src/render3/fields.js +5 -5
  102. package/esm2015/src/render3/global_utils.js +22 -7
  103. package/esm2015/src/render3/global_utils_api.js +13 -7
  104. package/esm2015/src/render3/hooks.js +21 -26
  105. package/esm2015/src/render3/i18n.js +134 -115
  106. package/esm2015/src/render3/index.js +15 -7
  107. package/esm2015/src/render3/instructions.js +938 -813
  108. package/esm2015/src/render3/interfaces/container.js +37 -6
  109. package/esm2015/src/render3/interfaces/context.js +39 -37
  110. package/esm2015/src/render3/interfaces/definition.js +225 -265
  111. package/esm2015/src/render3/interfaces/i18n.js +179 -151
  112. package/esm2015/src/render3/interfaces/injector.js +95 -13
  113. package/esm2015/src/render3/interfaces/node.js +413 -382
  114. package/esm2015/src/render3/interfaces/player.js +78 -37
  115. package/esm2015/src/render3/interfaces/projection.js +5 -10
  116. package/esm2015/src/render3/interfaces/query.js +66 -60
  117. package/esm2015/src/render3/interfaces/renderer.js +292 -117
  118. package/esm2015/src/render3/interfaces/sanitization.js +2 -6
  119. package/esm2015/src/render3/interfaces/styling.js +322 -111
  120. package/esm2015/src/render3/interfaces/view.js +356 -298
  121. package/esm2015/src/render3/jit/compiler_facade.js +10 -4
  122. package/esm2015/src/render3/jit/compiler_facade_interface.js +195 -152
  123. package/esm2015/src/render3/jit/directive.js +26 -16
  124. package/esm2015/src/render3/jit/environment.js +8 -5
  125. package/esm2015/src/render3/jit/injectable.js +7 -10
  126. package/esm2015/src/render3/jit/module.js +309 -25
  127. package/esm2015/src/render3/jit/pipe.js +2 -3
  128. package/esm2015/src/render3/jit/util.js +2 -3
  129. package/esm2015/src/render3/metadata.js +11 -10
  130. package/esm2015/src/render3/ng_dev_mode.js +5 -6
  131. package/esm2015/src/render3/ng_module_ref.js +48 -22
  132. package/esm2015/src/render3/node_assert.js +2 -3
  133. package/esm2015/src/render3/node_manipulation.js +137 -117
  134. package/esm2015/src/render3/node_selector_matcher.js +46 -19
  135. package/esm2015/src/render3/pipe.js +36 -21
  136. package/esm2015/src/render3/players.js +17 -12
  137. package/esm2015/src/render3/pure_function.js +86 -39
  138. package/esm2015/src/render3/query.js +93 -80
  139. package/esm2015/src/render3/state.js +88 -203
  140. package/esm2015/src/render3/styling/class_and_style_bindings.js +963 -249
  141. package/esm2015/src/render3/styling/core_player_handler.js +6 -4
  142. package/esm2015/src/render3/styling/player_factory.js +3 -4
  143. package/esm2015/src/render3/styling/util.js +69 -31
  144. package/esm2015/src/render3/tokens.js +7 -6
  145. package/esm2015/src/render3/util.js +65 -55
  146. package/esm2015/src/render3/view_engine_compatibility.js +36 -59
  147. package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
  148. package/esm2015/src/render3/view_ref.js +58 -44
  149. package/esm2015/src/sanitization/bypass.js +29 -6
  150. package/esm2015/src/sanitization/html_sanitizer.js +48 -16
  151. package/esm2015/src/sanitization/inert_body.js +33 -18
  152. package/esm2015/src/sanitization/sanitization.js +35 -25
  153. package/esm2015/src/sanitization/security.js +3 -4
  154. package/esm2015/src/sanitization/style_sanitizer.js +10 -7
  155. package/esm2015/src/sanitization/url_sanitizer.js +9 -7
  156. package/esm2015/src/testability/testability.js +72 -42
  157. package/esm2015/src/type.js +6 -8
  158. package/esm2015/src/util/decorators.js +19 -14
  159. package/esm2015/src/util/lang.js +2 -3
  160. package/esm2015/src/util/ng_reflect.js +2 -3
  161. package/esm2015/src/util/noop.js +2 -3
  162. package/esm2015/src/util/property.js +3 -4
  163. package/esm2015/src/util.js +12 -4
  164. package/esm2015/src/version.js +6 -6
  165. package/esm2015/src/view/element.js +17 -17
  166. package/esm2015/src/view/entrypoint.js +15 -5
  167. package/esm2015/src/view/errors.js +4 -5
  168. package/esm2015/src/view/index.js +2 -3
  169. package/esm2015/src/view/ng_content.js +3 -4
  170. package/esm2015/src/view/ng_module.js +2 -3
  171. package/esm2015/src/view/provider.js +89 -24
  172. package/esm2015/src/view/pure_expression.js +14 -15
  173. package/esm2015/src/view/query.js +14 -14
  174. package/esm2015/src/view/refs.js +96 -38
  175. package/esm2015/src/view/services.js +64 -37
  176. package/esm2015/src/view/text.js +5 -6
  177. package/esm2015/src/view/types.js +390 -325
  178. package/esm2015/src/view/util.js +29 -24
  179. package/esm2015/src/view/view.js +43 -36
  180. package/esm2015/src/view/view_attach.js +9 -10
  181. package/esm2015/src/zone/ng_zone.js +29 -28
  182. package/esm2015/src/zone.js +3 -3
  183. package/esm2015/testing/index.js +2 -3
  184. package/esm2015/testing/public_api.js +4 -4
  185. package/esm2015/testing/src/async.js +2 -3
  186. package/esm2015/testing/src/async_fallback.js +8 -7
  187. package/esm2015/testing/src/async_test_completer.js +14 -6
  188. package/esm2015/testing/src/before_each.js +10 -4
  189. package/esm2015/testing/src/component_fixture.js +48 -17
  190. package/esm2015/testing/src/fake_async.js +9 -3
  191. package/esm2015/testing/src/fake_async_fallback.js +5 -5
  192. package/esm2015/testing/src/lang_utils.js +3 -4
  193. package/esm2015/testing/src/logger.js +2 -3
  194. package/esm2015/testing/src/metadata_override.js +2 -6
  195. package/esm2015/testing/src/metadata_overrider.js +9 -8
  196. package/esm2015/testing/src/ng_zone_mock.js +2 -3
  197. package/esm2015/testing/src/private_export_testing.js +2 -3
  198. package/esm2015/testing/src/r3_test_bed.js +324 -174
  199. package/esm2015/testing/src/resolvers.js +28 -11
  200. package/esm2015/testing/src/test_bed.js +123 -54
  201. package/esm2015/testing/src/test_bed_common.js +142 -85
  202. package/esm2015/testing/src/test_compiler.js +2 -3
  203. package/esm2015/testing/src/testing.js +3 -3
  204. package/esm2015/testing/src/testing_internal.js +17 -12
  205. package/esm2015/testing/testing.js +1 -2
  206. package/esm5/core.js +12 -13
  207. package/esm5/index.js +1 -2
  208. package/esm5/public_api.js +1 -2
  209. package/esm5/src/application_init.js +1 -2
  210. package/esm5/src/application_module.js +1 -2
  211. package/esm5/src/application_ref.js +1 -2
  212. package/esm5/src/application_tokens.js +1 -2
  213. package/esm5/src/change_detection/change_detection.js +1 -2
  214. package/esm5/src/change_detection/change_detection_util.js +1 -2
  215. package/esm5/src/change_detection/change_detector_ref.js +1 -2
  216. package/esm5/src/change_detection/constants.js +3 -4
  217. package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -2
  218. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -2
  219. package/esm5/src/change_detection/differs/iterable_differs.js +1 -2
  220. package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -2
  221. package/esm5/src/change_detection/pipe_transform.js +1 -2
  222. package/esm5/src/change_detection.js +1 -2
  223. package/esm5/src/codegen_private_exports.js +1 -2
  224. package/esm5/src/console.js +1 -2
  225. package/esm5/src/core.js +1 -2
  226. package/esm5/src/core_private_export.js +1 -2
  227. package/esm5/src/core_render3_private_export.js +7 -5
  228. package/esm5/src/debug/debug_node.js +79 -58
  229. package/esm5/src/di/defs.js +3 -4
  230. package/esm5/src/di/forward_ref.js +1 -2
  231. package/esm5/src/di/injectable.js +1 -2
  232. package/esm5/src/di/injection_token.js +1 -2
  233. package/esm5/src/di/injector.js +1 -2
  234. package/esm5/src/di/injector_compatibility.js +1 -2
  235. package/esm5/src/di/metadata.js +1 -2
  236. package/esm5/src/di/provider.js +1 -2
  237. package/esm5/src/di/r3_injector.js +48 -28
  238. package/esm5/src/di/reflective_errors.js +1 -2
  239. package/esm5/src/di/reflective_injector.js +1 -2
  240. package/esm5/src/di/reflective_key.js +1 -2
  241. package/esm5/src/di/reflective_provider.js +1 -2
  242. package/esm5/src/di/scope.js +1 -2
  243. package/esm5/src/di/util.js +1 -2
  244. package/esm5/src/di.js +1 -2
  245. package/esm5/src/error_handler.js +1 -2
  246. package/esm5/src/errors.js +1 -2
  247. package/esm5/src/event_emitter.js +1 -2
  248. package/esm5/src/i18n/tokens.js +1 -2
  249. package/esm5/src/is_dev_mode.js +1 -2
  250. package/esm5/src/ivy_switch.js +1 -2
  251. package/esm5/src/linker/compiler.js +1 -2
  252. package/esm5/src/linker/component_factory.js +1 -2
  253. package/esm5/src/linker/component_factory_resolver.js +1 -2
  254. package/esm5/src/linker/element_ref.js +1 -2
  255. package/esm5/src/linker/ng_module_factory.js +1 -2
  256. package/esm5/src/linker/ng_module_factory_loader.js +37 -13
  257. package/esm5/src/linker/query_list.js +1 -2
  258. package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -2
  259. package/esm5/src/linker/template_ref.js +1 -2
  260. package/esm5/src/linker/view_container_ref.js +1 -2
  261. package/esm5/src/linker/view_ref.js +1 -2
  262. package/esm5/src/linker.js +1 -2
  263. package/esm5/src/metadata/di.js +1 -2
  264. package/esm5/src/metadata/directives.js +1 -2
  265. package/esm5/src/metadata/lifecycle_hooks.js +1 -2
  266. package/esm5/src/metadata/ng_module.js +1 -2
  267. package/esm5/src/metadata/resource_loading.js +1 -2
  268. package/esm5/src/metadata/view.js +1 -2
  269. package/esm5/src/metadata.js +1 -2
  270. package/esm5/src/platform_core_providers.js +1 -2
  271. package/esm5/src/profile/profile.js +1 -2
  272. package/esm5/src/profile/wtf_impl.js +1 -2
  273. package/esm5/src/r3_symbols.js +1 -2
  274. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -2
  275. package/esm5/src/reflection/reflection.js +1 -2
  276. package/esm5/src/reflection/reflection_capabilities.js +1 -2
  277. package/esm5/src/reflection/reflector.js +1 -2
  278. package/esm5/src/reflection/types.js +1 -2
  279. package/esm5/src/render/api.js +1 -2
  280. package/esm5/src/render.js +1 -2
  281. package/esm5/src/render3/assert.js +15 -2
  282. package/esm5/src/render3/bindings.js +63 -0
  283. package/esm5/src/render3/component.js +23 -16
  284. package/esm5/src/render3/component_ref.js +43 -36
  285. package/esm5/src/render3/context_discovery.js +68 -77
  286. package/esm5/src/render3/definition.js +30 -24
  287. package/esm5/src/render3/di.js +142 -135
  288. package/esm5/src/render3/di_setup.js +20 -21
  289. package/esm5/src/render3/discovery_utils.js +167 -36
  290. package/esm5/src/render3/empty.js +22 -0
  291. package/esm5/src/render3/errors.js +9 -12
  292. package/esm5/src/render3/features/inherit_definition_feature.js +3 -5
  293. package/esm5/src/render3/features/ng_onchanges_feature.js +11 -10
  294. package/esm5/src/render3/features/providers_feature.js +1 -2
  295. package/esm5/src/render3/fields.js +1 -2
  296. package/esm5/src/render3/global_utils.js +4 -3
  297. package/esm5/src/render3/global_utils_api.js +2 -3
  298. package/esm5/src/render3/hooks.js +14 -16
  299. package/esm5/src/render3/i18n.js +22 -27
  300. package/esm5/src/render3/index.js +5 -6
  301. package/esm5/src/render3/instructions.js +698 -593
  302. package/esm5/src/render3/interfaces/container.js +10 -3
  303. package/esm5/src/render3/interfaces/context.js +1 -2
  304. package/esm5/src/render3/interfaces/definition.js +1 -2
  305. package/esm5/src/render3/interfaces/i18n.js +1 -2
  306. package/esm5/src/render3/interfaces/injector.js +5 -6
  307. package/esm5/src/render3/interfaces/node.js +1 -2
  308. package/esm5/src/render3/interfaces/player.js +1 -2
  309. package/esm5/src/render3/interfaces/projection.js +1 -2
  310. package/esm5/src/render3/interfaces/query.js +1 -2
  311. package/esm5/src/render3/interfaces/renderer.js +1 -2
  312. package/esm5/src/render3/interfaces/sanitization.js +1 -2
  313. package/esm5/src/render3/interfaces/styling.js +1 -2
  314. package/esm5/src/render3/interfaces/view.js +3 -4
  315. package/esm5/src/render3/jit/compiler_facade.js +1 -2
  316. package/esm5/src/render3/jit/compiler_facade_interface.js +1 -2
  317. package/esm5/src/render3/jit/directive.js +19 -10
  318. package/esm5/src/render3/jit/environment.js +4 -2
  319. package/esm5/src/render3/jit/injectable.js +17 -18
  320. package/esm5/src/render3/jit/module.js +207 -13
  321. package/esm5/src/render3/jit/pipe.js +1 -2
  322. package/esm5/src/render3/jit/util.js +1 -2
  323. package/esm5/src/render3/metadata.js +1 -2
  324. package/esm5/src/render3/ng_dev_mode.js +1 -2
  325. package/esm5/src/render3/ng_module_ref.js +29 -11
  326. package/esm5/src/render3/node_assert.js +1 -2
  327. package/esm5/src/render3/node_manipulation.js +54 -50
  328. package/esm5/src/render3/node_selector_matcher.js +28 -9
  329. package/esm5/src/render3/pipe.js +33 -19
  330. package/esm5/src/render3/players.js +7 -9
  331. package/esm5/src/render3/pure_function.js +48 -38
  332. package/esm5/src/render3/query.js +8 -9
  333. package/esm5/src/render3/state.js +50 -135
  334. package/esm5/src/render3/styling/class_and_style_bindings.js +684 -214
  335. package/esm5/src/render3/styling/core_player_handler.js +1 -2
  336. package/esm5/src/render3/styling/player_factory.js +1 -2
  337. package/esm5/src/render3/styling/util.js +39 -22
  338. package/esm5/src/render3/tokens.js +1 -2
  339. package/esm5/src/render3/util.js +49 -37
  340. package/esm5/src/render3/view_engine_compatibility.js +20 -33
  341. package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -2
  342. package/esm5/src/render3/view_ref.js +33 -30
  343. package/esm5/src/sanitization/bypass.js +1 -2
  344. package/esm5/src/sanitization/html_sanitizer.js +1 -2
  345. package/esm5/src/sanitization/inert_body.js +4 -5
  346. package/esm5/src/sanitization/sanitization.js +25 -20
  347. package/esm5/src/sanitization/security.js +1 -2
  348. package/esm5/src/sanitization/style_sanitizer.js +1 -2
  349. package/esm5/src/sanitization/url_sanitizer.js +1 -2
  350. package/esm5/src/testability/testability.js +1 -2
  351. package/esm5/src/type.js +1 -2
  352. package/esm5/src/util/decorators.js +1 -2
  353. package/esm5/src/util/lang.js +1 -2
  354. package/esm5/src/util/ng_reflect.js +1 -2
  355. package/esm5/src/util/noop.js +1 -2
  356. package/esm5/src/util/property.js +1 -2
  357. package/esm5/src/util.js +1 -2
  358. package/esm5/src/version.js +2 -3
  359. package/esm5/src/view/element.js +1 -2
  360. package/esm5/src/view/entrypoint.js +1 -2
  361. package/esm5/src/view/errors.js +1 -2
  362. package/esm5/src/view/index.js +1 -2
  363. package/esm5/src/view/ng_content.js +1 -2
  364. package/esm5/src/view/ng_module.js +1 -2
  365. package/esm5/src/view/provider.js +1 -2
  366. package/esm5/src/view/pure_expression.js +1 -2
  367. package/esm5/src/view/query.js +1 -2
  368. package/esm5/src/view/refs.js +1 -2
  369. package/esm5/src/view/services.js +1 -2
  370. package/esm5/src/view/text.js +1 -2
  371. package/esm5/src/view/types.js +1 -2
  372. package/esm5/src/view/util.js +1 -2
  373. package/esm5/src/view/view.js +1 -2
  374. package/esm5/src/view/view_attach.js +1 -2
  375. package/esm5/src/zone/ng_zone.js +1 -2
  376. package/esm5/src/zone.js +1 -2
  377. package/esm5/testing/index.js +1 -2
  378. package/esm5/testing/public_api.js +1 -2
  379. package/esm5/testing/src/async.js +1 -2
  380. package/esm5/testing/src/async_fallback.js +1 -2
  381. package/esm5/testing/src/async_test_completer.js +1 -2
  382. package/esm5/testing/src/before_each.js +1 -2
  383. package/esm5/testing/src/component_fixture.js +1 -2
  384. package/esm5/testing/src/fake_async.js +1 -2
  385. package/esm5/testing/src/fake_async_fallback.js +1 -2
  386. package/esm5/testing/src/lang_utils.js +1 -2
  387. package/esm5/testing/src/logger.js +1 -2
  388. package/esm5/testing/src/metadata_override.js +1 -2
  389. package/esm5/testing/src/metadata_overrider.js +1 -2
  390. package/esm5/testing/src/ng_zone_mock.js +1 -2
  391. package/esm5/testing/src/private_export_testing.js +1 -2
  392. package/esm5/testing/src/r3_test_bed.js +182 -121
  393. package/esm5/testing/src/resolvers.js +11 -7
  394. package/esm5/testing/src/test_bed.js +1 -2
  395. package/esm5/testing/src/test_bed_common.js +1 -2
  396. package/esm5/testing/src/test_compiler.js +1 -2
  397. package/esm5/testing/src/testing.js +1 -2
  398. package/esm5/testing/src/testing_internal.js +2 -3
  399. package/esm5/testing/testing.js +1 -2
  400. package/fesm2015/core.js +8560 -6153
  401. package/fesm2015/core.js.map +1 -1
  402. package/fesm2015/testing.js +351 -229
  403. package/fesm2015/testing.js.map +1 -1
  404. package/fesm5/core.js +5541 -4482
  405. package/fesm5/core.js.map +1 -1
  406. package/fesm5/testing.js +185 -130
  407. package/fesm5/testing.js.map +1 -1
  408. package/package.json +1 -1
  409. package/src/change_detection/constants.d.ts +2 -2
  410. package/src/core_render3_private_export.d.ts +6 -3
  411. package/src/di/injectable.d.ts +3 -2
  412. package/src/di/r3_injector.d.ts +1 -1
  413. package/src/linker/ng_module_factory_loader.d.ts +5 -1
  414. package/src/render3/assert.d.ts +6 -0
  415. package/src/render3/bindings.d.ts +20 -0
  416. package/src/render3/component.d.ts +3 -3
  417. package/src/render3/component_ref.d.ts +14 -4
  418. package/src/render3/context_discovery.d.ts +9 -9
  419. package/src/render3/definition.d.ts +8 -23
  420. package/src/render3/di.d.ts +19 -17
  421. package/src/render3/discovery_utils.d.ts +66 -8
  422. package/src/render3/empty.d.ts +16 -0
  423. package/src/render3/errors.d.ts +1 -1
  424. package/src/render3/global_utils_api.d.ts +1 -1
  425. package/src/render3/hooks.d.ts +7 -6
  426. package/src/render3/index.d.ts +4 -4
  427. package/src/render3/instructions.d.ts +163 -118
  428. package/src/render3/interfaces/container.d.ts +9 -8
  429. package/src/render3/interfaces/context.d.ts +3 -3
  430. package/src/render3/interfaces/definition.d.ts +2 -12
  431. package/src/render3/interfaces/i18n.d.ts +25 -25
  432. package/src/render3/interfaces/injector.d.ts +8 -9
  433. package/src/render3/interfaces/node.d.ts +56 -23
  434. package/src/render3/interfaces/renderer.d.ts +2 -1
  435. package/src/render3/interfaces/styling.d.ts +392 -117
  436. package/src/render3/interfaces/view.d.ts +49 -35
  437. package/src/render3/jit/compiler_facade_interface.d.ts +10 -3
  438. package/src/render3/jit/module.d.ts +9 -1
  439. package/src/render3/metadata.d.ts +1 -1
  440. package/src/render3/ng_module_ref.d.ts +8 -6
  441. package/src/render3/node_manipulation.d.ts +21 -27
  442. package/src/render3/node_selector_matcher.d.ts +2 -2
  443. package/src/render3/state.d.ts +11 -38
  444. package/src/render3/styling/class_and_style_bindings.d.ts +130 -43
  445. package/src/render3/styling/util.d.ts +9 -4
  446. package/src/render3/util.d.ts +31 -25
  447. package/src/render3/view_engine_compatibility.d.ts +5 -12
  448. package/src/render3/view_engine_compatibility_prebound.d.ts +2 -2
  449. package/src/render3/view_ref.d.ts +2 -2
  450. package/src/sanitization/sanitization.d.ts +3 -2
  451. package/testing/src/r3_test_bed.d.ts +15 -0
  452. package/testing/src/resolvers.d.ts +2 -2
  453. package/testing/testing.metadata.json +1 -1
  454. package/testing.d.ts +5 -0
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
3
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
5
  /**
6
6
  * @license
@@ -9,6 +9,9 @@
9
9
  * Use of this source code is governed by an MIT-style license that can be
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
+ // Below are constants for LView indices to help us look up LView members
13
+ // without having to remember the specific indices.
14
+ // Uglify will inline these when minifying so there shouldn't be a cost.
12
15
  /** @type {?} */
13
16
  export const TVIEW = 0;
14
17
  /** @type {?} */
@@ -23,6 +26,7 @@ export const QUERIES = 4;
23
26
  export const HOST = 5;
24
27
  /** @type {?} */
25
28
  export const HOST_NODE = 6;
29
+ // Rename to `T_HOST`?
26
30
  /** @type {?} */
27
31
  export const BINDING_INDEX = 7;
28
32
  /** @type {?} */
@@ -45,57 +49,106 @@ export const CONTAINER_INDEX = 15;
45
49
  export const CONTENT_QUERIES = 16;
46
50
  /** @type {?} */
47
51
  export const DECLARATION_VIEW = 17;
48
- /** *
49
- * Size of LViewData's header. Necessary to adjust for it when setting slots.
50
- @type {?} */
52
+ /**
53
+ * Size of LView's header. Necessary to adjust for it when setting slots.
54
+ * @type {?}
55
+ */
51
56
  export const HEADER_OFFSET = 18;
52
57
  /**
53
58
  * @record
54
59
  */
55
60
  export function OpaqueViewState() { }
56
- /** @type {?} */
57
- OpaqueViewState.prototype.__brand__;
61
+ if (false) {
62
+ /** @type {?} */
63
+ OpaqueViewState.prototype.__brand__;
64
+ }
58
65
  /**
59
- * `LViewData` stores all of the information needed to process the instructions as
66
+ * `LView` stores all of the information needed to process the instructions as
60
67
  * they are invoked from the template. Each embedded view and component view has its
61
- * own `LViewData`. When processing a particular view, we set the `viewData` to that
62
- * `LViewData`. When that view is done processing, the `viewData` is set back to
63
- * whatever the original `viewData` was before (the parent `LViewData`).
68
+ * own `LView`. When processing a particular view, we set the `viewData` to that
69
+ * `LView`. When that view is done processing, the `viewData` is set back to
70
+ * whatever the original `viewData` was before (the parent `LView`).
64
71
  *
65
72
  * Keeping separate state for each view facilities view insertion / deletion, so we
66
73
  * don't have to edit the data array based on which views are present.
67
74
  * @record
68
75
  */
69
- export function LViewData() { }
76
+ export function LView() { }
77
+ if (false) {
78
+ /* Skipping unnamed member:
79
+ readonly[TVIEW]: TView;*/
80
+ /* Skipping unnamed member:
81
+ [FLAGS]: LViewFlags;*/
82
+ /* Skipping unnamed member:
83
+ [PARENT]: LView|null;*/
84
+ /* Skipping unnamed member:
85
+ [NEXT]: LView|LContainer|null;*/
86
+ /* Skipping unnamed member:
87
+ [QUERIES]: LQueries|null;*/
88
+ /* Skipping unnamed member:
89
+ [HOST]: RElement|StylingContext|null;*/
90
+ /* Skipping unnamed member:
91
+ [HOST_NODE]: TViewNode|TElementNode|null;*/
92
+ /* Skipping unnamed member:
93
+ [BINDING_INDEX]: number;*/
94
+ /* Skipping unnamed member:
95
+ [CLEANUP]: any[]|null;*/
96
+ /* Skipping unnamed member:
97
+ [CONTEXT]: {}|RootContext|null;*/
98
+ /* Skipping unnamed member:
99
+ readonly[INJECTOR]: Injector|null;*/
100
+ /* Skipping unnamed member:
101
+ [RENDERER_FACTORY]: RendererFactory3;*/
102
+ /* Skipping unnamed member:
103
+ [RENDERER]: Renderer3;*/
104
+ /* Skipping unnamed member:
105
+ [SANITIZER]: Sanitizer|null;*/
106
+ /* Skipping unnamed member:
107
+ [TAIL]: LView|LContainer|null;*/
108
+ /* Skipping unnamed member:
109
+ [CONTAINER_INDEX]: number;*/
110
+ /* Skipping unnamed member:
111
+ [CONTENT_QUERIES]: QueryList<any>[]|null;*/
112
+ /* Skipping unnamed member:
113
+ [DECLARATION_VIEW]: LView|null;*/
114
+ }
70
115
  /** @enum {number} */
71
- var LViewFlags = {
72
- /**
73
- * Whether or not the view is in creationMode.
74
- *
75
- * This must be stored in the view rather than using `data` as a marker so that
76
- * we can properly support embedded views. Otherwise, when exiting a child view
77
- * back into the parent view, `data` will be defined and `creationMode` will be
78
- * improperly reported as false.
79
- */
116
+ const LViewFlags = {
117
+ /**
118
+ * Whether or not the view is in creationMode.
119
+ *
120
+ * This must be stored in the view rather than using `data` as a marker so that
121
+ * we can properly support embedded views. Otherwise, when exiting a child view
122
+ * back into the parent view, `data` will be defined and `creationMode` will be
123
+ * improperly reported as false.
124
+ */
80
125
  CreationMode: 1,
126
+ /**
127
+ * Whether or not this LView instance is on its first processing pass.
128
+ *
129
+ * An LView instance is considered to be on its "first pass" until it
130
+ * has completed one creation mode run and one update mode run. At this
131
+ * time, the flag is turned off.
132
+ */
133
+ FirstLViewPass: 2,
81
134
  /** Whether this view has default change detection strategy (checks always) or onPush */
82
- CheckAlways: 2,
135
+ CheckAlways: 4,
83
136
  /** Whether or not this view is currently dirty (needing check) */
84
- Dirty: 4,
137
+ Dirty: 8,
85
138
  /** Whether or not this view is currently attached to change detection tree. */
86
- Attached: 8,
87
- /**
88
- * Whether or not the init hooks have run.
89
- *
90
- * If on, the init hooks haven't yet been run and should be executed by the first component that
91
- * runs OR the first cR() instruction that runs (so inits are run for the top level view before
92
- * any embedded views).
93
- */
94
- RunInit: 16,
139
+ Attached: 16,
140
+ /**
141
+ * Whether or not the init hooks have run.
142
+ *
143
+ * If on, the init hooks haven't yet been run and should be executed by the first component that
144
+ * runs OR the first cR() instruction that runs (so inits are run for the top level view before
145
+ * any embedded views).
146
+ */
147
+ RunInit: 32,
95
148
  /** Whether or not this view is destroyed. */
96
- Destroyed: 32,
149
+ Destroyed: 64,
97
150
  /** Whether or not this view is the root view */
98
- IsRoot: 64,
151
+ IsRoot: 128,
99
152
  };
100
153
  export { LViewFlags };
101
154
  /**
@@ -106,235 +159,243 @@ export { LViewFlags };
106
159
  * @record
107
160
  */
108
161
  export function TView() { }
109
- /**
110
- * ID for inline views to determine whether a view is the same as the previous view
111
- * in a certain position. If it's not, we know the new view needs to be inserted
112
- * and the one that exists needs to be removed (e.g. if/else statements)
113
- *
114
- * If this is -1, then this is a component view or a dynamically created view.
115
- * @type {?}
116
- */
117
- TView.prototype.id;
118
- /**
119
- * This is a blueprint used to generate LViewData instances for this TView. Copying this
120
- * blueprint is faster than creating a new LViewData from scratch.
121
- * @type {?}
122
- */
123
- TView.prototype.blueprint;
124
- /**
125
- * The template function used to refresh the view of dynamically created views
126
- * and components. Will be null for inline views.
127
- * @type {?}
128
- */
129
- TView.prototype.template;
130
- /**
131
- * A function containing query-related instructions.
132
- * @type {?}
133
- */
134
- TView.prototype.viewQuery;
135
- /**
136
- * Pointer to the `TNode` that represents the root of the view.
137
- *
138
- * If this is a `TNode` for an `LViewNode`, this is an embedded view of a container.
139
- * We need this pointer to be able to efficiently find this node when inserting the view
140
- * into an anchor.
141
- *
142
- * If this is a `TElementNode`, this is the view of a root component. It has exactly one
143
- * root TNode.
144
- *
145
- * If this is null, this is the view of a component that is not at root. We do not store
146
- * the host TNodes for child component views because they can potentially have several
147
- * different host TNodes, depending on where the component is being used. These host
148
- * TNodes cannot be shared (due to different indices, etc).
149
- * @type {?}
150
- */
151
- TView.prototype.node;
152
- /**
153
- * Whether or not this template has been processed.
154
- * @type {?}
155
- */
156
- TView.prototype.firstTemplatePass;
157
- /**
158
- * Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n.
159
- * @type {?}
160
- */
161
- TView.prototype.data;
162
- /**
163
- * The binding start index is the index at which the data array
164
- * starts to store bindings only. Saving this value ensures that we
165
- * will begin reading bindings at the correct point in the array when
166
- * we are in update mode.
167
- * @type {?}
168
- */
169
- TView.prototype.bindingStartIndex;
170
- /**
171
- * The index where the "expando" section of `LViewData` begins. The expando
172
- * section contains injectors, directive instances, and host binding values.
173
- * Unlike the "consts" and "vars" sections of `LViewData`, the length of this
174
- * section cannot be calculated at compile-time because directives are matched
175
- * at runtime to preserve locality.
176
- *
177
- * We store this start index so we know where to start checking host bindings
178
- * in `setHostBindings`.
179
- * @type {?}
180
- */
181
- TView.prototype.expandoStartIndex;
182
- /**
183
- * Index of the host node of the first LView or LContainer beneath this LView in
184
- * the hierarchy.
185
- *
186
- * Necessary to store this so views can traverse through their nested views
187
- * to remove listeners and call onDestroy callbacks.
188
- *
189
- * For embedded views, we store the index of an LContainer's host rather than the first
190
- * LView to avoid managing splicing when views are added/removed.
191
- * @type {?}
192
- */
193
- TView.prototype.childIndex;
194
- /**
195
- * A reference to the first child node located in the view.
196
- * @type {?}
197
- */
198
- TView.prototype.firstChild;
199
- /**
200
- * Set of instructions used to process host bindings efficiently.
201
- *
202
- * See VIEW_DATA.md for more information.
203
- * @type {?}
204
- */
205
- TView.prototype.expandoInstructions;
206
- /**
207
- * Full registry of directives and components that may be found in this view.
208
- *
209
- * It's necessary to keep a copy of the full def list on the TView so it's possible
210
- * to render template functions without a host component.
211
- * @type {?}
212
- */
213
- TView.prototype.directiveRegistry;
214
- /**
215
- * Full registry of pipes that may be found in this view.
216
- *
217
- * The property is either an array of `PipeDefs`s or a function which returns the array of
218
- * `PipeDefs`s. The function is necessary to be able to support forward declarations.
219
- *
220
- * It's necessary to keep a copy of the full def list on the TView so it's possible
221
- * to render template functions without a host component.
222
- * @type {?}
223
- */
224
- TView.prototype.pipeRegistry;
225
- /**
226
- * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in
227
- * creation mode.
228
- *
229
- * Even indices: Directive index
230
- * Odd indices: Hook function
231
- * @type {?}
232
- */
233
- TView.prototype.initHooks;
234
- /**
235
- * Array of ngDoCheck hooks that should be executed for this view in update mode.
236
- *
237
- * Even indices: Directive index
238
- * Odd indices: Hook function
239
- * @type {?}
240
- */
241
- TView.prototype.checkHooks;
242
- /**
243
- * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed
244
- * for this view in creation mode.
245
- *
246
- * Even indices: Directive index
247
- * Odd indices: Hook function
248
- * @type {?}
249
- */
250
- TView.prototype.contentHooks;
251
- /**
252
- * Array of ngAfterContentChecked hooks that should be executed for this view in update
253
- * mode.
254
- *
255
- * Even indices: Directive index
256
- * Odd indices: Hook function
257
- * @type {?}
258
- */
259
- TView.prototype.contentCheckHooks;
260
- /**
261
- * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for
262
- * this view in creation mode.
263
- *
264
- * Even indices: Directive index
265
- * Odd indices: Hook function
266
- * @type {?}
267
- */
268
- TView.prototype.viewHooks;
269
- /**
270
- * Array of ngAfterViewChecked hooks that should be executed for this view in
271
- * update mode.
272
- *
273
- * Even indices: Directive index
274
- * Odd indices: Hook function
275
- * @type {?}
276
- */
277
- TView.prototype.viewCheckHooks;
278
- /**
279
- * Array of ngOnDestroy hooks that should be executed when this view is destroyed.
280
- *
281
- * Even indices: Directive index
282
- * Odd indices: Hook function
283
- * @type {?}
284
- */
285
- TView.prototype.destroyHooks;
286
- /**
287
- * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.
288
- *
289
- * Even indices: Index of pipe in data
290
- * Odd indices: Hook function
291
- *
292
- * These must be stored separately from directive destroy hooks because their contexts
293
- * are stored in data.
294
- * @type {?}
295
- */
296
- TView.prototype.pipeDestroyHooks;
297
- /**
298
- * When a view is destroyed, listeners need to be released and outputs need to be
299
- * unsubscribed. This cleanup array stores both listener data (in chunks of 4)
300
- * and output data (in chunks of 2) for a particular view. Combining the arrays
301
- * saves on memory (70 bytes per array) and on a few bytes of code size (for two
302
- * separate for loops).
303
- *
304
- * If it's a native DOM listener being stored:
305
- * 1st index is: event name to remove
306
- * 2nd index is: index of native element in LView.data[]
307
- * 3rd index is: index of wrapped listener function in LView.cleanupInstances[]
308
- * 4th index is: useCapture boolean
309
- *
310
- * If it's a renderer2 style listener or ViewRef destroy hook being stored:
311
- * 1st index is: index of the cleanup function in LView.cleanupInstances[]
312
- * 2nd index is: null
313
- *
314
- * If it's an output subscription or query list destroy hook:
315
- * 1st index is: output unsubscribe function / query list destroy function
316
- * 2nd index is: index of function context in LView.cleanupInstances[]
317
- * @type {?}
318
- */
319
- TView.prototype.cleanup;
320
- /**
321
- * A list of element indices for child components that will need to be
322
- * refreshed when the current view has finished its check. These indices have
323
- * already been adjusted for the HEADER_OFFSET.
324
- *
325
- * @type {?}
326
- */
327
- TView.prototype.components;
328
- /**
329
- * A list of indices for child directives that have content queries.
330
- *
331
- * Even indices: Directive indices
332
- * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive
333
- * @type {?}
334
- */
335
- TView.prototype.contentQueries;
162
+ if (false) {
163
+ /**
164
+ * ID for inline views to determine whether a view is the same as the previous view
165
+ * in a certain position. If it's not, we know the new view needs to be inserted
166
+ * and the one that exists needs to be removed (e.g. if/else statements)
167
+ *
168
+ * If this is -1, then this is a component view or a dynamically created view.
169
+ * @type {?}
170
+ */
171
+ TView.prototype.id;
172
+ /**
173
+ * This is a blueprint used to generate LView instances for this TView. Copying this
174
+ * blueprint is faster than creating a new LView from scratch.
175
+ * @type {?}
176
+ */
177
+ TView.prototype.blueprint;
178
+ /**
179
+ * The template function used to refresh the view of dynamically created views
180
+ * and components. Will be null for inline views.
181
+ * @type {?}
182
+ */
183
+ TView.prototype.template;
184
+ /**
185
+ * A function containing query-related instructions.
186
+ * @type {?}
187
+ */
188
+ TView.prototype.viewQuery;
189
+ /**
190
+ * Pointer to the `TNode` that represents the root of the view.
191
+ *
192
+ * If this is a `TViewNode` for an `LViewNode`, this is an embedded view of a container.
193
+ * We need this pointer to be able to efficiently find this node when inserting the view
194
+ * into an anchor.
195
+ *
196
+ * If this is a `TElementNode`, this is the view of a root component. It has exactly one
197
+ * root TNode.
198
+ *
199
+ * If this is null, this is the view of a component that is not at root. We do not store
200
+ * the host TNodes for child component views because they can potentially have several
201
+ * different host TNodes, depending on where the component is being used. These host
202
+ * TNodes cannot be shared (due to different indices, etc).
203
+ * @type {?}
204
+ */
205
+ TView.prototype.node;
206
+ /**
207
+ * Whether or not this template has been processed.
208
+ * @type {?}
209
+ */
210
+ TView.prototype.firstTemplatePass;
211
+ /**
212
+ * Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n.
213
+ * @type {?}
214
+ */
215
+ TView.prototype.data;
216
+ /**
217
+ * The binding start index is the index at which the data array
218
+ * starts to store bindings only. Saving this value ensures that we
219
+ * will begin reading bindings at the correct point in the array when
220
+ * we are in update mode.
221
+ * @type {?}
222
+ */
223
+ TView.prototype.bindingStartIndex;
224
+ /**
225
+ * The index where the "expando" section of `LView` begins. The expando
226
+ * section contains injectors, directive instances, and host binding values.
227
+ * Unlike the "consts" and "vars" sections of `LView`, the length of this
228
+ * section cannot be calculated at compile-time because directives are matched
229
+ * at runtime to preserve locality.
230
+ *
231
+ * We store this start index so we know where to start checking host bindings
232
+ * in `setHostBindings`.
233
+ * @type {?}
234
+ */
235
+ TView.prototype.expandoStartIndex;
236
+ /**
237
+ * Index of the host node of the first LView or LContainer beneath this LView in
238
+ * the hierarchy.
239
+ *
240
+ * Necessary to store this so views can traverse through their nested views
241
+ * to remove listeners and call onDestroy callbacks.
242
+ *
243
+ * For embedded views, we store the index of an LContainer's host rather than the first
244
+ * LView to avoid managing splicing when views are added/removed.
245
+ * @type {?}
246
+ */
247
+ TView.prototype.childIndex;
248
+ /**
249
+ * A reference to the first child node located in the view.
250
+ * @type {?}
251
+ */
252
+ TView.prototype.firstChild;
253
+ /**
254
+ * Set of instructions used to process host bindings efficiently.
255
+ *
256
+ * See VIEW_DATA.md for more information.
257
+ * @type {?}
258
+ */
259
+ TView.prototype.expandoInstructions;
260
+ /**
261
+ * Full registry of directives and components that may be found in this view.
262
+ *
263
+ * It's necessary to keep a copy of the full def list on the TView so it's possible
264
+ * to render template functions without a host component.
265
+ * @type {?}
266
+ */
267
+ TView.prototype.directiveRegistry;
268
+ /**
269
+ * Full registry of pipes that may be found in this view.
270
+ *
271
+ * The property is either an array of `PipeDefs`s or a function which returns the array of
272
+ * `PipeDefs`s. The function is necessary to be able to support forward declarations.
273
+ *
274
+ * It's necessary to keep a copy of the full def list on the TView so it's possible
275
+ * to render template functions without a host component.
276
+ * @type {?}
277
+ */
278
+ TView.prototype.pipeRegistry;
279
+ /**
280
+ * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in
281
+ * creation mode.
282
+ *
283
+ * Even indices: Directive index
284
+ * Odd indices: Hook function
285
+ * @type {?}
286
+ */
287
+ TView.prototype.initHooks;
288
+ /**
289
+ * Array of ngDoCheck hooks that should be executed for this view in update mode.
290
+ *
291
+ * Even indices: Directive index
292
+ * Odd indices: Hook function
293
+ * @type {?}
294
+ */
295
+ TView.prototype.checkHooks;
296
+ /**
297
+ * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed
298
+ * for this view in creation mode.
299
+ *
300
+ * Even indices: Directive index
301
+ * Odd indices: Hook function
302
+ * @type {?}
303
+ */
304
+ TView.prototype.contentHooks;
305
+ /**
306
+ * Array of ngAfterContentChecked hooks that should be executed for this view in update
307
+ * mode.
308
+ *
309
+ * Even indices: Directive index
310
+ * Odd indices: Hook function
311
+ * @type {?}
312
+ */
313
+ TView.prototype.contentCheckHooks;
314
+ /**
315
+ * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for
316
+ * this view in creation mode.
317
+ *
318
+ * Even indices: Directive index
319
+ * Odd indices: Hook function
320
+ * @type {?}
321
+ */
322
+ TView.prototype.viewHooks;
323
+ /**
324
+ * Array of ngAfterViewChecked hooks that should be executed for this view in
325
+ * update mode.
326
+ *
327
+ * Even indices: Directive index
328
+ * Odd indices: Hook function
329
+ * @type {?}
330
+ */
331
+ TView.prototype.viewCheckHooks;
332
+ /**
333
+ * Array of ngOnDestroy hooks that should be executed when this view is destroyed.
334
+ *
335
+ * Even indices: Directive index
336
+ * Odd indices: Hook function
337
+ * @type {?}
338
+ */
339
+ TView.prototype.destroyHooks;
340
+ /**
341
+ * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.
342
+ *
343
+ * Even indices: Index of pipe in data
344
+ * Odd indices: Hook function
345
+ *
346
+ * These must be stored separately from directive destroy hooks because their contexts
347
+ * are stored in data.
348
+ * @type {?}
349
+ */
350
+ TView.prototype.pipeDestroyHooks;
351
+ /**
352
+ * When a view is destroyed, listeners need to be released and outputs need to be
353
+ * unsubscribed. This cleanup array stores both listener data (in chunks of 4)
354
+ * and output data (in chunks of 2) for a particular view. Combining the arrays
355
+ * saves on memory (70 bytes per array) and on a few bytes of code size (for two
356
+ * separate for loops).
357
+ *
358
+ * If it's a native DOM listener or output subscription being stored:
359
+ * 1st index is: event name `name = tView.cleanup[i+0]`
360
+ * 2nd index is: index of native element `element = lView[tView.cleanup[i+1]]`
361
+ * 3rd index is: index of listener function `listener = lView[CLEANUP][tView.cleanup[i+2]]`
362
+ * 4th index is: `useCaptureOrIndx = tView.cleanup[i+3]`
363
+ * `typeof useCaptureOrIndx == 'boolean' : useCapture boolean
364
+ * `typeof useCaptureOrIndx == 'number':
365
+ * `useCaptureOrIndx >= 0` `removeListener = LView[CLEANUP][useCaptureOrIndx]`
366
+ * `useCaptureOrIndx < 0` `subscription = LView[CLEANUP][-useCaptureOrIndx]`
367
+ *
368
+ * If it's a renderer2 style listener or ViewRef destroy hook being stored:
369
+ * 1st index is: index of the cleanup function in LView.cleanupInstances[]
370
+ * 2nd index is: `null`
371
+ * `lView[CLEANUP][tView.cleanup[i+0]]()`
372
+ *
373
+ * If it's an output subscription or query list destroy hook:
374
+ * 1st index is: output unsubscribe function / query list destroy function
375
+ * 2nd index is: index of function context in LView.cleanupInstances[]
376
+ * `tView.cleanup[i+0].call(lView[CLEANUP][tView.cleanup[i+1]])`
377
+ * @type {?}
378
+ */
379
+ TView.prototype.cleanup;
380
+ /**
381
+ * A list of element indices for child components that will need to be
382
+ * refreshed when the current view has finished its check. These indices have
383
+ * already been adjusted for the HEADER_OFFSET.
384
+ *
385
+ * @type {?}
386
+ */
387
+ TView.prototype.components;
388
+ /**
389
+ * A list of indices for child directives that have content queries.
390
+ *
391
+ * Even indices: Directive indices
392
+ * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive
393
+ * @type {?}
394
+ */
395
+ TView.prototype.contentQueries;
396
+ }
336
397
  /** @enum {number} */
337
- var RootContextFlags = {
398
+ const RootContextFlags = {
338
399
  Empty: 0, DetectChanges: 1, FlushPlayers: 2,
339
400
  };
340
401
  export { RootContextFlags };
@@ -344,42 +405,39 @@ export { RootContextFlags };
344
405
  * @record
345
406
  */
346
407
  export function RootContext() { }
347
- /**
348
- * A function used for scheduling change detection in the future. Usually
349
- * this is `requestAnimationFrame`.
350
- * @type {?}
351
- */
352
- RootContext.prototype.scheduler;
353
- /**
354
- * A promise which is resolved when all components are considered clean (not dirty).
355
- *
356
- * This promise is overwritten every time a first call to {\@link markDirty} is invoked.
357
- * @type {?}
358
- */
359
- RootContext.prototype.clean;
360
- /**
361
- * RootComponents - The components that were instantiated by the call to
362
- * {\@link renderComponent}.
363
- * @type {?}
364
- */
365
- RootContext.prototype.components;
366
- /**
367
- * The player flushing handler to kick off all animations
368
- * @type {?}
369
- */
370
- RootContext.prototype.playerHandler;
371
- /**
372
- * What render-related operations to run once a scheduler has been set
373
- * @type {?}
374
- */
375
- RootContext.prototype.flags;
376
- /** @typedef {?} */
377
- var HookData;
378
- export { HookData };
379
- /** @typedef {?} */
380
- var TData;
381
- export { TData };
408
+ if (false) {
409
+ /**
410
+ * A function used for scheduling change detection in the future. Usually
411
+ * this is `requestAnimationFrame`.
412
+ * @type {?}
413
+ */
414
+ RootContext.prototype.scheduler;
415
+ /**
416
+ * A promise which is resolved when all components are considered clean (not dirty).
417
+ *
418
+ * This promise is overwritten every time a first call to {\@link markDirty} is invoked.
419
+ * @type {?}
420
+ */
421
+ RootContext.prototype.clean;
422
+ /**
423
+ * RootComponents - The components that were instantiated by the call to
424
+ * {\@link renderComponent}.
425
+ * @type {?}
426
+ */
427
+ RootContext.prototype.components;
428
+ /**
429
+ * The player flushing handler to kick off all animations
430
+ * @type {?}
431
+ */
432
+ RootContext.prototype.playerHandler;
433
+ /**
434
+ * What render-related operations to run once a scheduler has been set
435
+ * @type {?}
436
+ */
437
+ RootContext.prototype.flags;
438
+ }
439
+ // Note: This hack is necessary so we don't erroneously get a circular dependency
440
+ // failure based on types.
382
441
  /** @type {?} */
383
442
  export const unusedValueExportToPlacateAjd = 1;
384
-
385
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/interfaces/view.ts"],"names":[],"mappings":";;;;;;;;;;;;AA0BA,aAAa,KAAK,GAAG,CAAC,CAAC;;AACvB,aAAa,KAAK,GAAG,CAAC,CAAC;;AACvB,aAAa,MAAM,GAAG,CAAC,CAAC;;AACxB,aAAa,IAAI,GAAG,CAAC,CAAC;;AACtB,aAAa,OAAO,GAAG,CAAC,CAAC;;AACzB,aAAa,IAAI,GAAG,CAAC,CAAC;;AACtB,aAAa,SAAS,GAAG,CAAC,CAAC;;AAC3B,aAAa,aAAa,GAAG,CAAC,CAAC;;AAC/B,aAAa,OAAO,GAAG,CAAC,CAAC;;AACzB,aAAa,OAAO,GAAG,CAAC,CAAC;;AACzB,aAAa,QAAQ,GAAG,EAAE,CAAC;;AAC3B,aAAa,gBAAgB,GAAG,EAAE,CAAC;;AACnC,aAAa,QAAQ,GAAG,EAAE,CAAC;;AAC3B,aAAa,SAAS,GAAG,EAAE,CAAC;;AAC5B,aAAa,IAAI,GAAG,EAAE,CAAC;;AACvB,aAAa,eAAe,GAAG,EAAE,CAAC;;AAClC,aAAa,eAAe,GAAG,EAAE,CAAC;;AAClC,aAAa,gBAAgB,GAAG,EAAE,CAAC;;;;AAEnC,aAAa,aAAa,GAAG,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAkL9B,eAAwB;;IAGxB,cAAuB;;IAGvB,QAAiB;;IAGjB,WAAoB;;;;;;;;IASpB,WAAmB;;IAGnB,aAAqB;;IAGrB,UAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA0OgB,QAAY,EAAE,gBAAoB,EAAE,eAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgE3F,aAAa,6BAA6B,GAAG,CAAC,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {InjectionToken} from '../../di/injection_token';\nimport {Injector} from '../../di/injector';\nimport {QueryList} from '../../linker';\nimport {Sanitizer} from '../../sanitization/security';\nimport {Type} from '../../type';\nimport {LContainer} from './container';\nimport {ComponentDef, ComponentQuery, ComponentTemplate, DirectiveDef, DirectiveDefList, HostBindingsFunction, PipeDef, PipeDefList} from './definition';\nimport {I18nUpdateOpCodes, TI18n} from './i18n';\nimport {TElementNode, TNode, TViewNode} from './node';\nimport {PlayerHandler} from './player';\nimport {LQueries} from './query';\nimport {RElement, Renderer3, RendererFactory3} from './renderer';\nimport {StylingContext} from './styling';\n\n\n// Below are constants for LViewData indices to help us look up LViewData members\n// without having to remember the specific indices.\n// Uglify will inline these when minifying so there shouldn't be a cost.\nexport const TVIEW = 0;\nexport const FLAGS = 1;\nexport const PARENT = 2;\nexport const NEXT = 3;\nexport const QUERIES = 4;\nexport const HOST = 5;\nexport const HOST_NODE = 6;  // Rename to `T_HOST`?\nexport const BINDING_INDEX = 7;\nexport const CLEANUP = 8;\nexport const CONTEXT = 9;\nexport const INJECTOR = 10;\nexport const RENDERER_FACTORY = 11;\nexport const RENDERER = 12;\nexport const SANITIZER = 13;\nexport const TAIL = 14;\nexport const CONTAINER_INDEX = 15;\nexport const CONTENT_QUERIES = 16;\nexport const DECLARATION_VIEW = 17;\n/** Size of LViewData's header. Necessary to adjust for it when setting slots.  */\nexport const HEADER_OFFSET = 18;\n\n\n// This interface replaces the real LViewData interface if it is an arg or a\n// return value of a public instruction. This ensures we don't need to expose\n// the actual interface, which should be kept private.\nexport interface OpaqueViewState {\n  '__brand__': 'Brand for OpaqueViewState that nothing will match';\n}\n\n\n/**\n * `LViewData` stores all of the information needed to process the instructions as\n * they are invoked from the template. Each embedded view and component view has its\n * own `LViewData`. When processing a particular view, we set the `viewData` to that\n * `LViewData`. When that view is done processing, the `viewData` is set back to\n * whatever the original `viewData` was before (the parent `LViewData`).\n *\n * Keeping separate state for each view facilities view insertion / deletion, so we\n * don't have to edit the data array based on which views are present.\n */\nexport interface LViewData extends Array<any> {\n  /**\n   * The static data for this view. We need a reference to this so we can easily walk up the\n   * node tree in DI and get the TView.data array associated with a node (where the\n   * directive defs are stored).\n   */\n  readonly[TVIEW]: TView;\n\n  /** Flags for this view. See LViewFlags for more info. */\n  [FLAGS]: LViewFlags;\n\n  /**\n   * The parent view is needed when we exit the view and must restore the previous\n   * `LViewData`. Without this, the render method would have to keep a stack of\n   * views as it is recursively rendering templates.\n   *\n   * This is the \"insertion\" view for embedded views. This allows us to properly\n   * destroy embedded views.\n   */\n  [PARENT]: LViewData|null;\n\n  /**\n   *\n   * The next sibling LViewData or LContainer.\n   *\n   * Allows us to propagate between sibling view states that aren't in the same\n   * container. Embedded views already have a node.next, but it is only set for\n   * views in the same container. We need a way to link component views and views\n   * across containers as well.\n   */\n  [NEXT]: LViewData|LContainer|null;\n\n  /** Queries active for this view - nodes from a view are reported to those queries. */\n  [QUERIES]: LQueries|null;\n\n  /**\n   * The host node for this LViewData instance, if this is a component view.\n   *\n   * If this is an embedded view, HOST will be null.\n   */\n  [HOST]: RElement|StylingContext|null;\n\n  /**\n   * Pointer to the `TViewNode` or `TElementNode` which represents the root of the view.\n   *\n   * If `TViewNode`, this is an embedded view of a container. We need this to be able to\n   * efficiently find the `LViewNode` when inserting the view into an anchor.\n   *\n   * If `TElementNode`, this is the LView of a component.\n   *\n   * If null, this is the root view of an application (root component is in this view).\n   */\n  [HOST_NODE]: TViewNode|TElementNode|null;\n\n  /**\n   * The binding index we should access next.\n   *\n   * This is stored so that bindings can continue where they left off\n   * if a view is left midway through processing bindings (e.g. if there is\n   * a setter that creates an embedded view, like in ngIf).\n   */\n  [BINDING_INDEX]: number;\n\n  /**\n   * When a view is destroyed, listeners need to be released and outputs need to be\n   * unsubscribed. This context array stores both listener functions wrapped with\n   * their context and output subscription instances for a particular view.\n   *\n   * These change per LView instance, so they cannot be stored on TView. Instead,\n   * TView.cleanup saves an index to the necessary context in this array.\n   */\n  // TODO: flatten into LViewData[]\n  [CLEANUP]: any[]|null;\n\n  /**\n   * - For dynamic views, this is the context with which to render the template (e.g.\n   *   `NgForContext`), or `{}` if not defined explicitly.\n   * - For root view of the root component the context contains change detection data.\n   * - For non-root components, the context is the component instance,\n   * - For inline views, the context is null.\n   */\n  [CONTEXT]: {}|RootContext|null;\n\n  /** An optional Module Injector to be used as fall back after Element Injectors are consulted. */\n  readonly[INJECTOR]: Injector|null;\n\n  /** Renderer to be used for this view. */\n  [RENDERER_FACTORY]: RendererFactory3;\n\n  /** Renderer to be used for this view. */\n  [RENDERER]: Renderer3;\n\n  /** An optional custom sanitizer. */\n  [SANITIZER]: Sanitizer|null;\n\n  /**\n   * The last LViewData or LContainer beneath this LViewData in the hierarchy.\n   *\n   * The tail allows us to quickly add a new state to the end of the view list\n   * without having to propagate starting from the first child.\n   */\n  [TAIL]: LViewData|LContainer|null;\n\n  /**\n   * The index of the parent container's host node. Applicable only to embedded views that\n   * have been inserted dynamically. Will be -1 for component views and inline views.\n   *\n   * This is necessary to jump from dynamically created embedded views to their parent\n   * containers because their parent cannot be stored on the TViewNode (views may be inserted\n   * in multiple containers, so the parent cannot be shared between view instances).\n   */\n  [CONTAINER_INDEX]: number;\n\n  /**\n   * Stores QueryLists associated with content queries of a directive. This data structure is\n   * filled-in as part of a directive creation process and is later used to retrieve a QueryList to\n   * be refreshed.\n   */\n  [CONTENT_QUERIES]: QueryList<any>[]|null;\n\n  /**\n   * View where this view's template was declared.\n   *\n   * Only applicable for dynamically created views. Will be null for inline/component views.\n   *\n   * The template for a dynamically created view may be declared in a different view than\n   * it is inserted. We already track the \"insertion view\" (view where the template was\n   * inserted) in LViewData[PARENT], but we also need access to the \"declaration view\"\n   * (view where the template was declared). Otherwise, we wouldn't be able to call the\n   * view's template function with the proper contexts. Context should be inherited from\n   * the declaration view tree, not the insertion view tree.\n   *\n   * Example (AppComponent template):\n   *\n   * <ng-template #foo></ng-template>       <-- declared here -->\n   * <some-comp [tpl]=\"foo\"></some-comp>    <-- inserted inside this component -->\n   *\n   * The <ng-template> above is declared in the AppComponent template, but it will be passed into\n   * SomeComp and inserted there. In this case, the declaration view would be the AppComponent,\n   * but the insertion view would be SomeComp. When we are removing views, we would want to\n   * traverse through the insertion view to clean up listeners. When we are calling the\n   * template function during change detection, we need the declaration view to get inherited\n   * context.\n   */\n  [DECLARATION_VIEW]: LViewData|null;\n}\n\n/** Flags associated with an LView (saved in LViewData[FLAGS]) */\nexport const enum LViewFlags {\n  /**\n   * Whether or not the view is in creationMode.\n   *\n   * This must be stored in the view rather than using `data` as a marker so that\n   * we can properly support embedded views. Otherwise, when exiting a child view\n   * back into the parent view, `data` will be defined and `creationMode` will be\n   * improperly reported as false.\n   */\n  CreationMode = 0b0000001,\n\n  /** Whether this view has default change detection strategy (checks always) or onPush */\n  CheckAlways = 0b0000010,\n\n  /** Whether or not this view is currently dirty (needing check) */\n  Dirty = 0b0000100,\n\n  /** Whether or not this view is currently attached to change detection tree. */\n  Attached = 0b0001000,\n\n  /**\n   *  Whether or not the init hooks have run.\n   *\n   * If on, the init hooks haven't yet been run and should be executed by the first component that\n   * runs OR the first cR() instruction that runs (so inits are run for the top level view before\n   * any embedded views).\n   */\n  RunInit = 0b0010000,\n\n  /** Whether or not this view is destroyed. */\n  Destroyed = 0b0100000,\n\n  /** Whether or not this view is the root view */\n  IsRoot = 0b1000000,\n}\n\n/**\n * The static data for an LView (shared between all templates of a\n * given type).\n *\n * Stored on the template function as ngPrivateData.\n */\nexport interface TView {\n  /**\n   * ID for inline views to determine whether a view is the same as the previous view\n   * in a certain position. If it's not, we know the new view needs to be inserted\n   * and the one that exists needs to be removed (e.g. if/else statements)\n   *\n   * If this is -1, then this is a component view or a dynamically created view.\n   */\n  readonly id: number;\n\n  /**\n   * This is a blueprint used to generate LViewData instances for this TView. Copying this\n   * blueprint is faster than creating a new LViewData from scratch.\n   */\n  blueprint: LViewData;\n\n  /**\n   * The template function used to refresh the view of dynamically created views\n   * and components. Will be null for inline views.\n   */\n  template: ComponentTemplate<{}>|null;\n\n  /**\n   * A function containing query-related instructions.\n   */\n  viewQuery: ComponentQuery<{}>|null;\n\n  /**\n   * Pointer to the `TNode` that represents the root of the view.\n   *\n   * If this is a `TNode` for an `LViewNode`, this is an embedded view of a container.\n   * We need this pointer to be able to efficiently find this node when inserting the view\n   * into an anchor.\n   *\n   * If this is a `TElementNode`, this is the view of a root component. It has exactly one\n   * root TNode.\n   *\n   * If this is null, this is the view of a component that is not at root. We do not store\n   * the host TNodes for child component views because they can potentially have several\n   * different host TNodes, depending on where the component is being used. These host\n   * TNodes cannot be shared (due to different indices, etc).\n   */\n  node: TViewNode|TElementNode|null;\n\n  /** Whether or not this template has been processed. */\n  firstTemplatePass: boolean;\n\n  /** Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n. */\n  data: TData;\n\n  /**\n   * The binding start index is the index at which the data array\n   * starts to store bindings only. Saving this value ensures that we\n   * will begin reading bindings at the correct point in the array when\n   * we are in update mode.\n   */\n  bindingStartIndex: number;\n\n  /**\n   * The index where the \"expando\" section of `LViewData` begins. The expando\n   * section contains injectors, directive instances, and host binding values.\n   * Unlike the \"consts\" and \"vars\" sections of `LViewData`, the length of this\n   * section cannot be calculated at compile-time because directives are matched\n   * at runtime to preserve locality.\n   *\n   * We store this start index so we know where to start checking host bindings\n   * in `setHostBindings`.\n   */\n  expandoStartIndex: number;\n\n  /**\n   * Index of the host node of the first LView or LContainer beneath this LView in\n   * the hierarchy.\n   *\n   * Necessary to store this so views can traverse through their nested views\n   * to remove listeners and call onDestroy callbacks.\n   *\n   * For embedded views, we store the index of an LContainer's host rather than the first\n   * LView to avoid managing splicing when views are added/removed.\n   */\n  childIndex: number;\n\n  /**\n   * A reference to the first child node located in the view.\n   */\n  firstChild: TNode|null;\n\n  /**\n   * Set of instructions used to process host bindings efficiently.\n   *\n   * See VIEW_DATA.md for more information.\n   */\n  expandoInstructions: (number|HostBindingsFunction<any>)[]|null;\n\n  /**\n   * Full registry of directives and components that may be found in this view.\n   *\n   * It's necessary to keep a copy of the full def list on the TView so it's possible\n   * to render template functions without a host component.\n   */\n  directiveRegistry: DirectiveDefList|null;\n\n  /**\n   * Full registry of pipes that may be found in this view.\n   *\n   * The property is either an array of `PipeDefs`s or a function which returns the array of\n   * `PipeDefs`s. The function is necessary to be able to support forward declarations.\n   *\n   * It's necessary to keep a copy of the full def list on the TView so it's possible\n   * to render template functions without a host component.\n   */\n  pipeRegistry: PipeDefList|null;\n\n  /**\n   * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in\n   * creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  initHooks: HookData|null;\n\n  /**\n   * Array of ngDoCheck hooks that should be executed for this view in update mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  checkHooks: HookData|null;\n\n  /**\n   * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed\n   * for this view in creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  contentHooks: HookData|null;\n\n  /**\n   * Array of ngAfterContentChecked hooks that should be executed for this view in update\n   * mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  contentCheckHooks: HookData|null;\n\n  /**\n   * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for\n   * this view in creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  viewHooks: HookData|null;\n\n  /**\n   * Array of ngAfterViewChecked hooks that should be executed for this view in\n   * update mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  viewCheckHooks: HookData|null;\n\n  /**\n   * Array of ngOnDestroy hooks that should be executed when this view is destroyed.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  destroyHooks: HookData|null;\n\n  /**\n   * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.\n   *\n   * Even indices: Index of pipe in data\n   * Odd indices: Hook function\n   *\n   * These must be stored separately from directive destroy hooks because their contexts\n   * are stored in data.\n   */\n  pipeDestroyHooks: HookData|null;\n\n  /**\n   * When a view is destroyed, listeners need to be released and outputs need to be\n   * unsubscribed. This cleanup array stores both listener data (in chunks of 4)\n   * and output data (in chunks of 2) for a particular view. Combining the arrays\n   * saves on memory (70 bytes per array) and on a few bytes of code size (for two\n   * separate for loops).\n   *\n   * If it's a native DOM listener being stored:\n   * 1st index is: event name to remove\n   * 2nd index is: index of native element in LView.data[]\n   * 3rd index is: index of wrapped listener function in LView.cleanupInstances[]\n   * 4th index is: useCapture boolean\n   *\n   * If it's a renderer2 style listener or ViewRef destroy hook being stored:\n   * 1st index is: index of the cleanup function in LView.cleanupInstances[]\n   * 2nd index is: null\n   *\n   * If it's an output subscription or query list destroy hook:\n   * 1st index is: output unsubscribe function / query list destroy function\n   * 2nd index is: index of function context in LView.cleanupInstances[]\n   */\n  cleanup: any[]|null;\n\n  /**\n   * A list of element indices for child components that will need to be\n   * refreshed when the current view has finished its check. These indices have\n   * already been adjusted for the HEADER_OFFSET.\n   *\n   */\n  components: number[]|null;\n\n  /**\n   * A list of indices for child directives that have content queries.\n   *\n   * Even indices: Directive indices\n   * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive\n   */\n  contentQueries: number[]|null;\n}\n\nexport const enum RootContextFlags {Empty = 0b00, DetectChanges = 0b01, FlushPlayers = 0b10}\n\n\n/**\n * RootContext contains information which is shared for all components which\n * were bootstrapped with {@link renderComponent}.\n */\nexport interface RootContext {\n  /**\n   * A function used for scheduling change detection in the future. Usually\n   * this is `requestAnimationFrame`.\n   */\n  scheduler: (workFn: () => void) => void;\n\n  /**\n   * A promise which is resolved when all components are considered clean (not dirty).\n   *\n   * This promise is overwritten every time a first call to {@link markDirty} is invoked.\n   */\n  clean: Promise<null>;\n\n  /**\n   * RootComponents - The components that were instantiated by the call to\n   * {@link renderComponent}.\n   */\n  components: {}[];\n\n  /**\n   * The player flushing handler to kick off all animations\n   */\n  playerHandler: PlayerHandler|null;\n\n  /**\n   * What render-related operations to run once a scheduler has been set\n   */\n  flags: RootContextFlags;\n}\n\n/**\n * Array of hooks that should be executed for a view and their directive indices.\n *\n * Even indices: Directive index\n * Odd indices: Hook function\n */\nexport type HookData = (number | (() => void))[];\n\n/**\n * Static data that corresponds to the instance-specific data array on an LView.\n *\n * Each node's static data is stored in tData at the same index that it's stored\n * in the data array.  Any nodes that do not have static data store a null value in\n * tData to avoid a sparse array.\n *\n * Each pipe's definition is stored here at the same index as its pipe instance in\n * the data array.\n *\n * Injector bloom filters are also stored here.\n */\nexport type TData =\n    (TNode | PipeDef<any>| DirectiveDef<any>| ComponentDef<any>| number | Type<any>|\n     InjectionToken<any>| TI18n | I18nUpdateOpCodes | null)[];\n\n// Note: This hack is necessary so we don't erroneously get a circular dependency\n// failure based on types.\nexport const unusedValueExportToPlacateAjd = 1;\n"]}
443
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/view.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AA0BA,MAAM,OAAO,KAAK,GAAG,CAAC;;AACtB,MAAM,OAAO,KAAK,GAAG,CAAC;;AACtB,MAAM,OAAO,MAAM,GAAG,CAAC;;AACvB,MAAM,OAAO,IAAI,GAAG,CAAC;;AACrB,MAAM,OAAO,OAAO,GAAG,CAAC;;AACxB,MAAM,OAAO,IAAI,GAAG,CAAC;;AACrB,MAAM,OAAO,SAAS,GAAG,CAAC;;;AAC1B,MAAM,OAAO,aAAa,GAAG,CAAC;;AAC9B,MAAM,OAAO,OAAO,GAAG,CAAC;;AACxB,MAAM,OAAO,OAAO,GAAG,CAAC;;AACxB,MAAM,OAAO,QAAQ,GAAG,EAAE;;AAC1B,MAAM,OAAO,gBAAgB,GAAG,EAAE;;AAClC,MAAM,OAAO,QAAQ,GAAG,EAAE;;AAC1B,MAAM,OAAO,SAAS,GAAG,EAAE;;AAC3B,MAAM,OAAO,IAAI,GAAG,EAAE;;AACtB,MAAM,OAAO,eAAe,GAAG,EAAE;;AACjC,MAAM,OAAO,eAAe,GAAG,EAAE;;AACjC,MAAM,OAAO,gBAAgB,GAAG,EAAE;;;;;AAElC,MAAM,OAAO,aAAa,GAAG,EAAE;;;;AAM/B,qCAEC;;;IADC,oCAAiE;;;;;;;;;;;;;AAcnE,2BAiJC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAIC;;;;;;;OAOG;IACH,eAA0B;IAE1B;;;;;;OAMG;IACH,iBAA4B;IAE5B,wFAAwF;IACxF,cAAyB;IAEzB,kEAAkE;IAClE,QAAmB;IAEnB,+EAA+E;IAC/E,YAAsB;IAEtB;;;;;;OAMG;IACH,WAAqB;IAErB,6CAA6C;IAC7C,aAAuB;IAEvB,gDAAgD;IAChD,WAAoB;;;;;;;;;;AAStB,2BAqOC;;;;;;;;;;IA7NC,mBAAoB;;;;;;IAMpB,0BAAiB;;;;;;IAMjB,yBAAqC;;;;;IAKrC,0BAAmC;;;;;;;;;;;;;;;;;IAiBnC,qBAAkC;;;;;IAGlC,kCAA2B;;;;;IAG3B,qBAAY;;;;;;;;IAQZ,kCAA0B;;;;;;;;;;;;IAY1B,kCAA0B;;;;;;;;;;;;IAY1B,2BAAmB;;;;;IAKnB,2BAAuB;;;;;;;IAOvB,oCAAoE;;;;;;;;IAQpE,kCAAyC;;;;;;;;;;;IAWzC,6BAA+B;;;;;;;;;IAS/B,0BAAyB;;;;;;;;IAQzB,2BAA0B;;;;;;;;;IAS1B,6BAA4B;;;;;;;;;IAS5B,kCAAiC;;;;;;;;;IASjC,0BAAyB;;;;;;;;;IASzB,+BAA8B;;;;;;;;IAQ9B,6BAA4B;;;;;;;;;;;IAW5B,iCAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA6BhC,wBAAoB;;;;;;;;IAQpB,2BAA0B;;;;;;;;IAQ1B,+BAA8B;;;;IAGI,QAAY,EAAE,gBAAoB,EAAE,eAAmB;;;;;;;;AAO3F,iCA6BC;;;;;;;IAxBC,gCAAwC;;;;;;;IAOxC,4BAAqB;;;;;;IAMrB,iCAAiB;;;;;IAKjB,oCAAkC;;;;;IAKlC,4BAAwB;;;;;AA6B1B,MAAM,OAAO,6BAA6B,GAAG,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {InjectionToken} from '../../di/injection_token';\nimport {Injector} from '../../di/injector';\nimport {QueryList} from '../../linker';\nimport {Sanitizer} from '../../sanitization/security';\nimport {Type} from '../../type';\nimport {LContainer} from './container';\nimport {ComponentDef, ComponentQuery, ComponentTemplate, DirectiveDef, DirectiveDefList, HostBindingsFunction, PipeDef, PipeDefList} from './definition';\nimport {I18nUpdateOpCodes, TI18n} from './i18n';\nimport {TElementNode, TNode, TViewNode} from './node';\nimport {PlayerHandler} from './player';\nimport {LQueries} from './query';\nimport {RElement, Renderer3, RendererFactory3} from './renderer';\nimport {StylingContext} from './styling';\n\n\n// Below are constants for LView indices to help us look up LView members\n// without having to remember the specific indices.\n// Uglify will inline these when minifying so there shouldn't be a cost.\nexport const TVIEW = 0;\nexport const FLAGS = 1;\nexport const PARENT = 2;\nexport const NEXT = 3;\nexport const QUERIES = 4;\nexport const HOST = 5;\nexport const HOST_NODE = 6;  // Rename to `T_HOST`?\nexport const BINDING_INDEX = 7;\nexport const CLEANUP = 8;\nexport const CONTEXT = 9;\nexport const INJECTOR = 10;\nexport const RENDERER_FACTORY = 11;\nexport const RENDERER = 12;\nexport const SANITIZER = 13;\nexport const TAIL = 14;\nexport const CONTAINER_INDEX = 15;\nexport const CONTENT_QUERIES = 16;\nexport const DECLARATION_VIEW = 17;\n/** Size of LView's header. Necessary to adjust for it when setting slots.  */\nexport const HEADER_OFFSET = 18;\n\n\n// This interface replaces the real LView interface if it is an arg or a\n// return value of a public instruction. This ensures we don't need to expose\n// the actual interface, which should be kept private.\nexport interface OpaqueViewState {\n  '__brand__': 'Brand for OpaqueViewState that nothing will match';\n}\n\n\n/**\n * `LView` stores all of the information needed to process the instructions as\n * they are invoked from the template. Each embedded view and component view has its\n * own `LView`. When processing a particular view, we set the `viewData` to that\n * `LView`. When that view is done processing, the `viewData` is set back to\n * whatever the original `viewData` was before (the parent `LView`).\n *\n * Keeping separate state for each view facilities view insertion / deletion, so we\n * don't have to edit the data array based on which views are present.\n */\nexport interface LView extends Array<any> {\n  /**\n   * The static data for this view. We need a reference to this so we can easily walk up the\n   * node tree in DI and get the TView.data array associated with a node (where the\n   * directive defs are stored).\n   */\n  readonly[TVIEW]: TView;\n\n  /** Flags for this view. See LViewFlags for more info. */\n  [FLAGS]: LViewFlags;\n\n  /**\n   * The parent view is needed when we exit the view and must restore the previous\n   * `LView`. Without this, the render method would have to keep a stack of\n   * views as it is recursively rendering templates.\n   *\n   * This is the \"insertion\" view for embedded views. This allows us to properly\n   * destroy embedded views.\n   */\n  [PARENT]: LView|null;\n\n  /**\n   *\n   * The next sibling LView or LContainer.\n   *\n   * Allows us to propagate between sibling view states that aren't in the same\n   * container. Embedded views already have a node.next, but it is only set for\n   * views in the same container. We need a way to link component views and views\n   * across containers as well.\n   */\n  [NEXT]: LView|LContainer|null;\n\n  /** Queries active for this view - nodes from a view are reported to those queries. */\n  [QUERIES]: LQueries|null;\n\n  /**\n   * The host node for this LView instance, if this is a component view.\n   *\n   * If this is an embedded view, HOST will be null.\n   */\n  [HOST]: RElement|StylingContext|null;\n\n  /**\n   * Pointer to the `TViewNode` or `TElementNode` which represents the root of the view.\n   *\n   * If `TViewNode`, this is an embedded view of a container. We need this to be able to\n   * efficiently find the `LViewNode` when inserting the view into an anchor.\n   *\n   * If `TElementNode`, this is the LView of a component.\n   *\n   * If null, this is the root view of an application (root component is in this view).\n   */\n  [HOST_NODE]: TViewNode|TElementNode|null;\n\n  /**\n   * The binding index we should access next.\n   *\n   * This is stored so that bindings can continue where they left off\n   * if a view is left midway through processing bindings (e.g. if there is\n   * a setter that creates an embedded view, like in ngIf).\n   */\n  [BINDING_INDEX]: number;\n\n  /**\n   * When a view is destroyed, listeners need to be released and outputs need to be\n   * unsubscribed. This context array stores both listener functions wrapped with\n   * their context and output subscription instances for a particular view.\n   *\n   * These change per LView instance, so they cannot be stored on TView. Instead,\n   * TView.cleanup saves an index to the necessary context in this array.\n   */\n  // TODO: flatten into LView[]\n  [CLEANUP]: any[]|null;\n\n  /**\n   * - For dynamic views, this is the context with which to render the template (e.g.\n   *   `NgForContext`), or `{}` if not defined explicitly.\n   * - For root view of the root component the context contains change detection data.\n   * - For non-root components, the context is the component instance,\n   * - For inline views, the context is null.\n   */\n  [CONTEXT]: {}|RootContext|null;\n\n  /** An optional Module Injector to be used as fall back after Element Injectors are consulted. */\n  readonly[INJECTOR]: Injector|null;\n\n  /** Renderer to be used for this view. */\n  [RENDERER_FACTORY]: RendererFactory3;\n\n  /** Renderer to be used for this view. */\n  [RENDERER]: Renderer3;\n\n  /** An optional custom sanitizer. */\n  [SANITIZER]: Sanitizer|null;\n\n  /**\n   * The last LView or LContainer beneath this LView in the hierarchy.\n   *\n   * The tail allows us to quickly add a new state to the end of the view list\n   * without having to propagate starting from the first child.\n   */\n  [TAIL]: LView|LContainer|null;\n\n  /**\n   * The index of the parent container's host node. Applicable only to embedded views that\n   * have been inserted dynamically. Will be -1 for component views and inline views.\n   *\n   * This is necessary to jump from dynamically created embedded views to their parent\n   * containers because their parent cannot be stored on the TViewNode (views may be inserted\n   * in multiple containers, so the parent cannot be shared between view instances).\n   */\n  [CONTAINER_INDEX]: number;\n\n  /**\n   * Stores QueryLists associated with content queries of a directive. This data structure is\n   * filled-in as part of a directive creation process and is later used to retrieve a QueryList to\n   * be refreshed.\n   */\n  [CONTENT_QUERIES]: QueryList<any>[]|null;\n\n  /**\n   * View where this view's template was declared.\n   *\n   * Only applicable for dynamically created views. Will be null for inline/component views.\n   *\n   * The template for a dynamically created view may be declared in a different view than\n   * it is inserted. We already track the \"insertion view\" (view where the template was\n   * inserted) in LView[PARENT], but we also need access to the \"declaration view\"\n   * (view where the template was declared). Otherwise, we wouldn't be able to call the\n   * view's template function with the proper contexts. Context should be inherited from\n   * the declaration view tree, not the insertion view tree.\n   *\n   * Example (AppComponent template):\n   *\n   * <ng-template #foo></ng-template>       <-- declared here -->\n   * <some-comp [tpl]=\"foo\"></some-comp>    <-- inserted inside this component -->\n   *\n   * The <ng-template> above is declared in the AppComponent template, but it will be passed into\n   * SomeComp and inserted there. In this case, the declaration view would be the AppComponent,\n   * but the insertion view would be SomeComp. When we are removing views, we would want to\n   * traverse through the insertion view to clean up listeners. When we are calling the\n   * template function during change detection, we need the declaration view to get inherited\n   * context.\n   */\n  [DECLARATION_VIEW]: LView|null;\n}\n\n/** Flags associated with an LView (saved in LView[FLAGS]) */\nexport const enum LViewFlags {\n  /**\n   * Whether or not the view is in creationMode.\n   *\n   * This must be stored in the view rather than using `data` as a marker so that\n   * we can properly support embedded views. Otherwise, when exiting a child view\n   * back into the parent view, `data` will be defined and `creationMode` will be\n   * improperly reported as false.\n   */\n  CreationMode = 0b000000001,\n\n  /**\n   * Whether or not this LView instance is on its first processing pass.\n   *\n   * An LView instance is considered to be on its \"first pass\" until it\n   * has completed one creation mode run and one update mode run. At this\n   * time, the flag is turned off.\n   */\n  FirstLViewPass = 0b000000010,\n\n  /** Whether this view has default change detection strategy (checks always) or onPush */\n  CheckAlways = 0b000000100,\n\n  /** Whether or not this view is currently dirty (needing check) */\n  Dirty = 0b000001000,\n\n  /** Whether or not this view is currently attached to change detection tree. */\n  Attached = 0b000010000,\n\n  /**\n   *  Whether or not the init hooks have run.\n   *\n   * If on, the init hooks haven't yet been run and should be executed by the first component that\n   * runs OR the first cR() instruction that runs (so inits are run for the top level view before\n   * any embedded views).\n   */\n  RunInit = 0b000100000,\n\n  /** Whether or not this view is destroyed. */\n  Destroyed = 0b001000000,\n\n  /** Whether or not this view is the root view */\n  IsRoot = 0b010000000,\n}\n\n/**\n * The static data for an LView (shared between all templates of a\n * given type).\n *\n * Stored on the template function as ngPrivateData.\n */\nexport interface TView {\n  /**\n   * ID for inline views to determine whether a view is the same as the previous view\n   * in a certain position. If it's not, we know the new view needs to be inserted\n   * and the one that exists needs to be removed (e.g. if/else statements)\n   *\n   * If this is -1, then this is a component view or a dynamically created view.\n   */\n  readonly id: number;\n\n  /**\n   * This is a blueprint used to generate LView instances for this TView. Copying this\n   * blueprint is faster than creating a new LView from scratch.\n   */\n  blueprint: LView;\n\n  /**\n   * The template function used to refresh the view of dynamically created views\n   * and components. Will be null for inline views.\n   */\n  template: ComponentTemplate<{}>|null;\n\n  /**\n   * A function containing query-related instructions.\n   */\n  viewQuery: ComponentQuery<{}>|null;\n\n  /**\n   * Pointer to the `TNode` that represents the root of the view.\n   *\n   * If this is a `TViewNode` for an `LViewNode`, this is an embedded view of a container.\n   * We need this pointer to be able to efficiently find this node when inserting the view\n   * into an anchor.\n   *\n   * If this is a `TElementNode`, this is the view of a root component. It has exactly one\n   * root TNode.\n   *\n   * If this is null, this is the view of a component that is not at root. We do not store\n   * the host TNodes for child component views because they can potentially have several\n   * different host TNodes, depending on where the component is being used. These host\n   * TNodes cannot be shared (due to different indices, etc).\n   */\n  node: TViewNode|TElementNode|null;\n\n  /** Whether or not this template has been processed. */\n  firstTemplatePass: boolean;\n\n  /** Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n. */\n  data: TData;\n\n  /**\n   * The binding start index is the index at which the data array\n   * starts to store bindings only. Saving this value ensures that we\n   * will begin reading bindings at the correct point in the array when\n   * we are in update mode.\n   */\n  bindingStartIndex: number;\n\n  /**\n   * The index where the \"expando\" section of `LView` begins. The expando\n   * section contains injectors, directive instances, and host binding values.\n   * Unlike the \"consts\" and \"vars\" sections of `LView`, the length of this\n   * section cannot be calculated at compile-time because directives are matched\n   * at runtime to preserve locality.\n   *\n   * We store this start index so we know where to start checking host bindings\n   * in `setHostBindings`.\n   */\n  expandoStartIndex: number;\n\n  /**\n   * Index of the host node of the first LView or LContainer beneath this LView in\n   * the hierarchy.\n   *\n   * Necessary to store this so views can traverse through their nested views\n   * to remove listeners and call onDestroy callbacks.\n   *\n   * For embedded views, we store the index of an LContainer's host rather than the first\n   * LView to avoid managing splicing when views are added/removed.\n   */\n  childIndex: number;\n\n  /**\n   * A reference to the first child node located in the view.\n   */\n  firstChild: TNode|null;\n\n  /**\n   * Set of instructions used to process host bindings efficiently.\n   *\n   * See VIEW_DATA.md for more information.\n   */\n  expandoInstructions: (number|HostBindingsFunction<any>|null)[]|null;\n\n  /**\n   * Full registry of directives and components that may be found in this view.\n   *\n   * It's necessary to keep a copy of the full def list on the TView so it's possible\n   * to render template functions without a host component.\n   */\n  directiveRegistry: DirectiveDefList|null;\n\n  /**\n   * Full registry of pipes that may be found in this view.\n   *\n   * The property is either an array of `PipeDefs`s or a function which returns the array of\n   * `PipeDefs`s. The function is necessary to be able to support forward declarations.\n   *\n   * It's necessary to keep a copy of the full def list on the TView so it's possible\n   * to render template functions without a host component.\n   */\n  pipeRegistry: PipeDefList|null;\n\n  /**\n   * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in\n   * creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  initHooks: HookData|null;\n\n  /**\n   * Array of ngDoCheck hooks that should be executed for this view in update mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  checkHooks: HookData|null;\n\n  /**\n   * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed\n   * for this view in creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  contentHooks: HookData|null;\n\n  /**\n   * Array of ngAfterContentChecked hooks that should be executed for this view in update\n   * mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  contentCheckHooks: HookData|null;\n\n  /**\n   * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for\n   * this view in creation mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  viewHooks: HookData|null;\n\n  /**\n   * Array of ngAfterViewChecked hooks that should be executed for this view in\n   * update mode.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  viewCheckHooks: HookData|null;\n\n  /**\n   * Array of ngOnDestroy hooks that should be executed when this view is destroyed.\n   *\n   * Even indices: Directive index\n   * Odd indices: Hook function\n   */\n  destroyHooks: HookData|null;\n\n  /**\n   * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.\n   *\n   * Even indices: Index of pipe in data\n   * Odd indices: Hook function\n   *\n   * These must be stored separately from directive destroy hooks because their contexts\n   * are stored in data.\n   */\n  pipeDestroyHooks: HookData|null;\n\n  /**\n   * When a view is destroyed, listeners need to be released and outputs need to be\n   * unsubscribed. This cleanup array stores both listener data (in chunks of 4)\n   * and output data (in chunks of 2) for a particular view. Combining the arrays\n   * saves on memory (70 bytes per array) and on a few bytes of code size (for two\n   * separate for loops).\n   *\n   * If it's a native DOM listener or output subscription being stored:\n   * 1st index is: event name  `name = tView.cleanup[i+0]`\n   * 2nd index is: index of native element `element = lView[tView.cleanup[i+1]]`\n   * 3rd index is: index of listener function `listener = lView[CLEANUP][tView.cleanup[i+2]]`\n   * 4th index is: `useCaptureOrIndx = tView.cleanup[i+3]`\n   *    `typeof useCaptureOrIndx == 'boolean' : useCapture boolean\n   *    `typeof useCaptureOrIndx == 'number':\n   *         `useCaptureOrIndx >= 0` `removeListener = LView[CLEANUP][useCaptureOrIndx]`\n   *         `useCaptureOrIndx <  0` `subscription = LView[CLEANUP][-useCaptureOrIndx]`\n   *\n   * If it's a renderer2 style listener or ViewRef destroy hook being stored:\n   * 1st index is: index of the cleanup function in LView.cleanupInstances[]\n   * 2nd index is: `null`\n   *               `lView[CLEANUP][tView.cleanup[i+0]]()`\n   *\n   * If it's an output subscription or query list destroy hook:\n   * 1st index is: output unsubscribe function / query list destroy function\n   * 2nd index is: index of function context in LView.cleanupInstances[]\n   *               `tView.cleanup[i+0].call(lView[CLEANUP][tView.cleanup[i+1]])`\n   */\n  cleanup: any[]|null;\n\n  /**\n   * A list of element indices for child components that will need to be\n   * refreshed when the current view has finished its check. These indices have\n   * already been adjusted for the HEADER_OFFSET.\n   *\n   */\n  components: number[]|null;\n\n  /**\n   * A list of indices for child directives that have content queries.\n   *\n   * Even indices: Directive indices\n   * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive\n   */\n  contentQueries: number[]|null;\n}\n\nexport const enum RootContextFlags {Empty = 0b00, DetectChanges = 0b01, FlushPlayers = 0b10}\n\n\n/**\n * RootContext contains information which is shared for all components which\n * were bootstrapped with {@link renderComponent}.\n */\nexport interface RootContext {\n  /**\n   * A function used for scheduling change detection in the future. Usually\n   * this is `requestAnimationFrame`.\n   */\n  scheduler: (workFn: () => void) => void;\n\n  /**\n   * A promise which is resolved when all components are considered clean (not dirty).\n   *\n   * This promise is overwritten every time a first call to {@link markDirty} is invoked.\n   */\n  clean: Promise<null>;\n\n  /**\n   * RootComponents - The components that were instantiated by the call to\n   * {@link renderComponent}.\n   */\n  components: {}[];\n\n  /**\n   * The player flushing handler to kick off all animations\n   */\n  playerHandler: PlayerHandler|null;\n\n  /**\n   * What render-related operations to run once a scheduler has been set\n   */\n  flags: RootContextFlags;\n}\n\n/**\n * Array of hooks that should be executed for a view and their directive indices.\n *\n * Even indices: Directive index\n * Odd indices: Hook function\n */\nexport type HookData = (number | (() => void))[];\n\n/**\n * Static data that corresponds to the instance-specific data array on an LView.\n *\n * Each node's static data is stored in tData at the same index that it's stored\n * in the data array.  Any nodes that do not have static data store a null value in\n * tData to avoid a sparse array.\n *\n * Each pipe's definition is stored here at the same index as its pipe instance in\n * the data array.\n *\n * Injector bloom filters are also stored here.\n */\nexport type TData =\n    (TNode | PipeDef<any>| DirectiveDef<any>| ComponentDef<any>| number | Type<any>|\n     InjectionToken<any>| TI18n | I18nUpdateOpCodes | null)[];\n\n// Note: This hack is necessary so we don't erroneously get a circular dependency\n// failure based on types.\nexport const unusedValueExportToPlacateAjd = 1;\n"]}