@angular/core 7.1.0 → 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 (406) hide show
  1. package/bundles/core-testing.umd.js +1 -1
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +1 -1
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +48 -33
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +106 -98
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.metadata.json +1 -1
  10. package/esm2015/core.externs.js +44 -34
  11. package/esm2015/core.js +1 -2
  12. package/esm2015/index.js +3 -4
  13. package/esm2015/public_api.js +3 -5
  14. package/esm2015/src/application_init.js +6 -6
  15. package/esm2015/src/application_module.js +6 -5
  16. package/esm2015/src/application_ref.js +31 -22
  17. package/esm2015/src/application_tokens.js +21 -16
  18. package/esm2015/src/change_detection/change_detection.js +8 -7
  19. package/esm2015/src/change_detection/change_detection_util.js +2 -4
  20. package/esm2015/src/change_detection/change_detector_ref.js +2 -3
  21. package/esm2015/src/change_detection/constants.js +30 -32
  22. package/esm2015/src/change_detection/differs/default_iterable_differ.js +51 -15
  23. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +7 -6
  24. package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
  25. package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
  26. package/esm2015/src/change_detection/pipe_transform.js +10 -5
  27. package/esm2015/src/change_detection.js +7 -3
  28. package/esm2015/src/codegen_private_exports.js +2 -3
  29. package/esm2015/src/console.js +3 -3
  30. package/esm2015/src/core.js +3 -4
  31. package/esm2015/src/core_private_export.js +2 -3
  32. package/esm2015/src/core_render3_private_export.js +7 -4
  33. package/esm2015/src/debug/debug_node.js +4 -4
  34. package/esm2015/src/di/defs.js +59 -50
  35. package/esm2015/src/di/forward_ref.js +5 -6
  36. package/esm2015/src/di/injectable.js +11 -11
  37. package/esm2015/src/di/injection_token.js +6 -5
  38. package/esm2015/src/di/injector.js +55 -48
  39. package/esm2015/src/di/injector_compatibility.js +27 -20
  40. package/esm2015/src/di/metadata.js +22 -13
  41. package/esm2015/src/di/provider.js +137 -120
  42. package/esm2015/src/di/r3_injector.js +61 -38
  43. package/esm2015/src/di/reflective_errors.js +19 -13
  44. package/esm2015/src/di/reflective_injector.js +10 -15
  45. package/esm2015/src/di/reflective_key.js +3 -4
  46. package/esm2015/src/di/reflective_provider.js +21 -20
  47. package/esm2015/src/di/scope.js +5 -5
  48. package/esm2015/src/di/util.js +13 -14
  49. package/esm2015/src/di.js +3 -4
  50. package/esm2015/src/error_handler.js +5 -4
  51. package/esm2015/src/errors.js +7 -8
  52. package/esm2015/src/event_emitter.js +3 -3
  53. package/esm2015/src/i18n/tokens.js +12 -10
  54. package/esm2015/src/is_dev_mode.js +2 -3
  55. package/esm2015/src/ivy_switch.js +2 -3
  56. package/esm2015/src/linker/compiler.js +5 -8
  57. package/esm2015/src/linker/component_factory.js +2 -3
  58. package/esm2015/src/linker/component_factory_resolver.js +4 -5
  59. package/esm2015/src/linker/element_ref.js +5 -3
  60. package/esm2015/src/linker/ng_module_factory.js +6 -5
  61. package/esm2015/src/linker/ng_module_factory_loader.js +2 -3
  62. package/esm2015/src/linker/query_list.js +12 -13
  63. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +2 -3
  64. package/esm2015/src/linker/template_ref.js +2 -3
  65. package/esm2015/src/linker/view_container_ref.js +2 -3
  66. package/esm2015/src/linker/view_ref.js +13 -7
  67. package/esm2015/src/linker.js +3 -3
  68. package/esm2015/src/metadata/di.js +22 -15
  69. package/esm2015/src/metadata/directives.js +34 -19
  70. package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
  71. package/esm2015/src/metadata/ng_module.js +82 -68
  72. package/esm2015/src/metadata/resource_loading.js +4 -3
  73. package/esm2015/src/metadata/view.js +25 -26
  74. package/esm2015/src/metadata.js +6 -3
  75. package/esm2015/src/platform_core_providers.js +5 -5
  76. package/esm2015/src/profile/profile.js +17 -13
  77. package/esm2015/src/profile/wtf_impl.js +36 -16
  78. package/esm2015/src/r3_symbols.js +18 -5
  79. package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
  80. package/esm2015/src/reflection/reflection.js +5 -5
  81. package/esm2015/src/reflection/reflection_capabilities.js +31 -26
  82. package/esm2015/src/reflection/reflector.js +2 -3
  83. package/esm2015/src/reflection/types.js +2 -12
  84. package/esm2015/src/render/api.js +67 -47
  85. package/esm2015/src/render.js +3 -3
  86. package/esm2015/src/render3/assert.js +5 -3
  87. package/esm2015/src/render3/component.js +66 -64
  88. package/esm2015/src/render3/component_ref.js +24 -21
  89. package/esm2015/src/render3/context_discovery.js +37 -17
  90. package/esm2015/src/render3/debug.js +9 -6
  91. package/esm2015/src/render3/definition.js +28 -28
  92. package/esm2015/src/render3/di.js +66 -39
  93. package/esm2015/src/render3/di_setup.js +34 -14
  94. package/esm2015/src/render3/discovery_utils.js +16 -17
  95. package/esm2015/src/render3/errors.js +2 -3
  96. package/esm2015/src/render3/features/inherit_definition_feature.js +12 -8
  97. package/esm2015/src/render3/features/ng_onchanges_feature.js +5 -6
  98. package/esm2015/src/render3/features/providers_feature.js +2 -3
  99. package/esm2015/src/render3/fields.js +5 -5
  100. package/esm2015/src/render3/global_utils.js +19 -6
  101. package/esm2015/src/render3/global_utils_api.js +12 -6
  102. package/esm2015/src/render3/hooks.js +4 -5
  103. package/esm2015/src/render3/i18n.js +112 -89
  104. package/esm2015/src/render3/index.js +11 -3
  105. package/esm2015/src/render3/instructions.js +201 -150
  106. package/esm2015/src/render3/interfaces/container.js +27 -5
  107. package/esm2015/src/render3/interfaces/context.js +38 -36
  108. package/esm2015/src/render3/interfaces/definition.js +234 -261
  109. package/esm2015/src/render3/interfaces/i18n.js +154 -126
  110. package/esm2015/src/render3/interfaces/injector.js +93 -10
  111. package/esm2015/src/render3/interfaces/node.js +369 -373
  112. package/esm2015/src/render3/interfaces/player.js +78 -37
  113. package/esm2015/src/render3/interfaces/projection.js +5 -10
  114. package/esm2015/src/render3/interfaces/query.js +66 -60
  115. package/esm2015/src/render3/interfaces/renderer.js +288 -117
  116. package/esm2015/src/render3/interfaces/sanitization.js +2 -6
  117. package/esm2015/src/render3/interfaces/styling.js +26 -6
  118. package/esm2015/src/render3/interfaces/view.js +326 -285
  119. package/esm2015/src/render3/jit/compiler_facade.js +10 -4
  120. package/esm2015/src/render3/jit/compiler_facade_interface.js +189 -152
  121. package/esm2015/src/render3/jit/directive.js +6 -6
  122. package/esm2015/src/render3/jit/environment.js +5 -5
  123. package/esm2015/src/render3/jit/injectable.js +6 -8
  124. package/esm2015/src/render3/jit/module.js +17 -13
  125. package/esm2015/src/render3/jit/pipe.js +2 -3
  126. package/esm2015/src/render3/jit/util.js +2 -3
  127. package/esm2015/src/render3/metadata.js +11 -10
  128. package/esm2015/src/render3/ng_dev_mode.js +5 -6
  129. package/esm2015/src/render3/ng_module_ref.js +11 -10
  130. package/esm2015/src/render3/node_assert.js +2 -3
  131. package/esm2015/src/render3/node_manipulation.js +86 -73
  132. package/esm2015/src/render3/node_selector_matcher.js +13 -12
  133. package/esm2015/src/render3/pipe.js +4 -5
  134. package/esm2015/src/render3/players.js +11 -5
  135. package/esm2015/src/render3/pure_function.js +29 -3
  136. package/esm2015/src/render3/query.js +74 -70
  137. package/esm2015/src/render3/state.js +44 -33
  138. package/esm2015/src/render3/styling/class_and_style_bindings.js +62 -43
  139. package/esm2015/src/render3/styling/core_player_handler.js +2 -3
  140. package/esm2015/src/render3/styling/player_factory.js +3 -4
  141. package/esm2015/src/render3/styling/util.js +18 -13
  142. package/esm2015/src/render3/tokens.js +7 -6
  143. package/esm2015/src/render3/util.js +18 -16
  144. package/esm2015/src/render3/view_engine_compatibility.js +18 -18
  145. package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
  146. package/esm2015/src/render3/view_ref.js +7 -10
  147. package/esm2015/src/sanitization/bypass.js +29 -6
  148. package/esm2015/src/sanitization/html_sanitizer.js +41 -15
  149. package/esm2015/src/sanitization/inert_body.js +14 -12
  150. package/esm2015/src/sanitization/sanitization.js +7 -7
  151. package/esm2015/src/sanitization/security.js +3 -4
  152. package/esm2015/src/sanitization/style_sanitizer.js +10 -7
  153. package/esm2015/src/sanitization/url_sanitizer.js +9 -7
  154. package/esm2015/src/testability/testability.js +47 -37
  155. package/esm2015/src/type.js +6 -8
  156. package/esm2015/src/util/decorators.js +19 -14
  157. package/esm2015/src/util/lang.js +2 -3
  158. package/esm2015/src/util/noop.js +2 -3
  159. package/esm2015/src/util/property.js +3 -4
  160. package/esm2015/src/util.js +12 -4
  161. package/esm2015/src/version.js +6 -6
  162. package/esm2015/src/view/element.js +17 -17
  163. package/esm2015/src/view/entrypoint.js +7 -3
  164. package/esm2015/src/view/errors.js +4 -5
  165. package/esm2015/src/view/index.js +2 -3
  166. package/esm2015/src/view/ng_content.js +3 -4
  167. package/esm2015/src/view/ng_module.js +2 -3
  168. package/esm2015/src/view/provider.js +89 -24
  169. package/esm2015/src/view/pure_expression.js +14 -15
  170. package/esm2015/src/view/query.js +14 -14
  171. package/esm2015/src/view/refs.js +24 -22
  172. package/esm2015/src/view/services.js +41 -31
  173. package/esm2015/src/view/text.js +5 -6
  174. package/esm2015/src/view/types.js +386 -324
  175. package/esm2015/src/view/util.js +29 -24
  176. package/esm2015/src/view/view.js +43 -36
  177. package/esm2015/src/view/view_attach.js +9 -10
  178. package/esm2015/src/zone/ng_zone.js +29 -28
  179. package/esm2015/src/zone.js +3 -3
  180. package/esm2015/testing/index.js +2 -3
  181. package/esm2015/testing/public_api.js +4 -4
  182. package/esm2015/testing/src/async.js +2 -3
  183. package/esm2015/testing/src/async_fallback.js +8 -7
  184. package/esm2015/testing/src/async_test_completer.js +2 -3
  185. package/esm2015/testing/src/before_each.js +10 -4
  186. package/esm2015/testing/src/component_fixture.js +6 -7
  187. package/esm2015/testing/src/fake_async.js +9 -3
  188. package/esm2015/testing/src/fake_async_fallback.js +5 -5
  189. package/esm2015/testing/src/lang_utils.js +3 -4
  190. package/esm2015/testing/src/logger.js +2 -3
  191. package/esm2015/testing/src/metadata_override.js +2 -6
  192. package/esm2015/testing/src/metadata_overrider.js +5 -7
  193. package/esm2015/testing/src/ng_zone_mock.js +2 -3
  194. package/esm2015/testing/src/private_export_testing.js +2 -3
  195. package/esm2015/testing/src/r3_test_bed.js +34 -27
  196. package/esm2015/testing/src/resolvers.js +9 -5
  197. package/esm2015/testing/src/test_bed.js +38 -34
  198. package/esm2015/testing/src/test_bed_common.js +142 -85
  199. package/esm2015/testing/src/test_compiler.js +2 -3
  200. package/esm2015/testing/src/testing.js +3 -3
  201. package/esm2015/testing/src/testing_internal.js +8 -9
  202. package/esm2015/testing/testing.js +1 -2
  203. package/esm5/core.js +1 -2
  204. package/esm5/index.js +1 -2
  205. package/esm5/public_api.js +1 -2
  206. package/esm5/src/application_init.js +1 -2
  207. package/esm5/src/application_module.js +1 -2
  208. package/esm5/src/application_ref.js +1 -2
  209. package/esm5/src/application_tokens.js +1 -2
  210. package/esm5/src/change_detection/change_detection.js +1 -2
  211. package/esm5/src/change_detection/change_detection_util.js +1 -2
  212. package/esm5/src/change_detection/change_detector_ref.js +1 -2
  213. package/esm5/src/change_detection/constants.js +1 -2
  214. package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -2
  215. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -2
  216. package/esm5/src/change_detection/differs/iterable_differs.js +1 -2
  217. package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -2
  218. package/esm5/src/change_detection/pipe_transform.js +1 -2
  219. package/esm5/src/change_detection.js +1 -2
  220. package/esm5/src/codegen_private_exports.js +1 -2
  221. package/esm5/src/console.js +1 -2
  222. package/esm5/src/core.js +1 -2
  223. package/esm5/src/core_private_export.js +1 -2
  224. package/esm5/src/core_render3_private_export.js +1 -2
  225. package/esm5/src/debug/debug_node.js +1 -2
  226. package/esm5/src/di/defs.js +1 -2
  227. package/esm5/src/di/forward_ref.js +1 -2
  228. package/esm5/src/di/injectable.js +1 -2
  229. package/esm5/src/di/injection_token.js +1 -2
  230. package/esm5/src/di/injector.js +7 -8
  231. package/esm5/src/di/injector_compatibility.js +30 -10
  232. package/esm5/src/di/metadata.js +1 -2
  233. package/esm5/src/di/provider.js +1 -2
  234. package/esm5/src/di/r3_injector.js +5 -6
  235. package/esm5/src/di/reflective_errors.js +1 -2
  236. package/esm5/src/di/reflective_injector.js +1 -2
  237. package/esm5/src/di/reflective_key.js +1 -2
  238. package/esm5/src/di/reflective_provider.js +1 -2
  239. package/esm5/src/di/scope.js +1 -2
  240. package/esm5/src/di/util.js +1 -2
  241. package/esm5/src/di.js +2 -3
  242. package/esm5/src/error_handler.js +1 -2
  243. package/esm5/src/errors.js +1 -2
  244. package/esm5/src/event_emitter.js +1 -2
  245. package/esm5/src/i18n/tokens.js +1 -2
  246. package/esm5/src/is_dev_mode.js +1 -2
  247. package/esm5/src/ivy_switch.js +1 -2
  248. package/esm5/src/linker/compiler.js +1 -2
  249. package/esm5/src/linker/component_factory.js +1 -2
  250. package/esm5/src/linker/component_factory_resolver.js +1 -2
  251. package/esm5/src/linker/element_ref.js +1 -2
  252. package/esm5/src/linker/ng_module_factory.js +1 -2
  253. package/esm5/src/linker/ng_module_factory_loader.js +1 -2
  254. package/esm5/src/linker/query_list.js +1 -2
  255. package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -2
  256. package/esm5/src/linker/template_ref.js +1 -2
  257. package/esm5/src/linker/view_container_ref.js +1 -2
  258. package/esm5/src/linker/view_ref.js +1 -2
  259. package/esm5/src/linker.js +1 -2
  260. package/esm5/src/metadata/di.js +1 -2
  261. package/esm5/src/metadata/directives.js +1 -2
  262. package/esm5/src/metadata/lifecycle_hooks.js +1 -2
  263. package/esm5/src/metadata/ng_module.js +1 -2
  264. package/esm5/src/metadata/resource_loading.js +1 -2
  265. package/esm5/src/metadata/view.js +1 -2
  266. package/esm5/src/metadata.js +1 -2
  267. package/esm5/src/platform_core_providers.js +1 -2
  268. package/esm5/src/profile/profile.js +1 -2
  269. package/esm5/src/profile/wtf_impl.js +1 -2
  270. package/esm5/src/r3_symbols.js +1 -2
  271. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -2
  272. package/esm5/src/reflection/reflection.js +1 -2
  273. package/esm5/src/reflection/reflection_capabilities.js +1 -2
  274. package/esm5/src/reflection/reflector.js +1 -2
  275. package/esm5/src/reflection/types.js +1 -2
  276. package/esm5/src/render/api.js +1 -2
  277. package/esm5/src/render.js +1 -2
  278. package/esm5/src/render3/assert.js +1 -2
  279. package/esm5/src/render3/component.js +1 -2
  280. package/esm5/src/render3/component_ref.js +1 -2
  281. package/esm5/src/render3/context_discovery.js +1 -2
  282. package/esm5/src/render3/debug.js +1 -2
  283. package/esm5/src/render3/definition.js +1 -2
  284. package/esm5/src/render3/di.js +12 -13
  285. package/esm5/src/render3/di_setup.js +1 -2
  286. package/esm5/src/render3/discovery_utils.js +1 -2
  287. package/esm5/src/render3/errors.js +1 -2
  288. package/esm5/src/render3/features/inherit_definition_feature.js +1 -2
  289. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -2
  290. package/esm5/src/render3/features/providers_feature.js +1 -2
  291. package/esm5/src/render3/fields.js +1 -2
  292. package/esm5/src/render3/global_utils.js +1 -2
  293. package/esm5/src/render3/global_utils_api.js +1 -2
  294. package/esm5/src/render3/hooks.js +1 -2
  295. package/esm5/src/render3/i18n.js +1 -2
  296. package/esm5/src/render3/index.js +1 -2
  297. package/esm5/src/render3/instructions.js +3 -3
  298. package/esm5/src/render3/interfaces/container.js +1 -2
  299. package/esm5/src/render3/interfaces/context.js +1 -2
  300. package/esm5/src/render3/interfaces/definition.js +1 -2
  301. package/esm5/src/render3/interfaces/i18n.js +1 -2
  302. package/esm5/src/render3/interfaces/injector.js +1 -2
  303. package/esm5/src/render3/interfaces/node.js +1 -2
  304. package/esm5/src/render3/interfaces/player.js +1 -2
  305. package/esm5/src/render3/interfaces/projection.js +1 -2
  306. package/esm5/src/render3/interfaces/query.js +1 -2
  307. package/esm5/src/render3/interfaces/renderer.js +1 -2
  308. package/esm5/src/render3/interfaces/sanitization.js +1 -2
  309. package/esm5/src/render3/interfaces/styling.js +1 -2
  310. package/esm5/src/render3/interfaces/view.js +1 -2
  311. package/esm5/src/render3/jit/compiler_facade.js +1 -2
  312. package/esm5/src/render3/jit/compiler_facade_interface.js +1 -2
  313. package/esm5/src/render3/jit/directive.js +1 -2
  314. package/esm5/src/render3/jit/environment.js +1 -2
  315. package/esm5/src/render3/jit/injectable.js +1 -2
  316. package/esm5/src/render3/jit/module.js +1 -2
  317. package/esm5/src/render3/jit/pipe.js +1 -2
  318. package/esm5/src/render3/jit/util.js +1 -2
  319. package/esm5/src/render3/metadata.js +1 -2
  320. package/esm5/src/render3/ng_dev_mode.js +1 -2
  321. package/esm5/src/render3/ng_module_ref.js +1 -2
  322. package/esm5/src/render3/node_assert.js +1 -2
  323. package/esm5/src/render3/node_manipulation.js +1 -2
  324. package/esm5/src/render3/node_selector_matcher.js +1 -2
  325. package/esm5/src/render3/pipe.js +1 -2
  326. package/esm5/src/render3/players.js +1 -2
  327. package/esm5/src/render3/pure_function.js +1 -2
  328. package/esm5/src/render3/query.js +1 -2
  329. package/esm5/src/render3/state.js +1 -2
  330. package/esm5/src/render3/styling/class_and_style_bindings.js +1 -2
  331. package/esm5/src/render3/styling/core_player_handler.js +1 -2
  332. package/esm5/src/render3/styling/player_factory.js +1 -2
  333. package/esm5/src/render3/styling/util.js +1 -2
  334. package/esm5/src/render3/tokens.js +1 -2
  335. package/esm5/src/render3/util.js +1 -2
  336. package/esm5/src/render3/view_engine_compatibility.js +3 -3
  337. package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -2
  338. package/esm5/src/render3/view_ref.js +1 -2
  339. package/esm5/src/sanitization/bypass.js +1 -2
  340. package/esm5/src/sanitization/html_sanitizer.js +1 -2
  341. package/esm5/src/sanitization/inert_body.js +1 -2
  342. package/esm5/src/sanitization/sanitization.js +1 -2
  343. package/esm5/src/sanitization/security.js +1 -2
  344. package/esm5/src/sanitization/style_sanitizer.js +1 -2
  345. package/esm5/src/sanitization/url_sanitizer.js +1 -2
  346. package/esm5/src/testability/testability.js +1 -2
  347. package/esm5/src/type.js +1 -2
  348. package/esm5/src/util/decorators.js +1 -2
  349. package/esm5/src/util/lang.js +1 -2
  350. package/esm5/src/util/noop.js +1 -2
  351. package/esm5/src/util/property.js +1 -2
  352. package/esm5/src/util.js +1 -2
  353. package/esm5/src/version.js +2 -3
  354. package/esm5/src/view/element.js +1 -2
  355. package/esm5/src/view/entrypoint.js +1 -2
  356. package/esm5/src/view/errors.js +1 -2
  357. package/esm5/src/view/index.js +1 -2
  358. package/esm5/src/view/ng_content.js +1 -2
  359. package/esm5/src/view/ng_module.js +1 -2
  360. package/esm5/src/view/provider.js +1 -2
  361. package/esm5/src/view/pure_expression.js +1 -2
  362. package/esm5/src/view/query.js +1 -2
  363. package/esm5/src/view/refs.js +5 -5
  364. package/esm5/src/view/services.js +1 -2
  365. package/esm5/src/view/text.js +1 -2
  366. package/esm5/src/view/types.js +1 -2
  367. package/esm5/src/view/util.js +1 -2
  368. package/esm5/src/view/view.js +1 -2
  369. package/esm5/src/view/view_attach.js +1 -2
  370. package/esm5/src/zone/ng_zone.js +1 -2
  371. package/esm5/src/zone.js +1 -2
  372. package/esm5/testing/index.js +1 -2
  373. package/esm5/testing/public_api.js +1 -2
  374. package/esm5/testing/src/async.js +1 -2
  375. package/esm5/testing/src/async_fallback.js +1 -2
  376. package/esm5/testing/src/async_test_completer.js +1 -2
  377. package/esm5/testing/src/before_each.js +1 -2
  378. package/esm5/testing/src/component_fixture.js +1 -2
  379. package/esm5/testing/src/fake_async.js +1 -2
  380. package/esm5/testing/src/fake_async_fallback.js +1 -2
  381. package/esm5/testing/src/lang_utils.js +1 -2
  382. package/esm5/testing/src/logger.js +1 -2
  383. package/esm5/testing/src/metadata_override.js +1 -2
  384. package/esm5/testing/src/metadata_overrider.js +1 -2
  385. package/esm5/testing/src/ng_zone_mock.js +1 -2
  386. package/esm5/testing/src/private_export_testing.js +1 -2
  387. package/esm5/testing/src/r3_test_bed.js +1 -2
  388. package/esm5/testing/src/resolvers.js +1 -2
  389. package/esm5/testing/src/test_bed.js +1 -2
  390. package/esm5/testing/src/test_bed_common.js +1 -2
  391. package/esm5/testing/src/test_compiler.js +1 -2
  392. package/esm5/testing/src/testing.js +1 -2
  393. package/esm5/testing/src/testing_internal.js +1 -2
  394. package/esm5/testing/testing.js +1 -2
  395. package/fesm2015/core.js +2040 -1354
  396. package/fesm2015/core.js.map +1 -1
  397. package/fesm2015/testing.js +123 -89
  398. package/fesm2015/testing.js.map +1 -1
  399. package/fesm5/core.js +55 -34
  400. package/fesm5/core.js.map +1 -1
  401. package/fesm5/testing.js +1 -1
  402. package/fesm5/testing.js.map +1 -1
  403. package/package.json +1 -1
  404. package/src/di/injector_compatibility.d.ts +1 -1
  405. package/testing.d.ts +5 -0
  406. package/npm_package.es6/external/ngdeps/node_modules/tslib/tslib.d.ts +0 -33
@@ -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,17 +9,22 @@
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
+ /**
13
+ * The goal here is to make sure that the browser DOM API is the Renderer.
14
+ * We do this by defining a subset of DOM API to be the renderer and than
15
+ * use that time for rendering.
16
+ *
17
+ * At runtime we can than use the DOM api directly, in server or web-worker
18
+ * it will be easy to implement such API.
19
+ */
12
20
  /** @enum {number} */
13
- var RendererStyleFlags3 = {
21
+ const RendererStyleFlags3 = {
14
22
  Important: 1,
15
23
  DashCase: 2,
16
24
  };
17
25
  export { RendererStyleFlags3 };
18
26
  RendererStyleFlags3[RendererStyleFlags3.Important] = 'Important';
19
27
  RendererStyleFlags3[RendererStyleFlags3.DashCase] = 'DashCase';
20
- /** @typedef {?} */
21
- var Renderer3;
22
- export { Renderer3 };
23
28
  /**
24
29
  * Object Oriented style of API needed to create elements and text nodes.
25
30
  *
@@ -30,23 +35,41 @@ export { Renderer3 };
30
35
  * @record
31
36
  */
32
37
  export function ObjectOrientedRenderer3() { }
33
- /** @type {?} */
34
- ObjectOrientedRenderer3.prototype.createComment;
35
- /** @type {?} */
36
- ObjectOrientedRenderer3.prototype.createElement;
37
- /** @type {?} */
38
- ObjectOrientedRenderer3.prototype.createElementNS;
39
- /** @type {?} */
40
- ObjectOrientedRenderer3.prototype.createTextNode;
41
- /** @type {?} */
42
- ObjectOrientedRenderer3.prototype.querySelector;
38
+ if (false) {
39
+ /**
40
+ * @param {?} data
41
+ * @return {?}
42
+ */
43
+ ObjectOrientedRenderer3.prototype.createComment = function (data) { };
44
+ /**
45
+ * @param {?} tagName
46
+ * @return {?}
47
+ */
48
+ ObjectOrientedRenderer3.prototype.createElement = function (tagName) { };
49
+ /**
50
+ * @param {?} namespace
51
+ * @param {?} tagName
52
+ * @return {?}
53
+ */
54
+ ObjectOrientedRenderer3.prototype.createElementNS = function (namespace, tagName) { };
55
+ /**
56
+ * @param {?} data
57
+ * @return {?}
58
+ */
59
+ ObjectOrientedRenderer3.prototype.createTextNode = function (data) { };
60
+ /**
61
+ * @param {?} selectors
62
+ * @return {?}
63
+ */
64
+ ObjectOrientedRenderer3.prototype.querySelector = function (selectors) { };
65
+ }
43
66
  /**
44
67
  * Returns whether the `renderer` is a `ProceduralRenderer3`
45
68
  * @param {?} renderer
46
69
  * @return {?}
47
70
  */
48
71
  export function isProceduralRenderer(renderer) {
49
- return !!((/** @type {?} */ (renderer)).listen);
72
+ return !!(((/** @type {?} */ (renderer))).listen);
50
73
  }
51
74
  /**
52
75
  * Procedural style of API needed to create elements and text nodes.
@@ -57,61 +80,151 @@ export function isProceduralRenderer(renderer) {
57
80
  * @record
58
81
  */
59
82
  export function ProceduralRenderer3() { }
60
- /** @type {?} */
61
- ProceduralRenderer3.prototype.destroy;
62
- /** @type {?} */
63
- ProceduralRenderer3.prototype.createComment;
64
- /** @type {?} */
65
- ProceduralRenderer3.prototype.createElement;
66
- /** @type {?} */
67
- ProceduralRenderer3.prototype.createText;
68
- /**
69
- * This property is allowed to be null / undefined,
70
- * in which case the view engine won't call it.
71
- * This is used as a performance optimization for production mode.
72
- * @type {?|undefined}
73
- */
74
- ProceduralRenderer3.prototype.destroyNode;
75
- /** @type {?} */
76
- ProceduralRenderer3.prototype.appendChild;
77
- /** @type {?} */
78
- ProceduralRenderer3.prototype.insertBefore;
79
- /** @type {?} */
80
- ProceduralRenderer3.prototype.removeChild;
81
- /** @type {?} */
82
- ProceduralRenderer3.prototype.selectRootElement;
83
- /** @type {?} */
84
- ProceduralRenderer3.prototype.parentNode;
85
- /** @type {?} */
86
- ProceduralRenderer3.prototype.nextSibling;
87
- /** @type {?} */
88
- ProceduralRenderer3.prototype.setAttribute;
89
- /** @type {?} */
90
- ProceduralRenderer3.prototype.removeAttribute;
91
- /** @type {?} */
92
- ProceduralRenderer3.prototype.addClass;
93
- /** @type {?} */
94
- ProceduralRenderer3.prototype.removeClass;
95
- /** @type {?} */
96
- ProceduralRenderer3.prototype.setStyle;
97
- /** @type {?} */
98
- ProceduralRenderer3.prototype.removeStyle;
99
- /** @type {?} */
100
- ProceduralRenderer3.prototype.setProperty;
101
- /** @type {?} */
102
- ProceduralRenderer3.prototype.setValue;
103
- /** @type {?} */
104
- ProceduralRenderer3.prototype.listen;
83
+ if (false) {
84
+ /**
85
+ * This property is allowed to be null / undefined,
86
+ * in which case the view engine won't call it.
87
+ * This is used as a performance optimization for production mode.
88
+ * @type {?|undefined}
89
+ */
90
+ ProceduralRenderer3.prototype.destroyNode;
91
+ /**
92
+ * @return {?}
93
+ */
94
+ ProceduralRenderer3.prototype.destroy = function () { };
95
+ /**
96
+ * @param {?} value
97
+ * @return {?}
98
+ */
99
+ ProceduralRenderer3.prototype.createComment = function (value) { };
100
+ /**
101
+ * @param {?} name
102
+ * @param {?=} namespace
103
+ * @return {?}
104
+ */
105
+ ProceduralRenderer3.prototype.createElement = function (name, namespace) { };
106
+ /**
107
+ * @param {?} value
108
+ * @return {?}
109
+ */
110
+ ProceduralRenderer3.prototype.createText = function (value) { };
111
+ /**
112
+ * @param {?} parent
113
+ * @param {?} newChild
114
+ * @return {?}
115
+ */
116
+ ProceduralRenderer3.prototype.appendChild = function (parent, newChild) { };
117
+ /**
118
+ * @param {?} parent
119
+ * @param {?} newChild
120
+ * @param {?} refChild
121
+ * @return {?}
122
+ */
123
+ ProceduralRenderer3.prototype.insertBefore = function (parent, newChild, refChild) { };
124
+ /**
125
+ * @param {?} parent
126
+ * @param {?} oldChild
127
+ * @return {?}
128
+ */
129
+ ProceduralRenderer3.prototype.removeChild = function (parent, oldChild) { };
130
+ /**
131
+ * @param {?} selectorOrNode
132
+ * @return {?}
133
+ */
134
+ ProceduralRenderer3.prototype.selectRootElement = function (selectorOrNode) { };
135
+ /**
136
+ * @param {?} node
137
+ * @return {?}
138
+ */
139
+ ProceduralRenderer3.prototype.parentNode = function (node) { };
140
+ /**
141
+ * @param {?} node
142
+ * @return {?}
143
+ */
144
+ ProceduralRenderer3.prototype.nextSibling = function (node) { };
145
+ /**
146
+ * @param {?} el
147
+ * @param {?} name
148
+ * @param {?} value
149
+ * @param {?=} namespace
150
+ * @return {?}
151
+ */
152
+ ProceduralRenderer3.prototype.setAttribute = function (el, name, value, namespace) { };
153
+ /**
154
+ * @param {?} el
155
+ * @param {?} name
156
+ * @param {?=} namespace
157
+ * @return {?}
158
+ */
159
+ ProceduralRenderer3.prototype.removeAttribute = function (el, name, namespace) { };
160
+ /**
161
+ * @param {?} el
162
+ * @param {?} name
163
+ * @return {?}
164
+ */
165
+ ProceduralRenderer3.prototype.addClass = function (el, name) { };
166
+ /**
167
+ * @param {?} el
168
+ * @param {?} name
169
+ * @return {?}
170
+ */
171
+ ProceduralRenderer3.prototype.removeClass = function (el, name) { };
172
+ /**
173
+ * @param {?} el
174
+ * @param {?} style
175
+ * @param {?} value
176
+ * @param {?=} flags
177
+ * @return {?}
178
+ */
179
+ ProceduralRenderer3.prototype.setStyle = function (el, style, value, flags) { };
180
+ /**
181
+ * @param {?} el
182
+ * @param {?} style
183
+ * @param {?=} flags
184
+ * @return {?}
185
+ */
186
+ ProceduralRenderer3.prototype.removeStyle = function (el, style, flags) { };
187
+ /**
188
+ * @param {?} el
189
+ * @param {?} name
190
+ * @param {?} value
191
+ * @return {?}
192
+ */
193
+ ProceduralRenderer3.prototype.setProperty = function (el, name, value) { };
194
+ /**
195
+ * @param {?} node
196
+ * @param {?} value
197
+ * @return {?}
198
+ */
199
+ ProceduralRenderer3.prototype.setValue = function (node, value) { };
200
+ /**
201
+ * @param {?} target
202
+ * @param {?} eventName
203
+ * @param {?} callback
204
+ * @return {?}
205
+ */
206
+ ProceduralRenderer3.prototype.listen = function (target, eventName, callback) { };
207
+ }
105
208
  /**
106
209
  * @record
107
210
  */
108
211
  export function RendererFactory3() { }
109
- /** @type {?} */
110
- RendererFactory3.prototype.createRenderer;
111
- /** @type {?|undefined} */
112
- RendererFactory3.prototype.begin;
113
- /** @type {?|undefined} */
114
- RendererFactory3.prototype.end;
212
+ if (false) {
213
+ /**
214
+ * @param {?} hostElement
215
+ * @param {?} rendererType
216
+ * @return {?}
217
+ */
218
+ RendererFactory3.prototype.createRenderer = function (hostElement, rendererType) { };
219
+ /**
220
+ * @return {?}
221
+ */
222
+ RendererFactory3.prototype.begin = function () { };
223
+ /**
224
+ * @return {?}
225
+ */
226
+ RendererFactory3.prototype.end = function () { };
227
+ }
115
228
  /** @type {?} */
116
229
  export const domRendererFactory3 = {
117
230
  createRenderer: (hostElement, rendererType) => { return document; }
@@ -121,77 +234,135 @@ export const domRendererFactory3 = {
121
234
  * @record
122
235
  */
123
236
  export function RNode() { }
124
- /** @type {?} */
125
- RNode.prototype.parentNode;
126
- /** @type {?} */
127
- RNode.prototype.nextSibling;
128
- /** @type {?} */
129
- RNode.prototype.removeChild;
130
- /**
131
- * Insert a child node.
132
- *
133
- * Used exclusively for adding View root nodes into ViewAnchor location.
134
- * @type {?}
135
- */
136
- RNode.prototype.insertBefore;
137
- /**
138
- * Append a child node.
139
- *
140
- * Used exclusively for building up DOM which are static (ie not View roots)
141
- * @type {?}
142
- */
143
- RNode.prototype.appendChild;
237
+ if (false) {
238
+ /** @type {?} */
239
+ RNode.prototype.parentNode;
240
+ /** @type {?} */
241
+ RNode.prototype.nextSibling;
242
+ /**
243
+ * @param {?} oldChild
244
+ * @return {?}
245
+ */
246
+ RNode.prototype.removeChild = function (oldChild) { };
247
+ /**
248
+ * Insert a child node.
249
+ *
250
+ * Used exclusively for adding View root nodes into ViewAnchor location.
251
+ * @param {?} newChild
252
+ * @param {?} refChild
253
+ * @param {?} isViewRoot
254
+ * @return {?}
255
+ */
256
+ RNode.prototype.insertBefore = function (newChild, refChild, isViewRoot) { };
257
+ /**
258
+ * Append a child node.
259
+ *
260
+ * Used exclusively for building up DOM which are static (ie not View roots)
261
+ * @param {?} newChild
262
+ * @return {?}
263
+ */
264
+ RNode.prototype.appendChild = function (newChild) { };
265
+ }
144
266
  /**
145
267
  * Subset of API needed for writing attributes, properties, and setting up
146
268
  * listeners on Element.
147
269
  * @record
148
270
  */
149
271
  export function RElement() { }
150
- /** @type {?} */
151
- RElement.prototype.style;
152
- /** @type {?} */
153
- RElement.prototype.classList;
154
- /** @type {?} */
155
- RElement.prototype.className;
156
- /** @type {?} */
157
- RElement.prototype.setAttribute;
158
- /** @type {?} */
159
- RElement.prototype.removeAttribute;
160
- /** @type {?} */
161
- RElement.prototype.setAttributeNS;
162
- /** @type {?} */
163
- RElement.prototype.addEventListener;
164
- /** @type {?} */
165
- RElement.prototype.removeEventListener;
166
- /** @type {?|undefined} */
167
- RElement.prototype.setProperty;
272
+ if (false) {
273
+ /** @type {?} */
274
+ RElement.prototype.style;
275
+ /** @type {?} */
276
+ RElement.prototype.classList;
277
+ /** @type {?} */
278
+ RElement.prototype.className;
279
+ /**
280
+ * @param {?} name
281
+ * @param {?} value
282
+ * @return {?}
283
+ */
284
+ RElement.prototype.setAttribute = function (name, value) { };
285
+ /**
286
+ * @param {?} name
287
+ * @return {?}
288
+ */
289
+ RElement.prototype.removeAttribute = function (name) { };
290
+ /**
291
+ * @param {?} namespaceURI
292
+ * @param {?} qualifiedName
293
+ * @param {?} value
294
+ * @return {?}
295
+ */
296
+ RElement.prototype.setAttributeNS = function (namespaceURI, qualifiedName, value) { };
297
+ /**
298
+ * @param {?} type
299
+ * @param {?} listener
300
+ * @param {?=} useCapture
301
+ * @return {?}
302
+ */
303
+ RElement.prototype.addEventListener = function (type, listener, useCapture) { };
304
+ /**
305
+ * @param {?} type
306
+ * @param {?=} listener
307
+ * @param {?=} options
308
+ * @return {?}
309
+ */
310
+ RElement.prototype.removeEventListener = function (type, listener, options) { };
311
+ /**
312
+ * @param {?} name
313
+ * @param {?} value
314
+ * @return {?}
315
+ */
316
+ RElement.prototype.setProperty = function (name, value) { };
317
+ }
168
318
  /**
169
319
  * @record
170
320
  */
171
321
  export function RCssStyleDeclaration() { }
172
- /** @type {?} */
173
- RCssStyleDeclaration.prototype.removeProperty;
174
- /** @type {?} */
175
- RCssStyleDeclaration.prototype.setProperty;
322
+ if (false) {
323
+ /**
324
+ * @param {?} propertyName
325
+ * @return {?}
326
+ */
327
+ RCssStyleDeclaration.prototype.removeProperty = function (propertyName) { };
328
+ /**
329
+ * @param {?} propertyName
330
+ * @param {?} value
331
+ * @param {?=} priority
332
+ * @return {?}
333
+ */
334
+ RCssStyleDeclaration.prototype.setProperty = function (propertyName, value, priority) { };
335
+ }
176
336
  /**
177
337
  * @record
178
338
  */
179
339
  export function RDomTokenList() { }
180
- /** @type {?} */
181
- RDomTokenList.prototype.add;
182
- /** @type {?} */
183
- RDomTokenList.prototype.remove;
340
+ if (false) {
341
+ /**
342
+ * @param {?} token
343
+ * @return {?}
344
+ */
345
+ RDomTokenList.prototype.add = function (token) { };
346
+ /**
347
+ * @param {?} token
348
+ * @return {?}
349
+ */
350
+ RDomTokenList.prototype.remove = function (token) { };
351
+ }
184
352
  /**
185
353
  * @record
186
354
  */
187
355
  export function RText() { }
188
- /** @type {?} */
189
- RText.prototype.textContent;
356
+ if (false) {
357
+ /** @type {?} */
358
+ RText.prototype.textContent;
359
+ }
190
360
  /**
191
361
  * @record
192
362
  */
193
363
  export function RComment() { }
364
+ // Note: This hack is necessary so we don't erroneously get a circular dependency
365
+ // failure based on types.
194
366
  /** @type {?} */
195
367
  export const unusedValueExportToPlacateAjd = 1;
196
-
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/interfaces/renderer.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAsBE,YAAkB;IAClB,WAAiB;;;wCADjB,SAAS;wCACT,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBV,MAAM,UAAU,oBAAoB,CAAC,QAAuD;IAE1F,OAAO,CAAC,CAAC,CAAC,mBAAC,QAAe,EAAC,CAAC,MAAM,CAAC,CAAC;CACrC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiDD,aAAa,mBAAmB,GAAqB;IACnD,cAAc,EAAE,CAAC,WAA4B,EAAE,YAAkC,EACnD,EAAE,GAAG,OAAO,QAAQ,CAAC,EAAC;CACrD,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0DF,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\n/**\n * The goal here is to make sure that the browser DOM API is the Renderer.\n * We do this by defining a subset of DOM API to be the renderer and than\n * use that time for rendering.\n *\n * At runtime we can than use the DOM api directly, in server or web-worker\n * it will be easy to implement such API.\n */\n\nimport {RendererStyleFlags2, RendererType2} from '../../render/api';\n\n\n// TODO: cleanup once the code is merged in angular/angular\nexport enum RendererStyleFlags3 {\n  Important = 1 << 0,\n  DashCase = 1 << 1\n}\n\nexport type Renderer3 = ObjectOrientedRenderer3 | ProceduralRenderer3;\n\n/**\n * Object Oriented style of API needed to create elements and text nodes.\n *\n * This is the native browser API style, e.g. operations are methods on individual objects\n * like HTMLElement. With this style, no additional code is needed as a facade\n * (reducing payload size).\n * */\nexport interface ObjectOrientedRenderer3 {\n  createComment(data: string): RComment;\n  createElement(tagName: string): RElement;\n  createElementNS(namespace: string, tagName: string): RElement;\n  createTextNode(data: string): RText;\n\n  querySelector(selectors: string): RElement|null;\n}\n\n/** Returns whether the `renderer` is a `ProceduralRenderer3` */\nexport function isProceduralRenderer(renderer: ProceduralRenderer3 | ObjectOrientedRenderer3):\n    renderer is ProceduralRenderer3 {\n  return !!((renderer as any).listen);\n}\n\n/**\n * Procedural style of API needed to create elements and text nodes.\n *\n * In non-native browser environments (e.g. platforms such as web-workers), this is the\n * facade that enables element manipulation. This also facilitates backwards compatibility\n * with Renderer2.\n */\nexport interface ProceduralRenderer3 {\n  destroy(): void;\n  createComment(value: string): RComment;\n  createElement(name: string, namespace?: string|null): RElement;\n  createText(value: string): RText;\n  /**\n   * This property is allowed to be null / undefined,\n   * in which case the view engine won't call it.\n   * This is used as a performance optimization for production mode.\n   */\n  destroyNode?: ((node: RNode) => void)|null;\n  appendChild(parent: RElement, newChild: RNode): void;\n  insertBefore(parent: RNode, newChild: RNode, refChild: RNode|null): void;\n  removeChild(parent: RElement, oldChild: RNode): void;\n  selectRootElement(selectorOrNode: string|any): RElement;\n\n  parentNode(node: RNode): RElement|null;\n  nextSibling(node: RNode): RNode|null;\n\n  setAttribute(el: RElement, name: string, value: string, namespace?: string|null): void;\n  removeAttribute(el: RElement, name: string, namespace?: string|null): void;\n  addClass(el: RElement, name: string): void;\n  removeClass(el: RElement, name: string): void;\n  setStyle(\n      el: RElement, style: string, value: any,\n      flags?: RendererStyleFlags2|RendererStyleFlags3): void;\n  removeStyle(el: RElement, style: string, flags?: RendererStyleFlags2|RendererStyleFlags3): void;\n  setProperty(el: RElement, name: string, value: any): void;\n  setValue(node: RText, value: string): void;\n\n  // TODO(misko): Deprecate in favor of addEventListener/removeEventListener\n  listen(target: RNode, eventName: string, callback: (event: any) => boolean | void): () => void;\n}\n\nexport interface RendererFactory3 {\n  createRenderer(hostElement: RElement|null, rendererType: RendererType2|null): Renderer3;\n  begin?(): void;\n  end?(): void;\n}\n\nexport const domRendererFactory3: RendererFactory3 = {\n  createRenderer: (hostElement: RElement | null, rendererType: RendererType2 | null):\n                      Renderer3 => { return document;}\n};\n\n/** Subset of API needed for appending elements and text nodes. */\nexport interface RNode {\n  parentNode: RNode|null;\n\n  nextSibling: RNode|null;\n\n  removeChild(oldChild: RNode): void;\n\n  /**\n   * Insert a child node.\n   *\n   * Used exclusively for adding View root nodes into ViewAnchor location.\n   */\n  insertBefore(newChild: RNode, refChild: RNode|null, isViewRoot: boolean): void;\n\n  /**\n   * Append a child node.\n   *\n   * Used exclusively for building up DOM which are static (ie not View roots)\n   */\n  appendChild(newChild: RNode): RNode;\n}\n\n/**\n * Subset of API needed for writing attributes, properties, and setting up\n * listeners on Element.\n */\nexport interface RElement extends RNode {\n  style: RCssStyleDeclaration;\n  classList: RDomTokenList;\n  className: string;\n  setAttribute(name: string, value: string): void;\n  removeAttribute(name: string): void;\n  setAttributeNS(namespaceURI: string, qualifiedName: string, value: string): void;\n  addEventListener(type: string, listener: EventListener, useCapture?: boolean): void;\n  removeEventListener(type: string, listener?: EventListener, options?: boolean): void;\n\n  setProperty?(name: string, value: any): void;\n}\n\nexport interface RCssStyleDeclaration {\n  removeProperty(propertyName: string): string;\n  setProperty(propertyName: string, value: string|null, priority?: string): void;\n}\n\nexport interface RDomTokenList {\n  add(token: string): void;\n  remove(token: string): void;\n}\n\nexport interface RText extends RNode { textContent: string|null; }\n\nexport interface RComment extends RNode {}\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"]}
368
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/renderer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;IAsBE,YAAkB;IAClB,WAAiB;;;;;;;;;;;;;;AAYnB,6CAOC;;;;;;IANC,sEAAsC;;;;;IACtC,yEAAyC;;;;;;IACzC,sFAA8D;;;;;IAC9D,uEAAoC;;;;;IAEpC,2EAAgD;;;;;;;AAIlD,MAAM,UAAU,oBAAoB,CAAC,QAAuD;IAE1F,OAAO,CAAC,CAAC,CAAC,CAAC,mBAAA,QAAQ,EAAO,CAAC,CAAC,MAAM,CAAC,CAAC;AACtC,CAAC;;;;;;;;;AASD,yCAgCC;;;;;;;;IAtBC,0CAA2C;;;;IAT3C,wDAAgB;;;;;IAChB,mEAAuC;;;;;;IACvC,6EAA+D;;;;;IAC/D,gEAAiC;;;;;;IAOjC,4EAAqD;;;;;;;IACrD,uFAAyE;;;;;;IACzE,4EAAqD;;;;;IACrD,gFAAwD;;;;;IAExD,+DAAuC;;;;;IACvC,gEAAqC;;;;;;;;IAErC,uFAAuF;;;;;;;IACvF,mFAA2E;;;;;;IAC3E,iEAA2C;;;;;;IAC3C,oEAA8C;;;;;;;;IAC9C,gFAE2D;;;;;;;IAC3D,4EAAgG;;;;;;;IAChG,2EAA0D;;;;;;IAC1D,oEAA2C;;;;;;;IAG3C,kFAA+F;;;;;AAGjG,sCAIC;;;;;;;IAHC,qFAAwF;;;;IACxF,mDAAe;;;;IACf,iDAAa;;;AAGf,MAAM,OAAO,mBAAmB,GAAqB;IACnD,cAAc,EAAE,CAAC,WAA4B,EAAE,YAAkC,EACnD,EAAE,GAAG,OAAO,QAAQ,CAAC,CAAA,CAAC;CACrD;;;;;AAGD,2BAoBC;;;IAnBC,2BAAuB;;IAEvB,4BAAwB;;;;;IAExB,sDAAmC;;;;;;;;;;IAOnC,6EAA+E;;;;;;;;IAO/E,sDAAoC;;;;;;;AAOtC,8BAWC;;;IAVC,yBAA4B;;IAC5B,6BAAyB;;IACzB,6BAAkB;;;;;;IAClB,6DAAgD;;;;;IAChD,yDAAoC;;;;;;;IACpC,sFAAiF;;;;;;;IACjF,gFAAoF;;;;;;;IACpF,gFAAqF;;;;;;IAErF,4DAA6C;;;;;AAG/C,0CAGC;;;;;;IAFC,4EAA6C;;;;;;;IAC7C,0FAA+E;;;;;AAGjF,mCAGC;;;;;;IAFC,mDAAyB;;;;;IACzB,sDAA4B;;;;;AAG9B,2BAAkE;;;IAA3B,4BAAyB;;;;;AAEhE,8BAA0C;;;;AAI1C,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\n/**\n * The goal here is to make sure that the browser DOM API is the Renderer.\n * We do this by defining a subset of DOM API to be the renderer and than\n * use that time for rendering.\n *\n * At runtime we can than use the DOM api directly, in server or web-worker\n * it will be easy to implement such API.\n */\n\nimport {RendererStyleFlags2, RendererType2} from '../../render/api';\n\n\n// TODO: cleanup once the code is merged in angular/angular\nexport enum RendererStyleFlags3 {\n  Important = 1 << 0,\n  DashCase = 1 << 1\n}\n\nexport type Renderer3 = ObjectOrientedRenderer3 | ProceduralRenderer3;\n\n/**\n * Object Oriented style of API needed to create elements and text nodes.\n *\n * This is the native browser API style, e.g. operations are methods on individual objects\n * like HTMLElement. With this style, no additional code is needed as a facade\n * (reducing payload size).\n * */\nexport interface ObjectOrientedRenderer3 {\n  createComment(data: string): RComment;\n  createElement(tagName: string): RElement;\n  createElementNS(namespace: string, tagName: string): RElement;\n  createTextNode(data: string): RText;\n\n  querySelector(selectors: string): RElement|null;\n}\n\n/** Returns whether the `renderer` is a `ProceduralRenderer3` */\nexport function isProceduralRenderer(renderer: ProceduralRenderer3 | ObjectOrientedRenderer3):\n    renderer is ProceduralRenderer3 {\n  return !!((renderer as any).listen);\n}\n\n/**\n * Procedural style of API needed to create elements and text nodes.\n *\n * In non-native browser environments (e.g. platforms such as web-workers), this is the\n * facade that enables element manipulation. This also facilitates backwards compatibility\n * with Renderer2.\n */\nexport interface ProceduralRenderer3 {\n  destroy(): void;\n  createComment(value: string): RComment;\n  createElement(name: string, namespace?: string|null): RElement;\n  createText(value: string): RText;\n  /**\n   * This property is allowed to be null / undefined,\n   * in which case the view engine won't call it.\n   * This is used as a performance optimization for production mode.\n   */\n  destroyNode?: ((node: RNode) => void)|null;\n  appendChild(parent: RElement, newChild: RNode): void;\n  insertBefore(parent: RNode, newChild: RNode, refChild: RNode|null): void;\n  removeChild(parent: RElement, oldChild: RNode): void;\n  selectRootElement(selectorOrNode: string|any): RElement;\n\n  parentNode(node: RNode): RElement|null;\n  nextSibling(node: RNode): RNode|null;\n\n  setAttribute(el: RElement, name: string, value: string, namespace?: string|null): void;\n  removeAttribute(el: RElement, name: string, namespace?: string|null): void;\n  addClass(el: RElement, name: string): void;\n  removeClass(el: RElement, name: string): void;\n  setStyle(\n      el: RElement, style: string, value: any,\n      flags?: RendererStyleFlags2|RendererStyleFlags3): void;\n  removeStyle(el: RElement, style: string, flags?: RendererStyleFlags2|RendererStyleFlags3): void;\n  setProperty(el: RElement, name: string, value: any): void;\n  setValue(node: RText, value: string): void;\n\n  // TODO(misko): Deprecate in favor of addEventListener/removeEventListener\n  listen(target: RNode, eventName: string, callback: (event: any) => boolean | void): () => void;\n}\n\nexport interface RendererFactory3 {\n  createRenderer(hostElement: RElement|null, rendererType: RendererType2|null): Renderer3;\n  begin?(): void;\n  end?(): void;\n}\n\nexport const domRendererFactory3: RendererFactory3 = {\n  createRenderer: (hostElement: RElement | null, rendererType: RendererType2 | null):\n                      Renderer3 => { return document;}\n};\n\n/** Subset of API needed for appending elements and text nodes. */\nexport interface RNode {\n  parentNode: RNode|null;\n\n  nextSibling: RNode|null;\n\n  removeChild(oldChild: RNode): void;\n\n  /**\n   * Insert a child node.\n   *\n   * Used exclusively for adding View root nodes into ViewAnchor location.\n   */\n  insertBefore(newChild: RNode, refChild: RNode|null, isViewRoot: boolean): void;\n\n  /**\n   * Append a child node.\n   *\n   * Used exclusively for building up DOM which are static (ie not View roots)\n   */\n  appendChild(newChild: RNode): RNode;\n}\n\n/**\n * Subset of API needed for writing attributes, properties, and setting up\n * listeners on Element.\n */\nexport interface RElement extends RNode {\n  style: RCssStyleDeclaration;\n  classList: RDomTokenList;\n  className: string;\n  setAttribute(name: string, value: string): void;\n  removeAttribute(name: string): void;\n  setAttributeNS(namespaceURI: string, qualifiedName: string, value: string): void;\n  addEventListener(type: string, listener: EventListener, useCapture?: boolean): void;\n  removeEventListener(type: string, listener?: EventListener, options?: boolean): void;\n\n  setProperty?(name: string, value: any): void;\n}\n\nexport interface RCssStyleDeclaration {\n  removeProperty(propertyName: string): string;\n  setProperty(propertyName: string, value: string|null, priority?: string): void;\n}\n\nexport interface RDomTokenList {\n  add(token: string): void;\n  remove(token: string): void;\n}\n\nexport interface RText extends RNode { textContent: string|null; }\n\nexport interface RComment extends RNode {}\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"]}
@@ -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,8 +9,4 @@
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
- /** @typedef {?} */
13
- var SanitizerFn;
14
- export { SanitizerFn };
15
-
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FuaXRpemF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy9pbnRlcmZhY2VzL3Nhbml0aXphdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vKipcbiAqIEZ1bmN0aW9uIHVzZWQgdG8gc2FuaXRpemUgdGhlIHZhbHVlIGJlZm9yZSB3cml0aW5nIGl0IGludG8gdGhlIHJlbmRlcmVyLlxuICovXG5leHBvcnQgdHlwZSBTYW5pdGl6ZXJGbiA9ICh2YWx1ZTogYW55KSA9PiBzdHJpbmc7XG4iXX0=
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FuaXRpemF0aW9uLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLyIsInNvdXJjZXMiOlsicGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy9pbnRlcmZhY2VzL3Nhbml0aXphdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vKipcbiAqIEZ1bmN0aW9uIHVzZWQgdG8gc2FuaXRpemUgdGhlIHZhbHVlIGJlZm9yZSB3cml0aW5nIGl0IGludG8gdGhlIHJlbmRlcmVyLlxuICovXG5leHBvcnQgdHlwZSBTYW5pdGl6ZXJGbiA9ICh2YWx1ZTogYW55KSA9PiBzdHJpbmc7XG4iXX0=
@@ -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
  * The styling context acts as a styling manifest (shaped as an array) for determining which
@@ -109,6 +109,24 @@
109
109
  * @record
110
110
  */
111
111
  export function StylingContext() { }
112
+ if (false) {
113
+ /* Skipping unnamed member:
114
+ [StylingIndex.PlayerContext]: PlayerContext|null;*/
115
+ /* Skipping unnamed member:
116
+ [StylingIndex.StyleSanitizerPosition]: StyleSanitizeFn|null;*/
117
+ /* Skipping unnamed member:
118
+ [StylingIndex.InitialStylesPosition]: InitialStyles;*/
119
+ /* Skipping unnamed member:
120
+ [StylingIndex.MasterFlagPosition]: number;*/
121
+ /* Skipping unnamed member:
122
+ [StylingIndex.ClassOffsetPosition]: number;*/
123
+ /* Skipping unnamed member:
124
+ [StylingIndex.ElementPosition]: RElement|null;*/
125
+ /* Skipping unnamed member:
126
+ [StylingIndex.PreviousOrCachedMultiClassValue]: {[key: string]: any}|string|null;*/
127
+ /* Skipping unnamed member:
128
+ [StylingIndex.PreviousMultiStyleValue]: {[key: string]: any}|null;*/
129
+ }
112
130
  /**
113
131
  * The initial styles is populated whether or not there are any initial styles passed into
114
132
  * the context during allocation. The 0th value must be null so that index values of `0` within
@@ -119,8 +137,12 @@ export function StylingContext() { }
119
137
  * @record
120
138
  */
121
139
  export function InitialStyles() { }
140
+ if (false) {
141
+ /* Skipping unnamed member:
142
+ [0]: null;*/
143
+ }
122
144
  /** @enum {number} */
123
- var StylingFlags = {
145
+ const StylingFlags = {
124
146
  // Implies no configurations
125
147
  None: 0,
126
148
  // Whether or not the entry or context itself is dirty
@@ -141,7 +163,7 @@ var StylingFlags = {
141
163
  };
142
164
  export { StylingFlags };
143
165
  /** @enum {number} */
144
- var StylingIndex = {
166
+ const StylingIndex = {
145
167
  // Position of where the initial styles are stored in the styling context
146
168
  PlayerContext: 0,
147
169
  // Position of where the style sanitizer is stored within the styling context
@@ -171,10 +193,8 @@ var StylingIndex = {
171
193
  Size: 4,
172
194
  // Each flag has a binary digit length of this value
173
195
  BitCountSize: 14,
174
- // (32 - 4) / 2 = ~14
175
196
  // The binary digit value as a mask
176
197
  BitMask: 16383,
177
198
  };
178
199
  export { StylingIndex };
179
-
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/interfaces/styling.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAuLE,OAAc;;IAEd,QAAe;;IAEf,QAAe;;IAEf,WAAkB;;IAElB,sBAA6B;;;IAG7B,4BAAkC;;IAElC,eAAgB;;IAEhB,WAAiB;;;;;;IAMjB,gBAAiB;;IAEjB,yBAA0B;;IAE1B,wBAAyB;;IAEzB,qBAAsB;;IAEtB,sBAAuB;;;IAGvB,kBAAmB;;;IAGnB,kCAAmC;;IAEnC,0BAA2B;;IAE3B,4BAA6B;;IAE7B,cAAe;IACf,iBAAkB;IAClB,cAAe;IACf,2BAA4B;;IAE5B,OAAQ;;IAER,gBAAiB;;;IAEjB,cAA0B","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 */\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {RElement} from '../interfaces/renderer';\nimport {PlayerContext} from './player';\n\n\n/**\n * The styling context acts as a styling manifest (shaped as an array) for determining which\n * styling properties have been assigned via the provided `updateStylingMap`, `updateStyleProp`\n * and `updateClassProp` functions. There are also two initialization functions\n * `allocStylingContext` and `createStylingContextTemplate` which are used to initialize\n * and/or clone the context.\n *\n * The context is an array where the first two cells are used for static data (initial styling)\n * and dirty flags / index offsets). The remaining set of cells is used for multi (map) and single\n * (prop) style values.\n *\n * each value from here onwards is mapped as so:\n * [i] = mutation/type flag for the style/class value\n * [i + 1] = prop string (or null incase it has been removed)\n * [i + 2] = value string (or null incase it has been removed)\n *\n * There are three types of styling types stored in this context:\n *   initial: any styles that are passed in once the context is created\n *            (these are stored in the first cell of the array and the first\n *             value of this array is always `null` even if no initial styling exists.\n *             the `null` value is there so that any new styles have a parent to point\n *             to. This way we can always assume that there is a parent.)\n *\n *   single: any styles that are updated using `updateStyleProp` or `updateClassProp` (fixed set)\n *\n *   multi: any styles that are updated using `updateStylingMap` (dynamic set)\n *\n * Note that context is only used to collect style information. Only when `renderStyling`\n * is called is when the styling payload will be rendered (or built as a key/value map).\n *\n * When the context is created, depending on what initial styling values are passed in, the\n * context itself will be pre-filled with slots based on the initial style properties. Say\n * for example we have a series of initial styles that look like so:\n *\n *   style=\"width:100px; height:200px;\"\n *   class=\"foo\"\n *\n * Then the initial state of the context (once initialized) will look like so:\n *\n * ```\n * context = [\n *   element,\n *   playerContext | null,\n *   styleSanitizer | null,\n *   [null, '100px', '200px', true],  // property names are not needed since they have already been\n * written to DOM.\n *\n *   configMasterVal,\n *   1, // this instructs how many `style` values there are so that class index values can be\n * offsetted\n *   { classOne: true, classTwo: false } | 'classOne classTwo' | null // last class value provided\n * into updateStylingMap\n *   { styleOne: '100px', styleTwo: 0 } | null // last style value provided into updateStylingMap\n *\n *   // 8\n *   'width',\n *   pointers(1, 15);  // Point to static `width`: `100px` and multi `width`.\n *   null,\n *\n *   // 11\n *   'height',\n *   pointers(2, 18); // Point to static `height`: `200px` and multi `height`.\n *   null,\n *\n *   // 14\n *   'foo',\n *   pointers(1, 21);  // Point to static `foo`: `true` and multi `foo`.\n *   null,\n *\n *   // 17\n *   'width',\n *   pointers(1, 6);  // Point to static `width`: `100px` and single `width`.\n *   null,\n *\n *   // 21\n *   'height',\n *   pointers(2, 9);  // Point to static `height`: `200px` and single `height`.\n *   null,\n *\n *   // 24\n *   'foo',\n *   pointers(3, 12);  // Point to static `foo`: `true` and single `foo`.\n *   null,\n * ]\n *\n * function pointers(staticIndex: number, dynamicIndex: number) {\n *   // combine the two indices into a single word.\n *   return (staticIndex << StylingFlags.BitCountSize) |\n *     (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n * }\n * ```\n *\n * The values are duplicated so that space is set aside for both multi ([style] and [class])\n * and single ([style.prop] or [class.named]) values. The respective config values\n * (configValA, configValB, etc...) are a combination of the StylingFlags with two index\n * values: the `initialIndex` (which points to the index location of the style value in\n * the initial styles array in slot 0) and the `dynamicIndex` (which points to the\n * matching single/multi index position in the context array for the same prop).\n *\n * This means that every time `updateStyleProp` or `updateClassProp` are called then they\n * must be called using an index value (not a property string) which references the index\n * value of the initial style prop/class when the context was created. This also means that\n * `updateStyleProp` or `updateClassProp` cannot be called with a new property (only\n * `updateStylingMap` can include new CSS properties that will be added to the context).\n */\nexport interface StylingContext extends Array<InitialStyles|{[key: string]: any}|number|string|\n                                              boolean|RElement|StyleSanitizeFn|PlayerContext|null> {\n  /**\n   * Location of animation context (which contains the active players) for this element styling\n   * context.\n   */\n  [StylingIndex.PlayerContext]: PlayerContext|null;\n\n  /**\n   * The style sanitizer that is used within this context\n   */\n  [StylingIndex.StyleSanitizerPosition]: StyleSanitizeFn|null;\n\n  /**\n   * Location of initial data shared by all instances of this style.\n   */\n  [StylingIndex.InitialStylesPosition]: InitialStyles;\n\n  /**\n   * A numeric value representing the configuration status (whether the context is dirty or not)\n   * mixed together (using bit shifting) with a index value which tells the starting index value\n   * of where the multi style entries begin.\n   */\n  [StylingIndex.MasterFlagPosition]: number;\n\n  /**\n   * A numeric value representing the class index offset value. Whenever a single class is\n   * applied (using `elementClassProp`) it should have an styling index value that doesn't\n   * need to take into account any style values that exist in the context.\n   */\n  [StylingIndex.ClassOffsetPosition]: number;\n\n  /**\n   * Location of element that is used as a target for this context.\n   */\n  [StylingIndex.ElementPosition]: RElement|null;\n\n  /**\n   * The last class value that was interpreted by elementStylingMap. This is cached\n   * So that the algorithm can exit early incase the value has not changed.\n   */\n  [StylingIndex.PreviousOrCachedMultiClassValue]: {[key: string]: any}|string|null;\n\n  /**\n   * The last style value that was interpreted by elementStylingMap. This is cached\n   * So that the algorithm can exit early incase the value has not changed.\n   */\n  [StylingIndex.PreviousMultiStyleValue]: {[key: string]: any}|null;\n}\n\n/**\n * The initial styles is populated whether or not there are any initial styles passed into\n * the context during allocation. The 0th value must be null so that index values of `0` within\n * the context flags can always point to a null value safely when nothing is set.\n *\n * All other entries in this array are of `string` value and correspond to the values that\n * were extracted from the `style=\"\"` attribute in the HTML code for the provided template.\n */\nexport interface InitialStyles extends Array<string|null|boolean> { [0]: null; }\n\n/**\n * Used to set the context to be dirty or not both on the master flag (position 1)\n * or for each single/multi property that exists in the context.\n */\nexport const enum StylingFlags {\n  // Implies no configurations\n  None = 0b00000,\n  // Whether or not the entry or context itself is dirty\n  Dirty = 0b00001,\n  // Whether or not this is a class-based assignment\n  Class = 0b00010,\n  // Whether or not a sanitizer was applied to this property\n  Sanitize = 0b00100,\n  // Whether or not any player builders within need to produce new players\n  PlayerBuildersDirty = 0b01000,\n  // If NgClass is present (or some other class handler) then it will handle the map expressions and\n  // initial classes\n  OnlyProcessSingleClasses = 0b10000,\n  // The max amount of bits used to represent these configuration values\n  BitCountSize = 5,\n  // There are only five bits here\n  BitMask = 0b11111\n}\n\n/** Used as numeric pointer values to determine what cells to update in the `StylingContext` */\nexport const enum StylingIndex {\n  // Position of where the initial styles are stored in the styling context\n  PlayerContext = 0,\n  // Position of where the style sanitizer is stored within the styling context\n  StyleSanitizerPosition = 1,\n  // Position of where the initial styles are stored in the styling context\n  InitialStylesPosition = 2,\n  // Index of location where the start of single properties are stored. (`updateStyleProp`)\n  MasterFlagPosition = 3,\n  // Index of location where the class index offset value is located\n  ClassOffsetPosition = 4,\n  // Position of where the initial styles are stored in the styling context\n  // This index must align with HOST, see interfaces/view.ts\n  ElementPosition = 5,\n  // Position of where the last string-based CSS class value was stored (or a cached version of the\n  // initial styles when a [class] directive is present)\n  PreviousOrCachedMultiClassValue = 6,\n  // Position of where the last string-based CSS class value was stored\n  PreviousMultiStyleValue = 7,\n  // Location of single (prop) value entries are stored within the context\n  SingleStylesStartPosition = 8,\n  // Multi and single entries are stored in `StylingContext` as: Flag; PropertyName;  PropertyValue\n  FlagsOffset = 0,\n  PropertyOffset = 1,\n  ValueOffset = 2,\n  PlayerBuilderIndexOffset = 3,\n  // Size of each multi or single entry (flag + prop + value + playerBuilderIndex)\n  Size = 4,\n  // Each flag has a binary digit length of this value\n  BitCountSize = 14,  // (32 - 4) / 2 = ~14\n  // The binary digit value as a mask\n  BitMask = 0b11111111111111,  // 14 bits\n}\n"]}
200
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/styling.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqHA,oCAgDC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUD,mCAAgF;;;;;;;IAO9E,4BAA4B;IAC5B,OAAc;IACd,sDAAsD;IACtD,QAAe;IACf,kDAAkD;IAClD,QAAe;IACf,0DAA0D;IAC1D,WAAkB;IAClB,wEAAwE;IACxE,sBAA6B;IAC7B,kGAAkG;IAClG,kBAAkB;IAClB,4BAAkC;IAClC,sEAAsE;IACtE,eAAgB;IAChB,gCAAgC;IAChC,WAAiB;;;;;IAKjB,yEAAyE;IACzE,gBAAiB;IACjB,6EAA6E;IAC7E,yBAA0B;IAC1B,yEAAyE;IACzE,wBAAyB;IACzB,yFAAyF;IACzF,qBAAsB;IACtB,kEAAkE;IAClE,sBAAuB;IACvB,yEAAyE;IACzE,0DAA0D;IAC1D,kBAAmB;IACnB,iGAAiG;IACjG,sDAAsD;IACtD,kCAAmC;IACnC,qEAAqE;IACrE,0BAA2B;IAC3B,wEAAwE;IACxE,4BAA6B;IAC7B,iGAAiG;IACjG,cAAe;IACf,iBAAkB;IAClB,cAAe;IACf,2BAA4B;IAC5B,gFAAgF;IAChF,OAAQ;IACR,oDAAoD;IACpD,gBAAiB;IACjB,mCAAmC;IACnC,cAA0B","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 */\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {RElement} from '../interfaces/renderer';\nimport {PlayerContext} from './player';\n\n\n/**\n * The styling context acts as a styling manifest (shaped as an array) for determining which\n * styling properties have been assigned via the provided `updateStylingMap`, `updateStyleProp`\n * and `updateClassProp` functions. There are also two initialization functions\n * `allocStylingContext` and `createStylingContextTemplate` which are used to initialize\n * and/or clone the context.\n *\n * The context is an array where the first two cells are used for static data (initial styling)\n * and dirty flags / index offsets). The remaining set of cells is used for multi (map) and single\n * (prop) style values.\n *\n * each value from here onwards is mapped as so:\n * [i] = mutation/type flag for the style/class value\n * [i + 1] = prop string (or null incase it has been removed)\n * [i + 2] = value string (or null incase it has been removed)\n *\n * There are three types of styling types stored in this context:\n *   initial: any styles that are passed in once the context is created\n *            (these are stored in the first cell of the array and the first\n *             value of this array is always `null` even if no initial styling exists.\n *             the `null` value is there so that any new styles have a parent to point\n *             to. This way we can always assume that there is a parent.)\n *\n *   single: any styles that are updated using `updateStyleProp` or `updateClassProp` (fixed set)\n *\n *   multi: any styles that are updated using `updateStylingMap` (dynamic set)\n *\n * Note that context is only used to collect style information. Only when `renderStyling`\n * is called is when the styling payload will be rendered (or built as a key/value map).\n *\n * When the context is created, depending on what initial styling values are passed in, the\n * context itself will be pre-filled with slots based on the initial style properties. Say\n * for example we have a series of initial styles that look like so:\n *\n *   style=\"width:100px; height:200px;\"\n *   class=\"foo\"\n *\n * Then the initial state of the context (once initialized) will look like so:\n *\n * ```\n * context = [\n *   element,\n *   playerContext | null,\n *   styleSanitizer | null,\n *   [null, '100px', '200px', true],  // property names are not needed since they have already been\n * written to DOM.\n *\n *   configMasterVal,\n *   1, // this instructs how many `style` values there are so that class index values can be\n * offsetted\n *   { classOne: true, classTwo: false } | 'classOne classTwo' | null // last class value provided\n * into updateStylingMap\n *   { styleOne: '100px', styleTwo: 0 } | null // last style value provided into updateStylingMap\n *\n *   // 8\n *   'width',\n *   pointers(1, 15);  // Point to static `width`: `100px` and multi `width`.\n *   null,\n *\n *   // 11\n *   'height',\n *   pointers(2, 18); // Point to static `height`: `200px` and multi `height`.\n *   null,\n *\n *   // 14\n *   'foo',\n *   pointers(1, 21);  // Point to static `foo`: `true` and multi `foo`.\n *   null,\n *\n *   // 17\n *   'width',\n *   pointers(1, 6);  // Point to static `width`: `100px` and single `width`.\n *   null,\n *\n *   // 21\n *   'height',\n *   pointers(2, 9);  // Point to static `height`: `200px` and single `height`.\n *   null,\n *\n *   // 24\n *   'foo',\n *   pointers(3, 12);  // Point to static `foo`: `true` and single `foo`.\n *   null,\n * ]\n *\n * function pointers(staticIndex: number, dynamicIndex: number) {\n *   // combine the two indices into a single word.\n *   return (staticIndex << StylingFlags.BitCountSize) |\n *     (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n * }\n * ```\n *\n * The values are duplicated so that space is set aside for both multi ([style] and [class])\n * and single ([style.prop] or [class.named]) values. The respective config values\n * (configValA, configValB, etc...) are a combination of the StylingFlags with two index\n * values: the `initialIndex` (which points to the index location of the style value in\n * the initial styles array in slot 0) and the `dynamicIndex` (which points to the\n * matching single/multi index position in the context array for the same prop).\n *\n * This means that every time `updateStyleProp` or `updateClassProp` are called then they\n * must be called using an index value (not a property string) which references the index\n * value of the initial style prop/class when the context was created. This also means that\n * `updateStyleProp` or `updateClassProp` cannot be called with a new property (only\n * `updateStylingMap` can include new CSS properties that will be added to the context).\n */\nexport interface StylingContext extends Array<InitialStyles|{[key: string]: any}|number|string|\n                                              boolean|RElement|StyleSanitizeFn|PlayerContext|null> {\n  /**\n   * Location of animation context (which contains the active players) for this element styling\n   * context.\n   */\n  [StylingIndex.PlayerContext]: PlayerContext|null;\n\n  /**\n   * The style sanitizer that is used within this context\n   */\n  [StylingIndex.StyleSanitizerPosition]: StyleSanitizeFn|null;\n\n  /**\n   * Location of initial data shared by all instances of this style.\n   */\n  [StylingIndex.InitialStylesPosition]: InitialStyles;\n\n  /**\n   * A numeric value representing the configuration status (whether the context is dirty or not)\n   * mixed together (using bit shifting) with a index value which tells the starting index value\n   * of where the multi style entries begin.\n   */\n  [StylingIndex.MasterFlagPosition]: number;\n\n  /**\n   * A numeric value representing the class index offset value. Whenever a single class is\n   * applied (using `elementClassProp`) it should have an styling index value that doesn't\n   * need to take into account any style values that exist in the context.\n   */\n  [StylingIndex.ClassOffsetPosition]: number;\n\n  /**\n   * Location of element that is used as a target for this context.\n   */\n  [StylingIndex.ElementPosition]: RElement|null;\n\n  /**\n   * The last class value that was interpreted by elementStylingMap. This is cached\n   * So that the algorithm can exit early incase the value has not changed.\n   */\n  [StylingIndex.PreviousOrCachedMultiClassValue]: {[key: string]: any}|string|null;\n\n  /**\n   * The last style value that was interpreted by elementStylingMap. This is cached\n   * So that the algorithm can exit early incase the value has not changed.\n   */\n  [StylingIndex.PreviousMultiStyleValue]: {[key: string]: any}|null;\n}\n\n/**\n * The initial styles is populated whether or not there are any initial styles passed into\n * the context during allocation. The 0th value must be null so that index values of `0` within\n * the context flags can always point to a null value safely when nothing is set.\n *\n * All other entries in this array are of `string` value and correspond to the values that\n * were extracted from the `style=\"\"` attribute in the HTML code for the provided template.\n */\nexport interface InitialStyles extends Array<string|null|boolean> { [0]: null; }\n\n/**\n * Used to set the context to be dirty or not both on the master flag (position 1)\n * or for each single/multi property that exists in the context.\n */\nexport const enum StylingFlags {\n  // Implies no configurations\n  None = 0b00000,\n  // Whether or not the entry or context itself is dirty\n  Dirty = 0b00001,\n  // Whether or not this is a class-based assignment\n  Class = 0b00010,\n  // Whether or not a sanitizer was applied to this property\n  Sanitize = 0b00100,\n  // Whether or not any player builders within need to produce new players\n  PlayerBuildersDirty = 0b01000,\n  // If NgClass is present (or some other class handler) then it will handle the map expressions and\n  // initial classes\n  OnlyProcessSingleClasses = 0b10000,\n  // The max amount of bits used to represent these configuration values\n  BitCountSize = 5,\n  // There are only five bits here\n  BitMask = 0b11111\n}\n\n/** Used as numeric pointer values to determine what cells to update in the `StylingContext` */\nexport const enum StylingIndex {\n  // Position of where the initial styles are stored in the styling context\n  PlayerContext = 0,\n  // Position of where the style sanitizer is stored within the styling context\n  StyleSanitizerPosition = 1,\n  // Position of where the initial styles are stored in the styling context\n  InitialStylesPosition = 2,\n  // Index of location where the start of single properties are stored. (`updateStyleProp`)\n  MasterFlagPosition = 3,\n  // Index of location where the class index offset value is located\n  ClassOffsetPosition = 4,\n  // Position of where the initial styles are stored in the styling context\n  // This index must align with HOST, see interfaces/view.ts\n  ElementPosition = 5,\n  // Position of where the last string-based CSS class value was stored (or a cached version of the\n  // initial styles when a [class] directive is present)\n  PreviousOrCachedMultiClassValue = 6,\n  // Position of where the last string-based CSS class value was stored\n  PreviousMultiStyleValue = 7,\n  // Location of single (prop) value entries are stored within the context\n  SingleStylesStartPosition = 8,\n  // Multi and single entries are stored in `StylingContext` as: Flag; PropertyName;  PropertyValue\n  FlagsOffset = 0,\n  PropertyOffset = 1,\n  ValueOffset = 2,\n  PlayerBuilderIndexOffset = 3,\n  // Size of each multi or single entry (flag + prop + value + playerBuilderIndex)\n  Size = 4,\n  // Each flag has a binary digit length of this value\n  BitCountSize = 14,  // (32 - 4) / 2 = ~14\n  // The binary digit value as a mask\n  BitMask = 0b11111111111111,  // 14 bits\n}\n"]}