@angular/core 7.1.3 → 7.1.4

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 (402) hide show
  1. package/bundles/core-testing.umd.js +1 -1
  2. package/bundles/core-testing.umd.min.js +1 -1
  3. package/bundles/core-testing.umd.min.js.map +1 -1
  4. package/bundles/core.umd.js +2 -2
  5. package/bundles/core.umd.js.map +1 -1
  6. package/bundles/core.umd.min.js +2 -2
  7. package/bundles/core.umd.min.js.map +1 -1
  8. package/core.metadata.json +1 -1
  9. package/esm2015/core.externs.js +44 -34
  10. package/esm2015/core.js +0 -1
  11. package/esm2015/index.js +1 -2
  12. package/esm2015/public_api.js +1 -3
  13. package/esm2015/src/application_init.js +6 -6
  14. package/esm2015/src/application_module.js +6 -5
  15. package/esm2015/src/application_ref.js +31 -22
  16. package/esm2015/src/application_tokens.js +21 -16
  17. package/esm2015/src/change_detection/change_detection.js +8 -7
  18. package/esm2015/src/change_detection/change_detection_util.js +2 -4
  19. package/esm2015/src/change_detection/change_detector_ref.js +2 -3
  20. package/esm2015/src/change_detection/constants.js +30 -32
  21. package/esm2015/src/change_detection/differs/default_iterable_differ.js +51 -15
  22. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +7 -6
  23. package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
  24. package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
  25. package/esm2015/src/change_detection/pipe_transform.js +10 -5
  26. package/esm2015/src/change_detection.js +7 -3
  27. package/esm2015/src/codegen_private_exports.js +1 -2
  28. package/esm2015/src/console.js +3 -3
  29. package/esm2015/src/core.js +1 -2
  30. package/esm2015/src/core_private_export.js +1 -2
  31. package/esm2015/src/core_render3_private_export.js +7 -4
  32. package/esm2015/src/debug/debug_node.js +4 -4
  33. package/esm2015/src/di/defs.js +59 -50
  34. package/esm2015/src/di/forward_ref.js +5 -6
  35. package/esm2015/src/di/injectable.js +11 -11
  36. package/esm2015/src/di/injection_token.js +6 -5
  37. package/esm2015/src/di/injector.js +49 -42
  38. package/esm2015/src/di/injector_compatibility.js +13 -12
  39. package/esm2015/src/di/metadata.js +22 -13
  40. package/esm2015/src/di/provider.js +137 -120
  41. package/esm2015/src/di/r3_injector.js +57 -34
  42. package/esm2015/src/di/reflective_errors.js +19 -13
  43. package/esm2015/src/di/reflective_injector.js +10 -15
  44. package/esm2015/src/di/reflective_key.js +3 -4
  45. package/esm2015/src/di/reflective_provider.js +21 -20
  46. package/esm2015/src/di/scope.js +5 -5
  47. package/esm2015/src/di/util.js +13 -14
  48. package/esm2015/src/di.js +1 -2
  49. package/esm2015/src/error_handler.js +5 -4
  50. package/esm2015/src/errors.js +7 -8
  51. package/esm2015/src/event_emitter.js +3 -3
  52. package/esm2015/src/i18n/tokens.js +12 -10
  53. package/esm2015/src/is_dev_mode.js +2 -3
  54. package/esm2015/src/ivy_switch.js +2 -3
  55. package/esm2015/src/linker/compiler.js +5 -8
  56. package/esm2015/src/linker/component_factory.js +2 -3
  57. package/esm2015/src/linker/component_factory_resolver.js +4 -5
  58. package/esm2015/src/linker/element_ref.js +5 -3
  59. package/esm2015/src/linker/ng_module_factory.js +6 -5
  60. package/esm2015/src/linker/ng_module_factory_loader.js +2 -3
  61. package/esm2015/src/linker/query_list.js +12 -13
  62. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +2 -3
  63. package/esm2015/src/linker/template_ref.js +2 -3
  64. package/esm2015/src/linker/view_container_ref.js +2 -3
  65. package/esm2015/src/linker/view_ref.js +13 -7
  66. package/esm2015/src/linker.js +3 -3
  67. package/esm2015/src/metadata/di.js +22 -15
  68. package/esm2015/src/metadata/directives.js +34 -19
  69. package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
  70. package/esm2015/src/metadata/ng_module.js +82 -68
  71. package/esm2015/src/metadata/resource_loading.js +4 -3
  72. package/esm2015/src/metadata/view.js +25 -26
  73. package/esm2015/src/metadata.js +6 -3
  74. package/esm2015/src/platform_core_providers.js +5 -5
  75. package/esm2015/src/profile/profile.js +17 -13
  76. package/esm2015/src/profile/wtf_impl.js +36 -16
  77. package/esm2015/src/r3_symbols.js +18 -5
  78. package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
  79. package/esm2015/src/reflection/reflection.js +5 -5
  80. package/esm2015/src/reflection/reflection_capabilities.js +31 -26
  81. package/esm2015/src/reflection/reflector.js +2 -3
  82. package/esm2015/src/reflection/types.js +1 -11
  83. package/esm2015/src/render/api.js +67 -47
  84. package/esm2015/src/render.js +3 -3
  85. package/esm2015/src/render3/assert.js +5 -3
  86. package/esm2015/src/render3/component.js +66 -64
  87. package/esm2015/src/render3/component_ref.js +24 -21
  88. package/esm2015/src/render3/context_discovery.js +37 -17
  89. package/esm2015/src/render3/debug.js +9 -6
  90. package/esm2015/src/render3/definition.js +28 -28
  91. package/esm2015/src/render3/di.js +55 -28
  92. package/esm2015/src/render3/di_setup.js +34 -14
  93. package/esm2015/src/render3/discovery_utils.js +16 -17
  94. package/esm2015/src/render3/errors.js +2 -3
  95. package/esm2015/src/render3/features/inherit_definition_feature.js +12 -8
  96. package/esm2015/src/render3/features/ng_onchanges_feature.js +5 -6
  97. package/esm2015/src/render3/features/providers_feature.js +2 -3
  98. package/esm2015/src/render3/fields.js +5 -5
  99. package/esm2015/src/render3/global_utils.js +19 -6
  100. package/esm2015/src/render3/global_utils_api.js +12 -6
  101. package/esm2015/src/render3/hooks.js +4 -5
  102. package/esm2015/src/render3/i18n.js +112 -89
  103. package/esm2015/src/render3/index.js +11 -3
  104. package/esm2015/src/render3/instructions.js +199 -149
  105. package/esm2015/src/render3/interfaces/container.js +27 -5
  106. package/esm2015/src/render3/interfaces/context.js +38 -36
  107. package/esm2015/src/render3/interfaces/definition.js +234 -261
  108. package/esm2015/src/render3/interfaces/i18n.js +154 -126
  109. package/esm2015/src/render3/interfaces/injector.js +93 -10
  110. package/esm2015/src/render3/interfaces/node.js +369 -373
  111. package/esm2015/src/render3/interfaces/player.js +78 -37
  112. package/esm2015/src/render3/interfaces/projection.js +5 -10
  113. package/esm2015/src/render3/interfaces/query.js +66 -60
  114. package/esm2015/src/render3/interfaces/renderer.js +288 -117
  115. package/esm2015/src/render3/interfaces/sanitization.js +1 -5
  116. package/esm2015/src/render3/interfaces/styling.js +26 -6
  117. package/esm2015/src/render3/interfaces/view.js +326 -285
  118. package/esm2015/src/render3/jit/compiler_facade.js +10 -4
  119. package/esm2015/src/render3/jit/compiler_facade_interface.js +189 -152
  120. package/esm2015/src/render3/jit/directive.js +6 -6
  121. package/esm2015/src/render3/jit/environment.js +5 -5
  122. package/esm2015/src/render3/jit/injectable.js +6 -8
  123. package/esm2015/src/render3/jit/module.js +17 -13
  124. package/esm2015/src/render3/jit/pipe.js +2 -3
  125. package/esm2015/src/render3/jit/util.js +2 -3
  126. package/esm2015/src/render3/metadata.js +11 -10
  127. package/esm2015/src/render3/ng_dev_mode.js +5 -6
  128. package/esm2015/src/render3/ng_module_ref.js +11 -10
  129. package/esm2015/src/render3/node_assert.js +2 -3
  130. package/esm2015/src/render3/node_manipulation.js +86 -73
  131. package/esm2015/src/render3/node_selector_matcher.js +13 -12
  132. package/esm2015/src/render3/pipe.js +4 -5
  133. package/esm2015/src/render3/players.js +11 -5
  134. package/esm2015/src/render3/pure_function.js +29 -3
  135. package/esm2015/src/render3/query.js +74 -70
  136. package/esm2015/src/render3/state.js +44 -33
  137. package/esm2015/src/render3/styling/class_and_style_bindings.js +62 -43
  138. package/esm2015/src/render3/styling/core_player_handler.js +2 -3
  139. package/esm2015/src/render3/styling/player_factory.js +3 -4
  140. package/esm2015/src/render3/styling/util.js +18 -13
  141. package/esm2015/src/render3/tokens.js +7 -6
  142. package/esm2015/src/render3/util.js +18 -16
  143. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  144. package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
  145. package/esm2015/src/render3/view_ref.js +7 -10
  146. package/esm2015/src/sanitization/bypass.js +29 -6
  147. package/esm2015/src/sanitization/html_sanitizer.js +41 -15
  148. package/esm2015/src/sanitization/inert_body.js +14 -12
  149. package/esm2015/src/sanitization/sanitization.js +7 -7
  150. package/esm2015/src/sanitization/security.js +3 -4
  151. package/esm2015/src/sanitization/style_sanitizer.js +10 -7
  152. package/esm2015/src/sanitization/url_sanitizer.js +9 -7
  153. package/esm2015/src/testability/testability.js +47 -37
  154. package/esm2015/src/type.js +6 -8
  155. package/esm2015/src/util/decorators.js +19 -14
  156. package/esm2015/src/util/lang.js +2 -3
  157. package/esm2015/src/util/noop.js +2 -3
  158. package/esm2015/src/util/property.js +3 -4
  159. package/esm2015/src/util.js +12 -4
  160. package/esm2015/src/version.js +6 -6
  161. package/esm2015/src/view/element.js +17 -17
  162. package/esm2015/src/view/entrypoint.js +7 -3
  163. package/esm2015/src/view/errors.js +4 -5
  164. package/esm2015/src/view/index.js +1 -2
  165. package/esm2015/src/view/ng_content.js +3 -4
  166. package/esm2015/src/view/ng_module.js +2 -3
  167. package/esm2015/src/view/provider.js +89 -24
  168. package/esm2015/src/view/pure_expression.js +14 -15
  169. package/esm2015/src/view/query.js +14 -14
  170. package/esm2015/src/view/refs.js +20 -19
  171. package/esm2015/src/view/services.js +41 -31
  172. package/esm2015/src/view/text.js +5 -6
  173. package/esm2015/src/view/types.js +386 -324
  174. package/esm2015/src/view/util.js +29 -24
  175. package/esm2015/src/view/view.js +43 -36
  176. package/esm2015/src/view/view_attach.js +9 -10
  177. package/esm2015/src/zone/ng_zone.js +29 -28
  178. package/esm2015/src/zone.js +3 -3
  179. package/esm2015/testing/index.js +1 -2
  180. package/esm2015/testing/public_api.js +4 -4
  181. package/esm2015/testing/src/async.js +2 -3
  182. package/esm2015/testing/src/async_fallback.js +8 -7
  183. package/esm2015/testing/src/async_test_completer.js +2 -3
  184. package/esm2015/testing/src/before_each.js +10 -4
  185. package/esm2015/testing/src/component_fixture.js +6 -7
  186. package/esm2015/testing/src/fake_async.js +9 -3
  187. package/esm2015/testing/src/fake_async_fallback.js +5 -5
  188. package/esm2015/testing/src/lang_utils.js +3 -4
  189. package/esm2015/testing/src/logger.js +2 -3
  190. package/esm2015/testing/src/metadata_override.js +1 -5
  191. package/esm2015/testing/src/metadata_overrider.js +5 -7
  192. package/esm2015/testing/src/ng_zone_mock.js +2 -3
  193. package/esm2015/testing/src/private_export_testing.js +1 -2
  194. package/esm2015/testing/src/r3_test_bed.js +34 -27
  195. package/esm2015/testing/src/resolvers.js +9 -5
  196. package/esm2015/testing/src/test_bed.js +38 -34
  197. package/esm2015/testing/src/test_bed_common.js +142 -85
  198. package/esm2015/testing/src/test_compiler.js +2 -3
  199. package/esm2015/testing/src/testing.js +3 -3
  200. package/esm2015/testing/src/testing_internal.js +8 -9
  201. package/esm2015/testing/testing.js +0 -1
  202. package/esm5/core.js +0 -1
  203. package/esm5/index.js +0 -1
  204. package/esm5/public_api.js +0 -1
  205. package/esm5/src/application_init.js +0 -1
  206. package/esm5/src/application_module.js +0 -1
  207. package/esm5/src/application_ref.js +0 -1
  208. package/esm5/src/application_tokens.js +0 -1
  209. package/esm5/src/change_detection/change_detection.js +0 -1
  210. package/esm5/src/change_detection/change_detection_util.js +0 -1
  211. package/esm5/src/change_detection/change_detector_ref.js +0 -1
  212. package/esm5/src/change_detection/constants.js +0 -1
  213. package/esm5/src/change_detection/differs/default_iterable_differ.js +0 -1
  214. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +0 -1
  215. package/esm5/src/change_detection/differs/iterable_differs.js +0 -1
  216. package/esm5/src/change_detection/differs/keyvalue_differs.js +0 -1
  217. package/esm5/src/change_detection/pipe_transform.js +0 -1
  218. package/esm5/src/change_detection.js +0 -1
  219. package/esm5/src/codegen_private_exports.js +0 -1
  220. package/esm5/src/console.js +0 -1
  221. package/esm5/src/core.js +0 -1
  222. package/esm5/src/core_private_export.js +0 -1
  223. package/esm5/src/core_render3_private_export.js +0 -1
  224. package/esm5/src/debug/debug_node.js +0 -1
  225. package/esm5/src/di/defs.js +0 -1
  226. package/esm5/src/di/forward_ref.js +0 -1
  227. package/esm5/src/di/injectable.js +0 -1
  228. package/esm5/src/di/injection_token.js +0 -1
  229. package/esm5/src/di/injector.js +0 -1
  230. package/esm5/src/di/injector_compatibility.js +0 -1
  231. package/esm5/src/di/metadata.js +0 -1
  232. package/esm5/src/di/provider.js +0 -1
  233. package/esm5/src/di/r3_injector.js +0 -1
  234. package/esm5/src/di/reflective_errors.js +0 -1
  235. package/esm5/src/di/reflective_injector.js +0 -1
  236. package/esm5/src/di/reflective_key.js +0 -1
  237. package/esm5/src/di/reflective_provider.js +0 -1
  238. package/esm5/src/di/scope.js +0 -1
  239. package/esm5/src/di/util.js +0 -1
  240. package/esm5/src/di.js +0 -1
  241. package/esm5/src/error_handler.js +0 -1
  242. package/esm5/src/errors.js +0 -1
  243. package/esm5/src/event_emitter.js +0 -1
  244. package/esm5/src/i18n/tokens.js +0 -1
  245. package/esm5/src/is_dev_mode.js +0 -1
  246. package/esm5/src/ivy_switch.js +0 -1
  247. package/esm5/src/linker/compiler.js +0 -1
  248. package/esm5/src/linker/component_factory.js +0 -1
  249. package/esm5/src/linker/component_factory_resolver.js +0 -1
  250. package/esm5/src/linker/element_ref.js +0 -1
  251. package/esm5/src/linker/ng_module_factory.js +0 -1
  252. package/esm5/src/linker/ng_module_factory_loader.js +0 -1
  253. package/esm5/src/linker/query_list.js +0 -1
  254. package/esm5/src/linker/system_js_ng_module_factory_loader.js +0 -1
  255. package/esm5/src/linker/template_ref.js +0 -1
  256. package/esm5/src/linker/view_container_ref.js +0 -1
  257. package/esm5/src/linker/view_ref.js +0 -1
  258. package/esm5/src/linker.js +0 -1
  259. package/esm5/src/metadata/di.js +0 -1
  260. package/esm5/src/metadata/directives.js +0 -1
  261. package/esm5/src/metadata/lifecycle_hooks.js +0 -1
  262. package/esm5/src/metadata/ng_module.js +0 -1
  263. package/esm5/src/metadata/resource_loading.js +0 -1
  264. package/esm5/src/metadata/view.js +0 -1
  265. package/esm5/src/metadata.js +0 -1
  266. package/esm5/src/platform_core_providers.js +0 -1
  267. package/esm5/src/profile/profile.js +0 -1
  268. package/esm5/src/profile/wtf_impl.js +0 -1
  269. package/esm5/src/r3_symbols.js +0 -1
  270. package/esm5/src/reflection/platform_reflection_capabilities.js +0 -1
  271. package/esm5/src/reflection/reflection.js +0 -1
  272. package/esm5/src/reflection/reflection_capabilities.js +0 -1
  273. package/esm5/src/reflection/reflector.js +0 -1
  274. package/esm5/src/reflection/types.js +0 -1
  275. package/esm5/src/render/api.js +0 -1
  276. package/esm5/src/render.js +0 -1
  277. package/esm5/src/render3/assert.js +0 -1
  278. package/esm5/src/render3/component.js +0 -1
  279. package/esm5/src/render3/component_ref.js +0 -1
  280. package/esm5/src/render3/context_discovery.js +0 -1
  281. package/esm5/src/render3/debug.js +0 -1
  282. package/esm5/src/render3/definition.js +0 -1
  283. package/esm5/src/render3/di.js +0 -1
  284. package/esm5/src/render3/di_setup.js +0 -1
  285. package/esm5/src/render3/discovery_utils.js +0 -1
  286. package/esm5/src/render3/errors.js +0 -1
  287. package/esm5/src/render3/features/inherit_definition_feature.js +0 -1
  288. package/esm5/src/render3/features/ng_onchanges_feature.js +0 -1
  289. package/esm5/src/render3/features/providers_feature.js +0 -1
  290. package/esm5/src/render3/fields.js +0 -1
  291. package/esm5/src/render3/global_utils.js +0 -1
  292. package/esm5/src/render3/global_utils_api.js +0 -1
  293. package/esm5/src/render3/hooks.js +0 -1
  294. package/esm5/src/render3/i18n.js +0 -1
  295. package/esm5/src/render3/index.js +0 -1
  296. package/esm5/src/render3/instructions.js +0 -1
  297. package/esm5/src/render3/interfaces/container.js +0 -1
  298. package/esm5/src/render3/interfaces/context.js +0 -1
  299. package/esm5/src/render3/interfaces/definition.js +0 -1
  300. package/esm5/src/render3/interfaces/i18n.js +0 -1
  301. package/esm5/src/render3/interfaces/injector.js +0 -1
  302. package/esm5/src/render3/interfaces/node.js +0 -1
  303. package/esm5/src/render3/interfaces/player.js +0 -1
  304. package/esm5/src/render3/interfaces/projection.js +0 -1
  305. package/esm5/src/render3/interfaces/query.js +0 -1
  306. package/esm5/src/render3/interfaces/renderer.js +0 -1
  307. package/esm5/src/render3/interfaces/sanitization.js +0 -1
  308. package/esm5/src/render3/interfaces/styling.js +0 -1
  309. package/esm5/src/render3/interfaces/view.js +0 -1
  310. package/esm5/src/render3/jit/compiler_facade.js +0 -1
  311. package/esm5/src/render3/jit/compiler_facade_interface.js +0 -1
  312. package/esm5/src/render3/jit/directive.js +0 -1
  313. package/esm5/src/render3/jit/environment.js +0 -1
  314. package/esm5/src/render3/jit/injectable.js +0 -1
  315. package/esm5/src/render3/jit/module.js +0 -1
  316. package/esm5/src/render3/jit/pipe.js +0 -1
  317. package/esm5/src/render3/jit/util.js +0 -1
  318. package/esm5/src/render3/metadata.js +0 -1
  319. package/esm5/src/render3/ng_dev_mode.js +0 -1
  320. package/esm5/src/render3/ng_module_ref.js +0 -1
  321. package/esm5/src/render3/node_assert.js +0 -1
  322. package/esm5/src/render3/node_manipulation.js +0 -1
  323. package/esm5/src/render3/node_selector_matcher.js +0 -1
  324. package/esm5/src/render3/pipe.js +0 -1
  325. package/esm5/src/render3/players.js +0 -1
  326. package/esm5/src/render3/pure_function.js +0 -1
  327. package/esm5/src/render3/query.js +0 -1
  328. package/esm5/src/render3/state.js +0 -1
  329. package/esm5/src/render3/styling/class_and_style_bindings.js +0 -1
  330. package/esm5/src/render3/styling/core_player_handler.js +0 -1
  331. package/esm5/src/render3/styling/player_factory.js +0 -1
  332. package/esm5/src/render3/styling/util.js +0 -1
  333. package/esm5/src/render3/tokens.js +0 -1
  334. package/esm5/src/render3/util.js +0 -1
  335. package/esm5/src/render3/view_engine_compatibility.js +0 -1
  336. package/esm5/src/render3/view_engine_compatibility_prebound.js +0 -1
  337. package/esm5/src/render3/view_ref.js +0 -1
  338. package/esm5/src/sanitization/bypass.js +0 -1
  339. package/esm5/src/sanitization/html_sanitizer.js +0 -1
  340. package/esm5/src/sanitization/inert_body.js +0 -1
  341. package/esm5/src/sanitization/sanitization.js +0 -1
  342. package/esm5/src/sanitization/security.js +0 -1
  343. package/esm5/src/sanitization/style_sanitizer.js +0 -1
  344. package/esm5/src/sanitization/url_sanitizer.js +0 -1
  345. package/esm5/src/testability/testability.js +0 -1
  346. package/esm5/src/type.js +0 -1
  347. package/esm5/src/util/decorators.js +0 -1
  348. package/esm5/src/util/lang.js +0 -1
  349. package/esm5/src/util/noop.js +0 -1
  350. package/esm5/src/util/property.js +0 -1
  351. package/esm5/src/util.js +0 -1
  352. package/esm5/src/version.js +1 -2
  353. package/esm5/src/view/element.js +0 -1
  354. package/esm5/src/view/entrypoint.js +0 -1
  355. package/esm5/src/view/errors.js +0 -1
  356. package/esm5/src/view/index.js +0 -1
  357. package/esm5/src/view/ng_content.js +0 -1
  358. package/esm5/src/view/ng_module.js +0 -1
  359. package/esm5/src/view/provider.js +0 -1
  360. package/esm5/src/view/pure_expression.js +0 -1
  361. package/esm5/src/view/query.js +0 -1
  362. package/esm5/src/view/refs.js +0 -1
  363. package/esm5/src/view/services.js +0 -1
  364. package/esm5/src/view/text.js +0 -1
  365. package/esm5/src/view/types.js +0 -1
  366. package/esm5/src/view/util.js +0 -1
  367. package/esm5/src/view/view.js +0 -1
  368. package/esm5/src/view/view_attach.js +0 -1
  369. package/esm5/src/zone/ng_zone.js +0 -1
  370. package/esm5/src/zone.js +0 -1
  371. package/esm5/testing/index.js +0 -1
  372. package/esm5/testing/public_api.js +0 -1
  373. package/esm5/testing/src/async.js +0 -1
  374. package/esm5/testing/src/async_fallback.js +0 -1
  375. package/esm5/testing/src/async_test_completer.js +0 -1
  376. package/esm5/testing/src/before_each.js +0 -1
  377. package/esm5/testing/src/component_fixture.js +0 -1
  378. package/esm5/testing/src/fake_async.js +0 -1
  379. package/esm5/testing/src/fake_async_fallback.js +0 -1
  380. package/esm5/testing/src/lang_utils.js +0 -1
  381. package/esm5/testing/src/logger.js +0 -1
  382. package/esm5/testing/src/metadata_override.js +0 -1
  383. package/esm5/testing/src/metadata_overrider.js +0 -1
  384. package/esm5/testing/src/ng_zone_mock.js +0 -1
  385. package/esm5/testing/src/private_export_testing.js +0 -1
  386. package/esm5/testing/src/r3_test_bed.js +0 -1
  387. package/esm5/testing/src/resolvers.js +0 -1
  388. package/esm5/testing/src/test_bed.js +0 -1
  389. package/esm5/testing/src/test_bed_common.js +0 -1
  390. package/esm5/testing/src/test_compiler.js +0 -1
  391. package/esm5/testing/src/testing.js +0 -1
  392. package/esm5/testing/src/testing_internal.js +0 -1
  393. package/esm5/testing/testing.js +0 -1
  394. package/fesm2015/core.js +1991 -1326
  395. package/fesm2015/core.js.map +1 -1
  396. package/fesm2015/testing.js +123 -89
  397. package/fesm2015/testing.js.map +1 -1
  398. package/fesm5/core.js +2 -2
  399. package/fesm5/core.js.map +1 -1
  400. package/fesm5/testing.js +1 -1
  401. package/package.json +1 -1
  402. package/testing.d.ts +1 -1
@@ -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,uselessCode} checked by tsc
4
4
  */
5
5
  /**
6
6
  * @license
@@ -9,10 +9,14 @@
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
- /** *
12
+ /**
13
13
  * Size of LViewData's header. Necessary to adjust for it when setting slots.
14
- @type {?} */
14
+ * @type {?}
15
+ */
15
16
  export const HEADER_OFFSET = 17;
17
+ // Below are constants for LViewData indices to help us look up LViewData members
18
+ // without having to remember the specific indices.
19
+ // Uglify will inline these when minifying so there shouldn't be a cost.
16
20
  /** @type {?} */
17
21
  export const TVIEW = 0;
18
22
  /** @type {?} */
@@ -51,8 +55,10 @@ export const DECLARATION_VIEW = 16;
51
55
  * @record
52
56
  */
53
57
  export function OpaqueViewState() { }
54
- /** @type {?} */
55
- OpaqueViewState.prototype.__brand__;
58
+ if (false) {
59
+ /** @type {?} */
60
+ OpaqueViewState.prototype.__brand__;
61
+ }
56
62
  /**
57
63
  * `LViewData` stores all of the information needed to process the instructions as
58
64
  * they are invoked from the template. Each embedded view and component view has its
@@ -65,16 +71,52 @@ OpaqueViewState.prototype.__brand__;
65
71
  * @record
66
72
  */
67
73
  export function LViewData() { }
74
+ if (false) {
75
+ /* Skipping unnamed member:
76
+ readonly[TVIEW]: TView;*/
77
+ /* Skipping unnamed member:
78
+ [FLAGS]: LViewFlags;*/
79
+ /* Skipping unnamed member:
80
+ [PARENT]: LViewData|null;*/
81
+ /* Skipping unnamed member:
82
+ [NEXT]: LViewData|LContainer|null;*/
83
+ /* Skipping unnamed member:
84
+ [QUERIES]: LQueries|null;*/
85
+ /* Skipping unnamed member:
86
+ [HOST]: RElement|StylingContext|null;*/
87
+ /* Skipping unnamed member:
88
+ [HOST_NODE]: TViewNode|TElementNode|null;*/
89
+ /* Skipping unnamed member:
90
+ [BINDING_INDEX]: number;*/
91
+ /* Skipping unnamed member:
92
+ [CLEANUP]: any[]|null;*/
93
+ /* Skipping unnamed member:
94
+ [CONTEXT]: {}|RootContext|null;*/
95
+ /* Skipping unnamed member:
96
+ readonly[INJECTOR]: Injector|null;*/
97
+ /* Skipping unnamed member:
98
+ [RENDERER]: Renderer3;*/
99
+ /* Skipping unnamed member:
100
+ [SANITIZER]: Sanitizer|null;*/
101
+ /* Skipping unnamed member:
102
+ [TAIL]: LViewData|LContainer|null;*/
103
+ /* Skipping unnamed member:
104
+ [CONTAINER_INDEX]: number;*/
105
+ /* Skipping unnamed member:
106
+ [CONTENT_QUERIES]: QueryList<any>[]|null;*/
107
+ /* Skipping unnamed member:
108
+ [DECLARATION_VIEW]: LViewData|null;*/
109
+ }
68
110
  /** @enum {number} */
69
- var LViewFlags = {
70
- /**
71
- * Whether or not the view is in creationMode.
72
- *
73
- * This must be stored in the view rather than using `data` as a marker so that
74
- * we can properly support embedded views. Otherwise, when exiting a child view
75
- * back into the parent view, `data` will be defined and `creationMode` will be
76
- * improperly reported as false.
77
- */
111
+ const LViewFlags = {
112
+ /**
113
+ * Whether or not the view is in creationMode.
114
+ *
115
+ * This must be stored in the view rather than using `data` as a marker so that
116
+ * we can properly support embedded views. Otherwise, when exiting a child view
117
+ * back into the parent view, `data` will be defined and `creationMode` will be
118
+ * improperly reported as false.
119
+ */
78
120
  CreationMode: 1,
79
121
  /** Whether this view has default change detection strategy (checks always) or onPush */
80
122
  CheckAlways: 2,
@@ -83,12 +125,12 @@ var LViewFlags = {
83
125
  /** Whether or not this view is currently attached to change detection tree. */
84
126
  Attached: 8,
85
127
  /**
86
- * Whether or not the init hooks have run.
87
- *
88
- * If on, the init hooks haven't yet been run and should be executed by the first component that
89
- * runs OR the first cR() instruction that runs (so inits are run for the top level view before
90
- * any embedded views).
91
- */
128
+ * Whether or not the init hooks have run.
129
+ *
130
+ * If on, the init hooks haven't yet been run and should be executed by the first component that
131
+ * runs OR the first cR() instruction that runs (so inits are run for the top level view before
132
+ * any embedded views).
133
+ */
92
134
  RunInit: 16,
93
135
  /** Whether or not this view is destroyed. */
94
136
  Destroyed: 32,
@@ -104,235 +146,237 @@ export { LViewFlags };
104
146
  * @record
105
147
  */
106
148
  export function TView() { }
107
- /**
108
- * ID for inline views to determine whether a view is the same as the previous view
109
- * in a certain position. If it's not, we know the new view needs to be inserted
110
- * and the one that exists needs to be removed (e.g. if/else statements)
111
- *
112
- * If this is -1, then this is a component view or a dynamically created view.
113
- * @type {?}
114
- */
115
- TView.prototype.id;
116
- /**
117
- * This is a blueprint used to generate LViewData instances for this TView. Copying this
118
- * blueprint is faster than creating a new LViewData from scratch.
119
- * @type {?}
120
- */
121
- TView.prototype.blueprint;
122
- /**
123
- * The template function used to refresh the view of dynamically created views
124
- * and components. Will be null for inline views.
125
- * @type {?}
126
- */
127
- TView.prototype.template;
128
- /**
129
- * A function containing query-related instructions.
130
- * @type {?}
131
- */
132
- TView.prototype.viewQuery;
133
- /**
134
- * Pointer to the `TNode` that represents the root of the view.
135
- *
136
- * If this is a `TNode` for an `LViewNode`, this is an embedded view of a container.
137
- * We need this pointer to be able to efficiently find this node when inserting the view
138
- * into an anchor.
139
- *
140
- * If this is a `TElementNode`, this is the view of a root component. It has exactly one
141
- * root TNode.
142
- *
143
- * If this is null, this is the view of a component that is not at root. We do not store
144
- * the host TNodes for child component views because they can potentially have several
145
- * different host TNodes, depending on where the component is being used. These host
146
- * TNodes cannot be shared (due to different indices, etc).
147
- * @type {?}
148
- */
149
- TView.prototype.node;
150
- /**
151
- * Whether or not this template has been processed.
152
- * @type {?}
153
- */
154
- TView.prototype.firstTemplatePass;
155
- /**
156
- * Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n.
157
- * @type {?}
158
- */
159
- TView.prototype.data;
160
- /**
161
- * The binding start index is the index at which the data array
162
- * starts to store bindings only. Saving this value ensures that we
163
- * will begin reading bindings at the correct point in the array when
164
- * we are in update mode.
165
- * @type {?}
166
- */
167
- TView.prototype.bindingStartIndex;
168
- /**
169
- * The index where the "expando" section of `LViewData` begins. The expando
170
- * section contains injectors, directive instances, and host binding values.
171
- * Unlike the "consts" and "vars" sections of `LViewData`, the length of this
172
- * section cannot be calculated at compile-time because directives are matched
173
- * at runtime to preserve locality.
174
- *
175
- * We store this start index so we know where to start checking host bindings
176
- * in `setHostBindings`.
177
- * @type {?}
178
- */
179
- TView.prototype.expandoStartIndex;
180
- /**
181
- * Index of the host node of the first LView or LContainer beneath this LView in
182
- * the hierarchy.
183
- *
184
- * Necessary to store this so views can traverse through their nested views
185
- * to remove listeners and call onDestroy callbacks.
186
- *
187
- * For embedded views, we store the index of an LContainer's host rather than the first
188
- * LView to avoid managing splicing when views are added/removed.
189
- * @type {?}
190
- */
191
- TView.prototype.childIndex;
192
- /**
193
- * A reference to the first child node located in the view.
194
- * @type {?}
195
- */
196
- TView.prototype.firstChild;
197
- /**
198
- * Set of instructions used to process host bindings efficiently.
199
- *
200
- * See VIEW_DATA.md for more information.
201
- * @type {?}
202
- */
203
- TView.prototype.expandoInstructions;
204
- /**
205
- * Full registry of directives and components that may be found in this view.
206
- *
207
- * It's necessary to keep a copy of the full def list on the TView so it's possible
208
- * to render template functions without a host component.
209
- * @type {?}
210
- */
211
- TView.prototype.directiveRegistry;
212
- /**
213
- * Full registry of pipes that may be found in this view.
214
- *
215
- * The property is either an array of `PipeDefs`s or a function which returns the array of
216
- * `PipeDefs`s. The function is necessary to be able to support forward declarations.
217
- *
218
- * It's necessary to keep a copy of the full def list on the TView so it's possible
219
- * to render template functions without a host component.
220
- * @type {?}
221
- */
222
- TView.prototype.pipeRegistry;
223
- /**
224
- * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in
225
- * creation mode.
226
- *
227
- * Even indices: Directive index
228
- * Odd indices: Hook function
229
- * @type {?}
230
- */
231
- TView.prototype.initHooks;
232
- /**
233
- * Array of ngDoCheck hooks that should be executed for this view in update mode.
234
- *
235
- * Even indices: Directive index
236
- * Odd indices: Hook function
237
- * @type {?}
238
- */
239
- TView.prototype.checkHooks;
240
- /**
241
- * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed
242
- * for this view in creation mode.
243
- *
244
- * Even indices: Directive index
245
- * Odd indices: Hook function
246
- * @type {?}
247
- */
248
- TView.prototype.contentHooks;
249
- /**
250
- * Array of ngAfterContentChecked hooks that should be executed for this view in update
251
- * mode.
252
- *
253
- * Even indices: Directive index
254
- * Odd indices: Hook function
255
- * @type {?}
256
- */
257
- TView.prototype.contentCheckHooks;
258
- /**
259
- * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for
260
- * this view in creation mode.
261
- *
262
- * Even indices: Directive index
263
- * Odd indices: Hook function
264
- * @type {?}
265
- */
266
- TView.prototype.viewHooks;
267
- /**
268
- * Array of ngAfterViewChecked hooks that should be executed for this view in
269
- * update mode.
270
- *
271
- * Even indices: Directive index
272
- * Odd indices: Hook function
273
- * @type {?}
274
- */
275
- TView.prototype.viewCheckHooks;
276
- /**
277
- * Array of ngOnDestroy hooks that should be executed when this view is destroyed.
278
- *
279
- * Even indices: Directive index
280
- * Odd indices: Hook function
281
- * @type {?}
282
- */
283
- TView.prototype.destroyHooks;
284
- /**
285
- * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.
286
- *
287
- * Even indices: Index of pipe in data
288
- * Odd indices: Hook function
289
- *
290
- * These must be stored separately from directive destroy hooks because their contexts
291
- * are stored in data.
292
- * @type {?}
293
- */
294
- TView.prototype.pipeDestroyHooks;
295
- /**
296
- * When a view is destroyed, listeners need to be released and outputs need to be
297
- * unsubscribed. This cleanup array stores both listener data (in chunks of 4)
298
- * and output data (in chunks of 2) for a particular view. Combining the arrays
299
- * saves on memory (70 bytes per array) and on a few bytes of code size (for two
300
- * separate for loops).
301
- *
302
- * If it's a native DOM listener being stored:
303
- * 1st index is: event name to remove
304
- * 2nd index is: index of native element in LView.data[]
305
- * 3rd index is: index of wrapped listener function in LView.cleanupInstances[]
306
- * 4th index is: useCapture boolean
307
- *
308
- * If it's a renderer2 style listener or ViewRef destroy hook being stored:
309
- * 1st index is: index of the cleanup function in LView.cleanupInstances[]
310
- * 2nd index is: null
311
- *
312
- * If it's an output subscription or query list destroy hook:
313
- * 1st index is: output unsubscribe function / query list destroy function
314
- * 2nd index is: index of function context in LView.cleanupInstances[]
315
- * @type {?}
316
- */
317
- TView.prototype.cleanup;
318
- /**
319
- * A list of element indices for child components that will need to be
320
- * refreshed when the current view has finished its check. These indices have
321
- * already been adjusted for the HEADER_OFFSET.
322
- *
323
- * @type {?}
324
- */
325
- TView.prototype.components;
326
- /**
327
- * A list of indices for child directives that have content queries.
328
- *
329
- * Even indices: Directive indices
330
- * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive
331
- * @type {?}
332
- */
333
- TView.prototype.contentQueries;
149
+ if (false) {
150
+ /**
151
+ * ID for inline views to determine whether a view is the same as the previous view
152
+ * in a certain position. If it's not, we know the new view needs to be inserted
153
+ * and the one that exists needs to be removed (e.g. if/else statements)
154
+ *
155
+ * If this is -1, then this is a component view or a dynamically created view.
156
+ * @type {?}
157
+ */
158
+ TView.prototype.id;
159
+ /**
160
+ * This is a blueprint used to generate LViewData instances for this TView. Copying this
161
+ * blueprint is faster than creating a new LViewData from scratch.
162
+ * @type {?}
163
+ */
164
+ TView.prototype.blueprint;
165
+ /**
166
+ * The template function used to refresh the view of dynamically created views
167
+ * and components. Will be null for inline views.
168
+ * @type {?}
169
+ */
170
+ TView.prototype.template;
171
+ /**
172
+ * A function containing query-related instructions.
173
+ * @type {?}
174
+ */
175
+ TView.prototype.viewQuery;
176
+ /**
177
+ * Pointer to the `TNode` that represents the root of the view.
178
+ *
179
+ * If this is a `TNode` for an `LViewNode`, this is an embedded view of a container.
180
+ * We need this pointer to be able to efficiently find this node when inserting the view
181
+ * into an anchor.
182
+ *
183
+ * If this is a `TElementNode`, this is the view of a root component. It has exactly one
184
+ * root TNode.
185
+ *
186
+ * If this is null, this is the view of a component that is not at root. We do not store
187
+ * the host TNodes for child component views because they can potentially have several
188
+ * different host TNodes, depending on where the component is being used. These host
189
+ * TNodes cannot be shared (due to different indices, etc).
190
+ * @type {?}
191
+ */
192
+ TView.prototype.node;
193
+ /**
194
+ * Whether or not this template has been processed.
195
+ * @type {?}
196
+ */
197
+ TView.prototype.firstTemplatePass;
198
+ /**
199
+ * Static data equivalent of LView.data[]. Contains TNodes, PipeDefInternal or TI18n.
200
+ * @type {?}
201
+ */
202
+ TView.prototype.data;
203
+ /**
204
+ * The binding start index is the index at which the data array
205
+ * starts to store bindings only. Saving this value ensures that we
206
+ * will begin reading bindings at the correct point in the array when
207
+ * we are in update mode.
208
+ * @type {?}
209
+ */
210
+ TView.prototype.bindingStartIndex;
211
+ /**
212
+ * The index where the "expando" section of `LViewData` begins. The expando
213
+ * section contains injectors, directive instances, and host binding values.
214
+ * Unlike the "consts" and "vars" sections of `LViewData`, the length of this
215
+ * section cannot be calculated at compile-time because directives are matched
216
+ * at runtime to preserve locality.
217
+ *
218
+ * We store this start index so we know where to start checking host bindings
219
+ * in `setHostBindings`.
220
+ * @type {?}
221
+ */
222
+ TView.prototype.expandoStartIndex;
223
+ /**
224
+ * Index of the host node of the first LView or LContainer beneath this LView in
225
+ * the hierarchy.
226
+ *
227
+ * Necessary to store this so views can traverse through their nested views
228
+ * to remove listeners and call onDestroy callbacks.
229
+ *
230
+ * For embedded views, we store the index of an LContainer's host rather than the first
231
+ * LView to avoid managing splicing when views are added/removed.
232
+ * @type {?}
233
+ */
234
+ TView.prototype.childIndex;
235
+ /**
236
+ * A reference to the first child node located in the view.
237
+ * @type {?}
238
+ */
239
+ TView.prototype.firstChild;
240
+ /**
241
+ * Set of instructions used to process host bindings efficiently.
242
+ *
243
+ * See VIEW_DATA.md for more information.
244
+ * @type {?}
245
+ */
246
+ TView.prototype.expandoInstructions;
247
+ /**
248
+ * Full registry of directives and components that may be found in this view.
249
+ *
250
+ * It's necessary to keep a copy of the full def list on the TView so it's possible
251
+ * to render template functions without a host component.
252
+ * @type {?}
253
+ */
254
+ TView.prototype.directiveRegistry;
255
+ /**
256
+ * Full registry of pipes that may be found in this view.
257
+ *
258
+ * The property is either an array of `PipeDefs`s or a function which returns the array of
259
+ * `PipeDefs`s. The function is necessary to be able to support forward declarations.
260
+ *
261
+ * It's necessary to keep a copy of the full def list on the TView so it's possible
262
+ * to render template functions without a host component.
263
+ * @type {?}
264
+ */
265
+ TView.prototype.pipeRegistry;
266
+ /**
267
+ * Array of ngOnInit and ngDoCheck hooks that should be executed for this view in
268
+ * creation mode.
269
+ *
270
+ * Even indices: Directive index
271
+ * Odd indices: Hook function
272
+ * @type {?}
273
+ */
274
+ TView.prototype.initHooks;
275
+ /**
276
+ * Array of ngDoCheck hooks that should be executed for this view in update mode.
277
+ *
278
+ * Even indices: Directive index
279
+ * Odd indices: Hook function
280
+ * @type {?}
281
+ */
282
+ TView.prototype.checkHooks;
283
+ /**
284
+ * Array of ngAfterContentInit and ngAfterContentChecked hooks that should be executed
285
+ * for this view in creation mode.
286
+ *
287
+ * Even indices: Directive index
288
+ * Odd indices: Hook function
289
+ * @type {?}
290
+ */
291
+ TView.prototype.contentHooks;
292
+ /**
293
+ * Array of ngAfterContentChecked hooks that should be executed for this view in update
294
+ * mode.
295
+ *
296
+ * Even indices: Directive index
297
+ * Odd indices: Hook function
298
+ * @type {?}
299
+ */
300
+ TView.prototype.contentCheckHooks;
301
+ /**
302
+ * Array of ngAfterViewInit and ngAfterViewChecked hooks that should be executed for
303
+ * this view in creation mode.
304
+ *
305
+ * Even indices: Directive index
306
+ * Odd indices: Hook function
307
+ * @type {?}
308
+ */
309
+ TView.prototype.viewHooks;
310
+ /**
311
+ * Array of ngAfterViewChecked hooks that should be executed for this view in
312
+ * update mode.
313
+ *
314
+ * Even indices: Directive index
315
+ * Odd indices: Hook function
316
+ * @type {?}
317
+ */
318
+ TView.prototype.viewCheckHooks;
319
+ /**
320
+ * Array of ngOnDestroy hooks that should be executed when this view is destroyed.
321
+ *
322
+ * Even indices: Directive index
323
+ * Odd indices: Hook function
324
+ * @type {?}
325
+ */
326
+ TView.prototype.destroyHooks;
327
+ /**
328
+ * Array of pipe ngOnDestroy hooks that should be executed when this view is destroyed.
329
+ *
330
+ * Even indices: Index of pipe in data
331
+ * Odd indices: Hook function
332
+ *
333
+ * These must be stored separately from directive destroy hooks because their contexts
334
+ * are stored in data.
335
+ * @type {?}
336
+ */
337
+ TView.prototype.pipeDestroyHooks;
338
+ /**
339
+ * When a view is destroyed, listeners need to be released and outputs need to be
340
+ * unsubscribed. This cleanup array stores both listener data (in chunks of 4)
341
+ * and output data (in chunks of 2) for a particular view. Combining the arrays
342
+ * saves on memory (70 bytes per array) and on a few bytes of code size (for two
343
+ * separate for loops).
344
+ *
345
+ * If it's a native DOM listener being stored:
346
+ * 1st index is: event name to remove
347
+ * 2nd index is: index of native element in LView.data[]
348
+ * 3rd index is: index of wrapped listener function in LView.cleanupInstances[]
349
+ * 4th index is: useCapture boolean
350
+ *
351
+ * If it's a renderer2 style listener or ViewRef destroy hook being stored:
352
+ * 1st index is: index of the cleanup function in LView.cleanupInstances[]
353
+ * 2nd index is: null
354
+ *
355
+ * If it's an output subscription or query list destroy hook:
356
+ * 1st index is: output unsubscribe function / query list destroy function
357
+ * 2nd index is: index of function context in LView.cleanupInstances[]
358
+ * @type {?}
359
+ */
360
+ TView.prototype.cleanup;
361
+ /**
362
+ * A list of element indices for child components that will need to be
363
+ * refreshed when the current view has finished its check. These indices have
364
+ * already been adjusted for the HEADER_OFFSET.
365
+ *
366
+ * @type {?}
367
+ */
368
+ TView.prototype.components;
369
+ /**
370
+ * A list of indices for child directives that have content queries.
371
+ *
372
+ * Even indices: Directive indices
373
+ * Odd indices: Starting index of content queries (stored in CONTENT_QUERIES) for this directive
374
+ * @type {?}
375
+ */
376
+ TView.prototype.contentQueries;
377
+ }
334
378
  /** @enum {number} */
335
- var RootContextFlags = {
379
+ const RootContextFlags = {
336
380
  Empty: 0, DetectChanges: 1, FlushPlayers: 2,
337
381
  };
338
382
  export { RootContextFlags };
@@ -342,42 +386,39 @@ export { RootContextFlags };
342
386
  * @record
343
387
  */
344
388
  export function RootContext() { }
345
- /**
346
- * A function used for scheduling change detection in the future. Usually
347
- * this is `requestAnimationFrame`.
348
- * @type {?}
349
- */
350
- RootContext.prototype.scheduler;
351
- /**
352
- * A promise which is resolved when all components are considered clean (not dirty).
353
- *
354
- * This promise is overwritten every time a first call to {\@link markDirty} is invoked.
355
- * @type {?}
356
- */
357
- RootContext.prototype.clean;
358
- /**
359
- * RootComponents - The components that were instantiated by the call to
360
- * {\@link renderComponent}.
361
- * @type {?}
362
- */
363
- RootContext.prototype.components;
364
- /**
365
- * The player flushing handler to kick off all animations
366
- * @type {?}
367
- */
368
- RootContext.prototype.playerHandler;
369
- /**
370
- * What render-related operations to run once a scheduler has been set
371
- * @type {?}
372
- */
373
- RootContext.prototype.flags;
374
- /** @typedef {?} */
375
- var HookData;
376
- export { HookData };
377
- /** @typedef {?} */
378
- var TData;
379
- export { TData };
389
+ if (false) {
390
+ /**
391
+ * A function used for scheduling change detection in the future. Usually
392
+ * this is `requestAnimationFrame`.
393
+ * @type {?}
394
+ */
395
+ RootContext.prototype.scheduler;
396
+ /**
397
+ * A promise which is resolved when all components are considered clean (not dirty).
398
+ *
399
+ * This promise is overwritten every time a first call to {\@link markDirty} is invoked.
400
+ * @type {?}
401
+ */
402
+ RootContext.prototype.clean;
403
+ /**
404
+ * RootComponents - The components that were instantiated by the call to
405
+ * {\@link renderComponent}.
406
+ * @type {?}
407
+ */
408
+ RootContext.prototype.components;
409
+ /**
410
+ * The player flushing handler to kick off all animations
411
+ * @type {?}
412
+ */
413
+ RootContext.prototype.playerHandler;
414
+ /**
415
+ * What render-related operations to run once a scheduler has been set
416
+ * @type {?}
417
+ */
418
+ RootContext.prototype.flags;
419
+ }
420
+ // Note: This hack is necessary so we don't erroneously get a circular dependency
421
+ // failure based on types.
380
422
  /** @type {?} */
381
423
  export const unusedValueExportToPlacateAjd = 1;
382
-
383
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/view.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAwBA,aAAa,aAAa,GAAG,EAAE,CAAC;;AAKhC,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,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA8KjC,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} from './renderer';\nimport {StylingContext} from './styling';\n\n\n/** Size of LViewData's header. Necessary to adjust for it when setting slots.  */\nexport const HEADER_OFFSET = 17;\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;\nexport const BINDING_INDEX = 7;\nexport const CLEANUP = 8;\nexport const CONTEXT = 9;\nexport const INJECTOR = 10;\nexport const RENDERER = 11;\nexport const SANITIZER = 12;\nexport const TAIL = 13;\nexport const CONTAINER_INDEX = 14;\nexport const CONTENT_QUERIES = 15;\nexport const DECLARATION_VIEW = 16;\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]: 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)[]|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"]}
424
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/view.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAwBA,MAAM,OAAO,aAAa,GAAG,EAAE;;;;;AAK/B,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,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;;;;AAKlC,qCAEC;;;IADC,oCAAiE;;;;;;;;;;;;;AAcnE,+BA8IC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAIC;;;;;;;OAOG;IACH,eAAwB;IAExB,wFAAwF;IACxF,cAAuB;IAEvB,kEAAkE;IAClE,QAAiB;IAEjB,+EAA+E;IAC/E,WAAoB;IAEpB;;;;;;OAMG;IACH,WAAmB;IAEnB,6CAA6C;IAC7C,aAAqB;IAErB,gDAAgD;IAChD,UAAkB;;;;;;;;;;AASpB,2BA+NC;;;;;;;;;;IAvNC,mBAAoB;;;;;;IAMpB,0BAAqB;;;;;;IAMrB,yBAAqC;;;;;IAKrC,0BAAmC;;;;;;;;;;;;;;;;;IAiBnC,qBAAkC;;;;;IAGlC,kCAA2B;;;;;IAG3B,qBAAY;;;;;;;;IAQZ,kCAA0B;;;;;;;;;;;;IAY1B,kCAA0B;;;;;;;;;;;;IAY1B,2BAAmB;;;;;IAKnB,2BAAuB;;;;;;;IAOvB,oCAA0D;;;;;;;;IAQ1D,kCAAyC;;;;;;;;;;;IAWzC,6BAA+B;;;;;;;;;IAS/B,0BAAyB;;;;;;;;IAQzB,2BAA0B;;;;;;;;;IAS1B,6BAA4B;;;;;;;;;IAS5B,kCAAiC;;;;;;;;;IASjC,0BAAyB;;;;;;;;;IASzB,+BAA8B;;;;;;;;IAQ9B,6BAA4B;;;;;;;;;;;IAW5B,iCAAgC;;;;;;;;;;;;;;;;;;;;;;;IAuBhC,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} from './renderer';\nimport {StylingContext} from './styling';\n\n\n/** Size of LViewData's header. Necessary to adjust for it when setting slots.  */\nexport const HEADER_OFFSET = 17;\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;\nexport const BINDING_INDEX = 7;\nexport const CLEANUP = 8;\nexport const CONTEXT = 9;\nexport const INJECTOR = 10;\nexport const RENDERER = 11;\nexport const SANITIZER = 12;\nexport const TAIL = 13;\nexport const CONTAINER_INDEX = 14;\nexport const CONTENT_QUERIES = 15;\nexport const DECLARATION_VIEW = 16;\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]: 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)[]|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"]}