@angular/core 7.2.0-beta.0 → 7.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (454) hide show
  1. package/bundles/core-testing.umd.js +194 -128
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +5582 -4512
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +122 -129
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +12 -12
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +45 -35
  12. package/esm2015/core.js +12 -13
  13. package/esm2015/index.js +3 -4
  14. package/esm2015/public_api.js +3 -5
  15. package/esm2015/src/application_init.js +22 -10
  16. package/esm2015/src/application_module.js +6 -5
  17. package/esm2015/src/application_ref.js +94 -37
  18. package/esm2015/src/application_tokens.js +21 -16
  19. package/esm2015/src/change_detection/change_detection.js +8 -7
  20. package/esm2015/src/change_detection/change_detection_util.js +2 -4
  21. package/esm2015/src/change_detection/change_detector_ref.js +2 -3
  22. package/esm2015/src/change_detection/constants.js +30 -32
  23. package/esm2015/src/change_detection/differs/default_iterable_differ.js +108 -29
  24. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +53 -16
  25. package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
  26. package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
  27. package/esm2015/src/change_detection/pipe_transform.js +10 -5
  28. package/esm2015/src/change_detection.js +7 -3
  29. package/esm2015/src/codegen_private_exports.js +2 -3
  30. package/esm2015/src/console.js +3 -3
  31. package/esm2015/src/core.js +3 -4
  32. package/esm2015/src/core_private_export.js +2 -3
  33. package/esm2015/src/core_render3_private_export.js +13 -7
  34. package/esm2015/src/debug/debug_node.js +132 -90
  35. package/esm2015/src/di/defs.js +59 -50
  36. package/esm2015/src/di/forward_ref.js +5 -6
  37. package/esm2015/src/di/injectable.js +11 -11
  38. package/esm2015/src/di/injection_token.js +10 -6
  39. package/esm2015/src/di/injector.js +53 -43
  40. package/esm2015/src/di/injector_compatibility.js +13 -12
  41. package/esm2015/src/di/metadata.js +22 -13
  42. package/esm2015/src/di/provider.js +137 -120
  43. package/esm2015/src/di/r3_injector.js +127 -57
  44. package/esm2015/src/di/reflective_errors.js +19 -13
  45. package/esm2015/src/di/reflective_injector.js +20 -16
  46. package/esm2015/src/di/reflective_key.js +7 -5
  47. package/esm2015/src/di/reflective_provider.js +21 -20
  48. package/esm2015/src/di/scope.js +5 -5
  49. package/esm2015/src/di/util.js +13 -14
  50. package/esm2015/src/di.js +2 -3
  51. package/esm2015/src/error_handler.js +5 -4
  52. package/esm2015/src/errors.js +7 -8
  53. package/esm2015/src/event_emitter.js +3 -3
  54. package/esm2015/src/i18n/tokens.js +12 -10
  55. package/esm2015/src/is_dev_mode.js +2 -3
  56. package/esm2015/src/ivy_switch.js +2 -3
  57. package/esm2015/src/linker/compiler.js +9 -12
  58. package/esm2015/src/linker/component_factory.js +2 -3
  59. package/esm2015/src/linker/component_factory_resolver.js +24 -10
  60. package/esm2015/src/linker/element_ref.js +5 -3
  61. package/esm2015/src/linker/ng_module_factory.js +6 -5
  62. package/esm2015/src/linker/ng_module_factory_loader.js +63 -16
  63. package/esm2015/src/linker/query_list.js +16 -14
  64. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +12 -5
  65. package/esm2015/src/linker/template_ref.js +2 -3
  66. package/esm2015/src/linker/view_container_ref.js +2 -3
  67. package/esm2015/src/linker/view_ref.js +13 -7
  68. package/esm2015/src/linker.js +3 -3
  69. package/esm2015/src/metadata/di.js +22 -15
  70. package/esm2015/src/metadata/directives.js +33 -19
  71. package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
  72. package/esm2015/src/metadata/ng_module.js +82 -68
  73. package/esm2015/src/metadata/resource_loading.js +4 -3
  74. package/esm2015/src/metadata/view.js +25 -26
  75. package/esm2015/src/metadata.js +6 -3
  76. package/esm2015/src/platform_core_providers.js +5 -5
  77. package/esm2015/src/profile/profile.js +17 -13
  78. package/esm2015/src/profile/wtf_impl.js +36 -16
  79. package/esm2015/src/r3_symbols.js +18 -5
  80. package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
  81. package/esm2015/src/reflection/reflection.js +5 -5
  82. package/esm2015/src/reflection/reflection_capabilities.js +38 -27
  83. package/esm2015/src/reflection/reflector.js +2 -3
  84. package/esm2015/src/reflection/types.js +2 -12
  85. package/esm2015/src/render/api.js +67 -47
  86. package/esm2015/src/render.js +3 -3
  87. package/esm2015/src/render3/assert.js +38 -3
  88. package/esm2015/src/render3/bindings.js +111 -0
  89. package/esm2015/src/render3/component.js +88 -77
  90. package/esm2015/src/render3/component_ref.js +86 -56
  91. package/esm2015/src/render3/context_discovery.js +94 -92
  92. package/esm2015/src/render3/definition.js +58 -51
  93. package/esm2015/src/render3/di.js +206 -166
  94. package/esm2015/src/render3/di_setup.js +51 -31
  95. package/esm2015/src/render3/discovery_utils.js +225 -39
  96. package/esm2015/src/render3/empty.js +28 -0
  97. package/esm2015/src/render3/errors.js +11 -15
  98. package/esm2015/src/render3/features/inherit_definition_feature.js +13 -10
  99. package/esm2015/src/render3/features/ng_onchanges_feature.js +15 -12
  100. package/esm2015/src/render3/features/providers_feature.js +2 -3
  101. package/esm2015/src/render3/fields.js +5 -5
  102. package/esm2015/src/render3/global_utils.js +22 -7
  103. package/esm2015/src/render3/global_utils_api.js +13 -7
  104. package/esm2015/src/render3/hooks.js +21 -26
  105. package/esm2015/src/render3/i18n.js +134 -115
  106. package/esm2015/src/render3/index.js +15 -7
  107. package/esm2015/src/render3/instructions.js +938 -813
  108. package/esm2015/src/render3/interfaces/container.js +37 -6
  109. package/esm2015/src/render3/interfaces/context.js +39 -37
  110. package/esm2015/src/render3/interfaces/definition.js +225 -265
  111. package/esm2015/src/render3/interfaces/i18n.js +179 -151
  112. package/esm2015/src/render3/interfaces/injector.js +95 -13
  113. package/esm2015/src/render3/interfaces/node.js +413 -382
  114. package/esm2015/src/render3/interfaces/player.js +78 -37
  115. package/esm2015/src/render3/interfaces/projection.js +5 -10
  116. package/esm2015/src/render3/interfaces/query.js +66 -60
  117. package/esm2015/src/render3/interfaces/renderer.js +292 -117
  118. package/esm2015/src/render3/interfaces/sanitization.js +2 -6
  119. package/esm2015/src/render3/interfaces/styling.js +322 -111
  120. package/esm2015/src/render3/interfaces/view.js +356 -298
  121. package/esm2015/src/render3/jit/compiler_facade.js +10 -4
  122. package/esm2015/src/render3/jit/compiler_facade_interface.js +195 -152
  123. package/esm2015/src/render3/jit/directive.js +26 -16
  124. package/esm2015/src/render3/jit/environment.js +8 -5
  125. package/esm2015/src/render3/jit/injectable.js +7 -10
  126. package/esm2015/src/render3/jit/module.js +309 -25
  127. package/esm2015/src/render3/jit/pipe.js +2 -3
  128. package/esm2015/src/render3/jit/util.js +2 -3
  129. package/esm2015/src/render3/metadata.js +11 -10
  130. package/esm2015/src/render3/ng_dev_mode.js +5 -6
  131. package/esm2015/src/render3/ng_module_ref.js +48 -22
  132. package/esm2015/src/render3/node_assert.js +2 -3
  133. package/esm2015/src/render3/node_manipulation.js +137 -117
  134. package/esm2015/src/render3/node_selector_matcher.js +46 -19
  135. package/esm2015/src/render3/pipe.js +36 -21
  136. package/esm2015/src/render3/players.js +17 -12
  137. package/esm2015/src/render3/pure_function.js +86 -39
  138. package/esm2015/src/render3/query.js +93 -80
  139. package/esm2015/src/render3/state.js +88 -203
  140. package/esm2015/src/render3/styling/class_and_style_bindings.js +963 -249
  141. package/esm2015/src/render3/styling/core_player_handler.js +6 -4
  142. package/esm2015/src/render3/styling/player_factory.js +3 -4
  143. package/esm2015/src/render3/styling/util.js +69 -31
  144. package/esm2015/src/render3/tokens.js +7 -6
  145. package/esm2015/src/render3/util.js +65 -55
  146. package/esm2015/src/render3/view_engine_compatibility.js +36 -59
  147. package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
  148. package/esm2015/src/render3/view_ref.js +58 -44
  149. package/esm2015/src/sanitization/bypass.js +29 -6
  150. package/esm2015/src/sanitization/html_sanitizer.js +48 -16
  151. package/esm2015/src/sanitization/inert_body.js +33 -18
  152. package/esm2015/src/sanitization/sanitization.js +35 -25
  153. package/esm2015/src/sanitization/security.js +3 -4
  154. package/esm2015/src/sanitization/style_sanitizer.js +10 -7
  155. package/esm2015/src/sanitization/url_sanitizer.js +9 -7
  156. package/esm2015/src/testability/testability.js +72 -42
  157. package/esm2015/src/type.js +6 -8
  158. package/esm2015/src/util/decorators.js +19 -14
  159. package/esm2015/src/util/lang.js +2 -3
  160. package/esm2015/src/util/ng_reflect.js +2 -3
  161. package/esm2015/src/util/noop.js +2 -3
  162. package/esm2015/src/util/property.js +3 -4
  163. package/esm2015/src/util.js +12 -4
  164. package/esm2015/src/version.js +6 -6
  165. package/esm2015/src/view/element.js +17 -17
  166. package/esm2015/src/view/entrypoint.js +15 -5
  167. package/esm2015/src/view/errors.js +4 -5
  168. package/esm2015/src/view/index.js +2 -3
  169. package/esm2015/src/view/ng_content.js +3 -4
  170. package/esm2015/src/view/ng_module.js +2 -3
  171. package/esm2015/src/view/provider.js +89 -24
  172. package/esm2015/src/view/pure_expression.js +14 -15
  173. package/esm2015/src/view/query.js +14 -14
  174. package/esm2015/src/view/refs.js +96 -38
  175. package/esm2015/src/view/services.js +64 -37
  176. package/esm2015/src/view/text.js +5 -6
  177. package/esm2015/src/view/types.js +390 -325
  178. package/esm2015/src/view/util.js +29 -24
  179. package/esm2015/src/view/view.js +43 -36
  180. package/esm2015/src/view/view_attach.js +9 -10
  181. package/esm2015/src/zone/ng_zone.js +29 -28
  182. package/esm2015/src/zone.js +3 -3
  183. package/esm2015/testing/index.js +2 -3
  184. package/esm2015/testing/public_api.js +4 -4
  185. package/esm2015/testing/src/async.js +2 -3
  186. package/esm2015/testing/src/async_fallback.js +8 -7
  187. package/esm2015/testing/src/async_test_completer.js +14 -6
  188. package/esm2015/testing/src/before_each.js +10 -4
  189. package/esm2015/testing/src/component_fixture.js +48 -17
  190. package/esm2015/testing/src/fake_async.js +9 -3
  191. package/esm2015/testing/src/fake_async_fallback.js +5 -5
  192. package/esm2015/testing/src/lang_utils.js +3 -4
  193. package/esm2015/testing/src/logger.js +2 -3
  194. package/esm2015/testing/src/metadata_override.js +2 -6
  195. package/esm2015/testing/src/metadata_overrider.js +9 -8
  196. package/esm2015/testing/src/ng_zone_mock.js +2 -3
  197. package/esm2015/testing/src/private_export_testing.js +2 -3
  198. package/esm2015/testing/src/r3_test_bed.js +324 -174
  199. package/esm2015/testing/src/resolvers.js +28 -11
  200. package/esm2015/testing/src/test_bed.js +123 -54
  201. package/esm2015/testing/src/test_bed_common.js +142 -85
  202. package/esm2015/testing/src/test_compiler.js +2 -3
  203. package/esm2015/testing/src/testing.js +3 -3
  204. package/esm2015/testing/src/testing_internal.js +17 -12
  205. package/esm2015/testing/testing.js +1 -2
  206. package/esm5/core.js +12 -13
  207. package/esm5/index.js +1 -2
  208. package/esm5/public_api.js +1 -2
  209. package/esm5/src/application_init.js +1 -2
  210. package/esm5/src/application_module.js +1 -2
  211. package/esm5/src/application_ref.js +1 -2
  212. package/esm5/src/application_tokens.js +1 -2
  213. package/esm5/src/change_detection/change_detection.js +1 -2
  214. package/esm5/src/change_detection/change_detection_util.js +1 -2
  215. package/esm5/src/change_detection/change_detector_ref.js +1 -2
  216. package/esm5/src/change_detection/constants.js +3 -4
  217. package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -2
  218. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -2
  219. package/esm5/src/change_detection/differs/iterable_differs.js +1 -2
  220. package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -2
  221. package/esm5/src/change_detection/pipe_transform.js +1 -2
  222. package/esm5/src/change_detection.js +1 -2
  223. package/esm5/src/codegen_private_exports.js +1 -2
  224. package/esm5/src/console.js +1 -2
  225. package/esm5/src/core.js +1 -2
  226. package/esm5/src/core_private_export.js +1 -2
  227. package/esm5/src/core_render3_private_export.js +7 -5
  228. package/esm5/src/debug/debug_node.js +79 -58
  229. package/esm5/src/di/defs.js +3 -4
  230. package/esm5/src/di/forward_ref.js +1 -2
  231. package/esm5/src/di/injectable.js +1 -2
  232. package/esm5/src/di/injection_token.js +1 -2
  233. package/esm5/src/di/injector.js +1 -2
  234. package/esm5/src/di/injector_compatibility.js +1 -2
  235. package/esm5/src/di/metadata.js +1 -2
  236. package/esm5/src/di/provider.js +1 -2
  237. package/esm5/src/di/r3_injector.js +48 -28
  238. package/esm5/src/di/reflective_errors.js +1 -2
  239. package/esm5/src/di/reflective_injector.js +1 -2
  240. package/esm5/src/di/reflective_key.js +1 -2
  241. package/esm5/src/di/reflective_provider.js +1 -2
  242. package/esm5/src/di/scope.js +1 -2
  243. package/esm5/src/di/util.js +1 -2
  244. package/esm5/src/di.js +1 -2
  245. package/esm5/src/error_handler.js +1 -2
  246. package/esm5/src/errors.js +1 -2
  247. package/esm5/src/event_emitter.js +1 -2
  248. package/esm5/src/i18n/tokens.js +1 -2
  249. package/esm5/src/is_dev_mode.js +1 -2
  250. package/esm5/src/ivy_switch.js +1 -2
  251. package/esm5/src/linker/compiler.js +1 -2
  252. package/esm5/src/linker/component_factory.js +1 -2
  253. package/esm5/src/linker/component_factory_resolver.js +1 -2
  254. package/esm5/src/linker/element_ref.js +1 -2
  255. package/esm5/src/linker/ng_module_factory.js +1 -2
  256. package/esm5/src/linker/ng_module_factory_loader.js +37 -13
  257. package/esm5/src/linker/query_list.js +1 -2
  258. package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -2
  259. package/esm5/src/linker/template_ref.js +1 -2
  260. package/esm5/src/linker/view_container_ref.js +1 -2
  261. package/esm5/src/linker/view_ref.js +1 -2
  262. package/esm5/src/linker.js +1 -2
  263. package/esm5/src/metadata/di.js +1 -2
  264. package/esm5/src/metadata/directives.js +1 -2
  265. package/esm5/src/metadata/lifecycle_hooks.js +1 -2
  266. package/esm5/src/metadata/ng_module.js +1 -2
  267. package/esm5/src/metadata/resource_loading.js +1 -2
  268. package/esm5/src/metadata/view.js +1 -2
  269. package/esm5/src/metadata.js +1 -2
  270. package/esm5/src/platform_core_providers.js +1 -2
  271. package/esm5/src/profile/profile.js +1 -2
  272. package/esm5/src/profile/wtf_impl.js +1 -2
  273. package/esm5/src/r3_symbols.js +1 -2
  274. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -2
  275. package/esm5/src/reflection/reflection.js +1 -2
  276. package/esm5/src/reflection/reflection_capabilities.js +1 -2
  277. package/esm5/src/reflection/reflector.js +1 -2
  278. package/esm5/src/reflection/types.js +1 -2
  279. package/esm5/src/render/api.js +1 -2
  280. package/esm5/src/render.js +1 -2
  281. package/esm5/src/render3/assert.js +15 -2
  282. package/esm5/src/render3/bindings.js +63 -0
  283. package/esm5/src/render3/component.js +23 -16
  284. package/esm5/src/render3/component_ref.js +43 -36
  285. package/esm5/src/render3/context_discovery.js +68 -77
  286. package/esm5/src/render3/definition.js +30 -24
  287. package/esm5/src/render3/di.js +142 -135
  288. package/esm5/src/render3/di_setup.js +20 -21
  289. package/esm5/src/render3/discovery_utils.js +167 -36
  290. package/esm5/src/render3/empty.js +22 -0
  291. package/esm5/src/render3/errors.js +9 -12
  292. package/esm5/src/render3/features/inherit_definition_feature.js +3 -5
  293. package/esm5/src/render3/features/ng_onchanges_feature.js +11 -10
  294. package/esm5/src/render3/features/providers_feature.js +1 -2
  295. package/esm5/src/render3/fields.js +1 -2
  296. package/esm5/src/render3/global_utils.js +4 -3
  297. package/esm5/src/render3/global_utils_api.js +2 -3
  298. package/esm5/src/render3/hooks.js +14 -16
  299. package/esm5/src/render3/i18n.js +22 -27
  300. package/esm5/src/render3/index.js +5 -6
  301. package/esm5/src/render3/instructions.js +698 -593
  302. package/esm5/src/render3/interfaces/container.js +10 -3
  303. package/esm5/src/render3/interfaces/context.js +1 -2
  304. package/esm5/src/render3/interfaces/definition.js +1 -2
  305. package/esm5/src/render3/interfaces/i18n.js +1 -2
  306. package/esm5/src/render3/interfaces/injector.js +5 -6
  307. package/esm5/src/render3/interfaces/node.js +1 -2
  308. package/esm5/src/render3/interfaces/player.js +1 -2
  309. package/esm5/src/render3/interfaces/projection.js +1 -2
  310. package/esm5/src/render3/interfaces/query.js +1 -2
  311. package/esm5/src/render3/interfaces/renderer.js +1 -2
  312. package/esm5/src/render3/interfaces/sanitization.js +1 -2
  313. package/esm5/src/render3/interfaces/styling.js +1 -2
  314. package/esm5/src/render3/interfaces/view.js +3 -4
  315. package/esm5/src/render3/jit/compiler_facade.js +1 -2
  316. package/esm5/src/render3/jit/compiler_facade_interface.js +1 -2
  317. package/esm5/src/render3/jit/directive.js +19 -10
  318. package/esm5/src/render3/jit/environment.js +4 -2
  319. package/esm5/src/render3/jit/injectable.js +17 -18
  320. package/esm5/src/render3/jit/module.js +207 -13
  321. package/esm5/src/render3/jit/pipe.js +1 -2
  322. package/esm5/src/render3/jit/util.js +1 -2
  323. package/esm5/src/render3/metadata.js +1 -2
  324. package/esm5/src/render3/ng_dev_mode.js +1 -2
  325. package/esm5/src/render3/ng_module_ref.js +29 -11
  326. package/esm5/src/render3/node_assert.js +1 -2
  327. package/esm5/src/render3/node_manipulation.js +54 -50
  328. package/esm5/src/render3/node_selector_matcher.js +28 -9
  329. package/esm5/src/render3/pipe.js +33 -19
  330. package/esm5/src/render3/players.js +7 -9
  331. package/esm5/src/render3/pure_function.js +48 -38
  332. package/esm5/src/render3/query.js +8 -9
  333. package/esm5/src/render3/state.js +50 -135
  334. package/esm5/src/render3/styling/class_and_style_bindings.js +684 -214
  335. package/esm5/src/render3/styling/core_player_handler.js +1 -2
  336. package/esm5/src/render3/styling/player_factory.js +1 -2
  337. package/esm5/src/render3/styling/util.js +39 -22
  338. package/esm5/src/render3/tokens.js +1 -2
  339. package/esm5/src/render3/util.js +49 -37
  340. package/esm5/src/render3/view_engine_compatibility.js +20 -33
  341. package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -2
  342. package/esm5/src/render3/view_ref.js +33 -30
  343. package/esm5/src/sanitization/bypass.js +1 -2
  344. package/esm5/src/sanitization/html_sanitizer.js +1 -2
  345. package/esm5/src/sanitization/inert_body.js +4 -5
  346. package/esm5/src/sanitization/sanitization.js +25 -20
  347. package/esm5/src/sanitization/security.js +1 -2
  348. package/esm5/src/sanitization/style_sanitizer.js +1 -2
  349. package/esm5/src/sanitization/url_sanitizer.js +1 -2
  350. package/esm5/src/testability/testability.js +1 -2
  351. package/esm5/src/type.js +1 -2
  352. package/esm5/src/util/decorators.js +1 -2
  353. package/esm5/src/util/lang.js +1 -2
  354. package/esm5/src/util/ng_reflect.js +1 -2
  355. package/esm5/src/util/noop.js +1 -2
  356. package/esm5/src/util/property.js +1 -2
  357. package/esm5/src/util.js +1 -2
  358. package/esm5/src/version.js +2 -3
  359. package/esm5/src/view/element.js +1 -2
  360. package/esm5/src/view/entrypoint.js +1 -2
  361. package/esm5/src/view/errors.js +1 -2
  362. package/esm5/src/view/index.js +1 -2
  363. package/esm5/src/view/ng_content.js +1 -2
  364. package/esm5/src/view/ng_module.js +1 -2
  365. package/esm5/src/view/provider.js +1 -2
  366. package/esm5/src/view/pure_expression.js +1 -2
  367. package/esm5/src/view/query.js +1 -2
  368. package/esm5/src/view/refs.js +1 -2
  369. package/esm5/src/view/services.js +1 -2
  370. package/esm5/src/view/text.js +1 -2
  371. package/esm5/src/view/types.js +1 -2
  372. package/esm5/src/view/util.js +1 -2
  373. package/esm5/src/view/view.js +1 -2
  374. package/esm5/src/view/view_attach.js +1 -2
  375. package/esm5/src/zone/ng_zone.js +1 -2
  376. package/esm5/src/zone.js +1 -2
  377. package/esm5/testing/index.js +1 -2
  378. package/esm5/testing/public_api.js +1 -2
  379. package/esm5/testing/src/async.js +1 -2
  380. package/esm5/testing/src/async_fallback.js +1 -2
  381. package/esm5/testing/src/async_test_completer.js +1 -2
  382. package/esm5/testing/src/before_each.js +1 -2
  383. package/esm5/testing/src/component_fixture.js +1 -2
  384. package/esm5/testing/src/fake_async.js +1 -2
  385. package/esm5/testing/src/fake_async_fallback.js +1 -2
  386. package/esm5/testing/src/lang_utils.js +1 -2
  387. package/esm5/testing/src/logger.js +1 -2
  388. package/esm5/testing/src/metadata_override.js +1 -2
  389. package/esm5/testing/src/metadata_overrider.js +1 -2
  390. package/esm5/testing/src/ng_zone_mock.js +1 -2
  391. package/esm5/testing/src/private_export_testing.js +1 -2
  392. package/esm5/testing/src/r3_test_bed.js +182 -121
  393. package/esm5/testing/src/resolvers.js +11 -7
  394. package/esm5/testing/src/test_bed.js +1 -2
  395. package/esm5/testing/src/test_bed_common.js +1 -2
  396. package/esm5/testing/src/test_compiler.js +1 -2
  397. package/esm5/testing/src/testing.js +1 -2
  398. package/esm5/testing/src/testing_internal.js +2 -3
  399. package/esm5/testing/testing.js +1 -2
  400. package/fesm2015/core.js +8560 -6153
  401. package/fesm2015/core.js.map +1 -1
  402. package/fesm2015/testing.js +351 -229
  403. package/fesm2015/testing.js.map +1 -1
  404. package/fesm5/core.js +5541 -4482
  405. package/fesm5/core.js.map +1 -1
  406. package/fesm5/testing.js +185 -130
  407. package/fesm5/testing.js.map +1 -1
  408. package/package.json +1 -1
  409. package/src/change_detection/constants.d.ts +2 -2
  410. package/src/core_render3_private_export.d.ts +6 -3
  411. package/src/di/injectable.d.ts +3 -2
  412. package/src/di/r3_injector.d.ts +1 -1
  413. package/src/linker/ng_module_factory_loader.d.ts +5 -1
  414. package/src/render3/assert.d.ts +6 -0
  415. package/src/render3/bindings.d.ts +20 -0
  416. package/src/render3/component.d.ts +3 -3
  417. package/src/render3/component_ref.d.ts +14 -4
  418. package/src/render3/context_discovery.d.ts +9 -9
  419. package/src/render3/definition.d.ts +8 -23
  420. package/src/render3/di.d.ts +19 -17
  421. package/src/render3/discovery_utils.d.ts +66 -8
  422. package/src/render3/empty.d.ts +16 -0
  423. package/src/render3/errors.d.ts +1 -1
  424. package/src/render3/global_utils_api.d.ts +1 -1
  425. package/src/render3/hooks.d.ts +7 -6
  426. package/src/render3/index.d.ts +4 -4
  427. package/src/render3/instructions.d.ts +163 -118
  428. package/src/render3/interfaces/container.d.ts +9 -8
  429. package/src/render3/interfaces/context.d.ts +3 -3
  430. package/src/render3/interfaces/definition.d.ts +2 -12
  431. package/src/render3/interfaces/i18n.d.ts +25 -25
  432. package/src/render3/interfaces/injector.d.ts +8 -9
  433. package/src/render3/interfaces/node.d.ts +56 -23
  434. package/src/render3/interfaces/renderer.d.ts +2 -1
  435. package/src/render3/interfaces/styling.d.ts +392 -117
  436. package/src/render3/interfaces/view.d.ts +49 -35
  437. package/src/render3/jit/compiler_facade_interface.d.ts +10 -3
  438. package/src/render3/jit/module.d.ts +9 -1
  439. package/src/render3/metadata.d.ts +1 -1
  440. package/src/render3/ng_module_ref.d.ts +8 -6
  441. package/src/render3/node_manipulation.d.ts +21 -27
  442. package/src/render3/node_selector_matcher.d.ts +2 -2
  443. package/src/render3/state.d.ts +11 -38
  444. package/src/render3/styling/class_and_style_bindings.d.ts +130 -43
  445. package/src/render3/styling/util.d.ts +9 -4
  446. package/src/render3/util.d.ts +31 -25
  447. package/src/render3/view_engine_compatibility.d.ts +5 -12
  448. package/src/render3/view_engine_compatibility_prebound.d.ts +2 -2
  449. package/src/render3/view_ref.d.ts +2 -2
  450. package/src/sanitization/sanitization.d.ts +3 -2
  451. package/testing/src/r3_test_bed.d.ts +15 -0
  452. package/testing/src/resolvers.d.ts +2 -2
  453. package/testing/testing.metadata.json +1 -1
  454. package/testing.d.ts +5 -0
@@ -1,126 +1,331 @@
1
1
  /**
2
2
  * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
3
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
5
  /**
6
6
  * The styling context acts as a styling manifest (shaped as an array) for determining which
7
7
  * styling properties have been assigned via the provided `updateStylingMap`, `updateStyleProp`
8
- * and `updateClassProp` functions. There are also two initialization functions
9
- * `allocStylingContext` and `createStylingContextTemplate` which are used to initialize
10
- * and/or clone the context.
8
+ * and `updateClassProp` functions. It also stores the static style/class values that were
9
+ * extracted from the template by the compiler.
11
10
  *
12
- * The context is an array where the first two cells are used for static data (initial styling)
13
- * and dirty flags / index offsets). The remaining set of cells is used for multi (map) and single
14
- * (prop) style values.
11
+ * A context is created by Angular when:
12
+ * 1. An element contains static styling values (like style="..." or class="...")
13
+ * 2. An element contains single property binding values (like [style.prop]="x" or
14
+ * [class.prop]="y")
15
+ * 3. An element contains multi property binding values (like [style]="x" or [class]="y")
16
+ * 4. A directive contains host bindings for static, single or multi styling properties/bindings.
17
+ * 5. An animation player is added to an element via `addPlayer`
15
18
  *
16
- * each value from here onwards is mapped as so:
17
- * [i] = mutation/type flag for the style/class value
18
- * [i + 1] = prop string (or null incase it has been removed)
19
- * [i + 2] = value string (or null incase it has been removed)
19
+ * Note that even if an element contains static styling then this context will be created and
20
+ * attached to it. The reason why this happens (instead of treating styles/classes as regular
21
+ * HTML attributes) is because the style/class bindings must be able to default themselves back
22
+ * to their respective static values when they are set to null.
20
23
  *
21
- * There are three types of styling types stored in this context:
22
- * initial: any styles that are passed in once the context is created
23
- * (these are stored in the first cell of the array and the first
24
- * value of this array is always `null` even if no initial styling exists.
25
- * the `null` value is there so that any new styles have a parent to point
26
- * to. This way we can always assume that there is a parent.)
24
+ * Say for example we have this:
25
+ * ```
26
+ * <!-- when myWidthExp=null then a width of "100px"
27
+ * will be used a default value for width -->
28
+ * <div style="width:100px" [style.width]="myWidthExp"></div>
29
+ * ```
30
+ *
31
+ * Even in the situation where there are no bindings, the static styling is still placed into the
32
+ * context because there may be another directive on the same element that has styling.
27
33
  *
28
- * single: any styles that are updated using `updateStyleProp` or `updateClassProp` (fixed set)
34
+ * When Angular initializes styling data for an element then it will first register the static
35
+ * styling values on the element using one of these two instructions:
29
36
  *
30
- * multi: any styles that are updated using `updateStylingMap` (dynamic set)
37
+ * 1. elementStart or element (within the template function of a component)
38
+ * 2. elementHostAttrs (for directive host bindings)
31
39
  *
32
- * Note that context is only used to collect style information. Only when `renderStyling`
33
- * is called is when the styling payload will be rendered (or built as a key/value map).
40
+ * In either case, a styling context will be created and stored within an element's LViewData. Once
41
+ * the styling context is created then single and multi properties can stored within it. For this to
42
+ * happen, the following function needs to be called:
34
43
  *
35
- * When the context is created, depending on what initial styling values are passed in, the
36
- * context itself will be pre-filled with slots based on the initial style properties. Say
37
- * for example we have a series of initial styles that look like so:
44
+ * `elementStyling` (called with style properties, class properties and a sanitizer + a directive
45
+ * instance).
38
46
  *
39
- * style="width:100px; height:200px;"
40
- * class="foo"
47
+ * When this instruction is called it will populate the styling context with the provided style
48
+ * and class names into the context.
41
49
  *
42
- * Then the initial state of the context (once initialized) will look like so:
50
+ * The context itself looks like this:
51
+ *
52
+ * context = [
53
+ * // 0-8: header values (about 8 entries of configuration data)
54
+ * // 9+: this is where each entry is stored:
55
+ * ]
56
+ *
57
+ * Let's say we have the following template code:
43
58
  *
44
59
  * ```
60
+ * <div class="foo bar"
61
+ * style="width:200px; color:red"
62
+ * [style.width]="myWidthExp"
63
+ * [style.height]="myHeightExp"
64
+ * [class.baz]="myBazExp">
65
+ * ```
66
+ *
67
+ * The context generated from these values will look like this (note that
68
+ * for each binding name (the class and style bindings) the values will
69
+ * be inserted twice into the array (once for single property entries) and
70
+ * another for multi property entries).
71
+ *
45
72
  * context = [
46
- * element,
47
- * playerContext | null,
48
- * styleSanitizer | null,
49
- * [null, '100px', '200px', true], // property names are not needed since they have already been
50
- * written to DOM.
51
- *
52
- * configMasterVal,
53
- * 1, // this instructs how many `style` values there are so that class index values can be
54
- * offsetted
55
- * { classOne: true, classTwo: false } | 'classOne classTwo' | null // last class value provided
56
- * into updateStylingMap
57
- * { styleOne: '100px', styleTwo: 0 } | null // last style value provided into updateStylingMap
58
- *
59
- * // 8
60
- * 'width',
61
- * pointers(1, 15); // Point to static `width`: `100px` and multi `width`.
62
- * null,
63
- *
64
- * // 11
65
- * 'height',
66
- * pointers(2, 18); // Point to static `height`: `200px` and multi `height`.
67
- * null,
68
- *
69
- * // 14
70
- * 'foo',
71
- * pointers(1, 21); // Point to static `foo`: `true` and multi `foo`.
72
- * null,
73
- *
74
- * // 17
75
- * 'width',
76
- * pointers(1, 6); // Point to static `width`: `100px` and single `width`.
77
- * null,
78
- *
79
- * // 21
80
- * 'height',
81
- * pointers(2, 9); // Point to static `height`: `200px` and single `height`.
82
- * null,
83
- *
84
- * // 24
85
- * 'foo',
86
- * pointers(3, 12); // Point to static `foo`: `true` and single `foo`.
87
- * null,
73
+ * // 0-8: header values (about 8 entries of configuration data)
74
+ * // 9+: this is where each entry is stored:
75
+ *
76
+ * // SINGLE PROPERTIES
77
+ * configForWidth,
78
+ * 'width'
79
+ * myWidthExp, // the binding value not the binding itself
80
+ * 0, // the directive owner
81
+ *
82
+ * configForHeight,
83
+ * 'height'
84
+ * myHeightExp, // the binding value not the binding itself
85
+ * 0, // the directive owner
86
+ *
87
+ * configForBazClass,
88
+ * 'baz
89
+ * myBazClassExp, // the binding value not the binding itself
90
+ * 0, // the directive owner
91
+ *
92
+ * // MULTI PROPERTIES
93
+ * configForWidth,
94
+ * 'width'
95
+ * myWidthExp, // the binding value not the binding itself
96
+ * 0, // the directive owner
97
+ *
98
+ * configForHeight,
99
+ * 'height'
100
+ * myHeightExp, // the binding value not the binding itself
101
+ * 0, // the directive owner
102
+ *
103
+ * configForBazClass,
104
+ * 'baz
105
+ * myBazClassExp, // the binding value not the binding itself
106
+ * 0, // the directive owner
88
107
  * ]
89
108
  *
90
- * function pointers(staticIndex: number, dynamicIndex: number) {
91
- * // combine the two indices into a single word.
92
- * return (staticIndex << StylingFlags.BitCountSize) |
93
- * (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));
109
+ * The configuration values are left out of the example above because
110
+ * the ordering of them could change between code patches. Please read the
111
+ * documentation below to get a better understand of what the configuration
112
+ * values are and how they work.
113
+ *
114
+ * Each time a binding property is updated (whether it be through a single
115
+ * property instruction like `elementStyleProp`, `elementClassProp` or
116
+ * `elementStylingMap`) then the values in the context will be updated as
117
+ * well.
118
+ *
119
+ * If for example `[style.width]` updates to `555px` then its value will be reflected
120
+ * in the context as so:
121
+ *
122
+ * context = [
123
+ * // ...
124
+ * configForWidth, // this will be marked DIRTY
125
+ * 'width'
126
+ * '555px',
127
+ * 0,
128
+ * //..
129
+ * ]
130
+ *
131
+ * The context and directive data will also be marked dirty.
132
+ *
133
+ * Despite the context being updated, nothing has been rendered on screen (not styles or
134
+ * classes have been set on the element). To kick off rendering for an element the following
135
+ * function needs to be run `elementStylingApply`.
136
+ *
137
+ * `elementStylingApply` will run through the context and find each dirty value and render them onto
138
+ * the element. Once complete, all styles/classes will be set to clean. Because of this, the render
139
+ * function will now know not to rerun itself again if called again unless new style/class values
140
+ * have changed.
141
+ *
142
+ * ## Directives
143
+ * Directives style values (which are provided through host bindings) are also supported and
144
+ * housed within the same styling context as are template-level style/class properties/bindings.
145
+ * Both directive-level and template-level styling bindings share the same context.
146
+ *
147
+ * Each of the following instructions supports accepting a directive instance as an input parameter:
148
+ *
149
+ * - `elementHostAttrs`
150
+ * - `elementStyling`
151
+ * - `elementStyleProp`
152
+ * - `elementClassProp`
153
+ * - `elementStylingMap`
154
+ * - `elementStylingApply`
155
+ *
156
+ * Each time a directiveRef is passed in, it will be converted into an index by examining the
157
+ * directive registry (which lives in the context configuration area). The index is then used
158
+ * to help single style properties figure out where a value is located in the context.
159
+ *
160
+ * If two directives or a directive + a template binding both write to the same style/class
161
+ * binding then the styling context code will decide which one wins based on the following
162
+ * rule:
163
+ *
164
+ * 1. If the template binding has a value then it always wins
165
+ * 2. If not then whichever first-registered directive that has that value first will win
166
+ *
167
+ * The code example helps make this clear:
168
+ *
169
+ * ```
170
+ * <div [style.width]="myWidth" [my-width-directive]="'600px">
171
+ * \@Directive({ selector: '[my-width-directive' ]})
172
+ * class MyWidthDirective {
173
+ * \@Input('my-width-directive')
174
+ * \@HostBinding('style.width')
175
+ * public width = null;
94
176
  * }
95
177
  * ```
96
178
  *
97
- * The values are duplicated so that space is set aside for both multi ([style] and [class])
98
- * and single ([style.prop] or [class.named]) values. The respective config values
99
- * (configValA, configValB, etc...) are a combination of the StylingFlags with two index
100
- * values: the `initialIndex` (which points to the index location of the style value in
101
- * the initial styles array in slot 0) and the `dynamicIndex` (which points to the
102
- * matching single/multi index position in the context array for the same prop).
103
- *
104
- * This means that every time `updateStyleProp` or `updateClassProp` are called then they
105
- * must be called using an index value (not a property string) which references the index
106
- * value of the initial style prop/class when the context was created. This also means that
107
- * `updateStyleProp` or `updateClassProp` cannot be called with a new property (only
108
- * `updateStylingMap` can include new CSS properties that will be added to the context).
179
+ * Since there is a style binding for width present on the element (`[style.width]`) then
180
+ * it will always win over the width binding that is present as a host binding within
181
+ * the `MyWidthDirective`. However, if `[style.width]` renders as `null` (so `myWidth=null`)
182
+ * then the `MyWidthDirective` will be able to write to the `width` style within the context.
183
+ * Simply put, whichever directive writes to a value ends up having ownership of it.
184
+ *
185
+ * The way in which the ownership is facilitated is through index value. The earliest directives
186
+ * get the smallest index values (with 0 being reserved for the template element bindings). Each
187
+ * time a value is written from a directive or the template bindings, the value itself gets
188
+ * assigned the directive index value in its data. If another directive writes a value again then
189
+ * its directive index gets compared against the directive index that exists on the element. Only
190
+ * when the new value's directive index is less than the existing directive index then the new
191
+ * value will be written to the context.
192
+ *
193
+ * Each directive also has its own sanitizer and dirty flags. These values are consumed within the
194
+ * rendering function.
109
195
  * @record
110
196
  */
111
197
  export function StylingContext() { }
198
+ if (false) {
199
+ /* Skipping unnamed member:
200
+ [StylingIndex.MasterFlagPosition]: number;*/
201
+ /* Skipping unnamed member:
202
+ [StylingIndex.DirectiveRegistryPosition]: DirectiveRegistryValues;*/
203
+ /* Skipping unnamed member:
204
+ [StylingIndex.InitialStyleValuesPosition]: InitialStylingValues;*/
205
+ /* Skipping unnamed member:
206
+ [StylingIndex.InitialClassValuesPosition]: InitialStylingValues;*/
207
+ /* Skipping unnamed member:
208
+ [StylingIndex.SinglePropOffsetPositions]: SinglePropOffsetValues;*/
209
+ /* Skipping unnamed member:
210
+ [StylingIndex.ElementPosition]: RElement|null;*/
211
+ /* Skipping unnamed member:
212
+ [StylingIndex.CachedClassValueOrInitialClassString]: {[key: string]: any}|string|(string)[]|null;*/
213
+ /* Skipping unnamed member:
214
+ [StylingIndex.CachedStyleValue]: {[key: string]: any}|(string)[]|null;*/
215
+ /* Skipping unnamed member:
216
+ [StylingIndex.PlayerContext]: PlayerContext|null;*/
217
+ }
218
+ /**
219
+ * Used as a styling array to house static class and style values that were extracted
220
+ * by the compiler and placed in the animation context via `elementStart` and
221
+ * `elementHostAttrs`.
222
+ *
223
+ * See [InitialStylingValuesIndex] for a breakdown of how all this works.
224
+ * @record
225
+ */
226
+ export function InitialStylingValues() { }
227
+ if (false) {
228
+ /* Skipping unnamed member:
229
+ [0]: null;*/
230
+ }
231
+ /** @enum {number} */
232
+ const InitialStylingValuesIndex = {
233
+ KeyValueStartPosition: 1,
234
+ PropOffset: 0,
235
+ ValueOffset: 1,
236
+ Size: 2,
237
+ };
238
+ export { InitialStylingValuesIndex };
239
+ /**
240
+ * An array located in the StylingContext that houses all directive instances and additional
241
+ * data about them.
242
+ *
243
+ * Each entry in this array represents a source of where style/class binding values could
244
+ * come from. By default, there is always at least one directive here with a null value and
245
+ * that represents bindings that live directly on an element (not host bindings).
246
+ *
247
+ * Each successive entry in the array is an actual instance of an array as well as some
248
+ * additional info.
249
+ *
250
+ * An entry within this array has the following values:
251
+ * [0] = The instance of the directive (or null when it is not a directive, but a template binding
252
+ * source)
253
+ * [1] = The pointer that tells where the single styling (stuff like [class.foo] and [style.prop])
254
+ * offset values are located. This value will allow for a binding instruction to find exactly
255
+ * where a style is located.
256
+ * [2] = Whether or not the directive has any styling values that are dirty. This is used as
257
+ * reference within the renderClassAndStyleBindings function to decide whether to skip
258
+ * iterating through the context when rendering is executed.
259
+ * [3] = The styleSanitizer instance that is assigned to the directive. Although it's unlikely,
260
+ * a directive could introduce its own special style sanitizer and for this reach each
261
+ * directive will get its own space for it (if null then the very first sanitizer is used).
262
+ *
263
+ * Each time a new directive is added it will insert these four values at the end of the array.
264
+ * When this array is examined (using indexOf) then the resulting directiveIndex will be resolved
265
+ * by dividing the index value by the size of the array entries (so if DirA is at spot 8 then its
266
+ * index will be 2).
267
+ * @record
268
+ */
269
+ export function DirectiveRegistryValues() { }
270
+ if (false) {
271
+ /* Skipping unnamed member:
272
+ [DirectiveRegistryValuesIndex.DirectiveValueOffset]: null;*/
273
+ /* Skipping unnamed member:
274
+ [DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset]: number;*/
275
+ /* Skipping unnamed member:
276
+ [DirectiveRegistryValuesIndex.DirtyFlagOffset]: boolean;*/
277
+ /* Skipping unnamed member:
278
+ [DirectiveRegistryValuesIndex.StyleSanitizerOffset]: StyleSanitizeFn|null;*/
279
+ }
280
+ /** @enum {number} */
281
+ const DirectiveRegistryValuesIndex = {
282
+ DirectiveValueOffset: 0,
283
+ SinglePropValuesIndexOffset: 1,
284
+ DirtyFlagOffset: 2,
285
+ StyleSanitizerOffset: 3,
286
+ Size: 4,
287
+ };
288
+ export { DirectiveRegistryValuesIndex };
112
289
  /**
113
- * The initial styles is populated whether or not there are any initial styles passed into
114
- * the context during allocation. The 0th value must be null so that index values of `0` within
115
- * the context flags can always point to a null value safely when nothing is set.
290
+ * An array that contains the index pointer values for every single styling property
291
+ * that exists in the context and for every directive. It also contains the total
292
+ * single styles and single classes that exists in the context as the first two values.
293
+ *
294
+ * Let's say we have the following template code:
295
+ *
296
+ * <div [style.width]="myWidth"
297
+ * [style.height]="myHeight"
298
+ * [class.flipped]="flipClass"
299
+ * directive-with-opacity>
300
+ * directive-with-foo-bar-classes>
116
301
  *
117
- * All other entries in this array are of `string` value and correspond to the values that
118
- * were extracted from the `style=""` attribute in the HTML code for the provided template.
302
+ * We have two directive and template-binding sources,
303
+ * 2 + 1 styles and 1 + 1 classes. When the bindings are
304
+ * registered the SinglePropOffsets array will look like so:
305
+ *
306
+ * s_0/c_0 = template directive value
307
+ * s_1/c_1 = directive one (directive-with-opacity)
308
+ * s_2/c_2 = directive two (directive-with-foo-bar-classes)
309
+ *
310
+ * [3, 2, 2, 1, s_00, s01, c_01, 1, 0, s_10, 0, 1, c_20
119
311
  * @record
120
312
  */
121
- export function InitialStyles() { }
313
+ export function SinglePropOffsetValues() { }
314
+ if (false) {
315
+ /* Skipping unnamed member:
316
+ [SinglePropOffsetValuesIndex.StylesCountPosition]: number;*/
317
+ /* Skipping unnamed member:
318
+ [SinglePropOffsetValuesIndex.ClassesCountPosition]: number;*/
319
+ }
320
+ /** @enum {number} */
321
+ const SinglePropOffsetValuesIndex = {
322
+ StylesCountPosition: 0,
323
+ ClassesCountPosition: 1,
324
+ ValueStartPosition: 2,
325
+ };
326
+ export { SinglePropOffsetValuesIndex };
122
327
  /** @enum {number} */
123
- var StylingFlags = {
328
+ const StylingFlags = {
124
329
  // Implies no configurations
125
330
  None: 0,
126
331
  // Whether or not the entry or context itself is dirty
@@ -135,34 +340,36 @@ var StylingFlags = {
135
340
  // initial classes
136
341
  OnlyProcessSingleClasses: 16,
137
342
  // The max amount of bits used to represent these configuration values
138
- BitCountSize: 5,
139
- // There are only five bits here
140
- BitMask: 31,
343
+ BindingAllocationLocked: 32,
344
+ BitCountSize: 6,
345
+ // There are only six bits here
346
+ BitMask: 63,
141
347
  };
142
348
  export { StylingFlags };
143
349
  /** @enum {number} */
144
- var StylingIndex = {
145
- // Position of where the initial styles are stored in the styling context
146
- PlayerContext: 0,
147
- // Position of where the style sanitizer is stored within the styling context
148
- StyleSanitizerPosition: 1,
149
- // Position of where the initial styles are stored in the styling context
150
- InitialStylesPosition: 2,
350
+ const StylingIndex = {
151
351
  // Index of location where the start of single properties are stored. (`updateStyleProp`)
152
- MasterFlagPosition: 3,
352
+ MasterFlagPosition: 0,
353
+ // Position of where the registered directives exist for this styling context
354
+ DirectiveRegistryPosition: 1,
355
+ // Position of where the initial styles are stored in the styling context
356
+ InitialStyleValuesPosition: 2,
357
+ InitialClassValuesPosition: 3,
153
358
  // Index of location where the class index offset value is located
154
- ClassOffsetPosition: 4,
359
+ SinglePropOffsetPositions: 4,
155
360
  // Position of where the initial styles are stored in the styling context
156
361
  // This index must align with HOST, see interfaces/view.ts
157
362
  ElementPosition: 5,
158
363
  // Position of where the last string-based CSS class value was stored (or a cached version of the
159
364
  // initial styles when a [class] directive is present)
160
- PreviousOrCachedMultiClassValue: 6,
365
+ CachedClassValueOrInitialClassString: 6,
161
366
  // Position of where the last string-based CSS class value was stored
162
- PreviousMultiStyleValue: 7,
163
- // Location of single (prop) value entries are stored within the context
164
- SingleStylesStartPosition: 8,
367
+ CachedStyleValue: 7,
165
368
  // Multi and single entries are stored in `StylingContext` as: Flag; PropertyName; PropertyValue
369
+ // Position of where the initial styles are stored in the styling context
370
+ PlayerContext: 8,
371
+ // Location of single (prop) value entries are stored within the context
372
+ SingleStylesStartPosition: 9,
166
373
  FlagsOffset: 0,
167
374
  PropertyOffset: 1,
168
375
  ValueOffset: 2,
@@ -171,10 +378,14 @@ var StylingIndex = {
171
378
  Size: 4,
172
379
  // Each flag has a binary digit length of this value
173
380
  BitCountSize: 14,
174
- // (32 - 4) / 2 = ~14
175
381
  // The binary digit value as a mask
176
382
  BitMask: 16383,
177
383
  };
178
384
  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"]}
385
+ /** @enum {number} */
386
+ const DirectiveOwnerAndPlayerBuilderIndex = {
387
+ BitCountSize: 16,
388
+ BitMask: 65535,
389
+ };
390
+ export { DirectiveOwnerAndPlayerBuilderIndex };
391
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"../../","sources":["packages/core/src/render3/interfaces/styling.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0MA,oCAqDC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASD,0CAAuF;;;;;;;IAuFrF,wBAAyB;IACzB,aAAc;IACd,cAAe;IACf,OAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgCV,6CAKC;;;;;;;;;;;;;IAOC,uBAAwB;IACxB,8BAA+B;IAC/B,kBAAmB;IACnB,uBAAwB;IACxB,OAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BV,4CAGC;;;;;;;;;IAOC,sBAAuB;IACvB,uBAAwB;IACxB,qBAAsB;;;;;IAQtB,4BAA4B;IAC5B,OAAe;IACf,sDAAsD;IACtD,QAAgB;IAChB,kDAAkD;IAClD,QAAgB;IAChB,0DAA0D;IAC1D,WAAmB;IACnB,wEAAwE;IACxE,sBAA8B;IAC9B,kGAAkG;IAClG,kBAAkB;IAClB,4BAAmC;IACnC,sEAAsE;IACtE,2BAAkC;IAClC,eAAgB;IAChB,+BAA+B;IAC/B,WAAkB;;;;;IAKlB,yFAAyF;IACzF,qBAAsB;IACtB,6EAA6E;IAC7E,4BAA6B;IAC7B,yEAAyE;IACzE,6BAA8B;IAC9B,6BAA8B;IAC9B,kEAAkE;IAClE,4BAA6B;IAC7B,yEAAyE;IACzE,0DAA0D;IAC1D,kBAAmB;IACnB,iGAAiG;IACjG,sDAAsD;IACtD,uCAAwC;IACxC,qEAAqE;IACrE,mBAAoB;IACpB,iGAAiG;IACjG,yEAAyE;IACzE,gBAAiB;IACjB,wEAAwE;IACxE,4BAA6B;IAC7B,cAAe;IACf,iBAAkB;IAClB,cAAe;IACf,2BAA4B;IAC5B,gFAAgF;IAChF,OAAQ;IACR,oDAAoD;IACpD,gBAAiB;IACjB,mCAAmC;IACnC,cAA0B;;;;;IAY1B,gBAAiB;IACjB,cAA4B","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 * 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. It also stores the static style/class values that were\n * extracted from the template by the compiler.\n *\n * A context is created by Angular when:\n * 1. An element contains static styling values (like style=\"...\" or class=\"...\")\n * 2. An element contains single property binding values (like [style.prop]=\"x\" or\n * [class.prop]=\"y\")\n * 3. An element contains multi property binding values (like [style]=\"x\" or [class]=\"y\")\n * 4. A directive contains host bindings for static, single or multi styling properties/bindings.\n * 5. An animation player is added to an element via `addPlayer`\n *\n * Note that even if an element contains static styling then this context will be created and\n * attached to it. The reason why this happens (instead of treating styles/classes as regular\n * HTML attributes) is because the style/class bindings must be able to default themselves back\n * to their respective static values when they are set to null.\n *\n * Say for example we have this:\n * ```\n * <!-- when myWidthExp=null then a width of \"100px\"\n *      will be used a default value for width -->\n * <div style=\"width:100px\" [style.width]=\"myWidthExp\"></div>\n * ```\n *\n * Even in the situation where there are no bindings, the static styling is still placed into the\n * context because there may be another directive on the same element that has styling.\n *\n * When Angular initializes styling data for an element then it will first register the static\n * styling values on the element using one of these two instructions:\n *\n * 1. elementStart or element (within the template function of a component)\n * 2. elementHostAttrs (for directive host bindings)\n *\n * In either case, a styling context will be created and stored within an element's LViewData. Once\n * the styling context is created then single and multi properties can stored within it. For this to\n * happen, the following function needs to be called:\n *\n * `elementStyling` (called with style properties, class properties and a sanitizer + a directive\n * instance).\n *\n * When this instruction is called it will populate the styling context with the provided style\n * and class names into the context.\n *\n * The context itself looks like this:\n *\n * context = [\n *   // 0-8: header values (about 8 entries of configuration data)\n *   // 9+: this is where each entry is stored:\n * ]\n *\n * Let's say we have the following template code:\n *\n * ```\n * <div class=\"foo bar\"\n *      style=\"width:200px; color:red\"\n *      [style.width]=\"myWidthExp\"\n *      [style.height]=\"myHeightExp\"\n *      [class.baz]=\"myBazExp\">\n * ```\n *\n * The context generated from these values will look like this (note that\n * for each binding name (the class and style bindings) the values will\n * be inserted twice into the array (once for single property entries) and\n * another for multi property entries).\n *\n * context = [\n *   // 0-8: header values (about 8 entries of configuration data)\n *   // 9+: this is where each entry is stored:\n *\n *   // SINGLE PROPERTIES\n *   configForWidth,\n *   'width'\n *   myWidthExp, // the binding value not the binding itself\n *   0, // the directive owner\n *\n *   configForHeight,\n *   'height'\n *   myHeightExp, // the binding value not the binding itself\n *   0, // the directive owner\n *\n *   configForBazClass,\n *   'baz\n *   myBazClassExp, // the binding value not the binding itself\n *   0, // the directive owner\n *\n *   // MULTI PROPERTIES\n *   configForWidth,\n *   'width'\n *   myWidthExp, // the binding value not the binding itself\n *   0, // the directive owner\n *\n *   configForHeight,\n *   'height'\n *   myHeightExp, // the binding value not the binding itself\n *   0, // the directive owner\n *\n *   configForBazClass,\n *   'baz\n *   myBazClassExp, // the binding value not the binding itself\n *   0, // the directive owner\n * ]\n *\n * The configuration values are left out of the example above because\n * the ordering of them could change between code patches. Please read the\n * documentation below to get a better understand of what the configuration\n * values are and how they work.\n *\n * Each time a binding property is updated (whether it be through a single\n * property instruction like `elementStyleProp`, `elementClassProp` or\n * `elementStylingMap`) then the values in the context will be updated as\n * well.\n *\n * If for example `[style.width]` updates to `555px` then its value will be reflected\n * in the context as so:\n *\n * context = [\n *   // ...\n *   configForWidth, // this will be marked DIRTY\n *   'width'\n *   '555px',\n *   0,\n *   //..\n * ]\n *\n * The context and directive data will also be marked dirty.\n *\n * Despite the context being updated, nothing has been rendered on screen (not styles or\n * classes have been set on the element). To kick off rendering for an element the following\n * function needs to be run `elementStylingApply`.\n *\n * `elementStylingApply` will run through the context and find each dirty value and render them onto\n * the element. Once complete, all styles/classes will be set to clean. Because of this, the render\n * function will now know not to rerun itself again if called again unless new style/class values\n * have changed.\n *\n * ## Directives\n * Directives style values (which are provided through host bindings) are also supported and\n * housed within the same styling context as are template-level style/class properties/bindings.\n * Both directive-level and template-level styling bindings share the same context.\n *\n * Each of the following instructions supports accepting a directive instance as an input parameter:\n *\n * - `elementHostAttrs`\n * - `elementStyling`\n * - `elementStyleProp`\n * - `elementClassProp`\n * - `elementStylingMap`\n * - `elementStylingApply`\n *\n * Each time a directiveRef is passed in, it will be converted into an index by examining the\n * directive registry (which lives in the context configuration area). The index is then used\n * to help single style properties figure out where a value is located in the context.\n *\n * If two directives or a directive + a template binding both write to the same style/class\n * binding then the styling context code will decide which one wins based on the following\n * rule:\n *\n * 1. If the template binding has a value then it always wins\n * 2. If not then whichever first-registered directive that has that value first will win\n *\n * The code example helps make this clear:\n *\n * ```\n * <div [style.width]=\"myWidth\" [my-width-directive]=\"'600px\">\n * @Directive({ selector: '[my-width-directive' ]})\n * class MyWidthDirective {\n *   @Input('my-width-directive')\n *   @HostBinding('style.width')\n *   public width = null;\n * }\n * ```\n *\n * Since there is a style binding for width present on the element (`[style.width]`) then\n * it will always win over the width binding that is present as a host binding within\n * the `MyWidthDirective`. However, if `[style.width]` renders as `null` (so `myWidth=null`)\n * then the `MyWidthDirective` will be able to write to the `width` style within the context.\n * Simply put, whichever directive writes to a value ends up having ownership of it.\n *\n * The way in which the ownership is facilitated is through index value. The earliest directives\n * get the smallest index values (with 0 being reserved for the template element bindings). Each\n * time a value is written from a directive or the template bindings, the value itself gets\n * assigned the directive index value in its data. If another directive writes a value again then\n * its directive index gets compared against the directive index that exists on the element. Only\n * when the new value's directive index is less than the existing directive index then the new\n * value will be written to the context.\n *\n * Each directive also has its own sanitizer and dirty flags. These values are consumed within the\n * rendering function.\n */\nexport interface StylingContext extends\n    Array<{[key: string]: any}|number|string|boolean|RElement|StyleSanitizeFn|PlayerContext|null> {\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   * Location of the collection of directives for this context\n   */\n  [StylingIndex.DirectiveRegistryPosition]: DirectiveRegistryValues;\n\n  /**\n   * Location of all static styles values\n   */\n  [StylingIndex.InitialStyleValuesPosition]: InitialStylingValues;\n\n  /**\n   * Location of all static class values\n   */\n  [StylingIndex.InitialClassValuesPosition]: InitialStylingValues;\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.SinglePropOffsetPositions]: SinglePropOffsetValues;\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.CachedClassValueOrInitialClassString]: {[key: string]: any}|string|(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.CachedStyleValue]: {[key: string]: any}|(string)[]|null;\n\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/**\n * Used as a styling array to house static class and style values that were extracted\n * by the compiler and placed in the animation context via `elementStart` and\n * `elementHostAttrs`.\n *\n * See [InitialStylingValuesIndex] for a breakdown of how all this works.\n */\nexport interface InitialStylingValues extends Array<string|boolean|null> { [0]: null; }\n\n/**\n * Used as an offset/position index to figure out where initial styling\n * values are located.\n *\n * Used as a reference point to provide markers to all static styling\n * values (the initial style and class values on an element) within an\n * array within the StylingContext. This array contains key/value pairs\n * where the key is the style property name or className and the value is\n * the style value or whether or not a class is present on the elment.\n *\n * The first value is also always null so that a initial index value of\n * `0` will always point to a null value.\n *\n * If a <div> elements contains a list of static styling values like so:\n *\n * <div class=\"foo bar baz\" style=\"width:100px; height:200px;\">\n *\n * Then the initial styles for that will look like so:\n *\n * Styles:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'width', '100px', height, '200px'\n * ]\n *\n * Classes:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'foo', true, 'bar', true, 'baz', true\n * ]\n *\n * Initial style and class entries have their own arrays. This is because\n * it's easier to add to the end of one array and not then have to update\n * every context entries' pointer index to the newly offseted values.\n *\n * When property bindinds are added to a context then initial style/class\n * values will also be inserted into the array. This is to create a space\n * in the situation when a follow-up directive inserts static styling into\n * the array. By default style values are `null` and class values are\n * `false` when inserted by property bindings.\n *\n * For example:\n * <div class=\"foo bar baz\"\n *      [class.car]=\"myCarExp\"\n *      style=\"width:100px; height:200px;\"\n *      [style.opacity]=\"myOpacityExp\">\n *\n * Will construct initial styling values that look like:\n *\n * Styles:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'width', '100px', height, '200px', 'opacity', null\n * ]\n *\n * Classes:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'foo', true, 'bar', true, 'baz', true, 'car', false\n * ]\n *\n * Now if a directive comes along and introduces `car` as a static\n * class value or `opacity` then those values will be filled into\n * the initial styles array.\n *\n * For example:\n *\n * @Directive({\n *   selector: 'opacity-car-directive',\n *   host: {\n *     'style': 'opacity:0.5',\n *     'class': 'car'\n *   }\n * })\n * class OpacityCarDirective {}\n *\n * This will render itself as:\n *\n * Styles:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'width', '100px', height, '200px', 'opacity', null\n * ]\n *\n * Classes:\n * StylingContext[InitialStylesIndex] = [\n *   null, 'foo', true, 'bar', true, 'baz', true, 'car', false\n * ]\n */\nexport const enum InitialStylingValuesIndex {\n  KeyValueStartPosition = 1,\n  PropOffset = 0,\n  ValueOffset = 1,\n  Size = 2\n}\n\n/**\n * An array located in the StylingContext that houses all directive instances and additional\n * data about them.\n *\n * Each entry in this array represents a source of where style/class binding values could\n * come from. By default, there is always at least one directive here with a null value and\n * that represents bindings that live directly on an element (not host bindings).\n *\n * Each successive entry in the array is an actual instance of an array as well as some\n * additional info.\n *\n * An entry within this array has the following values:\n * [0] = The instance of the directive (or null when it is not a directive, but a template binding\n * source)\n * [1] = The pointer that tells where the single styling (stuff like [class.foo] and [style.prop])\n *       offset values are located. This value will allow for a binding instruction to find exactly\n *       where a style is located.\n * [2] = Whether or not the directive has any styling values that are dirty. This is used as\n *       reference within the renderClassAndStyleBindings function to decide whether to skip\n *       iterating through the context when rendering is executed.\n * [3] = The styleSanitizer instance that is assigned to the directive. Although it's unlikely,\n *       a directive could introduce its own special style sanitizer and for this reach each\n *       directive will get its own space for it (if null then the very first sanitizer is used).\n *\n * Each time a new directive is added it will insert these four values at the end of the array.\n * When this array is examined (using indexOf) then the resulting directiveIndex will be resolved\n * by dividing the index value by the size of the array entries (so if DirA is at spot 8 then its\n * index will be 2).\n */\nexport interface DirectiveRegistryValues extends Array<null|{}|boolean|number|StyleSanitizeFn> {\n  [DirectiveRegistryValuesIndex.DirectiveValueOffset]: null;\n  [DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset]: number;\n  [DirectiveRegistryValuesIndex.DirtyFlagOffset]: boolean;\n  [DirectiveRegistryValuesIndex.StyleSanitizerOffset]: StyleSanitizeFn|null;\n}\n\n/**\n * An enum that outlines the offset/position values for each directive entry and its data\n * that are housed inside of [DirectiveRegistryValues].\n */\nexport const enum DirectiveRegistryValuesIndex {\n  DirectiveValueOffset = 0,\n  SinglePropValuesIndexOffset = 1,\n  DirtyFlagOffset = 2,\n  StyleSanitizerOffset = 3,\n  Size = 4\n}\n\n/**\n * An array that contains the index pointer values for every single styling property\n * that exists in the context and for every directive. It also contains the total\n * single styles and single classes that exists in the context as the first two values.\n *\n * Let's say we have the following template code:\n *\n * <div [style.width]=\"myWidth\"\n *      [style.height]=\"myHeight\"\n *      [class.flipped]=\"flipClass\"\n *      directive-with-opacity>\n *      directive-with-foo-bar-classes>\n *\n * We have two directive and template-binding sources,\n * 2 + 1 styles and 1 + 1 classes. When the bindings are\n * registered the SinglePropOffsets array will look like so:\n *\n * s_0/c_0 = template directive value\n * s_1/c_1 = directive one (directive-with-opacity)\n * s_2/c_2 = directive two (directive-with-foo-bar-classes)\n *\n * [3, 2, 2, 1, s_00, s01, c_01, 1, 0, s_10, 0, 1, c_20\n */\nexport interface SinglePropOffsetValues extends Array<number> {\n  [SinglePropOffsetValuesIndex.StylesCountPosition]: number;\n  [SinglePropOffsetValuesIndex.ClassesCountPosition]: number;\n}\n\n/**\n * An enum that outlines the offset/position values for each single prop/class entry\n * that are housed inside of [SinglePropOffsetValues].\n */\nexport const enum SinglePropOffsetValuesIndex {\n  StylesCountPosition = 0,\n  ClassesCountPosition = 1,\n  ValueStartPosition = 2\n}\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 = 0b000000,\n  // Whether or not the entry or context itself is dirty\n  Dirty = 0b000001,\n  // Whether or not this is a class-based assignment\n  Class = 0b000010,\n  // Whether or not a sanitizer was applied to this property\n  Sanitize = 0b000100,\n  // Whether or not any player builders within need to produce new players\n  PlayerBuildersDirty = 0b001000,\n  // If NgClass is present (or some other class handler) then it will handle the map expressions and\n  // initial classes\n  OnlyProcessSingleClasses = 0b010000,\n  // The max amount of bits used to represent these configuration values\n  BindingAllocationLocked = 0b100000,\n  BitCountSize = 6,\n  // There are only six bits here\n  BitMask = 0b111111\n}\n\n/** Used as numeric pointer values to determine what cells to update in the `StylingContext` */\nexport const enum StylingIndex {\n  // Index of location where the start of single properties are stored. (`updateStyleProp`)\n  MasterFlagPosition = 0,\n  // Position of where the registered directives exist for this styling context\n  DirectiveRegistryPosition = 1,\n  // Position of where the initial styles are stored in the styling context\n  InitialStyleValuesPosition = 2,\n  InitialClassValuesPosition = 3,\n  // Index of location where the class index offset value is located\n  SinglePropOffsetPositions = 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  CachedClassValueOrInitialClassString = 6,\n  // Position of where the last string-based CSS class value was stored\n  CachedStyleValue = 7,\n  // Multi and single entries are stored in `StylingContext` as: Flag; PropertyName;  PropertyValue\n  // Position of where the initial styles are stored in the styling context\n  PlayerContext = 8,\n  // Location of single (prop) value entries are stored within the context\n  SingleStylesStartPosition = 9,\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\n/**\n * An enum that outlines the bit flag data for directive owner and player index\n * values that exist within en entry that lives in the StylingContext.\n *\n * The values here split a number value into two sets of bits:\n *  - The first 16 bits are used to store the directiveIndex that owns this style value\n *  - The other 16 bits are used to store the playerBuilderIndex that is attached to this style\n */\nexport const enum DirectiveOwnerAndPlayerBuilderIndex {\n  BitCountSize = 16,\n  BitMask = 0b1111111111111111\n}\n"]}